blob: 0c3c2fb0f9395be596699830a62939cc83dd1609 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __SOUND_TEA575X_TUNER_H
2#define __SOUND_TEA575X_TUNER_H
3
4/*
5 * ALSA driver for TEA5757/5759 Philips AM/FM tuner chips
6 *
Jaroslav Kyselac1017a42007-10-15 09:50:19 +02007 * Copyright (c) 2004 Jaroslav Kysela <perex@perex.cz>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 *
Andrew Morton7477dda2006-06-21 01:29:38 -030023 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
Mauro Carvalho Chehab9b76ede2009-02-27 11:51:24 -030025#include <linux/videodev2.h>
Ondrej Zary4522e822011-05-23 09:17:19 -030026#include <media/v4l2-ctrls.h>
Andrew Morton7477dda2006-06-21 01:29:38 -030027#include <media/v4l2-dev.h>
Hans Verkuild4ecc832012-02-27 05:30:13 -030028#include <media/v4l2-device.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
Ondrej Zaryea273162011-05-12 22:17:56 +020030#define TEA575X_FMIF 10700
31
Ondrej Zary14219d02011-05-09 23:39:26 +020032#define TEA575X_DATA (1 << 0)
33#define TEA575X_CLK (1 << 1)
34#define TEA575X_WREN (1 << 2)
35#define TEA575X_MOST (1 << 3)
36
Takashi Iwai97f02e02005-11-17 14:17:19 +010037struct snd_tea575x;
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
39struct snd_tea575x_ops {
Ondrej Zary14219d02011-05-09 23:39:26 +020040 void (*set_pins)(struct snd_tea575x *tea, u8 pins);
41 u8 (*get_pins)(struct snd_tea575x *tea);
42 void (*set_direction)(struct snd_tea575x *tea, bool output);
Linus Torvalds1da177e2005-04-16 15:20:36 -070043};
44
45struct snd_tea575x {
Hans Verkuild4ecc832012-02-27 05:30:13 -030046 struct v4l2_device *v4l2_dev;
Hans de Goede5daf53a2012-05-19 07:57:03 -030047 struct v4l2_file_operations fops;
Ondrej Zary4522e822011-05-23 09:17:19 -030048 struct video_device vd; /* video device */
Hans Verkuild4ecc832012-02-27 05:30:13 -030049 int radio_nr; /* radio_nr */
Ondrej Zary375d1352011-03-19 16:32:53 +010050 bool tea5759; /* 5759 chip is present */
Hans Verkuild4ecc832012-02-27 05:30:13 -030051 bool cannot_read_data; /* Device cannot read the data pin */
Ondrej Zary375d1352011-03-19 16:32:53 +010052 bool mute; /* Device is muted? */
53 bool stereo; /* receiving stereo */
54 bool tuned; /* tuned to a station */
Linus Torvalds1da177e2005-04-16 15:20:36 -070055 unsigned int val; /* hw value */
Hans Verkuild4ecc832012-02-27 05:30:13 -030056 u32 freq; /* frequency */
Ondrej Zary6a529c12011-06-11 10:28:59 -030057 struct mutex mutex;
Linus Torvalds1da177e2005-04-16 15:20:36 -070058 struct snd_tea575x_ops *ops;
59 void *private_data;
Ondrej Zary10ca7202011-05-12 22:18:22 +020060 u8 card[32];
61 u8 bus_info[32];
Ondrej Zary4522e822011-05-23 09:17:19 -030062 struct v4l2_ctrl_handler ctrl_handler;
63 int (*ext_init)(struct snd_tea575x *tea);
Linus Torvalds1da177e2005-04-16 15:20:36 -070064};
65
Hans de Goede5daf53a2012-05-19 07:57:03 -030066int snd_tea575x_init(struct snd_tea575x *tea, struct module *owner);
Takashi Iwai97f02e02005-11-17 14:17:19 +010067void snd_tea575x_exit(struct snd_tea575x *tea);
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
69#endif /* __SOUND_TEA575X_TUNER_H */