vtoc.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. /*
  3. * This file contains volume label definitions for DASD devices.
  4. *
  5. * Copyright IBM Corp. 2005
  6. *
  7. * Author(s): Volker Sameske <sameske@de.ibm.com>
  8. *
  9. */
  10. #ifndef _ASM_S390_VTOC_H
  11. #define _ASM_S390_VTOC_H
  12. #include <linux/types.h>
  13. struct vtoc_ttr
  14. {
  15. __u16 tt;
  16. __u8 r;
  17. } __attribute__ ((packed));
  18. struct vtoc_cchhb
  19. {
  20. __u16 cc;
  21. __u16 hh;
  22. __u8 b;
  23. } __attribute__ ((packed));
  24. struct vtoc_cchh
  25. {
  26. __u16 cc;
  27. __u16 hh;
  28. } __attribute__ ((packed));
  29. struct vtoc_labeldate
  30. {
  31. __u8 year;
  32. __u16 day;
  33. } __attribute__ ((packed));
  34. struct vtoc_volume_label_cdl
  35. {
  36. char volkey[4]; /* volume key = volume label */
  37. char vollbl[4]; /* volume label */
  38. char volid[6]; /* volume identifier */
  39. __u8 security; /* security byte */
  40. struct vtoc_cchhb vtoc; /* VTOC address */
  41. char res1[5]; /* reserved */
  42. char cisize[4]; /* CI-size for FBA,... */
  43. /* ...blanks for CKD */
  44. char blkperci[4]; /* no of blocks per CI (FBA), blanks for CKD */
  45. char labperci[4]; /* no of labels per CI (FBA), blanks for CKD */
  46. char res2[4]; /* reserved */
  47. char lvtoc[14]; /* owner code for LVTOC */
  48. char res3[29]; /* reserved */
  49. } __attribute__ ((packed));
  50. struct vtoc_volume_label_ldl {
  51. char vollbl[4]; /* volume label */
  52. char volid[6]; /* volume identifier */
  53. char res3[69]; /* reserved */
  54. char ldl_version; /* version number, valid for ldl format */
  55. __u64 formatted_blocks; /* valid when ldl_version >= f2 */
  56. } __attribute__ ((packed));
  57. struct vtoc_extent
  58. {
  59. __u8 typeind; /* extent type indicator */
  60. __u8 seqno; /* extent sequence number */
  61. struct vtoc_cchh llimit; /* starting point of this extent */
  62. struct vtoc_cchh ulimit; /* ending point of this extent */
  63. } __attribute__ ((packed));
  64. struct vtoc_dev_const
  65. {
  66. __u16 DS4DSCYL; /* number of logical cyls */
  67. __u16 DS4DSTRK; /* number of tracks in a logical cylinder */
  68. __u16 DS4DEVTK; /* device track length */
  69. __u8 DS4DEVI; /* non-last keyed record overhead */
  70. __u8 DS4DEVL; /* last keyed record overhead */
  71. __u8 DS4DEVK; /* non-keyed record overhead differential */
  72. __u8 DS4DEVFG; /* flag byte */
  73. __u16 DS4DEVTL; /* device tolerance */
  74. __u8 DS4DEVDT; /* number of DSCB's per track */
  75. __u8 DS4DEVDB; /* number of directory blocks per track */
  76. } __attribute__ ((packed));
  77. struct vtoc_format1_label
  78. {
  79. char DS1DSNAM[44]; /* data set name */
  80. __u8 DS1FMTID; /* format identifier */
  81. char DS1DSSN[6]; /* data set serial number */
  82. __u16 DS1VOLSQ; /* volume sequence number */
  83. struct vtoc_labeldate DS1CREDT; /* creation date: ydd */
  84. struct vtoc_labeldate DS1EXPDT; /* expiration date */
  85. __u8 DS1NOEPV; /* number of extents on volume */
  86. __u8 DS1NOBDB; /* no. of bytes used in last direction blk */
  87. __u8 DS1FLAG1; /* flag 1 */
  88. char DS1SYSCD[13]; /* system code */
  89. struct vtoc_labeldate DS1REFD; /* date last referenced */
  90. __u8 DS1SMSFG; /* system managed storage indicators */
  91. __u8 DS1SCXTF; /* sec. space extension flag byte */
  92. __u16 DS1SCXTV; /* secondary space extension value */
  93. __u8 DS1DSRG1; /* data set organisation byte 1 */
  94. __u8 DS1DSRG2; /* data set organisation byte 2 */
  95. __u8 DS1RECFM; /* record format */
  96. __u8 DS1OPTCD; /* option code */
  97. __u16 DS1BLKL; /* block length */
  98. __u16 DS1LRECL; /* record length */
  99. __u8 DS1KEYL; /* key length */
  100. __u16 DS1RKP; /* relative key position */
  101. __u8 DS1DSIND; /* data set indicators */
  102. __u8 DS1SCAL1; /* secondary allocation flag byte */
  103. char DS1SCAL3[3]; /* secondary allocation quantity */
  104. struct vtoc_ttr DS1LSTAR; /* last used track and block on track */
  105. __u16 DS1TRBAL; /* space remaining on last used track */
  106. __u16 res1; /* reserved */
  107. struct vtoc_extent DS1EXT1; /* first extent description */
  108. struct vtoc_extent DS1EXT2; /* second extent description */
  109. struct vtoc_extent DS1EXT3; /* third extent description */
  110. struct vtoc_cchhb DS1PTRDS; /* possible pointer to f2 or f3 DSCB */
  111. } __attribute__ ((packed));
  112. struct vtoc_format4_label
  113. {
  114. char DS4KEYCD[44]; /* key code for VTOC labels: 44 times 0x04 */
  115. __u8 DS4IDFMT; /* format identifier */
  116. struct vtoc_cchhb DS4HPCHR; /* highest address of a format 1 DSCB */
  117. __u16 DS4DSREC; /* number of available DSCB's */
  118. struct vtoc_cchh DS4HCCHH; /* CCHH of next available alternate track */
  119. __u16 DS4NOATK; /* number of remaining alternate tracks */
  120. __u8 DS4VTOCI; /* VTOC indicators */
  121. __u8 DS4NOEXT; /* number of extents in VTOC */
  122. __u8 DS4SMSFG; /* system managed storage indicators */
  123. __u8 DS4DEVAC; /* number of alternate cylinders.
  124. * Subtract from first two bytes of
  125. * DS4DEVSZ to get number of usable
  126. * cylinders. can be zero. valid
  127. * only if DS4DEVAV on. */
  128. struct vtoc_dev_const DS4DEVCT; /* device constants */
  129. char DS4AMTIM[8]; /* VSAM time stamp */
  130. char DS4AMCAT[3]; /* VSAM catalog indicator */
  131. char DS4R2TIM[8]; /* VSAM volume/catalog match time stamp */
  132. char res1[5]; /* reserved */
  133. char DS4F6PTR[5]; /* pointer to first format 6 DSCB */
  134. struct vtoc_extent DS4VTOCE; /* VTOC extent description */
  135. char res2[10]; /* reserved */
  136. __u8 DS4EFLVL; /* extended free-space management level */
  137. struct vtoc_cchhb DS4EFPTR; /* pointer to extended free-space info */
  138. char res3; /* reserved */
  139. __u32 DS4DCYL; /* number of logical cyls */
  140. char res4[2]; /* reserved */
  141. __u8 DS4DEVF2; /* device flags */
  142. char res5; /* reserved */
  143. } __attribute__ ((packed));
  144. struct vtoc_ds5ext
  145. {
  146. __u16 t; /* RTA of the first track of free extent */
  147. __u16 fc; /* number of whole cylinders in free ext. */
  148. __u8 ft; /* number of remaining free tracks */
  149. } __attribute__ ((packed));
  150. struct vtoc_format5_label
  151. {
  152. char DS5KEYID[4]; /* key identifier */
  153. struct vtoc_ds5ext DS5AVEXT; /* first available (free-space) extent. */
  154. struct vtoc_ds5ext DS5EXTAV[7]; /* seven available extents */
  155. __u8 DS5FMTID; /* format identifier */
  156. struct vtoc_ds5ext DS5MAVET[18]; /* eighteen available extents */
  157. struct vtoc_cchhb DS5PTRDS; /* pointer to next format5 DSCB */
  158. } __attribute__ ((packed));
  159. struct vtoc_ds7ext
  160. {
  161. __u32 a; /* starting RTA value */
  162. __u32 b; /* ending RTA value + 1 */
  163. } __attribute__ ((packed));
  164. struct vtoc_format7_label
  165. {
  166. char DS7KEYID[4]; /* key identifier */
  167. struct vtoc_ds7ext DS7EXTNT[5]; /* space for 5 extent descriptions */
  168. __u8 DS7FMTID; /* format identifier */
  169. struct vtoc_ds7ext DS7ADEXT[11]; /* space for 11 extent descriptions */
  170. char res1[2]; /* reserved */
  171. struct vtoc_cchhb DS7PTRDS; /* pointer to next FMT7 DSCB */
  172. } __attribute__ ((packed));
  173. struct vtoc_cms_label {
  174. __u8 label_id[4]; /* Label identifier */
  175. __u8 vol_id[6]; /* Volid */
  176. __u16 version_id; /* Version identifier */
  177. __u32 block_size; /* Disk block size */
  178. __u32 origin_ptr; /* Disk origin pointer */
  179. __u32 usable_count; /* Number of usable cylinders/blocks */
  180. __u32 formatted_count; /* Maximum number of formatted cylinders/
  181. * blocks */
  182. __u32 block_count; /* Disk size in CMS blocks */
  183. __u32 used_count; /* Number of CMS blocks in use */
  184. __u32 fst_size; /* File Status Table (FST) size */
  185. __u32 fst_count; /* Number of FSTs per CMS block */
  186. __u8 format_date[6]; /* Disk FORMAT date */
  187. __u8 reserved1[2];
  188. __u32 disk_offset; /* Disk offset when reserved*/
  189. __u32 map_block; /* Allocation Map Block with next hole */
  190. __u32 hblk_disp; /* Displacement into HBLK data of next hole */
  191. __u32 user_disp; /* Displacement into user part of Allocation
  192. * map */
  193. __u8 reserved2[4];
  194. __u8 segment_name[8]; /* Name of shared segment */
  195. } __attribute__ ((packed));
  196. #endif /* _ASM_S390_VTOC_H */