195ffaba3SGraeme Russ /* 295ffaba3SGraeme Russ * linux/include/linux/edd.h 395ffaba3SGraeme Russ * Copyright (C) 2002, 2003, 2004 Dell Inc. 495ffaba3SGraeme Russ * by Matt Domsch <Matt_Domsch@dell.com> 595ffaba3SGraeme Russ * 695ffaba3SGraeme Russ * structures and definitions for the int 13h, ax={41,48}h 795ffaba3SGraeme Russ * BIOS Enhanced Disk Drive Services 895ffaba3SGraeme Russ * This is based on the T13 group document D1572 Revision 0 (August 14 2002) 995ffaba3SGraeme Russ * available at http://www.t13.org/docs2002/d1572r0.pdf. It is 1095ffaba3SGraeme Russ * very similar to D1484 Revision 3 http://www.t13.org/docs2002/d1484r3.pdf 1195ffaba3SGraeme Russ * 1295ffaba3SGraeme Russ * In a nutshell, arch/{i386,x86_64}/boot/setup.S populates a scratch 1395ffaba3SGraeme Russ * table in the boot_params that contains a list of BIOS-enumerated 1495ffaba3SGraeme Russ * boot devices. 1595ffaba3SGraeme Russ * In arch/{i386,x86_64}/kernel/setup.c, this information is 1695ffaba3SGraeme Russ * transferred into the edd structure, and in drivers/firmware/edd.c, that 1795ffaba3SGraeme Russ * information is used to identify BIOS boot disk. The code in setup.S 1895ffaba3SGraeme Russ * is very sensitive to the size of these structures. 1995ffaba3SGraeme Russ * 20*5b8031ccSTom Rini * SPDX-License-Identifier: GPL-2.0 2195ffaba3SGraeme Russ */ 2295ffaba3SGraeme Russ #ifndef _LINUX_EDD_H 2395ffaba3SGraeme Russ #define _LINUX_EDD_H 2495ffaba3SGraeme Russ 2595ffaba3SGraeme Russ #include <linux/types.h> 2695ffaba3SGraeme Russ 2795ffaba3SGraeme Russ #define EDDNR 0x1e9 /* addr of number of edd_info structs at EDDBUF 2895ffaba3SGraeme Russ in boot_params - treat this as 1 byte */ 2995ffaba3SGraeme Russ #define EDDBUF 0xd00 /* addr of edd_info structs in boot_params */ 3095ffaba3SGraeme Russ #define EDDMAXNR 6 /* number of edd_info structs starting at EDDBUF */ 3195ffaba3SGraeme Russ #define EDDEXTSIZE 8 /* change these if you muck with the structures */ 3295ffaba3SGraeme Russ #define EDDPARMSIZE 74 3395ffaba3SGraeme Russ #define CHECKEXTENSIONSPRESENT 0x41 3495ffaba3SGraeme Russ #define GETDEVICEPARAMETERS 0x48 3595ffaba3SGraeme Russ #define LEGACYGETDEVICEPARAMETERS 0x08 3695ffaba3SGraeme Russ #define EDDMAGIC1 0x55AA 3795ffaba3SGraeme Russ #define EDDMAGIC2 0xAA55 3895ffaba3SGraeme Russ 3995ffaba3SGraeme Russ 4095ffaba3SGraeme Russ #define READ_SECTORS 0x02 /* int13 AH=0x02 is READ_SECTORS command */ 4195ffaba3SGraeme Russ #define EDD_MBR_SIG_OFFSET 0x1B8 /* offset of signature in the MBR */ 4295ffaba3SGraeme Russ #define EDD_MBR_SIG_BUF 0x290 /* addr in boot params */ 4395ffaba3SGraeme Russ #define EDD_MBR_SIG_MAX 16 /* max number of signatures to store */ 4495ffaba3SGraeme Russ #define EDD_MBR_SIG_NR_BUF 0x1ea /* addr of number of MBR signtaures at EDD_MBR_SIG_BUF 4595ffaba3SGraeme Russ in boot_params - treat this as 1 byte */ 4695ffaba3SGraeme Russ 4795ffaba3SGraeme Russ #ifndef __ASSEMBLY__ 4895ffaba3SGraeme Russ 4995ffaba3SGraeme Russ #define EDD_EXT_FIXED_DISK_ACCESS (1 << 0) 5095ffaba3SGraeme Russ #define EDD_EXT_DEVICE_LOCKING_AND_EJECTING (1 << 1) 5195ffaba3SGraeme Russ #define EDD_EXT_ENHANCED_DISK_DRIVE_SUPPORT (1 << 2) 5295ffaba3SGraeme Russ #define EDD_EXT_64BIT_EXTENSIONS (1 << 3) 5395ffaba3SGraeme Russ 5495ffaba3SGraeme Russ #define EDD_INFO_DMA_BOUNDARY_ERROR_TRANSPARENT (1 << 0) 5595ffaba3SGraeme Russ #define EDD_INFO_GEOMETRY_VALID (1 << 1) 5695ffaba3SGraeme Russ #define EDD_INFO_REMOVABLE (1 << 2) 5795ffaba3SGraeme Russ #define EDD_INFO_WRITE_VERIFY (1 << 3) 5895ffaba3SGraeme Russ #define EDD_INFO_MEDIA_CHANGE_NOTIFICATION (1 << 4) 5995ffaba3SGraeme Russ #define EDD_INFO_LOCKABLE (1 << 5) 6095ffaba3SGraeme Russ #define EDD_INFO_NO_MEDIA_PRESENT (1 << 6) 6195ffaba3SGraeme Russ #define EDD_INFO_USE_INT13_FN50 (1 << 7) 6295ffaba3SGraeme Russ 6395ffaba3SGraeme Russ struct edd_device_params { 6495ffaba3SGraeme Russ __u16 length; 6595ffaba3SGraeme Russ __u16 info_flags; 6695ffaba3SGraeme Russ __u32 num_default_cylinders; 6795ffaba3SGraeme Russ __u32 num_default_heads; 6895ffaba3SGraeme Russ __u32 sectors_per_track; 6995ffaba3SGraeme Russ __u64 number_of_sectors; 7095ffaba3SGraeme Russ __u16 bytes_per_sector; 7195ffaba3SGraeme Russ __u32 dpte_ptr; /* 0xFFFFFFFF for our purposes */ 7295ffaba3SGraeme Russ __u16 key; /* = 0xBEDD */ 7395ffaba3SGraeme Russ __u8 device_path_info_length; /* = 44 */ 7495ffaba3SGraeme Russ __u8 reserved2; 7595ffaba3SGraeme Russ __u16 reserved3; 7695ffaba3SGraeme Russ __u8 host_bus_type[4]; 7795ffaba3SGraeme Russ __u8 interface_type[8]; 7895ffaba3SGraeme Russ union { 7995ffaba3SGraeme Russ struct { 8095ffaba3SGraeme Russ __u16 base_address; 8195ffaba3SGraeme Russ __u16 reserved1; 8295ffaba3SGraeme Russ __u32 reserved2; 8395ffaba3SGraeme Russ } __attribute__ ((packed)) isa; 8495ffaba3SGraeme Russ struct { 8595ffaba3SGraeme Russ __u8 bus; 8695ffaba3SGraeme Russ __u8 slot; 8795ffaba3SGraeme Russ __u8 function; 8895ffaba3SGraeme Russ __u8 channel; 8995ffaba3SGraeme Russ __u32 reserved; 9095ffaba3SGraeme Russ } __attribute__ ((packed)) pci; 9195ffaba3SGraeme Russ /* pcix is same as pci */ 9295ffaba3SGraeme Russ struct { 9395ffaba3SGraeme Russ __u64 reserved; 9495ffaba3SGraeme Russ } __attribute__ ((packed)) ibnd; 9595ffaba3SGraeme Russ struct { 9695ffaba3SGraeme Russ __u64 reserved; 9795ffaba3SGraeme Russ } __attribute__ ((packed)) xprs; 9895ffaba3SGraeme Russ struct { 9995ffaba3SGraeme Russ __u64 reserved; 10095ffaba3SGraeme Russ } __attribute__ ((packed)) htpt; 10195ffaba3SGraeme Russ struct { 10295ffaba3SGraeme Russ __u64 reserved; 10395ffaba3SGraeme Russ } __attribute__ ((packed)) unknown; 10495ffaba3SGraeme Russ } interface_path; 10595ffaba3SGraeme Russ union { 10695ffaba3SGraeme Russ struct { 10795ffaba3SGraeme Russ __u8 device; 10895ffaba3SGraeme Russ __u8 reserved1; 10995ffaba3SGraeme Russ __u16 reserved2; 11095ffaba3SGraeme Russ __u32 reserved3; 11195ffaba3SGraeme Russ __u64 reserved4; 11295ffaba3SGraeme Russ } __attribute__ ((packed)) ata; 11395ffaba3SGraeme Russ struct { 11495ffaba3SGraeme Russ __u8 device; 11595ffaba3SGraeme Russ __u8 lun; 11695ffaba3SGraeme Russ __u8 reserved1; 11795ffaba3SGraeme Russ __u8 reserved2; 11895ffaba3SGraeme Russ __u32 reserved3; 11995ffaba3SGraeme Russ __u64 reserved4; 12095ffaba3SGraeme Russ } __attribute__ ((packed)) atapi; 12195ffaba3SGraeme Russ struct { 12295ffaba3SGraeme Russ __u16 id; 12395ffaba3SGraeme Russ __u64 lun; 12495ffaba3SGraeme Russ __u16 reserved1; 12595ffaba3SGraeme Russ __u32 reserved2; 12695ffaba3SGraeme Russ } __attribute__ ((packed)) scsi; 12795ffaba3SGraeme Russ struct { 12895ffaba3SGraeme Russ __u64 serial_number; 12995ffaba3SGraeme Russ __u64 reserved; 13095ffaba3SGraeme Russ } __attribute__ ((packed)) usb; 13195ffaba3SGraeme Russ struct { 13295ffaba3SGraeme Russ __u64 eui; 13395ffaba3SGraeme Russ __u64 reserved; 13495ffaba3SGraeme Russ } __attribute__ ((packed)) i1394; 13595ffaba3SGraeme Russ struct { 13695ffaba3SGraeme Russ __u64 wwid; 13795ffaba3SGraeme Russ __u64 lun; 13895ffaba3SGraeme Russ } __attribute__ ((packed)) fibre; 13995ffaba3SGraeme Russ struct { 14095ffaba3SGraeme Russ __u64 identity_tag; 14195ffaba3SGraeme Russ __u64 reserved; 14295ffaba3SGraeme Russ } __attribute__ ((packed)) i2o; 14395ffaba3SGraeme Russ struct { 14495ffaba3SGraeme Russ __u32 array_number; 14595ffaba3SGraeme Russ __u32 reserved1; 14695ffaba3SGraeme Russ __u64 reserved2; 14795ffaba3SGraeme Russ } __attribute__ ((packed)) raid; 14895ffaba3SGraeme Russ struct { 14995ffaba3SGraeme Russ __u8 device; 15095ffaba3SGraeme Russ __u8 reserved1; 15195ffaba3SGraeme Russ __u16 reserved2; 15295ffaba3SGraeme Russ __u32 reserved3; 15395ffaba3SGraeme Russ __u64 reserved4; 15495ffaba3SGraeme Russ } __attribute__ ((packed)) sata; 15595ffaba3SGraeme Russ struct { 15695ffaba3SGraeme Russ __u64 reserved1; 15795ffaba3SGraeme Russ __u64 reserved2; 15895ffaba3SGraeme Russ } __attribute__ ((packed)) unknown; 15995ffaba3SGraeme Russ } device_path; 16095ffaba3SGraeme Russ __u8 reserved4; 16195ffaba3SGraeme Russ __u8 checksum; 16295ffaba3SGraeme Russ } __attribute__ ((packed)); 16395ffaba3SGraeme Russ 16495ffaba3SGraeme Russ struct edd_info { 16595ffaba3SGraeme Russ __u8 device; 16695ffaba3SGraeme Russ __u8 version; 16795ffaba3SGraeme Russ __u16 interface_support; 16895ffaba3SGraeme Russ __u16 legacy_max_cylinder; 16995ffaba3SGraeme Russ __u8 legacy_max_head; 17095ffaba3SGraeme Russ __u8 legacy_sectors_per_track; 17195ffaba3SGraeme Russ struct edd_device_params params; 17295ffaba3SGraeme Russ } __attribute__ ((packed)); 17395ffaba3SGraeme Russ 17495ffaba3SGraeme Russ struct edd { 17595ffaba3SGraeme Russ unsigned int mbr_signature[EDD_MBR_SIG_MAX]; 17695ffaba3SGraeme Russ struct edd_info edd_info[EDDMAXNR]; 17795ffaba3SGraeme Russ unsigned char mbr_signature_nr; 17895ffaba3SGraeme Russ unsigned char edd_info_nr; 17995ffaba3SGraeme Russ }; 18095ffaba3SGraeme Russ 18195ffaba3SGraeme Russ #ifdef __KERNEL__ 18295ffaba3SGraeme Russ extern struct edd edd; 18395ffaba3SGraeme Russ #endif /* __KERNEL__ */ 18495ffaba3SGraeme Russ #endif /*!__ASSEMBLY__ */ 18595ffaba3SGraeme Russ 18695ffaba3SGraeme Russ #endif /* _LINUX_EDD_H */ 187