Blame view

kernel/linux-rt-4.4.41/arch/powerpc/include/asm/hvsi.h 2.75 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
  #ifndef _HVSI_H
  #define _HVSI_H
  
  #define VS_DATA_PACKET_HEADER           0xff
  #define VS_CONTROL_PACKET_HEADER        0xfe
  #define VS_QUERY_PACKET_HEADER          0xfd
  #define VS_QUERY_RESPONSE_PACKET_HEADER 0xfc
  
  /* control verbs */
  #define VSV_SET_MODEM_CTL    1 /* to service processor only */
  #define VSV_MODEM_CTL_UPDATE 2 /* from service processor only */
  #define VSV_CLOSE_PROTOCOL   3
  
  /* query verbs */
  #define VSV_SEND_VERSION_NUMBER 1
  #define VSV_SEND_MODEM_CTL_STATUS 2
  
  /* yes, these masks are not consecutive. */
  #define HVSI_TSDTR 0x01
  #define HVSI_TSCD  0x20
  
  #define HVSI_MAX_OUTGOING_DATA 12
  #define HVSI_VERSION 1
  
  struct hvsi_header {
  	uint8_t  type;
  	uint8_t  len;
  	__be16 seqno;
  } __attribute__((packed));
  
  struct hvsi_data {
  	struct hvsi_header hdr;
  	uint8_t  data[HVSI_MAX_OUTGOING_DATA];
  } __attribute__((packed));
  
  struct hvsi_control {
  	struct hvsi_header hdr;
  	__be16 verb;
  	/* optional depending on verb: */
  	__be32 word;
  	__be32 mask;
  } __attribute__((packed));
  
  struct hvsi_query {
  	struct hvsi_header hdr;
  	__be16 verb;
  } __attribute__((packed));
  
  struct hvsi_query_response {
  	struct hvsi_header hdr;
  	__be16 verb;
  	__be16 query_seqno;
  	union {
  		uint8_t  version;
  		__be32 mctrl_word;
  	} u;
  } __attribute__((packed));
  
  /* hvsi lib struct definitions */
  #define HVSI_INBUF_SIZE		255
  struct tty_struct;
  struct hvsi_priv {
  	unsigned int	inbuf_len;	/* data in input buffer */
  	unsigned char	inbuf[HVSI_INBUF_SIZE];
  	unsigned int	inbuf_cur;	/* Cursor in input buffer */
  	unsigned int	inbuf_pktlen;	/* packet lenght from cursor */
  	atomic_t	seqno;		/* packet sequence number */
  	unsigned int	opened:1;	/* driver opened */
  	unsigned int	established:1;	/* protocol established */
  	unsigned int 	is_console:1;	/* used as a kernel console device */
  	unsigned int	mctrl_update:1;	/* modem control updated */
  	unsigned short	mctrl;		/* modem control */
  	struct tty_struct *tty;		/* tty structure */
  	int (*get_chars)(uint32_t termno, char *buf, int count);
  	int (*put_chars)(uint32_t termno, const char *buf, int count);
  	uint32_t	termno;
  };
  
  /* hvsi lib functions */
  struct hvc_struct;
  extern void hvsilib_init(struct hvsi_priv *pv,
  			 int (*get_chars)(uint32_t termno, char *buf, int count),
  			 int (*put_chars)(uint32_t termno, const char *buf,
  					  int count),
  			 int termno, int is_console);
  extern int hvsilib_open(struct hvsi_priv *pv, struct hvc_struct *hp);
  extern void hvsilib_close(struct hvsi_priv *pv, struct hvc_struct *hp);
  extern int hvsilib_read_mctrl(struct hvsi_priv *pv);
  extern int hvsilib_write_mctrl(struct hvsi_priv *pv, int dtr);
  extern void hvsilib_establish(struct hvsi_priv *pv);
  extern int hvsilib_get_chars(struct hvsi_priv *pv, char *buf, int count);
  extern int hvsilib_put_chars(struct hvsi_priv *pv, const char *buf, int count);
  
  #endif /* _HVSI_H */