xref: /OK3568_Linux_fs/kernel/drivers/input/misc/yealink.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * drivers/usb/input/yealink.h
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (c) 2005 Henk Vergonet <Henk.Vergonet@gmail.com>
6*4882a593Smuzhiyun  */
7*4882a593Smuzhiyun #ifndef INPUT_YEALINK_H
8*4882a593Smuzhiyun #define INPUT_YEALINK_H
9*4882a593Smuzhiyun 
10*4882a593Smuzhiyun /* Using the control channel on interface 3 various aspects of the phone
11*4882a593Smuzhiyun  * can be controlled like LCD, LED, dialtone and the ringtone.
12*4882a593Smuzhiyun  */
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun struct yld_ctl_packet {
15*4882a593Smuzhiyun 	u8	cmd;		/* command code, see below */
16*4882a593Smuzhiyun 	u8	size;		/* 1-11, size of used data bytes. */
17*4882a593Smuzhiyun 	__be16	offset;		/* internal packet offset */
18*4882a593Smuzhiyun 	u8	data[11];
19*4882a593Smuzhiyun 	s8	sum;		/* negative sum of 15 preceding bytes */
20*4882a593Smuzhiyun } __attribute__ ((packed));
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun #define USB_PKT_LEN	sizeof(struct yld_ctl_packet)
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun /* The following yld_ctl_packet's are available: */
25*4882a593Smuzhiyun 
26*4882a593Smuzhiyun /* Init registers
27*4882a593Smuzhiyun  *
28*4882a593Smuzhiyun  * cmd		0x8e
29*4882a593Smuzhiyun  * size		10
30*4882a593Smuzhiyun  * offset	0
31*4882a593Smuzhiyun  * data		0,0,0,0....
32*4882a593Smuzhiyun  */
33*4882a593Smuzhiyun #define CMD_INIT		0x8e
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun /* Request key scan
36*4882a593Smuzhiyun  *
37*4882a593Smuzhiyun  * cmd		0x80
38*4882a593Smuzhiyun  * size		1
39*4882a593Smuzhiyun  * offset	0
40*4882a593Smuzhiyun  * data[0]	on return returns the key number, if it changes there's a new
41*4882a593Smuzhiyun  * 		key pressed.
42*4882a593Smuzhiyun  */
43*4882a593Smuzhiyun #define CMD_KEYPRESS		0x80
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun /* Request scancode
46*4882a593Smuzhiyun  *
47*4882a593Smuzhiyun  * cmd		0x81
48*4882a593Smuzhiyun  * size		1
49*4882a593Smuzhiyun  * offset	key number [0-1f]
50*4882a593Smuzhiyun  * data[0]	on return returns the scancode
51*4882a593Smuzhiyun  */
52*4882a593Smuzhiyun #define CMD_SCANCODE		0x81
53*4882a593Smuzhiyun 
54*4882a593Smuzhiyun /* Set LCD
55*4882a593Smuzhiyun  *
56*4882a593Smuzhiyun  * cmd		0x04
57*4882a593Smuzhiyun  * size		1-11
58*4882a593Smuzhiyun  * offset	0-23
59*4882a593Smuzhiyun  * data		segment bits
60*4882a593Smuzhiyun  */
61*4882a593Smuzhiyun #define CMD_LCD			0x04
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun /* Set led
64*4882a593Smuzhiyun  *
65*4882a593Smuzhiyun  * cmd		0x05
66*4882a593Smuzhiyun  * size		1
67*4882a593Smuzhiyun  * offset	0
68*4882a593Smuzhiyun  * data[0]	0 OFF / 1 ON
69*4882a593Smuzhiyun  */
70*4882a593Smuzhiyun #define CMD_LED			0x05
71*4882a593Smuzhiyun 
72*4882a593Smuzhiyun /* Set ringtone volume
73*4882a593Smuzhiyun  *
74*4882a593Smuzhiyun  * cmd		0x11
75*4882a593Smuzhiyun  * size		1
76*4882a593Smuzhiyun  * offset	0
77*4882a593Smuzhiyun  * data[0]	0-0xff  volume
78*4882a593Smuzhiyun  */
79*4882a593Smuzhiyun #define CMD_RING_VOLUME		0x11
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun /* Set ringtone notes
82*4882a593Smuzhiyun  *
83*4882a593Smuzhiyun  * cmd		0x02
84*4882a593Smuzhiyun  * size		1-11
85*4882a593Smuzhiyun  * offset	0->
86*4882a593Smuzhiyun  * data		binary representation LE16(-freq), LE16(duration) ....
87*4882a593Smuzhiyun  */
88*4882a593Smuzhiyun #define CMD_RING_NOTE		0x02
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun /* Sound ringtone via the speaker on the back
91*4882a593Smuzhiyun  *
92*4882a593Smuzhiyun  * cmd		0x03
93*4882a593Smuzhiyun  * size		1
94*4882a593Smuzhiyun  * offset	0
95*4882a593Smuzhiyun  * data[0]	0 OFF / 0x24 ON
96*4882a593Smuzhiyun  */
97*4882a593Smuzhiyun #define CMD_RINGTONE		0x03
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun /* Sound dial tone via the ear speaker
100*4882a593Smuzhiyun  *
101*4882a593Smuzhiyun  * cmd		0x09
102*4882a593Smuzhiyun  * size		1
103*4882a593Smuzhiyun  * offset	0
104*4882a593Smuzhiyun  * data[0]	0 OFF / 1 ON
105*4882a593Smuzhiyun  */
106*4882a593Smuzhiyun #define CMD_DIALTONE		0x09
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun #endif /* INPUT_YEALINK_H */
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #if defined(_SEG) && defined(_PIC)
112*4882a593Smuzhiyun /* This table maps the LCD segments onto individual bit positions in the
113*4882a593Smuzhiyun  * yld_status struct.
114*4882a593Smuzhiyun  */
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun /* LCD, each segment must be driven separately.
117*4882a593Smuzhiyun  *
118*4882a593Smuzhiyun  * Layout:
119*4882a593Smuzhiyun  *
120*4882a593Smuzhiyun  *   |[]   [][]   [][]   [][]   in   |[][]
121*4882a593Smuzhiyun  *   |[] M [][] D [][] : [][]   out  |[][]
122*4882a593Smuzhiyun  *                             store
123*4882a593Smuzhiyun  *
124*4882a593Smuzhiyun  *    NEW REP         SU MO TU WE TH FR SA
125*4882a593Smuzhiyun  *
126*4882a593Smuzhiyun  *    [] [] [] [] [] [] [] [] [] [] [] []
127*4882a593Smuzhiyun  *    [] [] [] [] [] [] [] [] [] [] [] []
128*4882a593Smuzhiyun  */
129*4882a593Smuzhiyun 
130*4882a593Smuzhiyun /* Line 1
131*4882a593Smuzhiyun  *	Format		: 18.e8.M8.88...188
132*4882a593Smuzhiyun  *	Icon names	: M D : IN OUT STORE
133*4882a593Smuzhiyun  */
134*4882a593Smuzhiyun #define LCD_LINE1_OFFSET	0
135*4882a593Smuzhiyun #define LCD_LINE1_SIZE		17
136*4882a593Smuzhiyun 
137*4882a593Smuzhiyun /* Note: first g then f =>			       !      !      */
138*4882a593Smuzhiyun /* _SEG(    type    a      b      c      d      e      g      f   )  */
139*4882a593Smuzhiyun 	_SEG('1',  0,0 , 22,2 , 22,2 ,  0,0 ,  0,0 ,  0,0 ,  0,0	),
140*4882a593Smuzhiyun 	_SEG('8', 20,1 , 20,2 , 20,4 , 20,8 , 21,4 , 21,2 , 21,1	),
141*4882a593Smuzhiyun 	_PIC('.', 22,1 , "M"						),
142*4882a593Smuzhiyun 	_SEG('e', 18,1 , 18,2 , 18,4 , 18,1 , 19,2 , 18,1 , 19,1	),
143*4882a593Smuzhiyun 	_SEG('8', 16,1 , 16,2 , 16,4 , 16,8 , 17,4 , 17,2 , 17,1	),
144*4882a593Smuzhiyun 	_PIC('.', 15,8 , "D"						),
145*4882a593Smuzhiyun 	_SEG('M', 14,1 , 14,2 , 14,4 , 14,1 , 15,4 , 15,2 , 15,1	),
146*4882a593Smuzhiyun 	_SEG('8', 12,1 , 12,2 , 12,4 , 12,8 , 13,4 , 13,2 , 13,1	),
147*4882a593Smuzhiyun 	_PIC('.', 11,8 , ":"						),
148*4882a593Smuzhiyun 	_SEG('8', 10,1 , 10,2 , 10,4 , 10,8 , 11,4 , 11,2 , 11,1	),
149*4882a593Smuzhiyun 	_SEG('8',  8,1 ,  8,2 ,  8,4 ,  8,8 ,  9,4 ,  9,2 ,  9,1	),
150*4882a593Smuzhiyun 	_PIC('.',  7,1 , "IN"						),
151*4882a593Smuzhiyun 	_PIC('.',  7,2 , "OUT"						),
152*4882a593Smuzhiyun 	_PIC('.',  7,4 , "STORE"					),
153*4882a593Smuzhiyun 	_SEG('1',  0,0 ,  5,1 ,  5,1 ,  0,0 ,  0,0 ,  0,0 ,  0,0	),
154*4882a593Smuzhiyun 	_SEG('8',  4,1 ,  4,2 ,  4,4 ,  4,8 ,  5,8 ,  5,4 ,  5,2	),
155*4882a593Smuzhiyun 	_SEG('8',  2,1 ,  2,2 ,  2,4 ,  2,8 ,  3,4 ,  3,2 ,  3,1	),
156*4882a593Smuzhiyun 
157*4882a593Smuzhiyun /* Line 2
158*4882a593Smuzhiyun  *	Format		: .........
159*4882a593Smuzhiyun  *	Pict. name	: NEW REP SU MO TU WE TH FR SA
160*4882a593Smuzhiyun  */
161*4882a593Smuzhiyun #define LCD_LINE2_OFFSET	LCD_LINE1_OFFSET + LCD_LINE1_SIZE
162*4882a593Smuzhiyun #define LCD_LINE2_SIZE		9
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun 	_PIC('.', 23,2 , "NEW"	),
165*4882a593Smuzhiyun 	_PIC('.', 23,4 , "REP"	),
166*4882a593Smuzhiyun 	_PIC('.',  1,8 , "SU"	),
167*4882a593Smuzhiyun 	_PIC('.',  1,4 , "MO"	),
168*4882a593Smuzhiyun 	_PIC('.',  1,2 , "TU"	),
169*4882a593Smuzhiyun 	_PIC('.',  1,1 , "WE"	),
170*4882a593Smuzhiyun 	_PIC('.',  0,1 , "TH"	),
171*4882a593Smuzhiyun 	_PIC('.',  0,2 , "FR"	),
172*4882a593Smuzhiyun 	_PIC('.',  0,4 , "SA"	),
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun /* Line 3
175*4882a593Smuzhiyun  *	Format		: 888888888888
176*4882a593Smuzhiyun  */
177*4882a593Smuzhiyun #define LCD_LINE3_OFFSET	LCD_LINE2_OFFSET + LCD_LINE2_SIZE
178*4882a593Smuzhiyun #define LCD_LINE3_SIZE		12
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun 	_SEG('8', 22,16, 22,32, 22,64, 22,128, 23,128, 23,64, 23,32  ),
181*4882a593Smuzhiyun 	_SEG('8', 20,16, 20,32, 20,64, 20,128, 21,128, 21,64, 21,32  ),
182*4882a593Smuzhiyun 	_SEG('8', 18,16, 18,32, 18,64, 18,128, 19,128, 19,64, 19,32  ),
183*4882a593Smuzhiyun 	_SEG('8', 16,16, 16,32, 16,64, 16,128, 17,128, 17,64, 17,32  ),
184*4882a593Smuzhiyun 	_SEG('8', 14,16, 14,32, 14,64, 14,128, 15,128, 15,64, 15,32  ),
185*4882a593Smuzhiyun 	_SEG('8', 12,16, 12,32, 12,64, 12,128, 13,128, 13,64, 13,32  ),
186*4882a593Smuzhiyun 	_SEG('8', 10,16, 10,32, 10,64, 10,128, 11,128, 11,64, 11,32  ),
187*4882a593Smuzhiyun 	_SEG('8',  8,16,  8,32,  8,64,  8,128,  9,128,  9,64,  9,32  ),
188*4882a593Smuzhiyun 	_SEG('8',  6,16,  6,32,  6,64,  6,128,  7,128,  7,64,  7,32  ),
189*4882a593Smuzhiyun 	_SEG('8',  4,16,  4,32,  4,64,  4,128,  5,128,  5,64,  5,32  ),
190*4882a593Smuzhiyun 	_SEG('8',  2,16,  2,32,  2,64,  2,128,  3,128,  3,64,  3,32  ),
191*4882a593Smuzhiyun 	_SEG('8',  0,16,  0,32,  0,64,  0,128,  1,128,  1,64,  1,32  ),
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun /* Line 4
194*4882a593Smuzhiyun  *
195*4882a593Smuzhiyun  * The LED, DIALTONE and RINGTONE are implemented as icons and use the same
196*4882a593Smuzhiyun  * sysfs interface.
197*4882a593Smuzhiyun  */
198*4882a593Smuzhiyun #define LCD_LINE4_OFFSET	LCD_LINE3_OFFSET + LCD_LINE3_SIZE
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun 	_PIC('.', offsetof(struct yld_status, led)	, 0x01, "LED" ),
201*4882a593Smuzhiyun 	_PIC('.', offsetof(struct yld_status, dialtone) , 0x01, "DIALTONE" ),
202*4882a593Smuzhiyun 	_PIC('.', offsetof(struct yld_status, ringtone) , 0x24, "RINGTONE" ),
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun #undef _SEG
205*4882a593Smuzhiyun #undef _PIC
206*4882a593Smuzhiyun #endif /* _SEG && _PIC */
207