2  *  include/asm-s390/etr.h
 
   4  *  Copyright IBM Corp. 2006
 
   5  *  Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com)
 
  10 /* ETR attachment control register */
 
  12         unsigned int e0         : 1;    /* port 0 stepping control */
 
  13         unsigned int e1         : 1;    /* port 1 stepping control */
 
  14         unsigned int _pad0      : 5;    /* must be 00100 */
 
  15         unsigned int dp         : 1;    /* data port control */
 
  16         unsigned int p0         : 1;    /* port 0 change recognition control */
 
  17         unsigned int p1         : 1;    /* port 1 change recognition control */
 
  18         unsigned int _pad1      : 3;    /* must be 000 */
 
  19         unsigned int ea         : 1;    /* ETR alert control */
 
  20         unsigned int es         : 1;    /* ETR sync check control */
 
  21         unsigned int sl         : 1;    /* switch to local control */
 
  22 } __attribute__ ((packed));
 
  24 /* Port state returned by steai */
 
  26         etr_psc_operational = 0,
 
  27         etr_psc_semi_operational = 1,
 
  28         etr_psc_protocol_error =  4,
 
  29         etr_psc_no_symbols = 8,
 
  30         etr_psc_no_signal = 12,
 
  34 /* Logical port state returned by stetr */
 
  36         etr_lpsc_operational_step = 0,
 
  37         etr_lpsc_operational_alt = 1,
 
  38         etr_lpsc_semi_operational = 2,
 
  39         etr_lpsc_protocol_error =  4,
 
  40         etr_lpsc_no_symbol_sync = 8,
 
  41         etr_lpsc_no_signal = 12,
 
  42         etr_lpsc_pps_mode = 13
 
  45 /* ETR status words */
 
  47         struct etr_eacr eacr;           /* attachment control register */
 
  48         unsigned int y          : 1;    /* stepping mode */
 
  49         unsigned int _pad0      : 5;    /* must be 00000 */
 
  50         unsigned int p          : 1;    /* stepping port number */
 
  51         unsigned int q          : 1;    /* data port number */
 
  52         unsigned int psc0       : 4;    /* port 0 state code */
 
  53         unsigned int psc1       : 4;    /* port 1 state code */
 
  54 } __attribute__ ((packed));
 
  56 /* Second level data register status word */
 
  58         unsigned int vv1        : 1;    /* copy of validity bit data frame 1 */
 
  59         unsigned int vv2        : 1;    /* copy of validity bit data frame 2 */
 
  60         unsigned int vv3        : 1;    /* copy of validity bit data frame 3 */
 
  61         unsigned int vv4        : 1;    /* copy of validity bit data frame 4 */
 
  62         unsigned int _pad0      : 19;   /* must by all zeroes */
 
  63         unsigned int n          : 1;    /* EAF port number */
 
  64         unsigned int v1         : 1;    /* validity bit ETR data frame 1 */
 
  65         unsigned int v2         : 1;    /* validity bit ETR data frame 2 */
 
  66         unsigned int v3         : 1;    /* validity bit ETR data frame 3 */
 
  67         unsigned int v4         : 1;    /* validity bit ETR data frame 4 */
 
  68         unsigned int _pad1      : 4;    /* must be 0000 */
 
  69 } __attribute__ ((packed));
 
  73         unsigned int u          : 1;    /* untuned bit */
 
  74         unsigned int _pad0      : 1;    /* must be 0 */
 
  75         unsigned int r          : 1;    /* service request bit */
 
  76         unsigned int _pad1      : 4;    /* must be 0000 */
 
  77         unsigned int a          : 1;    /* time adjustment bit */
 
  78         unsigned int net_id     : 8;    /* ETR network id */
 
  79         unsigned int etr_id     : 8;    /* id of ETR which sends data frames */
 
  80         unsigned int etr_pn     : 8;    /* port number of ETR output port */
 
  81 } __attribute__ ((packed));
 
  84         unsigned int etv        : 32;   /* Upper 32 bits of TOD. */
 
  85 } __attribute__ ((packed));
 
  88         unsigned int rc         : 8;    /* failure reason code */
 
  89         unsigned int _pad0      : 3;    /* must be 000 */
 
  90         unsigned int c          : 1;    /* ETR coupled bit */
 
  91         unsigned int tc         : 4;    /* ETR type code */
 
  92         unsigned int blto       : 8;    /* biased local time offset */
 
  93                                         /* (blto - 128) * 15 = minutes */
 
  94         unsigned int buo        : 8;    /* biased utc offset */
 
  95                                         /* (buo - 128) = leap seconds */
 
  96 } __attribute__ ((packed));
 
  99         unsigned int ed         : 8;    /* ETS device dependent data */
 
 100         unsigned int _pad0      : 1;    /* must be 0 */
 
 101         unsigned int buc        : 5;    /* biased ut1 correction */
 
 102                                         /* (buc - 16) * 0.1 seconds */
 
 103         unsigned int em         : 6;    /* ETS error magnitude */
 
 104         unsigned int dc         : 6;    /* ETS drift code */
 
 105         unsigned int sc         : 6;    /* ETS steering code */
 
 106 } __attribute__ ((packed));
 
 109  * ETR attachment information block, two formats
 
 110  * format 1 has 4 reserved words with a size of 64 bytes
 
 111  * format 2 has 16 reserved words with a size of 96 bytes
 
 115         struct etr_slsw slsw;
 
 116         unsigned long long tsp;
 
 117         struct etr_edf1 edf1;
 
 118         struct etr_edf2 edf2;
 
 119         struct etr_edf3 edf3;
 
 120         struct etr_edf4 edf4;
 
 121         unsigned int reserved[16];
 
 122 } __attribute__ ((packed,aligned(8)));
 
 124 /* ETR interruption parameter */
 
 125 struct etr_irq_parm {
 
 126         unsigned int _pad0      : 8;
 
 127         unsigned int pc0        : 1;    /* port 0 state change */
 
 128         unsigned int pc1        : 1;    /* port 1 state change */
 
 129         unsigned int _pad1      : 3;
 
 130         unsigned int eai        : 1;    /* ETR alert indication */
 
 131         unsigned int _pad2      : 18;
 
 132 } __attribute__ ((packed));
 
 134 /* Query TOD offset result */
 
 135 struct etr_ptff_qto {
 
 136         unsigned long long physical_clock;
 
 137         unsigned long long tod_offset;
 
 138         unsigned long long logical_tod_offset;
 
 139         unsigned long long tod_epoch_difference;
 
 140 } __attribute__ ((packed));
 
 142 /* Inline assembly helper functions */
 
 143 static inline int etr_setr(struct etr_eacr *ctrl)
 
 148                 "       .insn   s,0xb2160000,0(%2)\n"
 
 152                 : "+d" (rc) : "m" (*ctrl), "a" (ctrl));
 
 156 /* Stores a format 1 aib with 64 bytes */
 
 157 static inline int etr_stetr(struct etr_aib *aib)
 
 162                 "       .insn   s,0xb2170000,0(%2)\n"
 
 166                 : "+d" (rc) : "m" (*aib), "a" (aib));
 
 170 /* Stores a format 2 aib with 96 bytes for specified port */
 
 171 static inline int etr_steai(struct etr_aib *aib, unsigned int func)
 
 173         register unsigned int reg0 asm("0") = func;
 
 177                 "       .insn   s,0xb2b30000,0(%2)\n"
 
 181                 : "+d" (rc) : "m" (*aib), "a" (aib), "d" (reg0));
 
 185 /* Function codes for the steai instruction. */
 
 186 #define ETR_STEAI_STEPPING_PORT         0x10
 
 187 #define ETR_STEAI_ALTERNATE_PORT        0x11
 
 188 #define ETR_STEAI_PORT_0                0x12
 
 189 #define ETR_STEAI_PORT_1                0x13
 
 191 static inline int etr_ptff(void *ptff_block, unsigned int func)
 
 193         register unsigned int reg0 asm("0") = func;
 
 194         register unsigned long reg1 asm("1") = (unsigned long) ptff_block;
 
 201                 : "=d" (rc), "=m" (ptff_block)
 
 202                 : "d" (reg0), "d" (reg1), "m" (ptff_block) : "cc");
 
 206 /* Function codes for the ptff instruction. */
 
 207 #define ETR_PTFF_QAF    0x00    /* query available functions */
 
 208 #define ETR_PTFF_QTO    0x01    /* query tod offset */
 
 209 #define ETR_PTFF_QSI    0x02    /* query steering information */
 
 210 #define ETR_PTFF_ATO    0x40    /* adjust tod offset */
 
 211 #define ETR_PTFF_STO    0x41    /* set tod offset */
 
 212 #define ETR_PTFF_SFS    0x42    /* set fine steering rate */
 
 213 #define ETR_PTFF_SGS    0x43    /* set gross steering rate */
 
 215 /* Functions needed by the machine check handler */
 
 216 void etr_switch_to_local(void);
 
 217 void etr_sync_check(void);
 
 219 /* STP interruption parameter */
 
 220 struct stp_irq_parm {
 
 221         unsigned int _pad0      : 14;
 
 222         unsigned int tsc        : 1;    /* Timing status change */
 
 223         unsigned int lac        : 1;    /* Link availability change */
 
 224         unsigned int tcpc       : 1;    /* Time control parameter change */
 
 225         unsigned int _pad2      : 15;
 
 226 } __attribute__ ((packed));
 
 228 #define STP_OP_SYNC     1
 
 229 #define STP_OP_CTRL     3
 
 233         unsigned int rsvd1 : 8;
 
 234         unsigned int stratum : 8;
 
 235         unsigned int vbits : 16;
 
 236         unsigned int leaps : 16;
 
 237         unsigned int tmd : 4;
 
 238         unsigned int ctn : 4;
 
 239         unsigned int rsvd2 : 3;
 
 241         unsigned int tst : 4;
 
 242         unsigned int tzo : 16;
 
 243         unsigned int dsto : 16;
 
 244         unsigned int ctrl : 16;
 
 245         unsigned int rsvd3 : 16;
 
 248         unsigned int ctnid[3];
 
 250         unsigned int todoff[4];
 
 251         unsigned int rsvd6[48];
 
 252 } __attribute__ ((packed));
 
 254 /* Functions needed by the machine check handler */
 
 255 void stp_sync_check(void);
 
 256 void stp_island_check(void);
 
 258 #endif /* __S390_ETR_H */