s390mach.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /*
  2. * drivers/s390/s390mach.h
  3. * S/390 data definitions for machine check processing
  4. *
  5. * S390 version
  6. * Copyright (C) 2000 IBM Deutschland Entwicklung GmbH, IBM Corporation
  7. * Author(s): Ingo Adlung (adlung@de.ibm.com)
  8. */
  9. #ifndef __s390mach_h
  10. #define __s390mach_h
  11. #include <asm/types.h>
  12. struct mci {
  13. __u32 sd : 1; /* 00 system damage */
  14. __u32 pd : 1; /* 01 instruction-processing damage */
  15. __u32 sr : 1; /* 02 system recovery */
  16. __u32 to_be_defined_1 : 1; /* 03 */
  17. __u32 cd : 1; /* 04 timing-facility damage */
  18. __u32 ed : 1; /* 05 external damage */
  19. __u32 to_be_defined_2 : 1; /* 06 */
  20. __u32 dg : 1; /* 07 degradation */
  21. __u32 w : 1; /* 08 warning pending */
  22. __u32 cp : 1; /* 09 channel-report pending */
  23. __u32 sp : 1; /* 10 service-processor damage */
  24. __u32 ck : 1; /* 11 channel-subsystem damage */
  25. __u32 to_be_defined_3 : 2; /* 12-13 */
  26. __u32 b : 1; /* 14 backed up */
  27. __u32 to_be_defined_4 : 1; /* 15 */
  28. __u32 se : 1; /* 16 storage error uncorrected */
  29. __u32 sc : 1; /* 17 storage error corrected */
  30. __u32 ke : 1; /* 18 storage-key error uncorrected */
  31. __u32 ds : 1; /* 19 storage degradation */
  32. __u32 wp : 1; /* 20 psw mwp validity */
  33. __u32 ms : 1; /* 21 psw mask and key validity */
  34. __u32 pm : 1; /* 22 psw program mask and cc validity */
  35. __u32 ia : 1; /* 23 psw instruction address validity */
  36. __u32 fa : 1; /* 24 failing storage address validity */
  37. __u32 to_be_defined_5 : 1; /* 25 */
  38. __u32 ec : 1; /* 26 external damage code validity */
  39. __u32 fp : 1; /* 27 floating point register validity */
  40. __u32 gr : 1; /* 28 general register validity */
  41. __u32 cr : 1; /* 29 control register validity */
  42. __u32 to_be_defined_6 : 1; /* 30 */
  43. __u32 st : 1; /* 31 storage logical validity */
  44. __u32 ie : 1; /* 32 indirect storage error */
  45. __u32 ar : 1; /* 33 access register validity */
  46. __u32 da : 1; /* 34 delayed access exception */
  47. __u32 to_be_defined_7 : 7; /* 35-41 */
  48. __u32 pr : 1; /* 42 tod programmable register validity */
  49. __u32 fc : 1; /* 43 fp control register validity */
  50. __u32 ap : 1; /* 44 ancillary report */
  51. __u32 to_be_defined_8 : 1; /* 45 */
  52. __u32 ct : 1; /* 46 cpu timer validity */
  53. __u32 cc : 1; /* 47 clock comparator validity */
  54. __u32 to_be_defined_9 : 16; /* 47-63 */
  55. };
  56. /*
  57. * Channel Report Word
  58. */
  59. struct crw {
  60. __u32 res1 : 1; /* reserved zero */
  61. __u32 slct : 1; /* solicited */
  62. __u32 oflw : 1; /* overflow */
  63. __u32 chn : 1; /* chained */
  64. __u32 rsc : 4; /* reporting source code */
  65. __u32 anc : 1; /* ancillary report */
  66. __u32 res2 : 1; /* reserved zero */
  67. __u32 erc : 6; /* error-recovery code */
  68. __u32 rsid : 16; /* reporting-source ID */
  69. } __attribute__ ((packed));
  70. #define CRW_RSC_MONITOR 0x2 /* monitoring facility */
  71. #define CRW_RSC_SCH 0x3 /* subchannel */
  72. #define CRW_RSC_CPATH 0x4 /* channel path */
  73. #define CRW_RSC_CONFIG 0x9 /* configuration-alert facility */
  74. #define CRW_RSC_CSS 0xB /* channel subsystem */
  75. #define CRW_ERC_EVENT 0x00 /* event information pending */
  76. #define CRW_ERC_AVAIL 0x01 /* available */
  77. #define CRW_ERC_INIT 0x02 /* initialized */
  78. #define CRW_ERC_TERROR 0x03 /* temporary error */
  79. #define CRW_ERC_IPARM 0x04 /* installed parm initialized */
  80. #define CRW_ERC_TERM 0x05 /* terminal */
  81. #define CRW_ERC_PERRN 0x06 /* perm. error, fac. not init */
  82. #define CRW_ERC_PERRI 0x07 /* perm. error, facility init */
  83. #define CRW_ERC_PMOD 0x08 /* installed parameters modified */
  84. extern __inline__ int stcrw(struct crw *pcrw )
  85. {
  86. int ccode;
  87. __asm__ __volatile__(
  88. "STCRW 0(%1)\n\t"
  89. "IPM %0\n\t"
  90. "SRL %0,28\n\t"
  91. : "=d" (ccode) : "a" (pcrw)
  92. : "cc", "1" );
  93. return ccode;
  94. }
  95. #endif /* __s390mach */