2005-06-24 13:05:09 +08:00
|
|
|
/*
|
|
|
|
*/
|
|
|
|
|
2013-05-29 17:59:45 +08:00
|
|
|
enum tveeprom_audio_processor {
|
|
|
|
/* No audio processor present */
|
|
|
|
TVEEPROM_AUDPROC_NONE,
|
|
|
|
/* The audio processor is internal to the video processor */
|
|
|
|
TVEEPROM_AUDPROC_INTERNAL,
|
|
|
|
/* The audio processor is a MSPXXXX device */
|
|
|
|
TVEEPROM_AUDPROC_MSP,
|
|
|
|
/* The audio processor is another device */
|
|
|
|
TVEEPROM_AUDPROC_OTHER,
|
|
|
|
};
|
|
|
|
|
2013-08-02 07:17:48 +08:00
|
|
|
#include <linux/if_ether.h>
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
struct tveeprom {
|
|
|
|
u32 has_radio;
|
2008-07-23 02:50:31 +08:00
|
|
|
/* If has_ir == 0, then it is unknown what the IR capabilities are,
|
|
|
|
otherwise:
|
|
|
|
bit 0: 1 (= IR capabilities are known)
|
|
|
|
bit 1: IR receiver present
|
|
|
|
bit 2: IR transmitter (blaster) present */
|
|
|
|
u32 has_ir;
|
2005-12-01 16:51:27 +08:00
|
|
|
u32 has_MAC_address; /* 0: no MAC, 1: MAC present, 2: unknown */
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
u32 tuner_type;
|
|
|
|
u32 tuner_formats;
|
2005-12-01 16:51:42 +08:00
|
|
|
u32 tuner_hauppauge_model;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2005-09-10 04:04:05 +08:00
|
|
|
u32 tuner2_type;
|
|
|
|
u32 tuner2_formats;
|
2005-12-01 16:51:42 +08:00
|
|
|
u32 tuner2_hauppauge_model;
|
2005-09-10 04:04:05 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
u32 digitizer;
|
|
|
|
u32 digitizer_formats;
|
|
|
|
|
|
|
|
u32 audio_processor;
|
2005-09-10 04:04:05 +08:00
|
|
|
u32 decoder_processor;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
u32 model;
|
|
|
|
u32 revision;
|
|
|
|
u32 serial_number;
|
|
|
|
char rev_str[5];
|
2013-08-02 07:17:48 +08:00
|
|
|
u8 MAC_address[ETH_ALEN];
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2005-09-10 04:04:05 +08:00
|
|
|
void tveeprom_hauppauge_analog(struct i2c_client *c, struct tveeprom *tvee,
|
2005-04-17 06:20:36 +08:00
|
|
|
unsigned char *eeprom_data);
|
|
|
|
|
|
|
|
int tveeprom_read(struct i2c_client *c, unsigned char *eedata, int len);
|