V4L/DVB (3278): convert diagnostics over to the new v4l2-common.h macros.

- Convert diagnostics over to the new v4l2-common.h macros.
- deprecated tuner_debug option, the new option is debug.
- renamed cx25840_debug to debug.

Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@brturbo.com.br>
This commit is contained in:
Hans Verkuil 2006-01-09 15:32:40 -02:00 committed by Mauro Carvalho Chehab
parent 0e7072ef66
commit fac9e89999
15 changed files with 186 additions and 266 deletions

View File

@ -27,7 +27,7 @@
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/i2c-id.h> #include <linux/i2c-id.h>
#include <linux/videodev.h> #include <linux/videodev.h>
#include <media/audiochip.h> #include <media/v4l2-common.h>
MODULE_DESCRIPTION("i2c device driver for cs53l32a Audio ADC"); MODULE_DESCRIPTION("i2c device driver for cs53l32a Audio ADC");
MODULE_AUTHOR("Martin Vaughan"); MODULE_AUTHOR("Martin Vaughan");
@ -39,21 +39,6 @@ module_param(debug, bool, 0644);
MODULE_PARM_DESC(debug, "Debugging messages\n\t\t\t0=Off (default), 1=On"); MODULE_PARM_DESC(debug, "Debugging messages\n\t\t\t0=Off (default), 1=On");
#define cs53l32a_dbg(fmt, arg...) \
do { \
if (debug) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, \
client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); \
} while (0)
#define cs53l32a_err(fmt, arg...) do { \
printk(KERN_ERR "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define cs53l32a_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
static unsigned short normal_i2c[] = { 0x22 >> 1, I2C_CLIENT_END }; static unsigned short normal_i2c[] = { 0x22 >> 1, I2C_CLIENT_END };
@ -84,7 +69,7 @@ static int cs53l32a_command(struct i2c_client *client, unsigned int cmd,
the second goes through the PGA. Hence there are three the second goes through the PGA. Hence there are three
possible inputs to choose from. */ possible inputs to choose from. */
if (input->index > 2) { if (input->index > 2) {
cs53l32a_err("Invalid input %d.\n", input->index); v4l_err(client, "Invalid input %d.\n", input->index);
return -EINVAL; return -EINVAL;
} }
cs53l32a_write(client, 0x01, 0x01 + (input->index << 4)); cs53l32a_write(client, 0x01, 0x01 + (input->index << 4));
@ -124,9 +109,9 @@ static int cs53l32a_command(struct i2c_client *client, unsigned int cmd,
u8 m = cs53l32a_read(client, 0x03); u8 m = cs53l32a_read(client, 0x03);
s8 vol = cs53l32a_read(client, 0x04); s8 vol = cs53l32a_read(client, 0x04);
cs53l32a_info("Input: %d%s\n", (v >> 4) & 3, v4l_info(client, "Input: %d%s\n", (v >> 4) & 3,
(m & 0xC0) ? " (muted)" : ""); (m & 0xC0) ? " (muted)" : "");
cs53l32a_info("Volume: %d dB\n", vol); v4l_info(client, "Volume: %d dB\n", vol);
break; break;
} }
@ -166,12 +151,12 @@ static int cs53l32a_attach(struct i2c_adapter *adapter, int address, int kind)
client->driver = &i2c_driver; client->driver = &i2c_driver;
snprintf(client->name, sizeof(client->name) - 1, "cs53l32a"); snprintf(client->name, sizeof(client->name) - 1, "cs53l32a");
cs53l32a_info("chip found @ 0x%x (%s)\n", address << 1, adapter->name); v4l_info(client, "chip found @ 0x%x (%s)\n", address << 1, adapter->name);
for (i = 1; i <= 7; i++) { for (i = 1; i <= 7; i++) {
u8 v = cs53l32a_read(client, i); u8 v = cs53l32a_read(client, i);
cs53l32a_dbg("Read Reg %d %02x\n", i, v); v4l_dbg(1, client, "Read Reg %d %02x\n", i, v);
} }
/* Set cs53l32a internal register for Adaptec 2010/2410 setup */ /* Set cs53l32a internal register for Adaptec 2010/2410 setup */
@ -189,7 +174,7 @@ static int cs53l32a_attach(struct i2c_adapter *adapter, int address, int kind)
for (i = 1; i <= 7; i++) { for (i = 1; i <= 7; i++) {
u8 v = cs53l32a_read(client, i); u8 v = cs53l32a_read(client, i);
cs53l32a_dbg("Read Reg %d %02x\n", i, v); v4l_dbg(1, client, "Read Reg %d %02x\n", i, v);
} }
i2c_attach_client(client); i2c_attach_client(client);

View File

@ -43,11 +43,11 @@ MODULE_LICENSE("GPL");
static unsigned short normal_i2c[] = { 0x88 >> 1, I2C_CLIENT_END }; static unsigned short normal_i2c[] = { 0x88 >> 1, I2C_CLIENT_END };
int cx25840_debug = 0; int debug = 0;
module_param(cx25840_debug, bool, 0644); module_param(debug, bool, 0644);
MODULE_PARM_DESC(cx25840_debug, "Debugging messages [0=Off (default) 1=On]"); MODULE_PARM_DESC(debug, "Debugging messages [0=Off (default) 1=On]");
I2C_CLIENT_INSMOD; I2C_CLIENT_INSMOD;
@ -265,7 +265,7 @@ static int set_input(struct i2c_client *client, enum cx25840_video_input vid_inp
vid_input <= CX25840_COMPOSITE8); vid_input <= CX25840_COMPOSITE8);
u8 reg; u8 reg;
cx25840_dbg("decoder set video input %d, audio input %d\n", v4l_dbg(1, client, "decoder set video input %d, audio input %d\n",
vid_input, aud_input); vid_input, aud_input);
if (is_composite) { if (is_composite) {
@ -277,7 +277,7 @@ static int set_input(struct i2c_client *client, enum cx25840_video_input vid_inp
if ((vid_input & ~0xff0) || if ((vid_input & ~0xff0) ||
luma < CX25840_SVIDEO_LUMA1 || luma > CX25840_SVIDEO_LUMA4 || luma < CX25840_SVIDEO_LUMA1 || luma > CX25840_SVIDEO_LUMA4 ||
chroma < CX25840_SVIDEO_CHROMA4 || chroma > CX25840_SVIDEO_CHROMA8) { chroma < CX25840_SVIDEO_CHROMA4 || chroma > CX25840_SVIDEO_CHROMA8) {
cx25840_err("0x%04x is not a valid video input!\n", vid_input); v4l_err(client, "0x%04x is not a valid video input!\n", vid_input);
return -EINVAL; return -EINVAL;
} }
reg = 0xf0 + ((luma - CX25840_SVIDEO_LUMA1) >> 4); reg = 0xf0 + ((luma - CX25840_SVIDEO_LUMA1) >> 4);
@ -301,7 +301,7 @@ static int set_input(struct i2c_client *client, enum cx25840_video_input vid_inp
case CX25840_AUDIO8: reg &= ~0xc0; reg |= 0x40; break; case CX25840_AUDIO8: reg &= ~0xc0; reg |= 0x40; break;
default: default:
cx25840_err("0x%04x is not a valid audio input!\n", aud_input); v4l_err(client, "0x%04x is not a valid audio input!\n", aud_input);
return -EINVAL; return -EINVAL;
} }
@ -396,7 +396,7 @@ static int set_v4lctrl(struct i2c_client *client, struct v4l2_control *ctrl)
case V4L2_CID_BRIGHTNESS: case V4L2_CID_BRIGHTNESS:
if (ctrl->value < 0 || ctrl->value > 255) { if (ctrl->value < 0 || ctrl->value > 255) {
cx25840_err("invalid brightness setting %d\n", v4l_err(client, "invalid brightness setting %d\n",
ctrl->value); ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -406,7 +406,7 @@ static int set_v4lctrl(struct i2c_client *client, struct v4l2_control *ctrl)
case V4L2_CID_CONTRAST: case V4L2_CID_CONTRAST:
if (ctrl->value < 0 || ctrl->value > 127) { if (ctrl->value < 0 || ctrl->value > 127) {
cx25840_err("invalid contrast setting %d\n", v4l_err(client, "invalid contrast setting %d\n",
ctrl->value); ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -416,7 +416,7 @@ static int set_v4lctrl(struct i2c_client *client, struct v4l2_control *ctrl)
case V4L2_CID_SATURATION: case V4L2_CID_SATURATION:
if (ctrl->value < 0 || ctrl->value > 127) { if (ctrl->value < 0 || ctrl->value > 127) {
cx25840_err("invalid saturation setting %d\n", v4l_err(client, "invalid saturation setting %d\n",
ctrl->value); ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -427,7 +427,7 @@ static int set_v4lctrl(struct i2c_client *client, struct v4l2_control *ctrl)
case V4L2_CID_HUE: case V4L2_CID_HUE:
if (ctrl->value < -127 || ctrl->value > 127) { if (ctrl->value < -127 || ctrl->value > 127) {
cx25840_err("invalid hue setting %d\n", ctrl->value); v4l_err(client, "invalid hue setting %d\n", ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -515,7 +515,7 @@ static int set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt)
if ((pix->width * 16 < Hsrc) || (Hsrc < pix->width) || if ((pix->width * 16 < Hsrc) || (Hsrc < pix->width) ||
(Vlines * 8 < Vsrc) || (Vsrc < Vlines)) { (Vlines * 8 < Vsrc) || (Vsrc < Vlines)) {
cx25840_err("%dx%d is not a valid size!\n", v4l_err(client, "%dx%d is not a valid size!\n",
pix->width, pix->height); pix->width, pix->height);
return -ERANGE; return -ERANGE;
} }
@ -533,7 +533,7 @@ static int set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt)
else else
filter = 3; filter = 3;
cx25840_dbg("decoder set size %dx%d -> scale %ux%u\n", v4l_dbg(1, client, "decoder set size %dx%d -> scale %ux%u\n",
pix->width, pix->height, HSC, VSC); pix->width, pix->height, HSC, VSC);
/* HSCALE=HSC */ /* HSCALE=HSC */
@ -602,13 +602,13 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,
return cx25840_audio(client, cmd, arg); return cx25840_audio(client, cmd, arg);
case VIDIOC_STREAMON: case VIDIOC_STREAMON:
cx25840_dbg("enable output\n"); v4l_dbg(1, client, "enable output\n");
cx25840_write(client, 0x115, 0x8c); cx25840_write(client, 0x115, 0x8c);
cx25840_write(client, 0x116, 0x07); cx25840_write(client, 0x116, 0x07);
break; break;
case VIDIOC_STREAMOFF: case VIDIOC_STREAMOFF:
cx25840_dbg("disable output\n"); v4l_dbg(1, client, "disable output\n");
cx25840_write(client, 0x115, 0x00); cx25840_write(client, 0x115, 0x00);
cx25840_write(client, 0x116, 0x00); cx25840_write(client, 0x116, 0x00);
break; break;
@ -774,7 +774,7 @@ static int cx25840_detect_client(struct i2c_adapter *adapter, int address,
client->driver = &i2c_driver_cx25840; client->driver = &i2c_driver_cx25840;
snprintf(client->name, sizeof(client->name) - 1, "cx25840"); snprintf(client->name, sizeof(client->name) - 1, "cx25840");
cx25840_dbg("detecting cx25840 client on address 0x%x\n", address << 1); v4l_dbg(1, client, "detecting cx25840 client on address 0x%x\n", address << 1);
device_id = cx25840_read(client, 0x101) << 8; device_id = cx25840_read(client, 0x101) << 8;
device_id |= cx25840_read(client, 0x100); device_id |= cx25840_read(client, 0x100);
@ -782,12 +782,12 @@ static int cx25840_detect_client(struct i2c_adapter *adapter, int address,
/* The high byte of the device ID should be /* The high byte of the device ID should be
* 0x84 if chip is present */ * 0x84 if chip is present */
if ((device_id & 0xff00) != 0x8400) { if ((device_id & 0xff00) != 0x8400) {
cx25840_dbg("cx25840 not found\n"); v4l_dbg(1, client, "cx25840 not found\n");
kfree(client); kfree(client);
return 0; return 0;
} }
cx25840_info("cx25%3x-2%x found @ 0x%x (%s)\n", v4l_info(client, "cx25%3x-2%x found @ 0x%x (%s)\n",
(device_id & 0xfff0) >> 4, (device_id & 0xfff0) >> 4,
(device_id & 0x0f) < 3 ? (device_id & 0x0f) + 1 : 3, (device_id & 0x0f) < 3 ? (device_id & 0x0f) + 1 : 3,
address << 1, adapter->name); address << 1, adapter->name);
@ -891,9 +891,9 @@ static void log_status(struct i2c_client *client)
int aud_input = state->aud_input; int aud_input = state->aud_input;
char *p; char *p;
cx25840_info("Video signal: %spresent\n", v4l_info(client, "Video signal: %spresent\n",
(microctrl_vidfmt & 0x10) ? "" : "not "); (microctrl_vidfmt & 0x10) ? "" : "not ");
cx25840_info("Detected format: %s\n", v4l_info(client, "Detected format: %s\n",
fmt_strs[gen_stat1 & 0xf]); fmt_strs[gen_stat1 & 0xf]);
switch (mod_det_stat0) { switch (mod_det_stat0) {
@ -908,7 +908,7 @@ static void log_status(struct i2c_client *client)
case 0xfe: p = "forced mode"; break; case 0xfe: p = "forced mode"; break;
default: p = "not defined"; default: p = "not defined";
} }
cx25840_info("Detected audio mode: %s\n", p); v4l_info(client, "Detected audio mode: %s\n", p);
switch (mod_det_stat1) { switch (mod_det_stat1) {
case 0x00: p = "not defined"; break; case 0x00: p = "not defined"; break;
@ -934,10 +934,10 @@ static void log_status(struct i2c_client *client)
case 0xff: p = "no detected audio standard"; break; case 0xff: p = "no detected audio standard"; break;
default: p = "not defined"; default: p = "not defined";
} }
cx25840_info("Detected audio standard: %s\n", p); v4l_info(client, "Detected audio standard: %s\n", p);
cx25840_info("Audio muted: %s\n", v4l_info(client, "Audio muted: %s\n",
(mute_ctl & 0x2) ? "yes" : "no"); (mute_ctl & 0x2) ? "yes" : "no");
cx25840_info("Audio microcontroller: %s\n", v4l_info(client, "Audio microcontroller: %s\n",
(download_ctl & 0x10) ? "running" : "stopped"); (download_ctl & 0x10) ? "running" : "stopped");
switch (audio_config >> 4) { switch (audio_config >> 4) {
@ -959,7 +959,7 @@ static void log_status(struct i2c_client *client)
case 0x0f: p = "automatic detection"; break; case 0x0f: p = "automatic detection"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Configured audio standard: %s\n", p); v4l_info(client, "Configured audio standard: %s\n", p);
if ((audio_config >> 4) < 0xF) { if ((audio_config >> 4) < 0xF) {
switch (audio_config & 0xF) { switch (audio_config & 0xF) {
@ -976,7 +976,7 @@ static void log_status(struct i2c_client *client)
case 0x0a: p = "SAP"; break; case 0x0a: p = "SAP"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Configured audio mode: %s\n", p); v4l_info(client, "Configured audio mode: %s\n", p);
} else { } else {
switch (audio_config & 0xF) { switch (audio_config & 0xF) {
case 0x00: p = "BG"; break; case 0x00: p = "BG"; break;
@ -992,27 +992,27 @@ static void log_status(struct i2c_client *client)
case 0x0f: p = "automatic standard and mode detection"; break; case 0x0f: p = "automatic standard and mode detection"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Configured audio system: %s\n", p); v4l_info(client, "Configured audio system: %s\n", p);
} }
cx25840_info("Specified standard: %s\n", v4l_info(client, "Specified standard: %s\n",
vidfmt_sel ? fmt_strs[vidfmt_sel] : "automatic detection"); vidfmt_sel ? fmt_strs[vidfmt_sel] : "automatic detection");
if (vid_input >= CX25840_COMPOSITE1 && if (vid_input >= CX25840_COMPOSITE1 &&
vid_input <= CX25840_COMPOSITE8) { vid_input <= CX25840_COMPOSITE8) {
cx25840_info("Specified video input: Composite %d\n", v4l_info(client, "Specified video input: Composite %d\n",
vid_input - CX25840_COMPOSITE1 + 1); vid_input - CX25840_COMPOSITE1 + 1);
} else { } else {
cx25840_info("Specified video input: S-Video (Luma In%d, Chroma In%d)\n", v4l_info(client, "Specified video input: S-Video (Luma In%d, Chroma In%d)\n",
(vid_input & 0xf0) >> 4, (vid_input & 0xf00) >> 8); (vid_input & 0xf0) >> 4, (vid_input & 0xf00) >> 8);
} }
if (aud_input) { if (aud_input) {
cx25840_info("Specified audio input: Tuner (In%d)\n", aud_input); v4l_info(client, "Specified audio input: Tuner (In%d)\n", aud_input);
} else { } else {
cx25840_info("Specified audio input: External\n"); v4l_info(client, "Specified audio input: External\n");
} }
cx25840_info("Specified audioclock freq: %d Hz\n", state->audclk_freq); v4l_info(client, "Specified audioclock freq: %d Hz\n", state->audclk_freq);
switch (pref_mode & 0xf) { switch (pref_mode & 0xf) {
case 0: p = "mono/language A"; break; case 0: p = "mono/language A"; break;
@ -1025,7 +1025,7 @@ static void log_status(struct i2c_client *client)
case 7: p = "language AB"; break; case 7: p = "language AB"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Preferred audio mode: %s\n", p); v4l_info(client, "Preferred audio mode: %s\n", p);
if ((audio_config & 0xf) == 0xf) { if ((audio_config & 0xf) == 0xf) {
switch ((afc0 >> 3) & 0x3) { switch ((afc0 >> 3) & 0x3) {
@ -1034,7 +1034,7 @@ static void log_status(struct i2c_client *client)
case 2: p = "autodetect"; break; case 2: p = "autodetect"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Selected 65 MHz format: %s\n", p); v4l_info(client, "Selected 65 MHz format: %s\n", p);
switch (afc0 & 0x7) { switch (afc0 & 0x7) {
case 0: p = "chroma"; break; case 0: p = "chroma"; break;
@ -1044,6 +1044,6 @@ static void log_status(struct i2c_client *client)
case 4: p = "autodetect"; break; case 4: p = "autodetect"; break;
default: p = "undefined"; default: p = "undefined";
} }
cx25840_info("Selected 45 MHz format: %s\n", p); v4l_info(client, "Selected 45 MHz format: %s\n", p);
} }
} }

View File

@ -83,11 +83,11 @@ static inline int check_fw_load(struct i2c_client *client, int size)
s |= cx25840_read(client, 0x800); s |= cx25840_read(client, 0x800);
if (size != s) { if (size != s) {
cx25840_err("firmware %s load failed\n", firmware); v4l_err(client, "firmware %s load failed\n", firmware);
return -EINVAL; return -EINVAL;
} }
cx25840_info("loaded %s firmware (%d bytes)\n", firmware, size); v4l_info(client, "loaded %s firmware (%d bytes)\n", firmware, size);
return 0; return 0;
} }
@ -98,7 +98,7 @@ static inline int fw_write(struct i2c_client *client, u8 * data, int size)
if ((sent = i2c_master_send(client, data, size)) < size) { if ((sent = i2c_master_send(client, data, size)) < size) {
if (fastfw) { if (fastfw) {
cx25840_err("333MHz i2c firmware load failed\n"); v4l_err(client, "333MHz i2c firmware load failed\n");
fastfw = 0; fastfw = 0;
set_i2c_delay(client, 10); set_i2c_delay(client, 10);
@ -111,13 +111,12 @@ static inline int fw_write(struct i2c_client *client, u8 * data, int size)
} }
if (i2c_master_send(client, data, size) < size) { if (i2c_master_send(client, data, size) < size) {
cx25840_err v4l_err(client, "100MHz i2c firmware load failed\n");
("100MHz i2c firmware load failed\n");
return -ENOSYS; return -ENOSYS;
} }
} else { } else {
cx25840_err("firmware load i2c failure\n"); v4l_err(client, "firmware load i2c failure\n");
return -ENOSYS; return -ENOSYS;
} }
@ -133,7 +132,7 @@ int cx25840_loadfw(struct i2c_client *client)
int size, send, retval; int size, send, retval;
if (request_firmware(&fw, firmware, FWDEV(client)) != 0) { if (request_firmware(&fw, firmware, FWDEV(client)) != 0) {
cx25840_err("unable to open firmware %s\n", firmware); v4l_err(client, "unable to open firmware %s\n", firmware);
return -EINVAL; return -EINVAL;
} }

View File

@ -20,25 +20,9 @@
#ifndef _CX25840_H_ #ifndef _CX25840_H_
#define _CX25840_H_ #define _CX25840_H_
#include <linux/videodev2.h> #include <linux/videodev2.h>
#include <linux/i2c.h> #include <linux/i2c.h>
extern int cx25840_debug;
#define cx25840_dbg(fmt, arg...) do { if (cx25840_debug) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, \
client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define cx25840_err(fmt, arg...) do { \
printk(KERN_ERR "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define cx25840_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
/* ENABLE_PVR150_WORKAROUND activates a workaround for a hardware bug that is /* ENABLE_PVR150_WORKAROUND activates a workaround for a hardware bug that is
present in Hauppauge PVR-150 (and possibly PVR-500) cards that have present in Hauppauge PVR-150 (and possibly PVR-500) cards that have
certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The

View File

@ -80,12 +80,12 @@ int stereo_threshold = 0x190; /* a2 threshold for stereo/bilingual
module_param(opmode, int, 0444); module_param(opmode, int, 0444);
/* read-write */ /* read-write */
module_param(once, int, 0644); module_param(once, bool, 0644);
module_param(debug, int, 0644); module_param(debug, int, 0644);
module_param(stereo_threshold, int, 0644); module_param(stereo_threshold, int, 0644);
module_param(standard, int, 0644); module_param(standard, int, 0644);
module_param(amsound, int, 0644); module_param(amsound, bool, 0644);
module_param(dolby, int, 0644); module_param(dolby, bool, 0644);
MODULE_PARM_DESC(opmode, "Forces a MSP3400 opmode. 0=Manual, 1=Autodetect, 2=Autodetect and autoselect"); MODULE_PARM_DESC(opmode, "Forces a MSP3400 opmode. 0=Manual, 1=Autodetect, 2=Autodetect and autoselect");
MODULE_PARM_DESC(once, "No continuous stereo monitoring"); MODULE_PARM_DESC(once, "No continuous stereo monitoring");

View File

@ -20,6 +20,9 @@ module_param(tv_antenna, int, 0644);
static unsigned int radio_antenna = 0; static unsigned int radio_antenna = 0;
module_param(radio_antenna, int, 0644); module_param(radio_antenna, int, 0644);
/* from tuner-core.c */
extern int debug;
/* ---------------------------------------------------------------------- */ /* ---------------------------------------------------------------------- */
#define MT2032 0x04 #define MT2032 0x04
@ -401,7 +404,7 @@ static void mt2050_set_if_freq(struct i2c_client *c,unsigned int freq, unsigned
div2a=(lo2/8)-1; div2a=(lo2/8)-1;
div2b=lo2-(div2a+1)*8; div2b=lo2-(div2a+1)*8;
if (tuner_debug > 1) { if (debug > 1) {
tuner_dbg("lo1 lo2 = %d %d\n", lo1, lo2); tuner_dbg("lo1 lo2 = %d %d\n", lo1, lo2);
tuner_dbg("num1 num2 div1a div1b div2a div2b= %x %x %x %x %x %x\n", tuner_dbg("num1 num2 div1a div1b div2a div2b= %x %x %x %x %x %x\n",
num1,num2,div1a,div1b,div2a,div2b); num1,num2,div1a,div1b,div2a,div2b);
@ -417,7 +420,7 @@ static void mt2050_set_if_freq(struct i2c_client *c,unsigned int freq, unsigned
buf[5]=div2a; buf[5]=div2a;
if(num2!=0) buf[5]=buf[5]|0x40; if(num2!=0) buf[5]=buf[5]|0x40;
if (tuner_debug > 1) { if (debug > 1) {
int i; int i;
tuner_dbg("bufs is: "); tuner_dbg("bufs is: ");
for(i=0;i<6;i++) for(i=0;i<6;i++)
@ -505,7 +508,7 @@ int microtune_init(struct i2c_client *c)
i2c_master_send(c,buf,1); i2c_master_send(c,buf,1);
i2c_master_recv(c,buf,21); i2c_master_recv(c,buf,21);
if (tuner_debug) { if (debug) {
int i; int i;
tuner_dbg("MT20xx hexdump:"); tuner_dbg("MT20xx hexdump:");
for(i=0;i<21;i++) { for(i=0;i<21;i++) {

View File

@ -47,25 +47,10 @@ MODULE_AUTHOR("Maxim Yevtyushkin, Kevin Thayer, Chris Kennedy, Hans Verkuil");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
static int debug = 0; static int debug = 0;
module_param(debug, int, 0644); module_param(debug, bool, 0644);
MODULE_PARM_DESC(debug, "Debug level (0-1)"); MODULE_PARM_DESC(debug, "Debug level (0-1)");
#define saa7115_dbg(fmt,arg...) \
do { \
if (debug) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, \
client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); \
} while (0)
#define saa7115_err(fmt, arg...) do { \
printk(KERN_ERR "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define saa7115_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
static unsigned short normal_i2c[] = { 0x42 >> 1, 0x40 >> 1, I2C_CLIENT_END }; static unsigned short normal_i2c[] = { 0x42 >> 1, 0x40 >> 1, I2C_CLIENT_END };
@ -564,7 +549,7 @@ static int saa7115_set_audio_clock_freq(struct i2c_client *client, u32 freq)
u32 hz; u32 hz;
u64 f; u64 f;
saa7115_dbg("set audio clock freq: %d\n", freq); v4l_dbg(1, client, "set audio clock freq: %d\n", freq);
/* sanity check */ /* sanity check */
if (freq < 32000 || freq > 48000) if (freq < 32000 || freq > 48000)
@ -599,7 +584,7 @@ static int saa7115_set_v4lctrl(struct i2c_client *client, struct v4l2_control *c
switch (ctrl->id) { switch (ctrl->id) {
case V4L2_CID_BRIGHTNESS: case V4L2_CID_BRIGHTNESS:
if (ctrl->value < 0 || ctrl->value > 255) { if (ctrl->value < 0 || ctrl->value > 255) {
saa7115_err("invalid brightness setting %d\n", ctrl->value); v4l_err(client, "invalid brightness setting %d\n", ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -609,7 +594,7 @@ static int saa7115_set_v4lctrl(struct i2c_client *client, struct v4l2_control *c
case V4L2_CID_CONTRAST: case V4L2_CID_CONTRAST:
if (ctrl->value < 0 || ctrl->value > 127) { if (ctrl->value < 0 || ctrl->value > 127) {
saa7115_err("invalid contrast setting %d\n", ctrl->value); v4l_err(client, "invalid contrast setting %d\n", ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -619,7 +604,7 @@ static int saa7115_set_v4lctrl(struct i2c_client *client, struct v4l2_control *c
case V4L2_CID_SATURATION: case V4L2_CID_SATURATION:
if (ctrl->value < 0 || ctrl->value > 127) { if (ctrl->value < 0 || ctrl->value > 127) {
saa7115_err("invalid saturation setting %d\n", ctrl->value); v4l_err(client, "invalid saturation setting %d\n", ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -629,7 +614,7 @@ static int saa7115_set_v4lctrl(struct i2c_client *client, struct v4l2_control *c
case V4L2_CID_HUE: case V4L2_CID_HUE:
if (ctrl->value < -127 || ctrl->value > 127) { if (ctrl->value < -127 || ctrl->value > 127) {
saa7115_err("invalid hue setting %d\n", ctrl->value); v4l_err(client, "invalid hue setting %d\n", ctrl->value);
return -ERANGE; return -ERANGE;
} }
@ -685,10 +670,10 @@ static void saa7115_set_v4lstd(struct i2c_client *client, v4l2_std_id std)
// This works for NTSC-M, SECAM-L and the 50Hz PAL variants. // This works for NTSC-M, SECAM-L and the 50Hz PAL variants.
if (std & V4L2_STD_525_60) { if (std & V4L2_STD_525_60) {
saa7115_dbg("decoder set standard 60 Hz\n"); v4l_dbg(1, client, "decoder set standard 60 Hz\n");
saa7115_writeregs(client, saa7115_cfg_60hz_video); saa7115_writeregs(client, saa7115_cfg_60hz_video);
} else { } else {
saa7115_dbg("decoder set standard 50 Hz\n"); v4l_dbg(1, client, "decoder set standard 50 Hz\n");
saa7115_writeregs(client, saa7115_cfg_50hz_video); saa7115_writeregs(client, saa7115_cfg_50hz_video);
} }
@ -717,13 +702,13 @@ static void saa7115_log_status(struct i2c_client *client)
int signalOk; int signalOk;
int vcr; int vcr;
saa7115_info("Audio frequency: %d Hz\n", state->audclk_freq); v4l_info(client, "Audio frequency: %d Hz\n", state->audclk_freq);
if (client->name[6] == '4') { if (client->name[6] == '4') {
/* status for the saa7114 */ /* status for the saa7114 */
reg1f = saa7115_read(client, 0x1f); reg1f = saa7115_read(client, 0x1f);
signalOk = (reg1f & 0xc1) == 0x81; signalOk = (reg1f & 0xc1) == 0x81;
saa7115_info("Video signal: %s\n", signalOk ? "ok" : "bad"); v4l_info(client, "Video signal: %s\n", signalOk ? "ok" : "bad");
saa7115_info("Frequency: %s\n", (reg1f & 0x20) ? "60 Hz" : "50 Hz"); v4l_info(client, "Frequency: %s\n", (reg1f & 0x20) ? "60 Hz" : "50 Hz");
return; return;
} }
@ -735,25 +720,25 @@ static void saa7115_log_status(struct i2c_client *client)
vcr = !(reg1f & 0x10); vcr = !(reg1f & 0x10);
if (state->input >= 6) { if (state->input >= 6) {
saa7115_info("Input: S-Video %d\n", state->input - 6); v4l_info(client, "Input: S-Video %d\n", state->input - 6);
} else { } else {
saa7115_info("Input: Composite %d\n", state->input); v4l_info(client, "Input: Composite %d\n", state->input);
} }
saa7115_info("Video signal: %s\n", signalOk ? (vcr ? "VCR" : "broadcast/DVD") : "bad"); v4l_info(client, "Video signal: %s\n", signalOk ? (vcr ? "VCR" : "broadcast/DVD") : "bad");
saa7115_info("Frequency: %s\n", (reg1f & 0x20) ? "60 Hz" : "50 Hz"); v4l_info(client, "Frequency: %s\n", (reg1f & 0x20) ? "60 Hz" : "50 Hz");
switch (reg1e & 0x03) { switch (reg1e & 0x03) {
case 1: case 1:
saa7115_info("Detected format: NTSC\n"); v4l_info(client, "Detected format: NTSC\n");
break; break;
case 2: case 2:
saa7115_info("Detected format: PAL\n"); v4l_info(client, "Detected format: PAL\n");
break; break;
case 3: case 3:
saa7115_info("Detected format: SECAM\n"); v4l_info(client, "Detected format: SECAM\n");
break; break;
default: default:
saa7115_info("Detected format: BW/No color\n"); v4l_info(client, "Detected format: BW/No color\n");
break; break;
} }
} }
@ -878,7 +863,7 @@ static int saa7115_set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt
pix = &(fmt->fmt.pix); pix = &(fmt->fmt.pix);
saa7115_dbg("decoder set size\n"); v4l_dbg(1, client, "decoder set size\n");
/* FIXME need better bounds checking here */ /* FIXME need better bounds checking here */
if ((pix->width < 1) || (pix->width > 1440)) if ((pix->width < 1) || (pix->width > 1440))
@ -904,7 +889,7 @@ static int saa7115_set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt
HPSC = HPSC ? HPSC : 1; HPSC = HPSC ? HPSC : 1;
HFSC = (int)((1024 * 720) / (HPSC * pix->width)); HFSC = (int)((1024 * 720) / (HPSC * pix->width));
saa7115_dbg("Hpsc: 0x%05x, Hfsc: 0x%05x\n", HPSC, HFSC); v4l_dbg(1, client, "Hpsc: 0x%05x, Hfsc: 0x%05x\n", HPSC, HFSC);
/* FIXME hardcodes to "Task B" /* FIXME hardcodes to "Task B"
* write H prescaler integer */ * write H prescaler integer */
saa7115_write(client, 0xd0, (u8) (HPSC & 0x3f)); saa7115_write(client, 0xd0, (u8) (HPSC & 0x3f));
@ -918,10 +903,10 @@ static int saa7115_set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt
saa7115_write(client, 0xDD, (u8) ((HFSC >> 9) & 0xff)); saa7115_write(client, 0xDD, (u8) ((HFSC >> 9) & 0xff));
} else { } else {
if (is_50hz) { if (is_50hz) {
saa7115_dbg("Setting full 50hz width\n"); v4l_dbg(1, client, "Setting full 50hz width\n");
saa7115_writeregs(client, saa7115_cfg_50hz_fullres_x); saa7115_writeregs(client, saa7115_cfg_50hz_fullres_x);
} else { } else {
saa7115_dbg("Setting full 60hz width\n"); v4l_dbg(1, client, "Setting full 60hz width\n");
saa7115_writeregs(client, saa7115_cfg_60hz_fullres_x); saa7115_writeregs(client, saa7115_cfg_60hz_fullres_x);
} }
} }
@ -930,7 +915,7 @@ static int saa7115_set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt
if (pix->height != Vsrc) { if (pix->height != Vsrc) {
VSCY = (int)((1024 * Vsrc) / pix->height); VSCY = (int)((1024 * Vsrc) / pix->height);
saa7115_dbg("Vsrc: %d, Vscy: 0x%05x\n", Vsrc, VSCY); v4l_dbg(1, client, "Vsrc: %d, Vscy: 0x%05x\n", Vsrc, VSCY);
/* Correct Contrast and Luminance */ /* Correct Contrast and Luminance */
saa7115_write(client, 0xd5, (u8) (64 * 1024 / VSCY)); saa7115_write(client, 0xd5, (u8) (64 * 1024 / VSCY));
@ -944,10 +929,10 @@ static int saa7115_set_v4lfmt(struct i2c_client *client, struct v4l2_format *fmt
saa7115_write(client, 0xe3, (u8) ((VSCY >> 8) & 0xff)); saa7115_write(client, 0xe3, (u8) ((VSCY >> 8) & 0xff));
} else { } else {
if (is_50hz) { if (is_50hz) {
saa7115_dbg("Setting full 50Hz height\n"); v4l_dbg(1, client, "Setting full 50Hz height\n");
saa7115_writeregs(client, saa7115_cfg_50hz_fullres_y); saa7115_writeregs(client, saa7115_cfg_50hz_fullres_y);
} else { } else {
saa7115_dbg("Setting full 60hz height\n"); v4l_dbg(1, client, "Setting full 60hz height\n");
saa7115_writeregs(client, saa7115_cfg_60hz_fullres_y); saa7115_writeregs(client, saa7115_cfg_60hz_fullres_y);
} }
} }
@ -1052,7 +1037,7 @@ static int saa7115_command(struct i2c_client *client, unsigned int cmd, void *ar
break; break;
status = saa7115_read(client, 0x1f); status = saa7115_read(client, 0x1f);
saa7115_dbg("status: 0x%02x\n", status); v4l_dbg(1, client, "status: 0x%02x\n", status);
vt->signal = ((status & (1 << 6)) == 0) ? 0xffff : 0x0; vt->signal = ((status & (1 << 6)) == 0) ? 0xffff : 0x0;
break; break;
} }
@ -1085,7 +1070,7 @@ static int saa7115_command(struct i2c_client *client, unsigned int cmd, void *ar
break; break;
case VIDIOC_S_INPUT: case VIDIOC_S_INPUT:
saa7115_dbg("decoder set input %d\n", *iarg); v4l_dbg(1, client, "decoder set input %d\n", *iarg);
/* inputs from 0-9 are available */ /* inputs from 0-9 are available */
if (*iarg < 0 || *iarg > 9) { if (*iarg < 0 || *iarg > 9) {
return -EINVAL; return -EINVAL;
@ -1093,7 +1078,7 @@ static int saa7115_command(struct i2c_client *client, unsigned int cmd, void *ar
if (state->input == *iarg) if (state->input == *iarg)
break; break;
saa7115_dbg("now setting %s input\n", v4l_dbg(1, client, "now setting %s input\n",
*iarg >= 6 ? "S-Video" : "Composite"); *iarg >= 6 ? "S-Video" : "Composite");
state->input = *iarg; state->input = *iarg;
@ -1110,7 +1095,7 @@ static int saa7115_command(struct i2c_client *client, unsigned int cmd, void *ar
case VIDIOC_STREAMON: case VIDIOC_STREAMON:
case VIDIOC_STREAMOFF: case VIDIOC_STREAMOFF:
saa7115_dbg("%s output\n", v4l_dbg(1, client, "%s output\n",
(cmd == VIDIOC_STREAMON) ? "enable" : "disable"); (cmd == VIDIOC_STREAMON) ? "enable" : "disable");
if (state->enable != (cmd == VIDIOC_STREAMON)) { if (state->enable != (cmd == VIDIOC_STREAMON)) {
@ -1124,7 +1109,7 @@ static int saa7115_command(struct i2c_client *client, unsigned int cmd, void *ar
break; break;
case VIDIOC_INT_RESET: case VIDIOC_INT_RESET:
saa7115_dbg("decoder RESET\n"); v4l_dbg(1, client, "decoder RESET\n");
saa7115_writeregs(client, saa7115_cfg_reset_scaler); saa7115_writeregs(client, saa7115_cfg_reset_scaler);
break; break;
@ -1218,19 +1203,19 @@ static int saa7115_attach(struct i2c_adapter *adapter, int address, int kind)
client->driver = &i2c_driver_saa7115; client->driver = &i2c_driver_saa7115;
snprintf(client->name, sizeof(client->name) - 1, "saa7115"); snprintf(client->name, sizeof(client->name) - 1, "saa7115");
saa7115_dbg("detecting saa7115 client on address 0x%x\n", address << 1); v4l_dbg(1, client, "detecting saa7115 client on address 0x%x\n", address << 1);
saa7115_write(client, 0, 5); saa7115_write(client, 0, 5);
chip_id = saa7115_read(client, 0) & 0x0f; chip_id = saa7115_read(client, 0) & 0x0f;
if (chip_id != 4 && chip_id != 5) { if (chip_id != 4 && chip_id != 5) {
saa7115_dbg("saa7115 not found\n"); v4l_dbg(1, client, "saa7115 not found\n");
kfree(client); kfree(client);
return 0; return 0;
} }
if (chip_id == 4) { if (chip_id == 4) {
snprintf(client->name, sizeof(client->name) - 1, "saa7114"); snprintf(client->name, sizeof(client->name) - 1, "saa7114");
} }
saa7115_info("saa711%d found @ 0x%x (%s)\n", chip_id, address << 1, adapter->name); v4l_info(client, "saa711%d found @ 0x%x (%s)\n", chip_id, address << 1, adapter->name);
state = kmalloc(sizeof(struct saa7115_state), GFP_KERNEL); state = kmalloc(sizeof(struct saa7115_state), GFP_KERNEL);
i2c_set_clientdata(client, state); i2c_set_clientdata(client, state);
@ -1250,7 +1235,7 @@ static int saa7115_attach(struct i2c_adapter *adapter, int address, int kind)
state->ident = (chip_id == 4) ? V4L2_IDENT_SAA7114 : V4L2_IDENT_SAA7115; state->ident = (chip_id == 4) ? V4L2_IDENT_SAA7114 : V4L2_IDENT_SAA7115;
state->audclk_freq = 48000; state->audclk_freq = 48000;
saa7115_dbg("writing init values\n"); v4l_dbg(1, client, "writing init values\n");
/* init to 60hz/48khz */ /* init to 60hz/48khz */
saa7115_writeregs(client, saa7115_init_auto_input); saa7115_writeregs(client, saa7115_init_auto_input);
@ -1263,7 +1248,7 @@ static int saa7115_attach(struct i2c_adapter *adapter, int address, int kind)
i2c_attach_client(client); i2c_attach_client(client);
saa7115_dbg("status: (1E) 0x%02x, (1F) 0x%02x\n", v4l_dbg(1, client, "status: (1E) 0x%02x, (1F) 0x%02x\n",
saa7115_read(client, 0x1e), saa7115_read(client, 0x1f)); saa7115_read(client, 0x1e), saa7115_read(client, 0x1f));
return 0; return 0;

View File

@ -66,30 +66,6 @@ module_param(test_image, int, 0644);
MODULE_PARM_DESC(debug, "debug level (0-2)"); MODULE_PARM_DESC(debug, "debug level (0-2)");
MODULE_PARM_DESC(test_image, "test_image (0-1)"); MODULE_PARM_DESC(test_image, "test_image (0-1)");
#define saa7127_dbg(fmt, arg...) \
do { \
if (debug >= 1) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, \
client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); \
} while (0)
/* High volume debug. Use with care. */
#define saa7127_dbg_highvol(fmt, arg...) \
do { \
if (debug == 2) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, \
client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); \
} while (0)
#define saa7127_err(fmt, arg...) do { \
printk(KERN_ERR "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define saa7127_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
static unsigned short normal_i2c[] = { 0x88 >> 1, I2C_CLIENT_END }; static unsigned short normal_i2c[] = { 0x88 >> 1, I2C_CLIENT_END };
@ -336,7 +312,7 @@ static int saa7127_write(struct i2c_client *client, u8 reg, u8 val)
if (i2c_smbus_write_byte_data(client, reg, val) == 0) if (i2c_smbus_write_byte_data(client, reg, val) == 0)
return 0; return 0;
} }
saa7127_err("I2C Write Problem\n"); v4l_err(client, "I2C Write Problem\n");
return -1; return -1;
} }
@ -362,7 +338,7 @@ static int saa7127_set_vps(struct i2c_client *client, struct v4l2_sliced_vbi_dat
if (enable && (data->field != 0 || data->line != 16)) if (enable && (data->field != 0 || data->line != 16))
return -EINVAL; return -EINVAL;
if (state->vps_enable != enable) { if (state->vps_enable != enable) {
saa7127_dbg("Turn VPS Signal %s\n", enable ? "on" : "off"); v4l_dbg(1, client, "Turn VPS Signal %s\n", enable ? "on" : "off");
saa7127_write(client, 0x54, enable << 7); saa7127_write(client, 0x54, enable << 7);
state->vps_enable = enable; state->vps_enable = enable;
} }
@ -374,7 +350,7 @@ static int saa7127_set_vps(struct i2c_client *client, struct v4l2_sliced_vbi_dat
state->vps_data[2] = data->data[11]; state->vps_data[2] = data->data[11];
state->vps_data[3] = data->data[12]; state->vps_data[3] = data->data[12];
state->vps_data[4] = data->data[13]; state->vps_data[4] = data->data[13];
saa7127_dbg("Set VPS data %02x %02x %02x %02x %02x\n", v4l_dbg(1, client, "Set VPS data %02x %02x %02x %02x %02x\n",
state->vps_data[0], state->vps_data[1], state->vps_data[0], state->vps_data[1],
state->vps_data[2], state->vps_data[3], state->vps_data[2], state->vps_data[3],
state->vps_data[4]); state->vps_data[4]);
@ -397,7 +373,7 @@ static int saa7127_set_cc(struct i2c_client *client, struct v4l2_sliced_vbi_data
if (enable && (data->field != 0 || data->line != 21)) if (enable && (data->field != 0 || data->line != 21))
return -EINVAL; return -EINVAL;
if (state->cc_enable != enable) { if (state->cc_enable != enable) {
saa7127_dbg("Turn CC %s\n", enable ? "on" : "off"); v4l_dbg(1, client, "Turn CC %s\n", enable ? "on" : "off");
saa7127_write(client, SAA7127_REG_CLOSED_CAPTION, saa7127_write(client, SAA7127_REG_CLOSED_CAPTION,
(state->xds_enable << 7) | (enable << 6) | 0x11); (state->xds_enable << 7) | (enable << 6) | 0x11);
state->cc_enable = enable; state->cc_enable = enable;
@ -405,7 +381,7 @@ static int saa7127_set_cc(struct i2c_client *client, struct v4l2_sliced_vbi_data
if (!enable) if (!enable)
return 0; return 0;
saa7127_dbg_highvol("CC data: %04x\n", cc); v4l_dbg(2, client, "CC data: %04x\n", cc);
saa7127_write(client, SAA7127_REG_LINE_21_ODD_0, cc & 0xff); saa7127_write(client, SAA7127_REG_LINE_21_ODD_0, cc & 0xff);
saa7127_write(client, SAA7127_REG_LINE_21_ODD_1, cc >> 8); saa7127_write(client, SAA7127_REG_LINE_21_ODD_1, cc >> 8);
state->cc_data = cc; state->cc_data = cc;
@ -423,7 +399,7 @@ static int saa7127_set_xds(struct i2c_client *client, struct v4l2_sliced_vbi_dat
if (enable && (data->field != 1 || data->line != 21)) if (enable && (data->field != 1 || data->line != 21))
return -EINVAL; return -EINVAL;
if (state->xds_enable != enable) { if (state->xds_enable != enable) {
saa7127_dbg("Turn XDS %s\n", enable ? "on" : "off"); v4l_dbg(1, client, "Turn XDS %s\n", enable ? "on" : "off");
saa7127_write(client, SAA7127_REG_CLOSED_CAPTION, saa7127_write(client, SAA7127_REG_CLOSED_CAPTION,
(enable << 7) | (state->cc_enable << 6) | 0x11); (enable << 7) | (state->cc_enable << 6) | 0x11);
state->xds_enable = enable; state->xds_enable = enable;
@ -431,7 +407,7 @@ static int saa7127_set_xds(struct i2c_client *client, struct v4l2_sliced_vbi_dat
if (!enable) if (!enable)
return 0; return 0;
saa7127_dbg_highvol("XDS data: %04x\n", xds); v4l_dbg(2, client, "XDS data: %04x\n", xds);
saa7127_write(client, SAA7127_REG_LINE_21_EVEN_0, xds & 0xff); saa7127_write(client, SAA7127_REG_LINE_21_EVEN_0, xds & 0xff);
saa7127_write(client, SAA7127_REG_LINE_21_EVEN_1, xds >> 8); saa7127_write(client, SAA7127_REG_LINE_21_EVEN_1, xds >> 8);
state->xds_data = xds; state->xds_data = xds;
@ -448,7 +424,7 @@ static int saa7127_set_wss(struct i2c_client *client, struct v4l2_sliced_vbi_dat
if (enable && (data->field != 0 || data->line != 23)) if (enable && (data->field != 0 || data->line != 23))
return -EINVAL; return -EINVAL;
if (state->wss_enable != enable) { if (state->wss_enable != enable) {
saa7127_dbg("Turn WSS %s\n", enable ? "on" : "off"); v4l_dbg(1, client, "Turn WSS %s\n", enable ? "on" : "off");
saa7127_write(client, 0x27, enable << 7); saa7127_write(client, 0x27, enable << 7);
state->wss_enable = enable; state->wss_enable = enable;
} }
@ -457,7 +433,7 @@ static int saa7127_set_wss(struct i2c_client *client, struct v4l2_sliced_vbi_dat
saa7127_write(client, 0x26, data->data[0]); saa7127_write(client, 0x26, data->data[0]);
saa7127_write(client, 0x27, 0x80 | (data->data[1] & 0x3f)); saa7127_write(client, 0x27, 0x80 | (data->data[1] & 0x3f));
saa7127_dbg("WSS mode: %s\n", wss_strs[data->data[0] & 0xf]); v4l_dbg(1, client, "WSS mode: %s\n", wss_strs[data->data[0] & 0xf]);
state->wss_mode = (data->data[1] & 0x3f) << 8 | data->data[0]; state->wss_mode = (data->data[1] & 0x3f) << 8 | data->data[0];
return 0; return 0;
} }
@ -469,11 +445,11 @@ static int saa7127_set_video_enable(struct i2c_client *client, int enable)
struct saa7127_state *state = i2c_get_clientdata(client); struct saa7127_state *state = i2c_get_clientdata(client);
if (enable) { if (enable) {
saa7127_dbg("Enable Video Output\n"); v4l_dbg(1, client, "Enable Video Output\n");
saa7127_write(client, 0x2d, state->reg_2d); saa7127_write(client, 0x2d, state->reg_2d);
saa7127_write(client, 0x61, state->reg_61); saa7127_write(client, 0x61, state->reg_61);
} else { } else {
saa7127_dbg("Disable Video Output\n"); v4l_dbg(1, client, "Disable Video Output\n");
saa7127_write(client, 0x2d, (state->reg_2d & 0xf0)); saa7127_write(client, 0x2d, (state->reg_2d & 0xf0));
saa7127_write(client, 0x61, (state->reg_61 | 0xc0)); saa7127_write(client, 0x61, (state->reg_61 | 0xc0));
} }
@ -489,11 +465,11 @@ static int saa7127_set_std(struct i2c_client *client, v4l2_std_id std)
const struct i2c_reg_value *inittab; const struct i2c_reg_value *inittab;
if (std & V4L2_STD_525_60) { if (std & V4L2_STD_525_60) {
saa7127_dbg("Selecting 60 Hz video Standard\n"); v4l_dbg(1, client, "Selecting 60 Hz video Standard\n");
inittab = saa7127_init_config_60hz; inittab = saa7127_init_config_60hz;
state->reg_61 = SAA7127_60HZ_DAC_CONTROL; state->reg_61 = SAA7127_60HZ_DAC_CONTROL;
} else { } else {
saa7127_dbg("Selecting 50 Hz video Standard\n"); v4l_dbg(1, client, "Selecting 50 Hz video Standard\n");
inittab = saa7127_init_config_50hz; inittab = saa7127_init_config_50hz;
state->reg_61 = SAA7127_50HZ_DAC_CONTROL; state->reg_61 = SAA7127_50HZ_DAC_CONTROL;
} }
@ -544,7 +520,7 @@ static int saa7127_set_output_type(struct i2c_client *client, int output)
default: default:
return -EINVAL; return -EINVAL;
} }
saa7127_dbg("Selecting %s output type\n", output_strs[output]); v4l_dbg(1, client, "Selecting %s output type\n", output_strs[output]);
/* Configure Encoder */ /* Configure Encoder */
saa7127_write(client, 0x2d, state->reg_2d); saa7127_write(client, 0x2d, state->reg_2d);
@ -561,12 +537,12 @@ static int saa7127_set_input_type(struct i2c_client *client, int input)
switch (input) { switch (input) {
case SAA7127_INPUT_TYPE_NORMAL: /* avia */ case SAA7127_INPUT_TYPE_NORMAL: /* avia */
saa7127_dbg("Selecting Normal Encoder Input\n"); v4l_dbg(1, client, "Selecting Normal Encoder Input\n");
state->reg_3a_cb = 0; state->reg_3a_cb = 0;
break; break;
case SAA7127_INPUT_TYPE_TEST_IMAGE: /* color bar */ case SAA7127_INPUT_TYPE_TEST_IMAGE: /* color bar */
saa7127_dbg("Selecting Color Bar generator\n"); v4l_dbg(1, client, "Selecting Color Bar generator\n");
state->reg_3a_cb = 0x80; state->reg_3a_cb = 0x80;
break; break;
@ -633,14 +609,14 @@ static int saa7127_command(struct i2c_client *client,
break; break;
case VIDIOC_LOG_STATUS: case VIDIOC_LOG_STATUS:
saa7127_info("Standard: %s\n", (state->std & V4L2_STD_525_60) ? "60 Hz" : "50 Hz"); v4l_info(client, "Standard: %s\n", (state->std & V4L2_STD_525_60) ? "60 Hz" : "50 Hz");
saa7127_info("Input: %s\n", state->input_type ? "color bars" : "normal"); v4l_info(client, "Input: %s\n", state->input_type ? "color bars" : "normal");
saa7127_info("Output: %s\n", state->video_enable ? v4l_info(client, "Output: %s\n", state->video_enable ?
output_strs[state->output_type] : "disabled"); output_strs[state->output_type] : "disabled");
saa7127_info("WSS: %s\n", state->wss_enable ? v4l_info(client, "WSS: %s\n", state->wss_enable ?
wss_strs[state->wss_mode] : "disabled"); wss_strs[state->wss_mode] : "disabled");
saa7127_info("VPS: %s\n", state->vps_enable ? "enabled" : "disabled"); v4l_info(client, "VPS: %s\n", state->vps_enable ? "enabled" : "disabled");
saa7127_info("CC: %s\n", state->cc_enable ? "enabled" : "disabled"); v4l_info(client, "CC: %s\n", state->cc_enable ? "enabled" : "disabled");
break; break;
#ifdef CONFIG_VIDEO_ADV_DEBUG #ifdef CONFIG_VIDEO_ADV_DEBUG
@ -723,7 +699,7 @@ static int saa7127_attach(struct i2c_adapter *adapter, int address, int kind)
client->driver = &i2c_driver_saa7127; client->driver = &i2c_driver_saa7127;
snprintf(client->name, sizeof(client->name) - 1, "saa7127"); snprintf(client->name, sizeof(client->name) - 1, "saa7127");
saa7127_dbg("detecting saa7127 client on address 0x%x\n", address << 1); v4l_dbg(1, client, "detecting saa7127 client on address 0x%x\n", address << 1);
/* First test register 0: Bits 5-7 are a version ID (should be 0), /* First test register 0: Bits 5-7 are a version ID (should be 0),
and bit 2 should also be 0. and bit 2 should also be 0.
@ -732,7 +708,7 @@ static int saa7127_attach(struct i2c_adapter *adapter, int address, int kind)
0x1d after a reset and not expected to ever change. */ 0x1d after a reset and not expected to ever change. */
if ((saa7127_read(client, 0) & 0xe4) != 0 || if ((saa7127_read(client, 0) & 0xe4) != 0 ||
(saa7127_read(client, 0x29) & 0x3f) != 0x1d) { (saa7127_read(client, 0x29) & 0x3f) != 0x1d) {
saa7127_dbg("saa7127 not found\n"); v4l_dbg(1, client, "saa7127 not found\n");
kfree(client); kfree(client);
return 0; return 0;
} }
@ -748,7 +724,7 @@ static int saa7127_attach(struct i2c_adapter *adapter, int address, int kind)
/* Configure Encoder */ /* Configure Encoder */
saa7127_dbg("Configuring encoder\n"); v4l_dbg(1, client, "Configuring encoder\n");
saa7127_write_inittab(client, saa7127_init_config_common); saa7127_write_inittab(client, saa7127_init_config_common);
saa7127_set_std(client, V4L2_STD_NTSC); saa7127_set_std(client, V4L2_STD_NTSC);
saa7127_set_output_type(client, SAA7127_OUTPUT_TYPE_BOTH); saa7127_set_output_type(client, SAA7127_OUTPUT_TYPE_BOTH);
@ -769,12 +745,12 @@ static int saa7127_attach(struct i2c_adapter *adapter, int address, int kind)
read_result = saa7127_read(client, SAA7129_REG_FADE_KEY_COL2); read_result = saa7127_read(client, SAA7129_REG_FADE_KEY_COL2);
saa7127_write(client, SAA7129_REG_FADE_KEY_COL2, 0xaa); saa7127_write(client, SAA7129_REG_FADE_KEY_COL2, 0xaa);
if (saa7127_read(client, SAA7129_REG_FADE_KEY_COL2) == 0xaa) { if (saa7127_read(client, SAA7129_REG_FADE_KEY_COL2) == 0xaa) {
saa7127_info("saa7129 found @ 0x%x (%s)\n", address << 1, adapter->name); v4l_info(client, "saa7129 found @ 0x%x (%s)\n", address << 1, adapter->name);
saa7127_write(client, SAA7129_REG_FADE_KEY_COL2, read_result); saa7127_write(client, SAA7129_REG_FADE_KEY_COL2, read_result);
saa7127_write_inittab(client, saa7129_init_config_extra); saa7127_write_inittab(client, saa7129_init_config_extra);
state->ident = V4L2_IDENT_SAA7129; state->ident = V4L2_IDENT_SAA7129;
} else { } else {
saa7127_info("saa7127 found @ 0x%x (%s)\n", address << 1, adapter->name); v4l_info(client, "saa7127 found @ 0x%x (%s)\n", address << 1, adapter->name);
state->ident = V4L2_IDENT_SAA7127; state->ident = V4L2_IDENT_SAA7127;
} }

View File

@ -17,6 +17,9 @@
#define PREFIX "TEA5767 " #define PREFIX "TEA5767 "
/* from tuner-core.c */
extern int debug;
/*****************************************************************************/ /*****************************************************************************/
/****************************** /******************************
@ -246,7 +249,7 @@ static void set_radio_freq(struct i2c_client *c, unsigned int frq)
if (5 != (rc = i2c_master_send(c, buffer, 5))) if (5 != (rc = i2c_master_send(c, buffer, 5)))
tuner_warn("i2c i/o error: rc == %d (should be 5)\n", rc); tuner_warn("i2c i/o error: rc == %d (should be 5)\n", rc);
if (tuner_debug) { if (debug) {
if (5 != (rc = i2c_master_recv(c, buffer, 5))) if (5 != (rc = i2c_master_recv(c, buffer, 5)))
tuner_warn("i2c i/o error: rc == %d (should be 5)\n", rc); tuner_warn("i2c i/o error: rc == %d (should be 5)\n", rc);
else else

View File

@ -23,8 +23,6 @@
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
#include <media/audiochip.h> #include <media/audiochip.h>
#include "msp3400.h"
#define UNSET (-1U) #define UNSET (-1U)
/* standard i2c insmod options */ /* standard i2c insmod options */
@ -43,7 +41,8 @@ static unsigned int no_autodetect = 0;
static unsigned int show_i2c = 0; static unsigned int show_i2c = 0;
/* insmod options used at runtime => read/write */ /* insmod options used at runtime => read/write */
unsigned int tuner_debug = 0; static unsigned int tuner_debug = 0;
int debug = 0;
static unsigned int tv_range[2] = { 44, 958 }; static unsigned int tv_range[2] = { 44, 958 };
static unsigned int radio_range[2] = { 65, 108 }; static unsigned int radio_range[2] = { 65, 108 };
@ -55,7 +54,9 @@ static char ntsc[] = "-";
module_param(addr, int, 0444); module_param(addr, int, 0444);
module_param(no_autodetect, int, 0444); module_param(no_autodetect, int, 0444);
module_param(show_i2c, int, 0444); module_param(show_i2c, int, 0444);
module_param(tuner_debug, int, 0644); /* Note: tuner_debug is deprecated and will be removed in 2.6.17 */
module_param(tuner_debug, int, 0444);
module_param(debug, int, 0644);
module_param_string(pal, pal, sizeof(pal), 0644); module_param_string(pal, pal, sizeof(pal), 0644);
module_param_string(secam, secam, sizeof(secam), 0644); module_param_string(secam, secam, sizeof(secam), 0644);
@ -419,6 +420,11 @@ static int tuner_attach(struct i2c_adapter *adap, int addr, int kind)
t->radio_if2 = 10700 * 1000; /* 10.7MHz - FM radio */ t->radio_if2 = 10700 * 1000; /* 10.7MHz - FM radio */
t->audmode = V4L2_TUNER_MODE_STEREO; t->audmode = V4L2_TUNER_MODE_STEREO;
t->mode_mask = T_UNINITIALIZED; t->mode_mask = T_UNINITIALIZED;
if (tuner_debug) {
debug = tuner_debug;
printk(KERN_ERR "tuner: tuner_debug is deprecated and will be removed in 2.6.17.\n");
printk(KERN_ERR "tuner: use the debug option instead.\n");
}
if (show_i2c) { if (show_i2c) {
unsigned char buffer[16]; unsigned char buffer[16];
@ -546,7 +552,7 @@ static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
{ {
struct tuner *t = i2c_get_clientdata(client); struct tuner *t = i2c_get_clientdata(client);
if (tuner_debug>1) if (debug>1)
v4l_i2c_print_ioctl(&(t->i2c),cmd); v4l_i2c_print_ioctl(&(t->i2c),cmd);
switch (cmd) { switch (cmd) {

View File

@ -47,19 +47,6 @@ MODULE_LICENSE("GPL");
#define UNSET (-1U) #define UNSET (-1U)
#define tvaudio_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, chip->c.driver->name, \
i2c_adapter_id(chip->c.adapter), chip->c.addr , ## arg); } while (0)
#define tvaudio_warn(fmt, arg...) do { \
printk(KERN_WARNING "%s %d-%04x: " fmt, chip->c.driver->name, \
i2c_adapter_id(chip->c.adapter), chip->c.addr , ## arg); } while (0)
#define tvaudio_dbg(fmt, arg...) \
do { \
if (debug) \
printk(KERN_INFO "%s debug %d-%04x: " fmt, chip->c.driver->name, \
i2c_adapter_id(chip->c.adapter), chip->c.addr , ## arg); \
} while (0)
/* ---------------------------------------------------------------------- */ /* ---------------------------------------------------------------------- */
/* our structs */ /* our structs */
@ -172,23 +159,23 @@ static int chip_write(struct CHIPSTATE *chip, int subaddr, int val)
unsigned char buffer[2]; unsigned char buffer[2];
if (-1 == subaddr) { if (-1 == subaddr) {
tvaudio_dbg("%s: chip_write: 0x%x\n", v4l_dbg(1, &chip->c, "%s: chip_write: 0x%x\n",
chip->c.name, val); chip->c.name, val);
chip->shadow.bytes[1] = val; chip->shadow.bytes[1] = val;
buffer[0] = val; buffer[0] = val;
if (1 != i2c_master_send(&chip->c,buffer,1)) { if (1 != i2c_master_send(&chip->c,buffer,1)) {
tvaudio_warn("%s: I/O error (write 0x%x)\n", v4l_warn(&chip->c, "%s: I/O error (write 0x%x)\n",
chip->c.name, val); chip->c.name, val);
return -1; return -1;
} }
} else { } else {
tvaudio_dbg("%s: chip_write: reg%d=0x%x\n", v4l_dbg(1, &chip->c, "%s: chip_write: reg%d=0x%x\n",
chip->c.name, subaddr, val); chip->c.name, subaddr, val);
chip->shadow.bytes[subaddr+1] = val; chip->shadow.bytes[subaddr+1] = val;
buffer[0] = subaddr; buffer[0] = subaddr;
buffer[1] = val; buffer[1] = val;
if (2 != i2c_master_send(&chip->c,buffer,2)) { if (2 != i2c_master_send(&chip->c,buffer,2)) {
tvaudio_warn("%s: I/O error (write reg%d=0x%x)\n", v4l_warn(&chip->c, "%s: I/O error (write reg%d=0x%x)\n",
chip->c.name, subaddr, val); chip->c.name, subaddr, val);
return -1; return -1;
} }
@ -213,11 +200,11 @@ static int chip_read(struct CHIPSTATE *chip)
unsigned char buffer; unsigned char buffer;
if (1 != i2c_master_recv(&chip->c,&buffer,1)) { if (1 != i2c_master_recv(&chip->c,&buffer,1)) {
tvaudio_warn("%s: I/O error (read)\n", v4l_warn(&chip->c, "%s: I/O error (read)\n",
chip->c.name); chip->c.name);
return -1; return -1;
} }
tvaudio_dbg("%s: chip_read: 0x%x\n",chip->c.name, buffer); v4l_dbg(1, &chip->c, "%s: chip_read: 0x%x\n",chip->c.name, buffer);
return buffer; return buffer;
} }
@ -232,10 +219,10 @@ static int chip_read2(struct CHIPSTATE *chip, int subaddr)
write[0] = subaddr; write[0] = subaddr;
if (2 != i2c_transfer(chip->c.adapter,msgs,2)) { if (2 != i2c_transfer(chip->c.adapter,msgs,2)) {
tvaudio_warn("%s: I/O error (read2)\n", chip->c.name); v4l_warn(&chip->c, "%s: I/O error (read2)\n", chip->c.name);
return -1; return -1;
} }
tvaudio_dbg("%s: chip_read2: reg%d=0x%x\n", v4l_dbg(1, &chip->c, "%s: chip_read2: reg%d=0x%x\n",
chip->c.name, subaddr,read[0]); chip->c.name, subaddr,read[0]);
return read[0]; return read[0];
} }
@ -248,7 +235,7 @@ static int chip_cmd(struct CHIPSTATE *chip, char *name, audiocmd *cmd)
return 0; return 0;
/* update our shadow register set; print bytes if (debug > 0) */ /* update our shadow register set; print bytes if (debug > 0) */
tvaudio_dbg("%s: chip_cmd(%s): reg=%d, data:", v4l_dbg(1, &chip->c, "%s: chip_cmd(%s): reg=%d, data:",
chip->c.name, name,cmd->bytes[0]); chip->c.name, name,cmd->bytes[0]);
for (i = 1; i < cmd->count; i++) { for (i = 1; i < cmd->count; i++) {
if (debug) if (debug)
@ -260,7 +247,7 @@ static int chip_cmd(struct CHIPSTATE *chip, char *name, audiocmd *cmd)
/* send data to the chip */ /* send data to the chip */
if (cmd->count != i2c_master_send(&chip->c,cmd->bytes,cmd->count)) { if (cmd->count != i2c_master_send(&chip->c,cmd->bytes,cmd->count)) {
tvaudio_warn("%s: I/O error (%s)\n", chip->c.name, name); v4l_warn(&chip->c, "%s: I/O error (%s)\n", chip->c.name, name);
return -1; return -1;
} }
return 0; return 0;
@ -287,7 +274,7 @@ static int chip_thread(void *data)
daemonize("%s", chip->c.name); daemonize("%s", chip->c.name);
allow_signal(SIGTERM); allow_signal(SIGTERM);
tvaudio_dbg("%s: thread started\n", chip->c.name); v4l_dbg(1, &chip->c, "%s: thread started\n", chip->c.name);
for (;;) { for (;;) {
add_wait_queue(&chip->wq, &wait); add_wait_queue(&chip->wq, &wait);
@ -299,7 +286,7 @@ static int chip_thread(void *data)
try_to_freeze(); try_to_freeze();
if (chip->done || signal_pending(current)) if (chip->done || signal_pending(current))
break; break;
tvaudio_dbg("%s: thread wakeup\n", chip->c.name); v4l_dbg(1, &chip->c, "%s: thread wakeup\n", chip->c.name);
/* don't do anything for radio or if mode != auto */ /* don't do anything for radio or if mode != auto */
if (chip->radio || chip->mode != 0) if (chip->radio || chip->mode != 0)
@ -312,7 +299,7 @@ static int chip_thread(void *data)
mod_timer(&chip->wt, jiffies+2*HZ); mod_timer(&chip->wt, jiffies+2*HZ);
} }
tvaudio_dbg("%s: thread exiting\n", chip->c.name); v4l_dbg(1, &chip->c, "%s: thread exiting\n", chip->c.name);
complete_and_exit(&chip->texit, 0); complete_and_exit(&chip->texit, 0);
return 0; return 0;
} }
@ -325,7 +312,7 @@ static void generic_checkmode(struct CHIPSTATE *chip)
if (mode == chip->prevmode) if (mode == chip->prevmode)
return; return;
tvaudio_dbg("%s: thread checkmode\n", chip->c.name); v4l_dbg(1, &chip->c, "%s: thread checkmode\n", chip->c.name);
chip->prevmode = mode; chip->prevmode = mode;
if (mode & VIDEO_SOUND_STEREO) if (mode & VIDEO_SOUND_STEREO)
@ -372,7 +359,7 @@ static int tda9840_getmode(struct CHIPSTATE *chip)
if (val & TDA9840_ST_STEREO) if (val & TDA9840_ST_STEREO)
mode |= VIDEO_SOUND_STEREO; mode |= VIDEO_SOUND_STEREO;
tvaudio_dbg ("tda9840_getmode(): raw chip read: %d, return: %d\n", v4l_dbg(1, &chip->c, "tda9840_getmode(): raw chip read: %d, return: %d\n",
val, mode); val, mode);
return mode; return mode;
} }
@ -668,7 +655,7 @@ static int tda9873_getmode(struct CHIPSTATE *chip)
mode |= VIDEO_SOUND_STEREO; mode |= VIDEO_SOUND_STEREO;
if (val & TDA9873_DUAL) if (val & TDA9873_DUAL)
mode |= VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2; mode |= VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
tvaudio_dbg ("tda9873_getmode(): raw chip read: %d, return: %d\n", v4l_dbg(1, &chip->c, "tda9873_getmode(): raw chip read: %d, return: %d\n",
val, mode); val, mode);
return mode; return mode;
} }
@ -679,12 +666,12 @@ static void tda9873_setmode(struct CHIPSTATE *chip, int mode)
/* int adj_data = chip->shadow.bytes[TDA9873_AD+1] ; */ /* int adj_data = chip->shadow.bytes[TDA9873_AD+1] ; */
if ((sw_data & TDA9873_INP_MASK) != TDA9873_INTERNAL) { if ((sw_data & TDA9873_INP_MASK) != TDA9873_INTERNAL) {
tvaudio_dbg("tda9873_setmode(): external input\n"); v4l_dbg(1, &chip->c, "tda9873_setmode(): external input\n");
return; return;
} }
tvaudio_dbg("tda9873_setmode(): chip->shadow.bytes[%d] = %d\n", TDA9873_SW+1, chip->shadow.bytes[TDA9873_SW+1]); v4l_dbg(1, &chip->c, "tda9873_setmode(): chip->shadow.bytes[%d] = %d\n", TDA9873_SW+1, chip->shadow.bytes[TDA9873_SW+1]);
tvaudio_dbg("tda9873_setmode(): sw_data = %d\n", sw_data); v4l_dbg(1, &chip->c, "tda9873_setmode(): sw_data = %d\n", sw_data);
switch (mode) { switch (mode) {
case VIDEO_SOUND_MONO: case VIDEO_SOUND_MONO:
@ -705,7 +692,7 @@ static void tda9873_setmode(struct CHIPSTATE *chip, int mode)
} }
chip_write(chip, TDA9873_SW, sw_data); chip_write(chip, TDA9873_SW, sw_data);
tvaudio_dbg("tda9873_setmode(): req. mode %d; chip_write: %d\n", v4l_dbg(1, &chip->c, "tda9873_setmode(): req. mode %d; chip_write: %d\n",
mode, sw_data); mode, sw_data);
} }
@ -844,7 +831,7 @@ static int tda9874a_setup(struct CHIPSTATE *chip)
chip_write(chip, TDA9874A_SDACOSR, (tda9874a_mode) ? 0x81:0x80); chip_write(chip, TDA9874A_SDACOSR, (tda9874a_mode) ? 0x81:0x80);
chip_write(chip, TDA9874A_AOSR, 0x00); /* or 0x10 */ chip_write(chip, TDA9874A_AOSR, 0x00); /* or 0x10 */
} }
tvaudio_dbg("tda9874a_setup(): %s [0x%02X].\n", v4l_dbg(1, &chip->c, "tda9874a_setup(): %s [0x%02X].\n",
tda9874a_modelist[tda9874a_STD].name,tda9874a_STD); tda9874a_modelist[tda9874a_STD].name,tda9874a_STD);
return 1; return 1;
} }
@ -887,7 +874,7 @@ static int tda9874a_getmode(struct CHIPSTATE *chip)
mode |= VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2; mode |= VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
} }
tvaudio_dbg("tda9874a_getmode(): DSR=0x%X, NSR=0x%X, NECR=0x%X, return: %d.\n", v4l_dbg(1, &chip->c, "tda9874a_getmode(): DSR=0x%X, NSR=0x%X, NECR=0x%X, return: %d.\n",
dsr, nsr, necr, mode); dsr, nsr, necr, mode);
return mode; return mode;
} }
@ -933,7 +920,7 @@ static void tda9874a_setmode(struct CHIPSTATE *chip, int mode)
chip_write(chip, TDA9874A_AOSR, aosr); chip_write(chip, TDA9874A_AOSR, aosr);
chip_write(chip, TDA9874A_MDACOSR, mdacosr); chip_write(chip, TDA9874A_MDACOSR, mdacosr);
tvaudio_dbg("tda9874a_setmode(): req. mode %d; AOSR=0x%X, MDACOSR=0x%X.\n", v4l_dbg(1, &chip->c, "tda9874a_setmode(): req. mode %d; AOSR=0x%X, MDACOSR=0x%X.\n",
mode, aosr, mdacosr); mode, aosr, mdacosr);
} else { /* dic == 0x07 */ } else { /* dic == 0x07 */
@ -968,7 +955,7 @@ static void tda9874a_setmode(struct CHIPSTATE *chip, int mode)
chip_write(chip, TDA9874A_FMMR, fmmr); chip_write(chip, TDA9874A_FMMR, fmmr);
chip_write(chip, TDA9874A_AOSR, aosr); chip_write(chip, TDA9874A_AOSR, aosr);
tvaudio_dbg("tda9874a_setmode(): req. mode %d; FMMR=0x%X, AOSR=0x%X.\n", v4l_dbg(1, &chip->c, "tda9874a_setmode(): req. mode %d; FMMR=0x%X, AOSR=0x%X.\n",
mode, fmmr, aosr); mode, fmmr, aosr);
} }
} }
@ -982,10 +969,10 @@ static int tda9874a_checkit(struct CHIPSTATE *chip)
if(-1 == (sic = chip_read2(chip,TDA9874A_SIC))) if(-1 == (sic = chip_read2(chip,TDA9874A_SIC)))
return 0; return 0;
tvaudio_dbg("tda9874a_checkit(): DIC=0x%X, SIC=0x%X.\n", dic, sic); v4l_dbg(1, &chip->c, "tda9874a_checkit(): DIC=0x%X, SIC=0x%X.\n", dic, sic);
if((dic == 0x11)||(dic == 0x07)) { if((dic == 0x11)||(dic == 0x07)) {
tvaudio_info("found tda9874%s.\n", (dic == 0x11) ? "a":"h"); v4l_info(&chip->c, "found tda9874%s.\n", (dic == 0x11) ? "a":"h");
tda9874a_dic = dic; /* remember device id. */ tda9874a_dic = dic; /* remember device id. */
return 1; return 1;
} }
@ -1197,7 +1184,7 @@ static int ta8874z_getmode(struct CHIPSTATE *chip)
}else if (!(val & TA8874Z_B0)){ }else if (!(val & TA8874Z_B0)){
mode |= VIDEO_SOUND_STEREO; mode |= VIDEO_SOUND_STEREO;
} }
/* tvaudio_dbg ("ta8874z_getmode(): raw chip read: 0x%02x, return: 0x%02x\n", val, mode); */ /* v4l_dbg(1, &chip->c, "ta8874z_getmode(): raw chip read: 0x%02x, return: 0x%02x\n", val, mode); */
return mode; return mode;
} }
@ -1210,7 +1197,7 @@ static void ta8874z_setmode(struct CHIPSTATE *chip, int mode)
{ {
int update = 1; int update = 1;
audiocmd *t = NULL; audiocmd *t = NULL;
tvaudio_dbg("ta8874z_setmode(): mode: 0x%02x\n", mode); v4l_dbg(1, &chip->c, "ta8874z_setmode(): mode: 0x%02x\n", mode);
switch(mode){ switch(mode){
case VIDEO_SOUND_MONO: case VIDEO_SOUND_MONO:
@ -1491,7 +1478,7 @@ static int chip_attach(struct i2c_adapter *adap, int addr, int kind)
i2c_set_clientdata(&chip->c, chip); i2c_set_clientdata(&chip->c, chip);
/* find description for the chip */ /* find description for the chip */
tvaudio_dbg("chip found @ 0x%x\n", addr<<1); v4l_dbg(1, &chip->c, "chip found @ 0x%x\n", addr<<1);
for (desc = chiplist; desc->name != NULL; desc++) { for (desc = chiplist; desc->name != NULL; desc++) {
if (0 == *(desc->insmodopt)) if (0 == *(desc->insmodopt))
continue; continue;
@ -1503,12 +1490,12 @@ static int chip_attach(struct i2c_adapter *adap, int addr, int kind)
break; break;
} }
if (desc->name == NULL) { if (desc->name == NULL) {
tvaudio_dbg("no matching chip description found\n"); v4l_dbg(1, &chip->c, "no matching chip description found\n");
return -EIO; return -EIO;
} }
tvaudio_info("%s found @ 0x%x (%s)\n", desc->name, addr<<1, adap->name); v4l_info(&chip->c, "%s found @ 0x%x (%s)\n", desc->name, addr<<1, adap->name);
if (desc->flags) { if (desc->flags) {
tvaudio_dbg("matches:%s%s%s.\n", v4l_dbg(1, &chip->c, "matches:%s%s%s.\n",
(desc->flags & CHIP_HAS_VOLUME) ? " volume" : "", (desc->flags & CHIP_HAS_VOLUME) ? " volume" : "",
(desc->flags & CHIP_HAS_BASSTREBLE) ? " bass/treble" : "", (desc->flags & CHIP_HAS_BASSTREBLE) ? " bass/treble" : "",
(desc->flags & CHIP_HAS_INPUTSEL) ? " audiomux" : ""); (desc->flags & CHIP_HAS_INPUTSEL) ? " audiomux" : "");
@ -1551,7 +1538,7 @@ static int chip_attach(struct i2c_adapter *adap, int addr, int kind)
init_completion(&chip->texit); init_completion(&chip->texit);
chip->tpid = kernel_thread(chip_thread,(void *)chip,0); chip->tpid = kernel_thread(chip_thread,(void *)chip,0);
if (chip->tpid < 0) if (chip->tpid < 0)
tvaudio_warn("%s: kernel_thread() failed\n", v4l_warn(&chip->c, "%s: kernel_thread() failed\n",
chip->c.name); chip->c.name);
wake_up_interruptible(&chip->wq); wake_up_interruptible(&chip->wq);
} }
@ -1596,7 +1583,7 @@ static int chip_command(struct i2c_client *client,
struct CHIPSTATE *chip = i2c_get_clientdata(client); struct CHIPSTATE *chip = i2c_get_clientdata(client);
struct CHIPDESC *desc = chiplist + chip->type; struct CHIPDESC *desc = chiplist + chip->type;
tvaudio_dbg("%s: chip_command 0x%x\n", chip->c.name, cmd); v4l_dbg(1, &chip->c, "%s: chip_command 0x%x\n", chip->c.name, cmd);
switch (cmd) { switch (cmd) {
case AUDC_SET_INPUT: case AUDC_SET_INPUT:

View File

@ -40,6 +40,7 @@
#include <media/tuner.h> #include <media/tuner.h>
#include <media/tveeprom.h> #include <media/tveeprom.h>
#include <media/v4l2-common.h>
#include <media/audiochip.h> #include <media/audiochip.h>
MODULE_DESCRIPTION("i2c Hauppauge eeprom decoder driver"); MODULE_DESCRIPTION("i2c Hauppauge eeprom decoder driver");
@ -52,16 +53,14 @@ MODULE_PARM_DESC(debug, "Debug level (0-1)");
#define STRM(array,i) (i < sizeof(array)/sizeof(char*) ? array[i] : "unknown") #define STRM(array,i) (i < sizeof(array)/sizeof(char*) ? array[i] : "unknown")
#define tveeprom_info(fmt, arg...) do {\ #define tveeprom_info(fmt, arg...) \
printk(KERN_INFO "tveeprom %d-%04x: " fmt, \ v4l_printk(KERN_INFO, "tveeprom", c->adapter, c->addr, fmt , ## arg)
c->adapter->nr, c->addr , ##arg); } while (0) #define tveeprom_warn(fmt, arg...) \
#define tveeprom_warn(fmt, arg...) do {\ v4l_printk(KERN_WARNING, "tveeprom", c->adapter, c->addr, fmt , ## arg)
printk(KERN_WARNING "tveeprom %d-%04x: " fmt, \ #define tveeprom_dbg(fmt, arg...) do { \
c->adapter->nr, c->addr , ##arg); } while (0)
#define tveeprom_dbg(fmt, arg...) do {\
if (debug) \ if (debug) \
printk(KERN_INFO "tveeprom %d-%04x: " fmt, \ v4l_printk(KERN_DEBUG, "tveeprom", c->adapter, c->addr, fmt , ## arg); \
c->adapter->nr, c->addr , ##arg); } while (0) } while (0)
/* /*
* The Hauppauge eeprom uses an 8bit field to determine which * The Hauppauge eeprom uses an 8bit field to determine which

View File

@ -32,20 +32,12 @@
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/i2c-id.h> #include <linux/i2c-id.h>
#include <linux/videodev.h> #include <linux/videodev.h>
#include <media/audiochip.h> #include <media/v4l2-common.h>
MODULE_DESCRIPTION("wm8775 driver"); MODULE_DESCRIPTION("wm8775 driver");
MODULE_AUTHOR("Ulf Eklund, Hans Verkuil"); MODULE_AUTHOR("Ulf Eklund, Hans Verkuil");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
#define wm8775_err(fmt, arg...) do { \
printk(KERN_ERR "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
#define wm8775_info(fmt, arg...) do { \
printk(KERN_INFO "%s %d-%04x: " fmt, client->driver->driver.name, \
i2c_adapter_id(client->adapter), client->addr , ## arg); } while (0)
static unsigned short normal_i2c[] = { 0x36 >> 1, I2C_CLIENT_END }; static unsigned short normal_i2c[] = { 0x36 >> 1, I2C_CLIENT_END };
@ -69,7 +61,7 @@ static int wm8775_write(struct i2c_client *client, int reg, u16 val)
int i; int i;
if (reg < 0 || reg >= TOT_REGS) { if (reg < 0 || reg >= TOT_REGS) {
wm8775_err("Invalid register R%d\n", reg); v4l_err(client, "Invalid register R%d\n", reg);
return -1; return -1;
} }
@ -79,7 +71,7 @@ static int wm8775_write(struct i2c_client *client, int reg, u16 val)
return 0; return 0;
} }
} }
wm8775_err("I2C: cannot write %03x to register R%d\n", val, reg); v4l_err(client, "I2C: cannot write %03x to register R%d\n", val, reg);
return -1; return -1;
} }
@ -98,7 +90,7 @@ static int wm8775_command(struct i2c_client *client, unsigned int cmd,
If only one input is active (the normal case) then the If only one input is active (the normal case) then the
input values 1, 2, 4 or 8 should be used. */ input values 1, 2, 4 or 8 should be used. */
if (input->index > 15) { if (input->index > 15) {
wm8775_err("Invalid input %d.\n", input->index); v4l_err(client, "Invalid input %d.\n", input->index);
return -EINVAL; return -EINVAL;
} }
state->input = input->index; state->input = input->index;
@ -133,7 +125,7 @@ static int wm8775_command(struct i2c_client *client, unsigned int cmd,
break; break;
case VIDIOC_LOG_STATUS: case VIDIOC_LOG_STATUS:
wm8775_info("Input: %d%s\n", state->input, v4l_info(client, "Input: %d%s\n", state->input,
state->muted ? " (muted)" : ""); state->muted ? " (muted)" : "");
break; break;
@ -184,7 +176,7 @@ static int wm8775_attach(struct i2c_adapter *adapter, int address, int kind)
client->driver = &i2c_driver; client->driver = &i2c_driver;
snprintf(client->name, sizeof(client->name) - 1, "wm8775"); snprintf(client->name, sizeof(client->name) - 1, "wm8775");
wm8775_info("chip found @ 0x%x (%s)\n", address << 1, adapter->name); v4l_info(client, "chip found @ 0x%x (%s)\n", address << 1, adapter->name);
state = kmalloc(sizeof(struct wm8775_state), GFP_KERNEL); state = kmalloc(sizeof(struct wm8775_state), GFP_KERNEL);
if (state == NULL) { if (state == NULL) {

View File

@ -202,7 +202,6 @@ struct tuner {
void (*standby)(struct i2c_client *c); void (*standby)(struct i2c_client *c);
}; };
extern unsigned int tuner_debug;
extern unsigned const int tuner_count; extern unsigned const int tuner_count;
extern int microtune_init(struct i2c_client *c); extern int microtune_init(struct i2c_client *c);
@ -220,7 +219,8 @@ extern int tea5767_autodetection(struct i2c_client *c);
printk(KERN_INFO "%s %d-%04x: " fmt, t->i2c.driver->driver.name, \ printk(KERN_INFO "%s %d-%04x: " fmt, t->i2c.driver->driver.name, \
i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0) i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0)
#define tuner_dbg(fmt, arg...) do {\ #define tuner_dbg(fmt, arg...) do {\
if (tuner_debug) \ extern int debug; \
if (debug) \
printk(KERN_DEBUG "%s %d-%04x: " fmt, t->i2c.driver->driver.name, \ printk(KERN_DEBUG "%s %d-%04x: " fmt, t->i2c.driver->driver.name, \
i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0) i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0)

View File

@ -51,6 +51,7 @@
parameter called 'debug'. */ parameter called 'debug'. */
#define v4l_dbg(level, client, fmt, arg...) \ #define v4l_dbg(level, client, fmt, arg...) \
do { \ do { \
extern int debug; \
if (debug >= (level)) \ if (debug >= (level)) \
v4l_client_printk(KERN_DEBUG, client, fmt , ## arg); \ v4l_client_printk(KERN_DEBUG, client, fmt , ## arg); \
} while (0) } while (0)