111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert/****************************************************************************
211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ****************************************************************************
311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***
411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***   This header was automatically generated from a Linux kernel header
511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***   of the same name, to make information necessary for userspace to
611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***   call into the kernel available to libc.  It contains only constants,
711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***   structures, and macros generated from the original header, and thus,
811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***   contains no copyrightable information.
911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ***
1011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ****************************************************************************
1111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ****************************************************************************/
1211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#ifndef _LINUX_HDREG_H
1311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define _LINUX_HDREG_H
1411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
1511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_CMD_HDR_SIZE (4 * sizeof(u8))
1611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_HOB_HDR_SIZE (8 * sizeof(u8))
1711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_TASK_HDR_SIZE (8 * sizeof(u8))
1811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
1911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_INVALID -1
2011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_NO_DATA 0
2111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_SET_XFER 1
2211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
2311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_IN 2
2411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
2511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_OUT 3
2611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_DRIVE_TASK_RAW_WRITE 4
2711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
2811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_TASKFILE_STD_IN_FLAGS 0xFE
2911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_HOB_STD_IN_FLAGS 0x3C
3011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_TASKFILE_STD_OUT_FLAGS 0xFE
3111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_HOB_STD_OUT_FLAGS 0x3C
3211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
3311cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef unsigned char task_ioreg_t;
3411cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef unsigned long sata_ioreg_t;
3511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
3611cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef union ide_reg_valid_s {
3711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned all : 16;
3811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert struct {
3911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned data : 1;
4011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned error_feature : 1;
4111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned sector : 1;
4211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned nsector : 1;
4311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned lcyl : 1;
4411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned hcyl : 1;
4511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned select : 1;
4611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned status_command : 1;
4711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
4811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned data_hob : 1;
4911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned error_feature_hob : 1;
5011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned sector_hob : 1;
5111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned nsector_hob : 1;
5211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned lcyl_hob : 1;
5311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned hcyl_hob : 1;
5411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned select_hob : 1;
5511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned control_hob : 1;
5611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } b;
5711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} ide_reg_valid_t;
5811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
5911cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef struct ide_task_request_s {
6011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t io_ports[8];
6111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t hob_ports[8];
6211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ide_reg_valid_t out_flags;
6311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ide_reg_valid_t in_flags;
6411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert int data_phase;
6511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert int req_cmd;
6611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned long out_size;
6711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned long in_size;
6811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} ide_task_request_t;
6911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
7011cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef struct ide_ioctl_request_s {
7111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert ide_task_request_t *task_request;
7211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char *out_buffer;
7311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char *in_buffer;
7411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} ide_ioctl_request_t;
7511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
7611cd02dfb91661c65134cac258cf5924270e9d2Dan Albertstruct hd_drive_cmd_hdr {
7711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t command;
7811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_number;
7911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t feature;
8011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_count;
8111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert};
8211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
8311cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef struct hd_drive_task_hdr {
8411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t data;
8511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t feature;
8611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_count;
8711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_number;
8811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t low_cylinder;
8911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t high_cylinder;
9011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t device_head;
9111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t command;
9211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} task_struct_t;
9311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
9411cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttypedef struct hd_drive_hob_hdr {
9511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t data;
9611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t feature;
9711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_count;
9811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t sector_number;
9911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t low_cylinder;
10011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t high_cylinder;
10111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t device_head;
10211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert task_ioreg_t control;
10311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} hob_struct_t;
10411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
10511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_INVALID 0x7fff
10611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_48 0x8000
10711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
10811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_NO_DATA 0x0000
10911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
11011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_IN 0x0001
11111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_MULTI_IN 0x0002
11211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
11311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_OUT 0x0004
11411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_MULTI_OUT 0x0008
11511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_IN_OUT 0x0010
11611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
11711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_IN_DMA 0x0020
11811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_OUT_DMA 0x0040
11911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_IN_DMAQ 0x0080
12011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_OUT_DMAQ 0x0100
12111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
12211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_IN 0x0200
12311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_OUT 0x0400
12411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_IN_DMA 0x0800
12511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_OUT_DMA 0x1000
12611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_IN_DMAQ 0x2000
12711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define TASKFILE_P_OUT_DMAQ 0x4000
12811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
12911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_NOP 0x00
13011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
13111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define CFA_REQ_EXT_ERROR_CODE 0x03
13211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
13311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SRST 0x08
13411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_DEVICE_RESET 0x08
13511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
13611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_RECAL 0x10
13711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_RESTORE WIN_RECAL
13811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
13911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ 0x20
14011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_ONCE 0x21
14111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_LONG 0x22
14211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_LONG_ONCE 0x23
14311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_EXT 0x24
14411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READDMA_EXT 0x25
14511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READDMA_QUEUED_EXT 0x26
14611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_NATIVE_MAX_EXT 0x27
14711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
14811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_MULTREAD_EXT 0x29
14911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
15011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE 0x30
15111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_ONCE 0x31
15211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_LONG 0x32
15311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_LONG_ONCE 0x33
15411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_EXT 0x34
15511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITEDMA_EXT 0x35
15611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITEDMA_QUEUED_EXT 0x36
15711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SET_MAX_EXT 0x37
15811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define CFA_WRITE_SECT_WO_ERASE 0x38
15911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_MULTWRITE_EXT 0x39
16011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
16111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_VERIFY 0x3C
16211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
16311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_VERIFY 0x40
16411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_VERIFY_ONCE 0x41
16511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_VERIFY_EXT 0x42
16611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
16711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_FORMAT 0x50
16811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
16911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_INIT 0x60
17011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
17111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SEEK 0x70
17211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
17311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define CFA_TRANSLATE_SECTOR 0x87
17411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_DIAGNOSE 0x90
17511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SPECIFY 0x91
17611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_DOWNLOAD_MICROCODE 0x92
17711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_STANDBYNOW2 0x94
17811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_STANDBY2 0x96
17911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SETIDLE2 0x97
18011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_CHECKPOWERMODE2 0x98
18111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SLEEPNOW2 0x99
18211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
18311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_PACKETCMD 0xA0
18411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_PIDENTIFY 0xA1
18511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_QUEUED_SERVICE 0xA2
18611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SMART 0xB0
18711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define CFA_ERASE_SECTORS 0xC0
18811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_MULTREAD 0xC4
18911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_MULTWRITE 0xC5
19011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SETMULT 0xC6
19111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READDMA_QUEUED 0xC7
19211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READDMA 0xC8
19311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READDMA_ONCE 0xC9
19411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITEDMA 0xCA
19511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITEDMA_ONCE 0xCB
19611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITEDMA_QUEUED 0xCC
19711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define CFA_WRITE_MULTI_WO_ERASE 0xCD
19811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_GETMEDIASTATUS 0xDA
19911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_ACKMEDIACHANGE 0xDB
20011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_POSTBOOT 0xDC
20111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_PREBOOT 0xDD
20211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_DOORLOCK 0xDE
20311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_DOORUNLOCK 0xDF
20411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_STANDBYNOW1 0xE0
20511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_IDLEIMMEDIATE 0xE1
20611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_STANDBY 0xE2
20711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SETIDLE1 0xE3
20811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_BUFFER 0xE4
20911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_CHECKPOWERMODE1 0xE5
21011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SLEEPNOW1 0xE6
21111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_FLUSH_CACHE 0xE7
21211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_BUFFER 0xE8
21311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_WRITE_SAME 0xE9
21411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
21511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_FLUSH_CACHE_EXT 0xEA
21611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_IDENTIFY 0xEC
21711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_MEDIAEJECT 0xED
21811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_IDENTIFY_DMA 0xEE
21911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SETFEATURES 0xEF
22011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define EXABYTE_ENABLE_NEST 0xF0
22111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_SET_PASS 0xF1
22211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_UNLOCK 0xF2
22311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_ERASE_PREPARE 0xF3
22411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_ERASE_UNIT 0xF4
22511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_FREEZE_LOCK 0xF5
22611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SECURITY_DISABLE 0xF6
22711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_READ_NATIVE_MAX 0xF8
22811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define WIN_SET_MAX 0xF9
22911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define DISABLE_SEAGATE 0xFB
23011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
23111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_READ_VALUES 0xD0
23211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_READ_THRESHOLDS 0xD1
23311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_AUTOSAVE 0xD2
23411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_SAVE 0xD3
23511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_IMMEDIATE_OFFLINE 0xD4
23611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_READ_LOG_SECTOR 0xD5
23711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_WRITE_LOG_SECTOR 0xD6
23811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_WRITE_THRESHOLDS 0xD7
23911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_ENABLE 0xD8
24011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_DISABLE 0xD9
24111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_STATUS 0xDA
24211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_AUTO_OFFLINE 0xDB
24311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
24411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_LCYL_PASS 0x4F
24511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SMART_HCYL_PASS 0xC2
24611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
24711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_8BIT 0x01
24811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_WCACHE 0x02
24911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_DEFECT 0x04
25011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_APM 0x05
25111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_SAME_R 0x22
25211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_MSN 0x31
25311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_RETRY 0x33
25411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_AAM 0x42
25511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_RW_LONG 0x44
25611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_SET_CACHE 0x54
25711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_RLA 0x55
25811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_RI 0x5D
25911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_SI 0x5E
26011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_RPOD 0x66
26111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_ECC 0x77
26211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_8BIT 0x81
26311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_WCACHE 0x82
26411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_DEFECT 0x84
26511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_APM 0x85
26611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_ECC 0x88
26711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_MSN 0x95
26811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_RETRY 0x99
26911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_RLA 0xAA
27011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_PREFETCH 0xAB
27111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_REST 0xAC
27211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_4B_RW_LONG 0xBB
27311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_AAM 0xC2
27411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_RPOD 0xCC
27511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_RI 0xDD
27611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_EN_SAME_M 0xDD
27711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SETFEATURES_DIS_SI 0xDE
27811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
27911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_SET_PASSWORD 0xBA
28011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_UNLOCK 0xBB
28111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_ERASE_PREPARE 0xBC
28211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_ERASE_UNIT 0xBD
28311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_FREEZE_LOCK 0xBE
28411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define SECURITY_DISABLE_PASSWORD 0xBF
28511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
28611cd02dfb91661c65134cac258cf5924270e9d2Dan Albertstruct hd_geometry {
28711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char heads;
28811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char sectors;
28911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cylinders;
29011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned long start;
29111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert};
29211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
29311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GETGEO 0x0301
29411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_UNMASKINTR 0x0302
29511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_MULTCOUNT 0x0304
29611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_QDMA 0x0305
29711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
29811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_XFER 0x0306
29911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
30011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_OBSOLETE_IDENTITY 0x0307
30111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_KEEPSETTINGS 0x0308
30211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_32BIT 0x0309
30311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_NOWERR 0x030a
30411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_DMA 0x030b
30511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_NICE 0x030c
30611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_IDENTITY 0x030d
30711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_WCACHE 0x030e
30811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_ACOUSTIC 0x030f
30911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_ADDRESS 0x0310
31011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
31111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_GET_BUSSTATE 0x031a
31211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_TRISTATE_HWIF 0x031b
31311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_RESET 0x031c
31411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_TASKFILE 0x031d
31511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_TASK 0x031e
31611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_CMD 0x031f
31711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_DRIVE_CMD_AEB HDIO_DRIVE_TASK
31811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
31911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_MULTCOUNT 0x0321
32011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_UNMASKINTR 0x0322
32111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_KEEPSETTINGS 0x0323
32211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_32BIT 0x0324
32311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_NOWERR 0x0325
32411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_DMA 0x0326
32511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_PIO_MODE 0x0327
32611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SCAN_HWIF 0x0328
32711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_NICE 0x0329
32811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_UNREGISTER_HWIF 0x032a
32911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_WCACHE 0x032b
33011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_ACOUSTIC 0x032c
33111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_BUSSTATE 0x032d
33211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_QDMA 0x032e
33311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define HDIO_SET_ADDRESS 0x032f
33411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
33511cd02dfb91661c65134cac258cf5924270e9d2Dan Albertenum {
33611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert BUSSTATE_OFF = 0,
33711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert BUSSTATE_ON,
33811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert BUSSTATE_TRISTATE
33911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert};
34011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
34111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define __NEW_HD_DRIVE_ID
34211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
34311cd02dfb91661c65134cac258cf5924270e9d2Dan Albertstruct hd_driveid {
34411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short config;
34511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cyls;
34611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short reserved2;
34711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short heads;
34811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short track_bytes;
34911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short sector_bytes;
35011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short sectors;
35111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short vendor0;
35211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short vendor1;
35311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short vendor2;
35411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char serial_no[20];
35511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short buf_type;
35611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short buf_size;
35711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short ecc_bytes;
35811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char fw_rev[8];
35911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char model[40];
36011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char max_multsect;
36111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char vendor3;
36211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short dword_io;
36311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char vendor4;
36411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char capability;
36511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short reserved50;
36611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char vendor5;
36711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char tPIO;
36811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char vendor6;
36911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char tDMA;
37011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short field_valid;
37111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cur_cyls;
37211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cur_heads;
37311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cur_sectors;
37411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cur_capacity0;
37511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cur_capacity1;
37611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char multsect;
37711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned char multsect_valid;
37811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned int lba_capacity;
37911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short dma_1word;
38011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short dma_mword;
38111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short eide_pio_modes;
38211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short eide_dma_min;
38311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short eide_dma_time;
38411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short eide_pio;
38511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short eide_pio_iordy;
38611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words69_70[2];
38711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
38811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words71_74[4];
38911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short queue_depth;
39011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words76_79[4];
39111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short major_rev_num;
39211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short minor_rev_num;
39311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short command_set_1;
39411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short command_set_2;
39511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cfsse;
39611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cfs_enable_1;
39711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cfs_enable_2;
39811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short csf_default;
39911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short dma_ultra;
40011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short trseuc;
40111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short trsEuc;
40211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short CurAPMvalues;
40311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short mprc;
40411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short hw_config;
40511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short acoustic;
40611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short msrqs;
40711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short sxfert;
40811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short sal;
40911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned int spg;
41011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned long long lba_capacity_2;
41111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words104_125[22];
41211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short last_lun;
41311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short word127;
41411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short dlf;
41511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short csfo;
41611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words130_155[26];
41711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short word156;
41811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words157_159[3];
41911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short cfa_power;
42011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words161_175[15];
42111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words176_205[30];
42211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short words206_254[49];
42311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert unsigned short integrity_word;
42411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert};
42511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
42611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_NICE_DSC_OVERLAP (0)
42711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_NICE_ATAPI_OVERLAP (1)
42811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_NICE_0 (2)
42911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_NICE_1 (3)
43011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#define IDE_NICE_2 (4)
43111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert
43211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#endif
433