dasd_eckd.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. /*
  2. * File...........: linux/drivers/s390/block/dasd_eckd.h
  3. * Author(s)......: Holger Smolinski <Holger.Smolinski@de.ibm.com>
  4. * Horst Hummel <Horst.Hummel@de.ibm.com>
  5. * Bugreports.to..: <Linux390@de.ibm.com>
  6. * (C) IBM Corporation, IBM Deutschland Entwicklung GmbH, 1999,2000
  7. *
  8. */
  9. #ifndef DASD_ECKD_H
  10. #define DASD_ECKD_H
  11. /*****************************************************************************
  12. * SECTION: CCW Definitions
  13. ****************************************************************************/
  14. #define DASD_ECKD_CCW_WRITE 0x05
  15. #define DASD_ECKD_CCW_READ 0x06
  16. #define DASD_ECKD_CCW_WRITE_HOME_ADDRESS 0x09
  17. #define DASD_ECKD_CCW_READ_HOME_ADDRESS 0x0a
  18. #define DASD_ECKD_CCW_WRITE_KD 0x0d
  19. #define DASD_ECKD_CCW_READ_KD 0x0e
  20. #define DASD_ECKD_CCW_ERASE 0x11
  21. #define DASD_ECKD_CCW_READ_COUNT 0x12
  22. #define DASD_ECKD_CCW_SLCK 0x14
  23. #define DASD_ECKD_CCW_WRITE_RECORD_ZERO 0x15
  24. #define DASD_ECKD_CCW_READ_RECORD_ZERO 0x16
  25. #define DASD_ECKD_CCW_WRITE_CKD 0x1d
  26. #define DASD_ECKD_CCW_READ_CKD 0x1e
  27. #define DASD_ECKD_CCW_PSF 0x27
  28. #define DASD_ECKD_CCW_RSSD 0x3e
  29. #define DASD_ECKD_CCW_LOCATE_RECORD 0x47
  30. #define DASD_ECKD_CCW_SNSS 0x54
  31. #define DASD_ECKD_CCW_DEFINE_EXTENT 0x63
  32. #define DASD_ECKD_CCW_WRITE_MT 0x85
  33. #define DASD_ECKD_CCW_READ_MT 0x86
  34. #define DASD_ECKD_CCW_WRITE_KD_MT 0x8d
  35. #define DASD_ECKD_CCW_READ_KD_MT 0x8e
  36. #define DASD_ECKD_CCW_RELEASE 0x94
  37. #define DASD_ECKD_CCW_READ_CKD_MT 0x9e
  38. #define DASD_ECKD_CCW_WRITE_CKD_MT 0x9d
  39. #define DASD_ECKD_CCW_WRITE_TRACK_DATA 0xA5
  40. #define DASD_ECKD_CCW_READ_TRACK_DATA 0xA6
  41. #define DASD_ECKD_CCW_RESERVE 0xB4
  42. #define DASD_ECKD_CCW_PFX 0xE7
  43. #define DASD_ECKD_CCW_PFX_READ 0xEA
  44. #define DASD_ECKD_CCW_RSCK 0xF9
  45. /*
  46. * Perform Subsystem Function / Sub-Orders
  47. */
  48. #define PSF_ORDER_PRSSD 0x18
  49. #define PSF_ORDER_SSC 0x1D
  50. /*
  51. * Size that is reportet for large volumes in the old 16-bit no_cyl field
  52. */
  53. #define LV_COMPAT_CYL 0xFFFE
  54. /*****************************************************************************
  55. * SECTION: Type Definitions
  56. ****************************************************************************/
  57. struct eckd_count {
  58. __u16 cyl;
  59. __u16 head;
  60. __u8 record;
  61. __u8 kl;
  62. __u16 dl;
  63. } __attribute__ ((packed));
  64. struct ch_t {
  65. __u16 cyl;
  66. __u16 head;
  67. } __attribute__ ((packed));
  68. struct chs_t {
  69. __u16 cyl;
  70. __u16 head;
  71. __u32 sector;
  72. } __attribute__ ((packed));
  73. struct chr_t {
  74. __u16 cyl;
  75. __u16 head;
  76. __u8 record;
  77. } __attribute__ ((packed));
  78. struct geom_t {
  79. __u16 cyl;
  80. __u16 head;
  81. __u32 sector;
  82. } __attribute__ ((packed));
  83. struct eckd_home {
  84. __u8 skip_control[14];
  85. __u16 cell_number;
  86. __u8 physical_addr[3];
  87. __u8 flag;
  88. struct ch_t track_addr;
  89. __u8 reserved;
  90. __u8 key_length;
  91. __u8 reserved2[2];
  92. } __attribute__ ((packed));
  93. struct DE_eckd_data {
  94. struct {
  95. unsigned char perm:2; /* Permissions on this extent */
  96. unsigned char reserved:1;
  97. unsigned char seek:2; /* Seek control */
  98. unsigned char auth:2; /* Access authorization */
  99. unsigned char pci:1; /* PCI Fetch mode */
  100. } __attribute__ ((packed)) mask;
  101. struct {
  102. unsigned char mode:2; /* Architecture mode */
  103. unsigned char ckd:1; /* CKD Conversion */
  104. unsigned char operation:3; /* Operation mode */
  105. unsigned char cfw:1; /* Cache fast write */
  106. unsigned char dfw:1; /* DASD fast write */
  107. } __attribute__ ((packed)) attributes;
  108. __u16 blk_size; /* Blocksize */
  109. __u16 fast_write_id;
  110. __u8 ga_additional; /* Global Attributes Additional */
  111. __u8 ga_extended; /* Global Attributes Extended */
  112. struct ch_t beg_ext;
  113. struct ch_t end_ext;
  114. unsigned long long ep_sys_time; /* Ext Parameter - System Time Stamp */
  115. __u8 ep_format; /* Extended Parameter format byte */
  116. __u8 ep_prio; /* Extended Parameter priority I/O byte */
  117. __u8 ep_reserved1; /* Extended Parameter Reserved */
  118. __u8 ep_rec_per_track; /* Number of records on a track */
  119. __u8 ep_reserved[4]; /* Extended Parameter Reserved */
  120. } __attribute__ ((packed));
  121. struct LO_eckd_data {
  122. struct {
  123. unsigned char orientation:2;
  124. unsigned char operation:6;
  125. } __attribute__ ((packed)) operation;
  126. struct {
  127. unsigned char last_bytes_used:1;
  128. unsigned char reserved:6;
  129. unsigned char read_count_suffix:1;
  130. } __attribute__ ((packed)) auxiliary;
  131. __u8 unused;
  132. __u8 count;
  133. struct ch_t seek_addr;
  134. struct chr_t search_arg;
  135. __u8 sector;
  136. __u16 length;
  137. } __attribute__ ((packed));
  138. struct LRE_eckd_data {
  139. struct {
  140. unsigned char orientation:2;
  141. unsigned char operation:6;
  142. } __attribute__ ((packed)) operation;
  143. struct {
  144. unsigned char length_valid:1;
  145. unsigned char length_scope:1;
  146. unsigned char imbedded_ccw_valid:1;
  147. unsigned char check_bytes:2;
  148. unsigned char imbedded_count_valid:1;
  149. unsigned char reserved:1;
  150. unsigned char read_count_suffix:1;
  151. } __attribute__ ((packed)) auxiliary;
  152. __u8 imbedded_ccw;
  153. __u8 count;
  154. struct ch_t seek_addr;
  155. struct chr_t search_arg;
  156. __u8 sector;
  157. __u16 length;
  158. __u8 imbedded_count;
  159. __u8 extended_operation;
  160. __u16 extended_parameter_length;
  161. __u8 extended_parameter[0];
  162. } __attribute__ ((packed));
  163. /* Prefix data for format 0x00 and 0x01 */
  164. struct PFX_eckd_data {
  165. unsigned char format;
  166. struct {
  167. unsigned char define_extent:1;
  168. unsigned char time_stamp:1;
  169. unsigned char verify_base:1;
  170. unsigned char hyper_pav:1;
  171. unsigned char reserved:4;
  172. } __attribute__ ((packed)) validity;
  173. __u8 base_address;
  174. __u8 aux;
  175. __u8 base_lss;
  176. __u8 reserved[7];
  177. struct DE_eckd_data define_extent;
  178. struct LRE_eckd_data locate_record;
  179. } __attribute__ ((packed));
  180. struct dasd_eckd_characteristics {
  181. __u16 cu_type;
  182. struct {
  183. unsigned char support:2;
  184. unsigned char async:1;
  185. unsigned char reserved:1;
  186. unsigned char cache_info:1;
  187. unsigned char model:3;
  188. } __attribute__ ((packed)) cu_model;
  189. __u16 dev_type;
  190. __u8 dev_model;
  191. struct {
  192. unsigned char mult_burst:1;
  193. unsigned char RT_in_LR:1;
  194. unsigned char reserved1:1;
  195. unsigned char RD_IN_LR:1;
  196. unsigned char reserved2:4;
  197. unsigned char reserved3:8;
  198. unsigned char defect_wr:1;
  199. unsigned char XRC_supported:1;
  200. unsigned char reserved4:1;
  201. unsigned char striping:1;
  202. unsigned char reserved5:4;
  203. unsigned char cfw:1;
  204. unsigned char reserved6:2;
  205. unsigned char cache:1;
  206. unsigned char dual_copy:1;
  207. unsigned char dfw:1;
  208. unsigned char reset_alleg:1;
  209. unsigned char sense_down:1;
  210. } __attribute__ ((packed)) facilities;
  211. __u8 dev_class;
  212. __u8 unit_type;
  213. __u16 no_cyl;
  214. __u16 trk_per_cyl;
  215. __u8 sec_per_trk;
  216. __u8 byte_per_track[3];
  217. __u16 home_bytes;
  218. __u8 formula;
  219. union {
  220. struct {
  221. __u8 f1;
  222. __u16 f2;
  223. __u16 f3;
  224. } __attribute__ ((packed)) f_0x01;
  225. struct {
  226. __u8 f1;
  227. __u8 f2;
  228. __u8 f3;
  229. __u8 f4;
  230. __u8 f5;
  231. } __attribute__ ((packed)) f_0x02;
  232. } __attribute__ ((packed)) factors;
  233. __u16 first_alt_trk;
  234. __u16 no_alt_trk;
  235. __u16 first_dia_trk;
  236. __u16 no_dia_trk;
  237. __u16 first_sup_trk;
  238. __u16 no_sup_trk;
  239. __u8 MDR_ID;
  240. __u8 OBR_ID;
  241. __u8 director;
  242. __u8 rd_trk_set;
  243. __u16 max_rec_zero;
  244. __u8 reserved1;
  245. __u8 RWANY_in_LR;
  246. __u8 factor6;
  247. __u8 factor7;
  248. __u8 factor8;
  249. __u8 reserved2[3];
  250. __u8 reserved3[6];
  251. __u32 long_no_cyl;
  252. } __attribute__ ((packed));
  253. /* elements of the configuration data */
  254. struct dasd_ned {
  255. struct {
  256. __u8 identifier:2;
  257. __u8 token_id:1;
  258. __u8 sno_valid:1;
  259. __u8 subst_sno:1;
  260. __u8 recNED:1;
  261. __u8 emuNED:1;
  262. __u8 reserved:1;
  263. } __attribute__ ((packed)) flags;
  264. __u8 descriptor;
  265. __u8 dev_class;
  266. __u8 reserved;
  267. __u8 dev_type[6];
  268. __u8 dev_model[3];
  269. __u8 HDA_manufacturer[3];
  270. __u8 HDA_location[2];
  271. __u8 HDA_seqno[12];
  272. __u8 ID;
  273. __u8 unit_addr;
  274. } __attribute__ ((packed));
  275. struct dasd_sneq {
  276. struct {
  277. __u8 identifier:2;
  278. __u8 reserved:6;
  279. } __attribute__ ((packed)) flags;
  280. __u8 res1;
  281. __u16 format;
  282. __u8 res2[4]; /* byte 4- 7 */
  283. __u8 sua_flags; /* byte 8 */
  284. __u8 base_unit_addr; /* byte 9 */
  285. __u8 res3[22]; /* byte 10-31 */
  286. } __attribute__ ((packed));
  287. struct vd_sneq {
  288. struct {
  289. __u8 identifier:2;
  290. __u8 reserved:6;
  291. } __attribute__ ((packed)) flags;
  292. __u8 res1;
  293. __u16 format;
  294. __u8 res2[4]; /* byte 4- 7 */
  295. __u8 uit[16]; /* byte 8-23 */
  296. __u8 res3[8]; /* byte 24-31 */
  297. } __attribute__ ((packed));
  298. struct dasd_gneq {
  299. struct {
  300. __u8 identifier:2;
  301. __u8 reserved:6;
  302. } __attribute__ ((packed)) flags;
  303. __u8 reserved[5];
  304. struct {
  305. __u8 value:2;
  306. __u8 number:6;
  307. } __attribute__ ((packed)) timeout;
  308. __u8 reserved3;
  309. __u16 subsystemID;
  310. __u8 reserved2[22];
  311. } __attribute__ ((packed));
  312. struct dasd_eckd_path {
  313. __u8 opm;
  314. __u8 ppm;
  315. __u8 npm;
  316. };
  317. struct dasd_rssd_features {
  318. char feature[256];
  319. } __attribute__((packed));
  320. /*
  321. * Perform Subsystem Function - Prepare for Read Subsystem Data
  322. */
  323. struct dasd_psf_prssd_data {
  324. unsigned char order;
  325. unsigned char flags;
  326. unsigned char reserved[4];
  327. unsigned char suborder;
  328. unsigned char varies[5];
  329. } __attribute__ ((packed));
  330. /*
  331. * Perform Subsystem Function - Set Subsystem Characteristics
  332. */
  333. struct dasd_psf_ssc_data {
  334. unsigned char order;
  335. unsigned char flags;
  336. unsigned char cu_type[4];
  337. unsigned char suborder;
  338. unsigned char reserved[59];
  339. } __attribute__((packed));
  340. /*
  341. * some structures and definitions for alias handling
  342. */
  343. struct dasd_unit_address_configuration {
  344. struct {
  345. char ua_type;
  346. char base_ua;
  347. } unit[256];
  348. } __attribute__((packed));
  349. #define MAX_DEVICES_PER_LCU 256
  350. /* flags on the LCU */
  351. #define NEED_UAC_UPDATE 0x01
  352. #define UPDATE_PENDING 0x02
  353. enum pavtype {NO_PAV, BASE_PAV, HYPER_PAV};
  354. struct alias_root {
  355. struct list_head serverlist;
  356. spinlock_t lock;
  357. };
  358. struct alias_server {
  359. struct list_head server;
  360. struct dasd_uid uid;
  361. struct list_head lculist;
  362. };
  363. struct summary_unit_check_work_data {
  364. char reason;
  365. struct dasd_device *device;
  366. struct work_struct worker;
  367. };
  368. struct read_uac_work_data {
  369. struct dasd_device *device;
  370. struct delayed_work dwork;
  371. };
  372. struct alias_lcu {
  373. struct list_head lcu;
  374. struct dasd_uid uid;
  375. enum pavtype pav;
  376. char flags;
  377. spinlock_t lock;
  378. struct list_head grouplist;
  379. struct list_head active_devices;
  380. struct list_head inactive_devices;
  381. struct dasd_unit_address_configuration *uac;
  382. struct summary_unit_check_work_data suc_data;
  383. struct read_uac_work_data ruac_data;
  384. struct dasd_ccw_req *rsu_cqr;
  385. struct completion lcu_setup;
  386. };
  387. struct alias_pav_group {
  388. struct list_head group;
  389. struct dasd_uid uid;
  390. struct alias_lcu *lcu;
  391. struct list_head baselist;
  392. struct list_head aliaslist;
  393. struct dasd_device *next;
  394. };
  395. struct dasd_eckd_private {
  396. struct dasd_eckd_characteristics rdc_data;
  397. u8 *conf_data;
  398. int conf_len;
  399. /* pointers to specific parts in the conf_data */
  400. struct dasd_ned *ned;
  401. struct dasd_sneq *sneq;
  402. struct vd_sneq *vdsneq;
  403. struct dasd_gneq *gneq;
  404. struct dasd_eckd_path path_data;
  405. struct eckd_count count_area[5];
  406. int init_cqr_status;
  407. int uses_cdl;
  408. struct attrib_data_t attrib; /* e.g. cache operations */
  409. struct dasd_rssd_features features;
  410. u32 real_cyl;
  411. /* alias managemnet */
  412. struct dasd_uid uid;
  413. struct alias_pav_group *pavgroup;
  414. struct alias_lcu *lcu;
  415. int count;
  416. };
  417. int dasd_alias_make_device_known_to_lcu(struct dasd_device *);
  418. void dasd_alias_disconnect_device_from_lcu(struct dasd_device *);
  419. int dasd_alias_add_device(struct dasd_device *);
  420. int dasd_alias_remove_device(struct dasd_device *);
  421. struct dasd_device *dasd_alias_get_start_dev(struct dasd_device *);
  422. void dasd_alias_handle_summary_unit_check(struct dasd_device *, struct irb *);
  423. void dasd_eckd_reset_ccw_to_base_io(struct dasd_ccw_req *);
  424. void dasd_alias_lcu_setup_complete(struct dasd_device *);
  425. void dasd_alias_wait_for_lcu_setup(struct dasd_device *);
  426. int dasd_alias_update_add_device(struct dasd_device *);
  427. #endif /* DASD_ECKD_H */