1*53ee8cc1Swenshuai.xi /* 2*53ee8cc1Swenshuai.xi * linux/include/linux/edd.h 3*53ee8cc1Swenshuai.xi * Copyright (C) 2002, 2003, 2004 Dell Inc. 4*53ee8cc1Swenshuai.xi * by Matt Domsch <Matt_Domsch@dell.com> 5*53ee8cc1Swenshuai.xi * 6*53ee8cc1Swenshuai.xi * structures and definitions for the int 13h, ax={41,48}h 7*53ee8cc1Swenshuai.xi * BIOS Enhanced Disk Drive Services 8*53ee8cc1Swenshuai.xi * This is based on the T13 group document D1572 Revision 0 (August 14 2002) 9*53ee8cc1Swenshuai.xi * available at http://www.t13.org/docs2002/d1572r0.pdf. It is 10*53ee8cc1Swenshuai.xi * very similar to D1484 Revision 3 http://www.t13.org/docs2002/d1484r3.pdf 11*53ee8cc1Swenshuai.xi * 12*53ee8cc1Swenshuai.xi * In a nutshell, arch/{i386,x86_64}/boot/setup.S populates a scratch 13*53ee8cc1Swenshuai.xi * table in the boot_params that contains a list of BIOS-enumerated 14*53ee8cc1Swenshuai.xi * boot devices. 15*53ee8cc1Swenshuai.xi * In arch/{i386,x86_64}/kernel/setup.c, this information is 16*53ee8cc1Swenshuai.xi * transferred into the edd structure, and in drivers/firmware/edd.c, that 17*53ee8cc1Swenshuai.xi * information is used to identify BIOS boot disk. The code in setup.S 18*53ee8cc1Swenshuai.xi * is very sensitive to the size of these structures. 19*53ee8cc1Swenshuai.xi * 20*53ee8cc1Swenshuai.xi * This program is free software; you can redistribute it and/or modify 21*53ee8cc1Swenshuai.xi * it under the terms of the GNU General Public License v2.0 as published by 22*53ee8cc1Swenshuai.xi * the Free Software Foundation 23*53ee8cc1Swenshuai.xi * 24*53ee8cc1Swenshuai.xi * This program is distributed in the hope that it will be useful, 25*53ee8cc1Swenshuai.xi * but WITHOUT ANY WARRANTY; without even the implied warranty of 26*53ee8cc1Swenshuai.xi * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 27*53ee8cc1Swenshuai.xi * GNU General Public License for more details. 28*53ee8cc1Swenshuai.xi * 29*53ee8cc1Swenshuai.xi */ 30*53ee8cc1Swenshuai.xi #ifndef _LINUX_EDD_H 31*53ee8cc1Swenshuai.xi #define _LINUX_EDD_H 32*53ee8cc1Swenshuai.xi 33*53ee8cc1Swenshuai.xi #define EDDNR 0x1e9 /* addr of number of edd_info structs at EDDBUF 34*53ee8cc1Swenshuai.xi in boot_params - treat this as 1 byte */ 35*53ee8cc1Swenshuai.xi #define EDDBUF 0xd00 /* addr of edd_info structs in boot_params */ 36*53ee8cc1Swenshuai.xi #define EDDMAXNR 6 /* number of edd_info structs starting at EDDBUF */ 37*53ee8cc1Swenshuai.xi #define EDDEXTSIZE 8 /* change these if you muck with the structures */ 38*53ee8cc1Swenshuai.xi #define EDDPARMSIZE 74 39*53ee8cc1Swenshuai.xi #define CHECKEXTENSIONSPRESENT 0x41 40*53ee8cc1Swenshuai.xi #define GETDEVICEPARAMETERS 0x48 41*53ee8cc1Swenshuai.xi #define LEGACYGETDEVICEPARAMETERS 0x08 42*53ee8cc1Swenshuai.xi #define EDDMAGIC1 0x55AA 43*53ee8cc1Swenshuai.xi #define EDDMAGIC2 0xAA55 44*53ee8cc1Swenshuai.xi 45*53ee8cc1Swenshuai.xi 46*53ee8cc1Swenshuai.xi #define READ_SECTORS 0x02 /* int13 AH=0x02 is READ_SECTORS command */ 47*53ee8cc1Swenshuai.xi #define EDD_MBR_SIG_OFFSET 0x1B8 /* offset of signature in the MBR */ 48*53ee8cc1Swenshuai.xi #define EDD_MBR_SIG_BUF 0x290 /* addr in boot params */ 49*53ee8cc1Swenshuai.xi #define EDD_MBR_SIG_MAX 16 /* max number of signatures to store */ 50*53ee8cc1Swenshuai.xi #define EDD_MBR_SIG_NR_BUF 0x1ea /* addr of number of MBR signtaures at EDD_MBR_SIG_BUF 51*53ee8cc1Swenshuai.xi in boot_params - treat this as 1 byte */ 52*53ee8cc1Swenshuai.xi 53*53ee8cc1Swenshuai.xi #ifndef __ASSEMBLY__ 54*53ee8cc1Swenshuai.xi 55*53ee8cc1Swenshuai.xi #define EDD_EXT_FIXED_DISK_ACCESS (1 << 0) 56*53ee8cc1Swenshuai.xi #define EDD_EXT_DEVICE_LOCKING_AND_EJECTING (1 << 1) 57*53ee8cc1Swenshuai.xi #define EDD_EXT_ENHANCED_DISK_DRIVE_SUPPORT (1 << 2) 58*53ee8cc1Swenshuai.xi #define EDD_EXT_64BIT_EXTENSIONS (1 << 3) 59*53ee8cc1Swenshuai.xi 60*53ee8cc1Swenshuai.xi #define EDD_INFO_DMA_BOUNDARY_ERROR_TRANSPARENT (1 << 0) 61*53ee8cc1Swenshuai.xi #define EDD_INFO_GEOMETRY_VALID (1 << 1) 62*53ee8cc1Swenshuai.xi #define EDD_INFO_REMOVABLE (1 << 2) 63*53ee8cc1Swenshuai.xi #define EDD_INFO_WRITE_VERIFY (1 << 3) 64*53ee8cc1Swenshuai.xi #define EDD_INFO_MEDIA_CHANGE_NOTIFICATION (1 << 4) 65*53ee8cc1Swenshuai.xi #define EDD_INFO_LOCKABLE (1 << 5) 66*53ee8cc1Swenshuai.xi #define EDD_INFO_NO_MEDIA_PRESENT (1 << 6) 67*53ee8cc1Swenshuai.xi #define EDD_INFO_USE_INT13_FN50 (1 << 7) 68*53ee8cc1Swenshuai.xi 69*53ee8cc1Swenshuai.xi struct edd_device_params { 70*53ee8cc1Swenshuai.xi __u16 length; 71*53ee8cc1Swenshuai.xi __u16 info_flags; 72*53ee8cc1Swenshuai.xi __u32 num_default_cylinders; 73*53ee8cc1Swenshuai.xi __u32 num_default_heads; 74*53ee8cc1Swenshuai.xi __u32 sectors_per_track; 75*53ee8cc1Swenshuai.xi __u64 number_of_sectors; 76*53ee8cc1Swenshuai.xi __u16 bytes_per_sector; 77*53ee8cc1Swenshuai.xi __u32 dpte_ptr; /* 0xFFFFFFFF for our purposes */ 78*53ee8cc1Swenshuai.xi __u16 key; /* = 0xBEDD */ 79*53ee8cc1Swenshuai.xi __u8 device_path_info_length; /* = 44 */ 80*53ee8cc1Swenshuai.xi __u8 reserved2; 81*53ee8cc1Swenshuai.xi __u16 reserved3; 82*53ee8cc1Swenshuai.xi __u8 host_bus_type[4]; 83*53ee8cc1Swenshuai.xi __u8 interface_type[8]; 84*53ee8cc1Swenshuai.xi union { 85*53ee8cc1Swenshuai.xi struct { 86*53ee8cc1Swenshuai.xi __u16 base_address; 87*53ee8cc1Swenshuai.xi __u16 reserved1; 88*53ee8cc1Swenshuai.xi __u32 reserved2; 89*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) isa; 90*53ee8cc1Swenshuai.xi struct { 91*53ee8cc1Swenshuai.xi __u8 bus; 92*53ee8cc1Swenshuai.xi __u8 slot; 93*53ee8cc1Swenshuai.xi __u8 function; 94*53ee8cc1Swenshuai.xi __u8 channel; 95*53ee8cc1Swenshuai.xi __u32 reserved; 96*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) pci; 97*53ee8cc1Swenshuai.xi /* pcix is same as pci */ 98*53ee8cc1Swenshuai.xi struct { 99*53ee8cc1Swenshuai.xi __u64 reserved; 100*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) ibnd; 101*53ee8cc1Swenshuai.xi struct { 102*53ee8cc1Swenshuai.xi __u64 reserved; 103*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) xprs; 104*53ee8cc1Swenshuai.xi struct { 105*53ee8cc1Swenshuai.xi __u64 reserved; 106*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) htpt; 107*53ee8cc1Swenshuai.xi struct { 108*53ee8cc1Swenshuai.xi __u64 reserved; 109*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) unknown; 110*53ee8cc1Swenshuai.xi } interface_path; 111*53ee8cc1Swenshuai.xi union { 112*53ee8cc1Swenshuai.xi struct { 113*53ee8cc1Swenshuai.xi __u8 device; 114*53ee8cc1Swenshuai.xi __u8 reserved1; 115*53ee8cc1Swenshuai.xi __u16 reserved2; 116*53ee8cc1Swenshuai.xi __u32 reserved3; 117*53ee8cc1Swenshuai.xi __u64 reserved4; 118*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) ata; 119*53ee8cc1Swenshuai.xi struct { 120*53ee8cc1Swenshuai.xi __u8 device; 121*53ee8cc1Swenshuai.xi __u8 lun; 122*53ee8cc1Swenshuai.xi __u8 reserved1; 123*53ee8cc1Swenshuai.xi __u8 reserved2; 124*53ee8cc1Swenshuai.xi __u32 reserved3; 125*53ee8cc1Swenshuai.xi __u64 reserved4; 126*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) atapi; 127*53ee8cc1Swenshuai.xi struct { 128*53ee8cc1Swenshuai.xi __u16 id; 129*53ee8cc1Swenshuai.xi __u64 lun; 130*53ee8cc1Swenshuai.xi __u16 reserved1; 131*53ee8cc1Swenshuai.xi __u32 reserved2; 132*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) scsi; 133*53ee8cc1Swenshuai.xi struct { 134*53ee8cc1Swenshuai.xi __u64 serial_number; 135*53ee8cc1Swenshuai.xi __u64 reserved; 136*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) usb; 137*53ee8cc1Swenshuai.xi struct { 138*53ee8cc1Swenshuai.xi __u64 eui; 139*53ee8cc1Swenshuai.xi __u64 reserved; 140*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) i1394; 141*53ee8cc1Swenshuai.xi struct { 142*53ee8cc1Swenshuai.xi __u64 wwid; 143*53ee8cc1Swenshuai.xi __u64 lun; 144*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) fibre; 145*53ee8cc1Swenshuai.xi struct { 146*53ee8cc1Swenshuai.xi __u64 identity_tag; 147*53ee8cc1Swenshuai.xi __u64 reserved; 148*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) i2o; 149*53ee8cc1Swenshuai.xi struct { 150*53ee8cc1Swenshuai.xi __u32 array_number; 151*53ee8cc1Swenshuai.xi __u32 reserved1; 152*53ee8cc1Swenshuai.xi __u64 reserved2; 153*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) raid; 154*53ee8cc1Swenshuai.xi struct { 155*53ee8cc1Swenshuai.xi __u8 device; 156*53ee8cc1Swenshuai.xi __u8 reserved1; 157*53ee8cc1Swenshuai.xi __u16 reserved2; 158*53ee8cc1Swenshuai.xi __u32 reserved3; 159*53ee8cc1Swenshuai.xi __u64 reserved4; 160*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) sata; 161*53ee8cc1Swenshuai.xi struct { 162*53ee8cc1Swenshuai.xi __u64 reserved1; 163*53ee8cc1Swenshuai.xi __u64 reserved2; 164*53ee8cc1Swenshuai.xi } __attribute__ ((packed)) unknown; 165*53ee8cc1Swenshuai.xi } device_path; 166*53ee8cc1Swenshuai.xi __u8 reserved4; 167*53ee8cc1Swenshuai.xi __u8 checksum; 168*53ee8cc1Swenshuai.xi } __attribute__ ((packed)); 169*53ee8cc1Swenshuai.xi 170*53ee8cc1Swenshuai.xi struct edd_info { 171*53ee8cc1Swenshuai.xi __u8 device; 172*53ee8cc1Swenshuai.xi __u8 version; 173*53ee8cc1Swenshuai.xi __u16 interface_support; 174*53ee8cc1Swenshuai.xi __u16 legacy_max_cylinder; 175*53ee8cc1Swenshuai.xi __u8 legacy_max_head; 176*53ee8cc1Swenshuai.xi __u8 legacy_sectors_per_track; 177*53ee8cc1Swenshuai.xi struct edd_device_params params; 178*53ee8cc1Swenshuai.xi } __attribute__ ((packed)); 179*53ee8cc1Swenshuai.xi 180*53ee8cc1Swenshuai.xi struct edd { 181*53ee8cc1Swenshuai.xi unsigned int mbr_signature[EDD_MBR_SIG_MAX]; 182*53ee8cc1Swenshuai.xi struct edd_info edd_info[EDDMAXNR]; 183*53ee8cc1Swenshuai.xi unsigned char mbr_signature_nr; 184*53ee8cc1Swenshuai.xi unsigned char edd_info_nr; 185*53ee8cc1Swenshuai.xi }; 186*53ee8cc1Swenshuai.xi 187*53ee8cc1Swenshuai.xi #endif /*!__ASSEMBLY__ */ 188*53ee8cc1Swenshuai.xi 189*53ee8cc1Swenshuai.xi #endif /* _LINUX_EDD_H */ 190