blob: 21de0dff872195acb21cf96eb211ace463f4b1f6 [file] [log] [blame]
Elliott Hughes180edef2023-11-02 00:08:05 +00001/*
2 * This file is auto-generated. Modifications will be lost.
3 *
4 * See https://android.googlesource.com/platform/bionic/+/master/libc/kernel/
5 * for more information.
6 */
Ben Cheng655a7c02013-10-16 16:09:24 -07007#ifndef _LINUX_HDREG_H
8#define _LINUX_HDREG_H
9#include <linux/types.h>
10#define HDIO_DRIVE_CMD_HDR_SIZE (4 * sizeof(__u8))
Ben Cheng655a7c02013-10-16 16:09:24 -070011#define HDIO_DRIVE_HOB_HDR_SIZE (8 * sizeof(__u8))
12#define HDIO_DRIVE_TASK_HDR_SIZE (8 * sizeof(__u8))
13#define IDE_DRIVE_TASK_NO_DATA 0
Tao Baod7db5942015-01-28 10:07:51 -080014#define IDE_DRIVE_TASK_INVALID - 1
Ben Cheng655a7c02013-10-16 16:09:24 -070015#define IDE_DRIVE_TASK_SET_XFER 1
16#define IDE_DRIVE_TASK_IN 2
17#define IDE_DRIVE_TASK_OUT 3
18#define IDE_DRIVE_TASK_RAW_WRITE 4
Ben Cheng655a7c02013-10-16 16:09:24 -070019#define IDE_TASKFILE_STD_IN_FLAGS 0xFE
20#define IDE_HOB_STD_IN_FLAGS 0x3C
21#define IDE_TASKFILE_STD_OUT_FLAGS 0xFE
22#define IDE_HOB_STD_OUT_FLAGS 0x3C
Ben Cheng655a7c02013-10-16 16:09:24 -070023typedef unsigned char task_ioreg_t;
24typedef unsigned long sata_ioreg_t;
25typedef union ide_reg_valid_s {
Tao Baod7db5942015-01-28 10:07:51 -080026 unsigned all : 16;
Tao Baod7db5942015-01-28 10:07:51 -080027 struct {
28 unsigned data : 1;
29 unsigned error_feature : 1;
30 unsigned sector : 1;
Tao Baod7db5942015-01-28 10:07:51 -080031 unsigned nsector : 1;
32 unsigned lcyl : 1;
33 unsigned hcyl : 1;
34 unsigned select : 1;
Tao Baod7db5942015-01-28 10:07:51 -080035 unsigned status_command : 1;
36 unsigned data_hob : 1;
37 unsigned error_feature_hob : 1;
38 unsigned sector_hob : 1;
Tao Baod7db5942015-01-28 10:07:51 -080039 unsigned nsector_hob : 1;
40 unsigned lcyl_hob : 1;
41 unsigned hcyl_hob : 1;
42 unsigned select_hob : 1;
Tao Baod7db5942015-01-28 10:07:51 -080043 unsigned control_hob : 1;
44 } b;
Ben Cheng655a7c02013-10-16 16:09:24 -070045} ide_reg_valid_t;
46typedef struct ide_task_request_s {
Tao Baod7db5942015-01-28 10:07:51 -080047 __u8 io_ports[8];
48 __u8 hob_ports[8];
49 ide_reg_valid_t out_flags;
50 ide_reg_valid_t in_flags;
Tao Baod7db5942015-01-28 10:07:51 -080051 int data_phase;
52 int req_cmd;
53 unsigned long out_size;
54 unsigned long in_size;
Ben Cheng655a7c02013-10-16 16:09:24 -070055} ide_task_request_t;
56typedef struct ide_ioctl_request_s {
Tao Baod7db5942015-01-28 10:07:51 -080057 ide_task_request_t * task_request;
58 unsigned char * out_buffer;
Tao Baod7db5942015-01-28 10:07:51 -080059 unsigned char * in_buffer;
Ben Cheng655a7c02013-10-16 16:09:24 -070060} ide_ioctl_request_t;
61struct hd_drive_cmd_hdr {
Tao Baod7db5942015-01-28 10:07:51 -080062 __u8 command;
Tao Baod7db5942015-01-28 10:07:51 -080063 __u8 sector_number;
64 __u8 feature;
65 __u8 sector_count;
Ben Cheng655a7c02013-10-16 16:09:24 -070066};
Ben Cheng655a7c02013-10-16 16:09:24 -070067typedef struct hd_drive_task_hdr {
Tao Baod7db5942015-01-28 10:07:51 -080068 __u8 data;
69 __u8 feature;
70 __u8 sector_count;
Tao Baod7db5942015-01-28 10:07:51 -080071 __u8 sector_number;
72 __u8 low_cylinder;
73 __u8 high_cylinder;
74 __u8 device_head;
Tao Baod7db5942015-01-28 10:07:51 -080075 __u8 command;
Ben Cheng655a7c02013-10-16 16:09:24 -070076} task_struct_t;
77typedef struct hd_drive_hob_hdr {
Tao Baod7db5942015-01-28 10:07:51 -080078 __u8 data;
Tao Baod7db5942015-01-28 10:07:51 -080079 __u8 feature;
80 __u8 sector_count;
81 __u8 sector_number;
82 __u8 low_cylinder;
Tao Baod7db5942015-01-28 10:07:51 -080083 __u8 high_cylinder;
84 __u8 device_head;
85 __u8 control;
Ben Cheng655a7c02013-10-16 16:09:24 -070086} hob_struct_t;
Ben Cheng655a7c02013-10-16 16:09:24 -070087#define TASKFILE_NO_DATA 0x0000
88#define TASKFILE_IN 0x0001
89#define TASKFILE_MULTI_IN 0x0002
90#define TASKFILE_OUT 0x0004
Ben Cheng655a7c02013-10-16 16:09:24 -070091#define TASKFILE_MULTI_OUT 0x0008
92#define TASKFILE_IN_OUT 0x0010
93#define TASKFILE_IN_DMA 0x0020
94#define TASKFILE_OUT_DMA 0x0040
Ben Cheng655a7c02013-10-16 16:09:24 -070095#define TASKFILE_IN_DMAQ 0x0080
96#define TASKFILE_OUT_DMAQ 0x0100
97#define TASKFILE_P_IN 0x0200
98#define TASKFILE_P_OUT 0x0400
Ben Cheng655a7c02013-10-16 16:09:24 -070099#define TASKFILE_P_IN_DMA 0x0800
100#define TASKFILE_P_OUT_DMA 0x1000
101#define TASKFILE_P_IN_DMAQ 0x2000
102#define TASKFILE_P_OUT_DMAQ 0x4000
Ben Cheng655a7c02013-10-16 16:09:24 -0700103#define TASKFILE_48 0x8000
104#define TASKFILE_INVALID 0x7fff
105#define WIN_NOP 0x00
106#define CFA_REQ_EXT_ERROR_CODE 0x03
Ben Cheng655a7c02013-10-16 16:09:24 -0700107#define WIN_SRST 0x08
108#define WIN_DEVICE_RESET 0x08
109#define WIN_RECAL 0x10
110#define WIN_RESTORE WIN_RECAL
Ben Cheng655a7c02013-10-16 16:09:24 -0700111#define WIN_READ 0x20
112#define WIN_READ_ONCE 0x21
113#define WIN_READ_LONG 0x22
114#define WIN_READ_LONG_ONCE 0x23
Ben Cheng655a7c02013-10-16 16:09:24 -0700115#define WIN_READ_EXT 0x24
116#define WIN_READDMA_EXT 0x25
117#define WIN_READDMA_QUEUED_EXT 0x26
118#define WIN_READ_NATIVE_MAX_EXT 0x27
Ben Cheng655a7c02013-10-16 16:09:24 -0700119#define WIN_MULTREAD_EXT 0x29
120#define WIN_WRITE 0x30
121#define WIN_WRITE_ONCE 0x31
122#define WIN_WRITE_LONG 0x32
Ben Cheng655a7c02013-10-16 16:09:24 -0700123#define WIN_WRITE_LONG_ONCE 0x33
124#define WIN_WRITE_EXT 0x34
125#define WIN_WRITEDMA_EXT 0x35
126#define WIN_WRITEDMA_QUEUED_EXT 0x36
Ben Cheng655a7c02013-10-16 16:09:24 -0700127#define WIN_SET_MAX_EXT 0x37
128#define CFA_WRITE_SECT_WO_ERASE 0x38
129#define WIN_MULTWRITE_EXT 0x39
130#define WIN_WRITE_VERIFY 0x3C
Ben Cheng655a7c02013-10-16 16:09:24 -0700131#define WIN_VERIFY 0x40
132#define WIN_VERIFY_ONCE 0x41
133#define WIN_VERIFY_EXT 0x42
134#define WIN_FORMAT 0x50
Ben Cheng655a7c02013-10-16 16:09:24 -0700135#define WIN_INIT 0x60
136#define WIN_SEEK 0x70
137#define CFA_TRANSLATE_SECTOR 0x87
138#define WIN_DIAGNOSE 0x90
Ben Cheng655a7c02013-10-16 16:09:24 -0700139#define WIN_SPECIFY 0x91
140#define WIN_DOWNLOAD_MICROCODE 0x92
141#define WIN_STANDBYNOW2 0x94
142#define WIN_STANDBY2 0x96
Ben Cheng655a7c02013-10-16 16:09:24 -0700143#define WIN_SETIDLE2 0x97
144#define WIN_CHECKPOWERMODE2 0x98
145#define WIN_SLEEPNOW2 0x99
146#define WIN_PACKETCMD 0xA0
Ben Cheng655a7c02013-10-16 16:09:24 -0700147#define WIN_PIDENTIFY 0xA1
148#define WIN_QUEUED_SERVICE 0xA2
149#define WIN_SMART 0xB0
150#define CFA_ERASE_SECTORS 0xC0
Ben Cheng655a7c02013-10-16 16:09:24 -0700151#define WIN_MULTREAD 0xC4
152#define WIN_MULTWRITE 0xC5
153#define WIN_SETMULT 0xC6
154#define WIN_READDMA_QUEUED 0xC7
Ben Cheng655a7c02013-10-16 16:09:24 -0700155#define WIN_READDMA 0xC8
156#define WIN_READDMA_ONCE 0xC9
157#define WIN_WRITEDMA 0xCA
158#define WIN_WRITEDMA_ONCE 0xCB
Ben Cheng655a7c02013-10-16 16:09:24 -0700159#define WIN_WRITEDMA_QUEUED 0xCC
160#define CFA_WRITE_MULTI_WO_ERASE 0xCD
161#define WIN_GETMEDIASTATUS 0xDA
162#define WIN_ACKMEDIACHANGE 0xDB
Ben Cheng655a7c02013-10-16 16:09:24 -0700163#define WIN_POSTBOOT 0xDC
164#define WIN_PREBOOT 0xDD
165#define WIN_DOORLOCK 0xDE
166#define WIN_DOORUNLOCK 0xDF
Ben Cheng655a7c02013-10-16 16:09:24 -0700167#define WIN_STANDBYNOW1 0xE0
168#define WIN_IDLEIMMEDIATE 0xE1
169#define WIN_STANDBY 0xE2
170#define WIN_SETIDLE1 0xE3
Ben Cheng655a7c02013-10-16 16:09:24 -0700171#define WIN_READ_BUFFER 0xE4
172#define WIN_CHECKPOWERMODE1 0xE5
173#define WIN_SLEEPNOW1 0xE6
174#define WIN_FLUSH_CACHE 0xE7
Ben Cheng655a7c02013-10-16 16:09:24 -0700175#define WIN_WRITE_BUFFER 0xE8
176#define WIN_WRITE_SAME 0xE9
177#define WIN_FLUSH_CACHE_EXT 0xEA
178#define WIN_IDENTIFY 0xEC
Ben Cheng655a7c02013-10-16 16:09:24 -0700179#define WIN_MEDIAEJECT 0xED
180#define WIN_IDENTIFY_DMA 0xEE
181#define WIN_SETFEATURES 0xEF
182#define EXABYTE_ENABLE_NEST 0xF0
Ben Cheng655a7c02013-10-16 16:09:24 -0700183#define WIN_SECURITY_SET_PASS 0xF1
184#define WIN_SECURITY_UNLOCK 0xF2
185#define WIN_SECURITY_ERASE_PREPARE 0xF3
186#define WIN_SECURITY_ERASE_UNIT 0xF4
Ben Cheng655a7c02013-10-16 16:09:24 -0700187#define WIN_SECURITY_FREEZE_LOCK 0xF5
188#define WIN_SECURITY_DISABLE 0xF6
189#define WIN_READ_NATIVE_MAX 0xF8
190#define WIN_SET_MAX 0xF9
Ben Cheng655a7c02013-10-16 16:09:24 -0700191#define DISABLE_SEAGATE 0xFB
192#define SMART_READ_VALUES 0xD0
193#define SMART_READ_THRESHOLDS 0xD1
194#define SMART_AUTOSAVE 0xD2
Ben Cheng655a7c02013-10-16 16:09:24 -0700195#define SMART_SAVE 0xD3
196#define SMART_IMMEDIATE_OFFLINE 0xD4
197#define SMART_READ_LOG_SECTOR 0xD5
198#define SMART_WRITE_LOG_SECTOR 0xD6
Ben Cheng655a7c02013-10-16 16:09:24 -0700199#define SMART_WRITE_THRESHOLDS 0xD7
200#define SMART_ENABLE 0xD8
201#define SMART_DISABLE 0xD9
202#define SMART_STATUS 0xDA
Ben Cheng655a7c02013-10-16 16:09:24 -0700203#define SMART_AUTO_OFFLINE 0xDB
204#define SMART_LCYL_PASS 0x4F
205#define SMART_HCYL_PASS 0xC2
206#define SETFEATURES_EN_8BIT 0x01
Ben Cheng655a7c02013-10-16 16:09:24 -0700207#define SETFEATURES_EN_WCACHE 0x02
208#define SETFEATURES_DIS_DEFECT 0x04
209#define SETFEATURES_EN_APM 0x05
210#define SETFEATURES_EN_SAME_R 0x22
Ben Cheng655a7c02013-10-16 16:09:24 -0700211#define SETFEATURES_DIS_MSN 0x31
212#define SETFEATURES_DIS_RETRY 0x33
213#define SETFEATURES_EN_AAM 0x42
214#define SETFEATURES_RW_LONG 0x44
Ben Cheng655a7c02013-10-16 16:09:24 -0700215#define SETFEATURES_SET_CACHE 0x54
216#define SETFEATURES_DIS_RLA 0x55
217#define SETFEATURES_EN_RI 0x5D
218#define SETFEATURES_EN_SI 0x5E
Ben Cheng655a7c02013-10-16 16:09:24 -0700219#define SETFEATURES_DIS_RPOD 0x66
220#define SETFEATURES_DIS_ECC 0x77
221#define SETFEATURES_DIS_8BIT 0x81
222#define SETFEATURES_DIS_WCACHE 0x82
Ben Cheng655a7c02013-10-16 16:09:24 -0700223#define SETFEATURES_EN_DEFECT 0x84
224#define SETFEATURES_DIS_APM 0x85
225#define SETFEATURES_EN_ECC 0x88
226#define SETFEATURES_EN_MSN 0x95
Ben Cheng655a7c02013-10-16 16:09:24 -0700227#define SETFEATURES_EN_RETRY 0x99
228#define SETFEATURES_EN_RLA 0xAA
229#define SETFEATURES_PREFETCH 0xAB
230#define SETFEATURES_EN_REST 0xAC
Ben Cheng655a7c02013-10-16 16:09:24 -0700231#define SETFEATURES_4B_RW_LONG 0xBB
232#define SETFEATURES_DIS_AAM 0xC2
233#define SETFEATURES_EN_RPOD 0xCC
234#define SETFEATURES_DIS_RI 0xDD
Ben Cheng655a7c02013-10-16 16:09:24 -0700235#define SETFEATURES_EN_SAME_M 0xDD
236#define SETFEATURES_DIS_SI 0xDE
237#define SECURITY_SET_PASSWORD 0xBA
238#define SECURITY_UNLOCK 0xBB
Ben Cheng655a7c02013-10-16 16:09:24 -0700239#define SECURITY_ERASE_PREPARE 0xBC
240#define SECURITY_ERASE_UNIT 0xBD
241#define SECURITY_FREEZE_LOCK 0xBE
242#define SECURITY_DISABLE_PASSWORD 0xBF
Ben Cheng655a7c02013-10-16 16:09:24 -0700243struct hd_geometry {
Tao Baod7db5942015-01-28 10:07:51 -0800244 unsigned char heads;
245 unsigned char sectors;
246 unsigned short cylinders;
Tao Baod7db5942015-01-28 10:07:51 -0800247 unsigned long start;
Ben Cheng655a7c02013-10-16 16:09:24 -0700248};
249#define HDIO_GETGEO 0x0301
250#define HDIO_GET_UNMASKINTR 0x0302
Ben Cheng655a7c02013-10-16 16:09:24 -0700251#define HDIO_GET_MULTCOUNT 0x0304
252#define HDIO_GET_QDMA 0x0305
253#define HDIO_SET_XFER 0x0306
254#define HDIO_OBSOLETE_IDENTITY 0x0307
Ben Cheng655a7c02013-10-16 16:09:24 -0700255#define HDIO_GET_KEEPSETTINGS 0x0308
256#define HDIO_GET_32BIT 0x0309
257#define HDIO_GET_NOWERR 0x030a
258#define HDIO_GET_DMA 0x030b
Ben Cheng655a7c02013-10-16 16:09:24 -0700259#define HDIO_GET_NICE 0x030c
260#define HDIO_GET_IDENTITY 0x030d
261#define HDIO_GET_WCACHE 0x030e
262#define HDIO_GET_ACOUSTIC 0x030f
Ben Cheng655a7c02013-10-16 16:09:24 -0700263#define HDIO_GET_ADDRESS 0x0310
264#define HDIO_GET_BUSSTATE 0x031a
265#define HDIO_TRISTATE_HWIF 0x031b
266#define HDIO_DRIVE_RESET 0x031c
Ben Cheng655a7c02013-10-16 16:09:24 -0700267#define HDIO_DRIVE_TASKFILE 0x031d
268#define HDIO_DRIVE_TASK 0x031e
269#define HDIO_DRIVE_CMD 0x031f
270#define HDIO_DRIVE_CMD_AEB HDIO_DRIVE_TASK
Ben Cheng655a7c02013-10-16 16:09:24 -0700271#define HDIO_SET_MULTCOUNT 0x0321
272#define HDIO_SET_UNMASKINTR 0x0322
273#define HDIO_SET_KEEPSETTINGS 0x0323
274#define HDIO_SET_32BIT 0x0324
Ben Cheng655a7c02013-10-16 16:09:24 -0700275#define HDIO_SET_NOWERR 0x0325
276#define HDIO_SET_DMA 0x0326
277#define HDIO_SET_PIO_MODE 0x0327
278#define HDIO_SCAN_HWIF 0x0328
Ben Cheng655a7c02013-10-16 16:09:24 -0700279#define HDIO_UNREGISTER_HWIF 0x032a
280#define HDIO_SET_NICE 0x0329
281#define HDIO_SET_WCACHE 0x032b
282#define HDIO_SET_ACOUSTIC 0x032c
Ben Cheng655a7c02013-10-16 16:09:24 -0700283#define HDIO_SET_BUSSTATE 0x032d
284#define HDIO_SET_QDMA 0x032e
285#define HDIO_SET_ADDRESS 0x032f
286enum {
Tao Baod7db5942015-01-28 10:07:51 -0800287 BUSSTATE_OFF = 0,
288 BUSSTATE_ON,
289 BUSSTATE_TRISTATE
Ben Cheng655a7c02013-10-16 16:09:24 -0700290};
Ben Cheng655a7c02013-10-16 16:09:24 -0700291#define __NEW_HD_DRIVE_ID
292struct hd_driveid {
Tao Baod7db5942015-01-28 10:07:51 -0800293 unsigned short config;
294 unsigned short cyls;
Tao Baod7db5942015-01-28 10:07:51 -0800295 unsigned short reserved2;
296 unsigned short heads;
297 unsigned short track_bytes;
298 unsigned short sector_bytes;
Tao Baod7db5942015-01-28 10:07:51 -0800299 unsigned short sectors;
300 unsigned short vendor0;
301 unsigned short vendor1;
302 unsigned short vendor2;
Tao Baod7db5942015-01-28 10:07:51 -0800303 unsigned char serial_no[20];
304 unsigned short buf_type;
305 unsigned short buf_size;
306 unsigned short ecc_bytes;
Tao Baod7db5942015-01-28 10:07:51 -0800307 unsigned char fw_rev[8];
308 unsigned char model[40];
309 unsigned char max_multsect;
310 unsigned char vendor3;
Tao Baod7db5942015-01-28 10:07:51 -0800311 unsigned short dword_io;
312 unsigned char vendor4;
313 unsigned char capability;
314 unsigned short reserved50;
Tao Baod7db5942015-01-28 10:07:51 -0800315 unsigned char vendor5;
316 unsigned char tPIO;
317 unsigned char vendor6;
318 unsigned char tDMA;
Tao Baod7db5942015-01-28 10:07:51 -0800319 unsigned short field_valid;
320 unsigned short cur_cyls;
321 unsigned short cur_heads;
322 unsigned short cur_sectors;
Tao Baod7db5942015-01-28 10:07:51 -0800323 unsigned short cur_capacity0;
324 unsigned short cur_capacity1;
325 unsigned char multsect;
326 unsigned char multsect_valid;
Tao Baod7db5942015-01-28 10:07:51 -0800327 unsigned int lba_capacity;
328 unsigned short dma_1word;
329 unsigned short dma_mword;
330 unsigned short eide_pio_modes;
Tao Baod7db5942015-01-28 10:07:51 -0800331 unsigned short eide_dma_min;
332 unsigned short eide_dma_time;
333 unsigned short eide_pio;
334 unsigned short eide_pio_iordy;
Tao Baod7db5942015-01-28 10:07:51 -0800335 unsigned short words69_70[2];
336 unsigned short words71_74[4];
337 unsigned short queue_depth;
338 unsigned short words76_79[4];
Tao Baod7db5942015-01-28 10:07:51 -0800339 unsigned short major_rev_num;
340 unsigned short minor_rev_num;
341 unsigned short command_set_1;
342 unsigned short command_set_2;
Tao Baod7db5942015-01-28 10:07:51 -0800343 unsigned short cfsse;
344 unsigned short cfs_enable_1;
345 unsigned short cfs_enable_2;
346 unsigned short csf_default;
Tao Baod7db5942015-01-28 10:07:51 -0800347 unsigned short dma_ultra;
348 unsigned short trseuc;
349 unsigned short trsEuc;
350 unsigned short CurAPMvalues;
Tao Baod7db5942015-01-28 10:07:51 -0800351 unsigned short mprc;
352 unsigned short hw_config;
353 unsigned short acoustic;
354 unsigned short msrqs;
Tao Baod7db5942015-01-28 10:07:51 -0800355 unsigned short sxfert;
356 unsigned short sal;
357 unsigned int spg;
358 unsigned long long lba_capacity_2;
Tao Baod7db5942015-01-28 10:07:51 -0800359 unsigned short words104_125[22];
360 unsigned short last_lun;
361 unsigned short word127;
362 unsigned short dlf;
Tao Baod7db5942015-01-28 10:07:51 -0800363 unsigned short csfo;
364 unsigned short words130_155[26];
365 unsigned short word156;
366 unsigned short words157_159[3];
Tao Baod7db5942015-01-28 10:07:51 -0800367 unsigned short cfa_power;
368 unsigned short words161_175[15];
369 unsigned short words176_205[30];
370 unsigned short words206_254[49];
Tao Baod7db5942015-01-28 10:07:51 -0800371 unsigned short integrity_word;
Ben Cheng655a7c02013-10-16 16:09:24 -0700372};
373#define IDE_NICE_DSC_OVERLAP (0)
374#define IDE_NICE_ATAPI_OVERLAP (1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700375#define IDE_NICE_1 (3)
376#define IDE_NICE_0 (2)
377#define IDE_NICE_2 (4)
378#endif