MOXA linux-2.6.x / linux-2.6.9-uc0 from sdlinux-moxaart.tgz
[linux-2.6.9-moxart.git] / fs / udf / lowlevel.c
blobf7d15571de4e1baf9825718b3c634eba539f5ce2
1 /*
2 * lowlevel.c
4 * PURPOSE
5 * Low Level Device Routines for the UDF filesystem
7 * CONTACTS
8 * E-mail regarding any portion of the Linux UDF file system should be
9 * directed to the development team mailing list (run by majordomo):
10 * linux_udf@hpesjro.fc.hp.com
12 * COPYRIGHT
13 * This file is distributed under the terms of the GNU General Public
14 * License (GPL). Copies of the GPL can be obtained from:
15 * ftp://prep.ai.mit.edu/pub/gnu/GPL
16 * Each contributing author retains all rights to their own work.
18 * (C) 1999-2001 Ben Fennema
20 * HISTORY
22 * 03/26/99 blf Created.
25 #include "udfdecl.h"
27 #include <linux/blkdev.h>
28 #include <linux/cdrom.h>
29 #include <asm/uaccess.h>
30 #include <scsi/scsi.h>
32 typedef struct scsi_device Scsi_Device;
33 typedef struct scsi_cmnd Scsi_Cmnd;
35 #include <scsi/scsi_ioctl.h>
37 #include <linux/udf_fs.h>
38 #include "udf_sb.h"
40 unsigned int
41 udf_get_last_session(struct super_block *sb)
43 struct cdrom_multisession ms_info;
44 unsigned int vol_desc_start;
45 struct block_device *bdev = sb->s_bdev;
46 int i;
48 vol_desc_start=0;
49 ms_info.addr_format=CDROM_LBA;
50 i = ioctl_by_bdev(bdev, CDROMMULTISESSION, (unsigned long) &ms_info);
52 #define WE_OBEY_THE_WRITTEN_STANDARDS 1
54 if (i == 0)
56 udf_debug("XA disk: %s, vol_desc_start=%d\n",
57 (ms_info.xa_flag ? "yes" : "no"), ms_info.addr.lba);
58 #if WE_OBEY_THE_WRITTEN_STANDARDS
59 if (ms_info.xa_flag) /* necessary for a valid ms_info.addr */
60 #endif
61 vol_desc_start = ms_info.addr.lba;
63 else
65 udf_debug("CDROMMULTISESSION not supported: rc=%d\n", i);
67 return vol_desc_start;
70 unsigned long
71 udf_get_last_block(struct super_block *sb)
73 struct block_device *bdev = sb->s_bdev;
74 unsigned long lblock = 0;
76 if (ioctl_by_bdev(bdev, CDROM_LAST_WRITTEN, (unsigned long) &lblock))
77 lblock = bdev->bd_inode->i_size >> sb->s_blocksize_bits;
79 if (lblock)
80 return lblock - 1;
81 else
82 return 0;