Commit 29cda539 authored by Jaroslav Kysela's avatar Jaroslav Kysela

ALSA CVS update - Jaroslav Kysela <perex@suse.cz>

TEA575x tuner
TEA575x code is now 2.6 videodev compatible
parent ee50487c
...@@ -34,6 +34,9 @@ struct snd_tea575x_ops { ...@@ -34,6 +34,9 @@ struct snd_tea575x_ops {
struct snd_tea575x { struct snd_tea575x {
snd_card_t *card; snd_card_t *card;
struct video_device vd; /* video device */ struct video_device vd; /* video device */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 5, 0)
struct file_operations fops;
#endif
int dev_nr; /* requested device number + 1 */ int dev_nr; /* requested device number + 1 */
int vd_registered; /* video device is registered */ int vd_registered; /* video device is registered */
int tea5759; /* 5759 chip is present */ int tea5759; /* 5759 chip is present */
......
...@@ -85,18 +85,11 @@ static void snd_tea575x_set_freq(tea575x_t *tea) ...@@ -85,18 +85,11 @@ static void snd_tea575x_set_freq(tea575x_t *tea)
* Linux Video interface * Linux Video interface
*/ */
static int snd_tea575x_open(struct video_device *dev, int flags) static int snd_tea575x_do_ioctl(struct inode *inode, struct file *file,
unsigned int cmd, void *arg)
{ {
return 0; struct video_device *dev = video_devdata(file);
} tea575x_t *tea = video_get_drvdata(dev);
static void snd_tea575x_close(struct video_device *dev)
{
}
static int snd_tea575x_ioctl(struct video_device *dev, unsigned int cmd, void *arg)
{
tea575x_t *tea = dev->priv;
switch(cmd) { switch(cmd) {
case VIDIOCGCAP: case VIDIOCGCAP:
...@@ -174,6 +167,12 @@ static int snd_tea575x_ioctl(struct video_device *dev, unsigned int cmd, void *a ...@@ -174,6 +167,12 @@ static int snd_tea575x_ioctl(struct video_device *dev, unsigned int cmd, void *a
} }
} }
static int snd_tea575x_ioctl(struct inode *inode, struct file *file,
unsigned int cmd, unsigned long arg)
{
return video_usercopy(inode, file, cmd, arg, snd_tea575x_do_ioctl);
}
/* /*
* initialize all the tea575x chips * initialize all the tea575x chips
*/ */
...@@ -192,10 +191,12 @@ void snd_tea575x_init(tea575x_t *tea) ...@@ -192,10 +191,12 @@ void snd_tea575x_init(tea575x_t *tea)
strcpy(tea->vd.name, tea->tea5759 ? "TEA5759 radio" : "TEA5757 radio"); strcpy(tea->vd.name, tea->tea5759 ? "TEA5759 radio" : "TEA5757 radio");
tea->vd.type = VID_TYPE_TUNER; tea->vd.type = VID_TYPE_TUNER;
tea->vd.hardware = VID_HARDWARE_RTRACK; /* FIXME: assign new number */ tea->vd.hardware = VID_HARDWARE_RTRACK; /* FIXME: assign new number */
tea->vd.open = snd_tea575x_open; video_set_drvdata(&tea->vd, tea);
tea->vd.close = snd_tea575x_close; tea->vd.fops = &tea->fops;
tea->vd.ioctl = snd_tea575x_ioctl; tea->fops.owner = tea->card->module;
tea->vd.priv = tea; tea->fops.open = video_exclusive_open;
tea->fops.release = video_exclusive_release;
tea->fops.ioctl = snd_tea575x_ioctl;
if (video_register_device(&tea->vd, VFL_TYPE_RADIO, tea->dev_nr - 1) < 0) { if (video_register_device(&tea->vd, VFL_TYPE_RADIO, tea->dev_nr - 1) < 0) {
snd_printk(KERN_ERR "unable to register tea575x tuner\n"); snd_printk(KERN_ERR "unable to register tea575x tuner\n");
return; return;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment