aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/radio/radio-gemtek.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/radio/radio-gemtek.c')
-rw-r--r--drivers/media/radio/radio-gemtek.c32
1 files changed, 16 insertions, 16 deletions
diff --git a/drivers/media/radio/radio-gemtek.c b/drivers/media/radio/radio-gemtek.c
index 47173be97b9f..77a1e12333a3 100644
--- a/drivers/media/radio/radio-gemtek.c
+++ b/drivers/media/radio/radio-gemtek.c
@@ -6,7 +6,7 @@
6 * Besides the protocol changes, this is mostly a copy of: 6 * Besides the protocol changes, this is mostly a copy of:
7 * 7 *
8 * RadioTrack II driver for Linux radio support (C) 1998 Ben Pfaff 8 * RadioTrack II driver for Linux radio support (C) 1998 Ben Pfaff
9 * 9 *
10 * Based on RadioTrack I/RadioReveal (C) 1997 M. Kirkwood 10 * Based on RadioTrack I/RadioReveal (C) 1997 M. Kirkwood
11 * Converted to new API by Alan Cox <Alan.Cox@linux.org> 11 * Converted to new API by Alan Cox <Alan.Cox@linux.org>
12 * Various bugfixes and enhancements by Russell Kroll <rkroll@exploits.org> 12 * Various bugfixes and enhancements by Russell Kroll <rkroll@exploits.org>
@@ -29,7 +29,7 @@
29#define CONFIG_RADIO_GEMTEK_PORT -1 29#define CONFIG_RADIO_GEMTEK_PORT -1
30#endif 30#endif
31 31
32static int io = CONFIG_RADIO_GEMTEK_PORT; 32static int io = CONFIG_RADIO_GEMTEK_PORT;
33static int radio_nr = -1; 33static int radio_nr = -1;
34static spinlock_t lock; 34static spinlock_t lock;
35 35
@@ -48,7 +48,7 @@ struct gemtek_device
48 */ 48 */
49static void gemtek_mute(struct gemtek_device *dev) 49static void gemtek_mute(struct gemtek_device *dev)
50{ 50{
51 if(dev->muted) 51 if(dev->muted)
52 return; 52 return;
53 spin_lock(&lock); 53 spin_lock(&lock);
54 outb(0x10, io); 54 outb(0x10, io);
@@ -94,20 +94,20 @@ static int gemtek_setfreq(struct gemtek_device *dev, unsigned long freq)
94 freq /= 100000; 94 freq /= 100000;
95 95
96 spin_lock(&lock); 96 spin_lock(&lock);
97 97
98 /* 2 start bits */ 98 /* 2 start bits */
99 outb_p(0x03, io); 99 outb_p(0x03, io);
100 udelay(5); 100 udelay(5);
101 outb_p(0x07, io); 101 outb_p(0x07, io);
102 udelay(5); 102 udelay(5);
103 103
104 /* 28 frequency bits (lsb first) */ 104 /* 28 frequency bits (lsb first) */
105 for (i = 0; i < 14; i++) 105 for (i = 0; i < 14; i++)
106 if (freq & (1 << i)) 106 if (freq & (1 << i))
107 one(); 107 one();
108 else 108 else
109 zero(); 109 zero();
110 /* 36 unknown bits */ 110 /* 36 unknown bits */
111 for (i = 0; i < 11; i++) 111 for (i = 0; i < 11; i++)
112 zero(); 112 zero();
113 one(); 113 one();
@@ -123,7 +123,7 @@ static int gemtek_setfreq(struct gemtek_device *dev, unsigned long freq)
123 udelay(5); 123 udelay(5);
124 124
125 spin_unlock(&lock); 125 spin_unlock(&lock);
126 126
127 return 0; 127 return 0;
128} 128}
129 129
@@ -159,7 +159,7 @@ static int gemtek_do_ioctl(struct inode *inode, struct file *file,
159 case VIDIOCGTUNER: 159 case VIDIOCGTUNER:
160 { 160 {
161 struct video_tuner *v = arg; 161 struct video_tuner *v = arg;
162 if(v->tuner) /* Only 1 tuner */ 162 if(v->tuner) /* Only 1 tuner */
163 return -EINVAL; 163 return -EINVAL;
164 v->rangelow=87*16000; 164 v->rangelow=87*16000;
165 v->rangehigh=108*16000; 165 v->rangehigh=108*16000;
@@ -193,25 +193,25 @@ static int gemtek_do_ioctl(struct inode *inode, struct file *file,
193 return 0; 193 return 0;
194 } 194 }
195 case VIDIOCGAUDIO: 195 case VIDIOCGAUDIO:
196 { 196 {
197 struct video_audio *v = arg; 197 struct video_audio *v = arg;
198 memset(v,0, sizeof(*v)); 198 memset(v,0, sizeof(*v));
199 v->flags|=VIDEO_AUDIO_MUTABLE; 199 v->flags|=VIDEO_AUDIO_MUTABLE;
200 v->volume=1; 200 v->volume=1;
201 v->step=65535; 201 v->step=65535;
202 strcpy(v->name, "Radio"); 202 strcpy(v->name, "Radio");
203 return 0; 203 return 0;
204 } 204 }
205 case VIDIOCSAUDIO: 205 case VIDIOCSAUDIO:
206 { 206 {
207 struct video_audio *v = arg; 207 struct video_audio *v = arg;
208 if(v->audio) 208 if(v->audio)
209 return -EINVAL; 209 return -EINVAL;
210 210
211 if(v->flags&VIDEO_AUDIO_MUTE) 211 if(v->flags&VIDEO_AUDIO_MUTE)
212 gemtek_mute(rt); 212 gemtek_mute(rt);
213 else 213 else
214 gemtek_unmute(rt); 214 gemtek_unmute(rt);
215 215
216 return 0; 216 return 0;
217 } 217 }
@@ -254,14 +254,14 @@ static int __init gemtek_init(void)
254 return -EINVAL; 254 return -EINVAL;
255 } 255 }
256 256
257 if (!request_region(io, 4, "gemtek")) 257 if (!request_region(io, 4, "gemtek"))
258 { 258 {
259 printk(KERN_ERR "gemtek: port 0x%x already in use\n", io); 259 printk(KERN_ERR "gemtek: port 0x%x already in use\n", io);
260 return -EBUSY; 260 return -EBUSY;
261 } 261 }
262 262
263 gemtek_radio.priv=&gemtek_unit; 263 gemtek_radio.priv=&gemtek_unit;
264 264
265 if(video_register_device(&gemtek_radio, VFL_TYPE_RADIO, radio_nr)==-1) 265 if(video_register_device(&gemtek_radio, VFL_TYPE_RADIO, radio_nr)==-1)
266 { 266 {
267 release_region(io, 4); 267 release_region(io, 4);
@@ -274,7 +274,7 @@ static int __init gemtek_init(void)
274 /* this is _maybe_ unnecessary */ 274 /* this is _maybe_ unnecessary */
275 outb(0x01, io); 275 outb(0x01, io);
276 276
277 /* mute card - prevents noisy bootups */ 277 /* mute card - prevents noisy bootups */
278 gemtek_unit.muted = 0; 278 gemtek_unit.muted = 0;
279 gemtek_mute(&gemtek_unit); 279 gemtek_mute(&gemtek_unit);
280 280