]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/dev/bktr/ioctl_bt848.h
This commit was generated by cvs2svn to compensate for changes in r52746,
[FreeBSD/FreeBSD.git] / sys / dev / bktr / ioctl_bt848.h
1 /*
2  * extensions to ioctl_meteor.h for the bt848 cards
3  *
4  * $FreeBSD$
5  */
6
7 /*
8  * frequency sets
9  */
10 #define CHNLSET_NABCST          1
11 #define CHNLSET_CABLEIRC        2
12 #define CHNLSET_CABLEHRC        3
13 #define CHNLSET_WEUROPE         4
14 #define CHNLSET_JPNBCST         5
15 #define CHNLSET_JPNCABLE        6
16 #define CHNLSET_XUSSR           7
17 #define CHNLSET_AUSTRALIA       8
18 #define CHNLSET_MIN             CHNLSET_NABCST
19 #define CHNLSET_MAX             CHNLSET_AUSTRALIA
20
21
22 /*
23  * constants for various tuner registers
24  */
25 #define BT848_HUEMIN            (-90)
26 #define BT848_HUEMAX            90
27 #define BT848_HUECENTER         0
28 #define BT848_HUERANGE          179.3
29 #define BT848_HUEREGMIN         (-128)
30 #define BT848_HUEREGMAX         127
31 #define BT848_HUESTEPS          256
32
33 #define BT848_BRIGHTMIN         (-50)
34 #define BT848_BRIGHTMAX         50
35 #define BT848_BRIGHTCENTER      0
36 #define BT848_BRIGHTRANGE       99.6
37 #define BT848_BRIGHTREGMIN      (-128)
38 #define BT848_BRIGHTREGMAX      127
39 #define BT848_BRIGHTSTEPS       256
40
41 #define BT848_CONTRASTMIN       0
42 #define BT848_CONTRASTMAX       237
43 #define BT848_CONTRASTCENTER    100
44 #define BT848_CONTRASTRANGE     236.57
45 #define BT848_CONTRASTREGMIN    0
46 #define BT848_CONTRASTREGMAX    511
47 #define BT848_CONTRASTSTEPS     512
48
49 #define BT848_CHROMAMIN         0
50 #define BT848_CHROMAMAX         284
51 #define BT848_CHROMACENTER      100
52 #define BT848_CHROMARANGE       283.89
53 #define BT848_CHROMAREGMIN      0
54 #define BT848_CHROMAREGMAX      511
55 #define BT848_CHROMASTEPS       512
56
57 #define BT848_SATUMIN           0
58 #define BT848_SATUMAX           202
59 #define BT848_SATUCENTER        100
60 #define BT848_SATURANGE         201.18
61 #define BT848_SATUREGMIN        0
62 #define BT848_SATUREGMAX        511
63 #define BT848_SATUSTEPS         512
64
65 #define BT848_SATVMIN           0
66 #define BT848_SATVMAX           284
67 #define BT848_SATVCENTER        100
68 #define BT848_SATVRANGE         283.89
69 #define BT848_SATVREGMIN        0
70 #define BT848_SATVREGMAX        511
71 #define BT848_SATVSTEPS         512
72
73
74 /*
75  * audio stuff
76  */
77 #define AUDIO_TUNER             0x00    /* command for the audio routine */
78 #define AUDIO_EXTERN            0x01    /* don't confuse them with bit */
79 #define AUDIO_INTERN            0x02    /* settings */
80 #define AUDIO_MUTE              0x80
81 #define AUDIO_UNMUTE            0x81
82
83
84 /*
85  * EEProm stuff
86  */
87 struct eeProm {
88         short   offset;
89         short   count;
90         u_char  bytes[ 256 ];
91 };
92
93
94 /*
95  * XXX: this is a hack, should be in ioctl_meteor.h
96  * here to avoid touching that file for now...
97  */
98 #define TVTUNER_SETCHNL    _IOW('x', 32, unsigned int)  /* set channel */
99 #define TVTUNER_GETCHNL    _IOR('x', 32, unsigned int)  /* get channel */
100 #define TVTUNER_SETTYPE    _IOW('x', 33, unsigned int)  /* set tuner type */
101 #define TVTUNER_GETTYPE    _IOR('x', 33, unsigned int)  /* get tuner type */
102 #define TVTUNER_GETSTATUS  _IOR('x', 34, unsigned int)  /* get tuner status */
103 #define TVTUNER_SETFREQ    _IOW('x', 35, unsigned int)  /* set frequency */
104 #define TVTUNER_GETFREQ    _IOR('x', 36, unsigned int)  /* get frequency */
105  
106
107 #define BT848_SHUE      _IOW('x', 37, int)              /* set hue */
108 #define BT848_GHUE      _IOR('x', 37, int)              /* get hue */
109 #define BT848_SBRIG     _IOW('x', 38, int)              /* set brightness */
110 #define BT848_GBRIG     _IOR('x', 38, int)              /* get brightness */
111 #define BT848_SCSAT     _IOW('x', 39, int)              /* set chroma sat */
112 #define BT848_GCSAT     _IOR('x', 39, int)              /* get UV saturation */
113 #define BT848_SCONT     _IOW('x', 40, int)              /* set contrast */
114 #define BT848_GCONT     _IOR('x', 40, int)              /* get contrast */
115 #define BT848_SVSAT     _IOW('x', 41, int)              /* set chroma V sat */
116 #define BT848_GVSAT     _IOR('x', 41, int)              /* get V saturation */
117 #define BT848_SUSAT     _IOW('x', 42, int)              /* set chroma U sat */
118 #define BT848_GUSAT     _IOR('x', 42, int)              /* get U saturation */
119
120 #define BT848_SCBARS    _IOR('x', 43, int)              /* set colorbar */
121 #define BT848_CCBARS    _IOR('x', 44, int)              /* clear colorbar */
122
123
124 #define BT848_SAUDIO    _IOW('x', 46, int)              /* set audio channel */
125 #define BT848_GAUDIO    _IOR('x', 47, int)              /* get audio channel */
126 #define BT848_SBTSC     _IOW('x', 48, int)              /* set audio channel */
127
128 #define BT848_GSTATUS   _IOR('x', 49, unsigned int)     /* reap status */
129
130 #define BT848_WEEPROM   _IOWR('x', 50, struct eeProm)   /* write to EEProm */
131 #define BT848_REEPROM   _IOWR('x', 51, struct eeProm)   /* read from EEProm */
132
133 #define BT848_SIGNATURE _IOWR('x', 52, struct eeProm)   /* read card sig */
134
135 #define TVTUNER_SETAFC  _IOW('x', 53, int)              /* turn AFC on/off */
136 #define TVTUNER_GETAFC  _IOR('x', 54, int)              /* query AFC on/off */
137 #define BT848_SLNOTCH   _IOW('x', 55, int)              /* set luma notch */
138 #define BT848_GLNOTCH   _IOR('x', 56, int)              /* get luma notch */
139
140 /* Read/Write the BT848's I2C bus directly
141  * b7-b0:    data (read/write)
142  * b15-b8:   internal peripheral register (write)   
143  * b23-b16:  i2c addr (write)
144  * b31-b24:  1 = write, 0 = read 
145  */
146 #define BT848_I2CWR     _IOWR('x', 57, u_long)    /* i2c read-write */
147
148 /* Support for radio tuner */
149 #define RADIO_SETMODE    _IOW('x', 58, unsigned int)  /* set radio modes */
150 #define RADIO_GETMODE    _IOR('x', 58, unsigned char)  /* get radio modes */
151 #define   RADIO_AFC      0x01           /* These modes will probably not */
152 #define   RADIO_MONO     0x02           /*  work on the FRxxxx. It does  */
153 #define   RADIO_MUTE     0x08           /*  work on the FMxxxx. */
154 #define RADIO_SETFREQ    _IOW('x', 59, unsigned int)  /* set frequency   */
155 #define RADIO_GETFREQ    _IOR('x', 59, unsigned int)  /* set frequency   */
156  /*        Argument is frequency*100MHz  */
157
158 /*
159  * XXX: more bad magic,
160  *      we need to fix the METEORGINPUT to return something public
161  *      duplicate them here for now...
162  */
163 #define METEOR_DEV0             0x00001000
164 #define METEOR_DEV1             0x00002000
165 #define METEOR_DEV2             0x00004000
166 #define METEOR_DEV3             0x00008000
167 #define METEOR_DEV_SVIDEO       0x00006000
168 /*
169  * right now I don't know were to put these, but as they are suppose to be
170  * a part of a common video capture interface, these should be relocated to
171  * another place.  Probably most of the METEOR_xxx defines need to be
172  * renamed and moved to a common header
173  */
174
175 typedef enum { METEOR_PIXTYPE_RGB, METEOR_PIXTYPE_YUV,
176                METEOR_PIXTYPE_YUV_PACKED,
177                METEOR_PIXTYPE_YUV_12 } METEOR_PIXTYPE;
178
179
180 struct meteor_pixfmt {
181         u_int          index;         /* Index in supported pixfmt list     */
182         METEOR_PIXTYPE type;          /* What's the board gonna feed us     */
183         u_int          Bpp;           /* Bytes per pixel                    */
184         u_long         masks[3];      /* R,G,B or Y,U,V masks, respectively */
185         unsigned       swap_bytes :1; /* Bytes  swapped within shorts       */
186         unsigned       swap_shorts:1; /* Shorts swapped within longs        */
187 };
188
189
190 struct bktr_clip {
191     int          x_min;
192     int          x_max;
193     int          y_min;
194     int          y_max;
195 };
196
197 #define BT848_MAX_CLIP_NODE 100
198 struct _bktr_clip {
199     struct bktr_clip x[BT848_MAX_CLIP_NODE];
200 };
201
202 /*
203  * I'm using METEOR_xxx just because that will be common to other interface
204  * and less of a surprise
205  */
206 #define METEORSACTPIXFMT        _IOW('x', 64, int )
207 #define METEORGACTPIXFMT        _IOR('x', 64, int )
208 #define METEORGSUPPIXFMT        _IOWR('x', 65, struct meteor_pixfmt)
209
210 /* set clip list */
211 #define BT848SCLIP     _IOW('x', 66, struct _bktr_clip )
212 #define BT848GCLIP     _IOR('x', 66, struct _bktr_clip )
213
214
215 /* set input format */
216 #define BT848SFMT               _IOW('x', 67, unsigned long )
217 #define BT848GFMT               _IOR('x', 67, unsigned long )
218
219 /* set clear-buffer-on-start */
220 #define BT848SCBUF      _IOW('x', 68, int)
221 #define BT848GCBUF      _IOR('x', 68, int)
222
223 /* set capture area */
224 /* The capture area is the area of the video image which is grabbed */
225 /* Usually the capture area is 640x480 (768x576 PAL) pixels */
226 /* This area is then scaled to the dimensions the user requires */
227 /* using the METEORGEO ioctl */
228 /* However, the capture area could be 400x300 pixels from the top right */
229 /* corner of the video image */
230 struct bktr_capture_area {
231    int      x_offset;
232    int      y_offset;
233    int      x_size;
234    int      y_size;
235 };
236 #define BT848_SCAPAREA   _IOW('x', 69, struct bktr_capture_area)
237 #define BT848_GCAPAREA   _IOR('x', 69, struct bktr_capture_area)
238
239
240 /* Get channel Set */
241 #define BT848_MAX_CHNLSET_NAME_LEN 16
242 struct bktr_chnlset {
243        short   index;
244        short   max_channel;
245        char    name[BT848_MAX_CHNLSET_NAME_LEN];
246 };
247 #define TVTUNER_GETCHNLSET _IOWR('x', 70, struct bktr_chnlset)
248
249
250
251 /* Infra Red Remote Control */
252 struct bktr_remote {
253        unsigned char data[3];
254 };
255 #define REMOTE_GETKEY      _IOR('x', 71, struct bktr_remote)/*read the remote */
256                                                             /*control receiver*/
257                                                             /*returns raw data*/
258
259  
260 /*
261  * Direct access to GPIO pins. You must add BKTR_GPIO_ACCESS to your kernel
262  * configuration file to use these 
263  */
264 #define BT848_GPIO_SET_EN      _IOW('x', 72, int)      /* set gpio_out_en */
265 #define BT848_GPIO_GET_EN      _IOR('x', 73, int)      /* get gpio_out_en */
266 #define BT848_GPIO_SET_DATA    _IOW('x', 74, int)      /* set gpio_data */
267 #define BT848_GPIO_GET_DATA    _IOR('x', 75, int)      /* get gpio_data */
268
269
270
271 /*  XXX - Copied from /sys/pci/brktree_reg.h  */
272 #define BT848_IFORM_FORMAT              (0x7<<0)
273 # define BT848_IFORM_F_RSVD             (0x7)
274 # define BT848_IFORM_F_SECAM            (0x6)
275 # define BT848_IFORM_F_PALN             (0x5)
276 # define BT848_IFORM_F_PALM             (0x4)
277 # define BT848_IFORM_F_PALBDGHI         (0x3)
278 # define BT848_IFORM_F_NTSCJ            (0x2)
279 # define BT848_IFORM_F_NTSCM            (0x1)
280 # define BT848_IFORM_F_AUTO             (0x0)
281