V4L/DVB (7264): cx88-cards: always use a level on printk messages
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
parent
c450e50e8d
commit
0f19e65bc5
1 changed files with 41 additions and 30 deletions
|
@ -45,6 +45,16 @@ static unsigned int latency = UNSET;
|
||||||
module_param(latency,int,0444);
|
module_param(latency,int,0444);
|
||||||
MODULE_PARM_DESC(latency,"pci latency timer");
|
MODULE_PARM_DESC(latency,"pci latency timer");
|
||||||
|
|
||||||
|
#define info_printk(core, fmt, arg...) \
|
||||||
|
printk(KERN_INFO "%s: " fmt, core->name , ## arg)
|
||||||
|
|
||||||
|
#define warn_printk(core, fmt, arg...) \
|
||||||
|
printk(KERN_WARNING "%s: " fmt, core->name , ## arg)
|
||||||
|
|
||||||
|
#define err_printk(core, fmt, arg...) \
|
||||||
|
printk(KERN_ERR "%s: " fmt, core->name , ## arg)
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------ */
|
/* ------------------------------------------------------------------ */
|
||||||
/* board config info */
|
/* board config info */
|
||||||
|
|
||||||
|
@ -1915,17 +1925,16 @@ static void leadtek_eeprom(struct cx88_core *core, u8 *eeprom_data)
|
||||||
if (eeprom_data[4] != 0x7d ||
|
if (eeprom_data[4] != 0x7d ||
|
||||||
eeprom_data[5] != 0x10 ||
|
eeprom_data[5] != 0x10 ||
|
||||||
eeprom_data[7] != 0x66) {
|
eeprom_data[7] != 0x66) {
|
||||||
printk(KERN_WARNING "%s: Leadtek eeprom invalid.\n",
|
warn_printk(core, "Leadtek eeprom invalid.\n");
|
||||||
core->name);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
core->board.tuner_type = (eeprom_data[6] == 0x13) ?
|
core->board.tuner_type = (eeprom_data[6] == 0x13) ?
|
||||||
TUNER_PHILIPS_FM1236_MK3 : TUNER_PHILIPS_FM1216ME_MK3;
|
TUNER_PHILIPS_FM1236_MK3 : TUNER_PHILIPS_FM1216ME_MK3;
|
||||||
|
|
||||||
printk(KERN_INFO "%s: Leadtek Winfast 2000XP Expert config: "
|
info_printk(core, "Leadtek Winfast 2000XP Expert config: "
|
||||||
"tuner=%d, eeprom[0]=0x%02x\n",
|
"tuner=%d, eeprom[0]=0x%02x\n",
|
||||||
core->name, core->board.tuner_type, eeprom_data[0]);
|
core->board.tuner_type, eeprom_data[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void hauppauge_eeprom(struct cx88_core *core, u8 *eeprom_data)
|
static void hauppauge_eeprom(struct cx88_core *core, u8 *eeprom_data)
|
||||||
|
@ -1969,13 +1978,12 @@ static void hauppauge_eeprom(struct cx88_core *core, u8 *eeprom_data)
|
||||||
/* known */
|
/* known */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printk("%s: warning: unknown hauppauge model #%d\n",
|
warn_printk(core, "warning: unknown hauppauge model #%d\n",
|
||||||
core->name, tv.model);
|
tv.model);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
printk(KERN_INFO "%s: hauppauge eeprom: model=%d\n",
|
info_printk(core, "hauppauge eeprom: model=%d\n", tv.model);
|
||||||
core->name, tv.model);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------- */
|
/* ----------------------------------------------------------------------- */
|
||||||
|
@ -2021,8 +2029,7 @@ static void gdi_eeprom(struct cx88_core *core, u8 *eeprom_data)
|
||||||
char *name = (eeprom_data[0x0d] < ARRAY_SIZE(gdi_tuner))
|
char *name = (eeprom_data[0x0d] < ARRAY_SIZE(gdi_tuner))
|
||||||
? gdi_tuner[eeprom_data[0x0d]].name : NULL;
|
? gdi_tuner[eeprom_data[0x0d]].name : NULL;
|
||||||
|
|
||||||
printk(KERN_INFO "%s: GDI: tuner=%s\n", core->name,
|
info_printk(core, "GDI: tuner=%s\n", name ? name : "unknown");
|
||||||
name ? name : "unknown");
|
|
||||||
if (NULL == name)
|
if (NULL == name)
|
||||||
return;
|
return;
|
||||||
core->board.tuner_type = gdi_tuner[eeprom_data[0x0d]].id;
|
core->board.tuner_type = gdi_tuner[eeprom_data[0x0d]].id;
|
||||||
|
@ -2110,7 +2117,8 @@ static void dvico_fusionhdtv_hybrid_init(struct cx88_core *core)
|
||||||
msg.len = (i != 12 ? 5 : 2);
|
msg.len = (i != 12 ? 5 : 2);
|
||||||
err = i2c_transfer(&core->i2c_adap, &msg, 1);
|
err = i2c_transfer(&core->i2c_adap, &msg, 1);
|
||||||
if (err != 1) {
|
if (err != 1) {
|
||||||
printk("dvico_fusionhdtv_hybrid_init buf %d failed (err = %d)!\n", i, err);
|
warn_printk(core, "dvico_fusionhdtv_hybrid_init buf %d "
|
||||||
|
"failed (err = %d)!\n", i, err);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2135,7 +2143,7 @@ static int cx88_xc2028_tuner_callback(void *priv, int command, int arg)
|
||||||
case XC2028_TUNER_RESET:
|
case XC2028_TUNER_RESET:
|
||||||
switch (INPUT(core->input).type) {
|
switch (INPUT(core->input).type) {
|
||||||
case CX88_RADIO:
|
case CX88_RADIO:
|
||||||
printk(KERN_INFO "setting GPIO to radio!\n");
|
info_printk(core, "setting GPIO to radio!\n");
|
||||||
cx_write(MO_GP0_IO, 0x4ff);
|
cx_write(MO_GP0_IO, 0x4ff);
|
||||||
mdelay(250);
|
mdelay(250);
|
||||||
cx_write(MO_GP2_IO, 0xff);
|
cx_write(MO_GP2_IO, 0xff);
|
||||||
|
@ -2143,7 +2151,7 @@ static int cx88_xc2028_tuner_callback(void *priv, int command, int arg)
|
||||||
break;
|
break;
|
||||||
case CX88_VMUX_DVB: /* Digital TV*/
|
case CX88_VMUX_DVB: /* Digital TV*/
|
||||||
default: /* Analog TV */
|
default: /* Analog TV */
|
||||||
printk(KERN_INFO "setting GPIO to TV!\n");
|
info_printk(core, "setting GPIO to TV!\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
cx_write(MO_GP1_IO, 0x101010);
|
cx_write(MO_GP1_IO, 0x101010);
|
||||||
|
@ -2176,8 +2184,8 @@ static int cx88_xc5000_tuner_callback(void *priv, int command, int arg)
|
||||||
cx_write(MO_SRST_IO, 1);
|
cx_write(MO_SRST_IO, 1);
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_ERR
|
err_printk(core, "xc5000: unknown tuner "
|
||||||
"xc5000: unknown tuner callback command.\n");
|
"callback command.\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -2192,10 +2200,14 @@ int cx88_tuner_callback(void *priv, int command, int arg)
|
||||||
|
|
||||||
switch (core->board.tuner_type) {
|
switch (core->board.tuner_type) {
|
||||||
case TUNER_XC2028:
|
case TUNER_XC2028:
|
||||||
|
info_printk(core, "Calling XC2028/3028 callback\n");
|
||||||
return cx88_xc2028_tuner_callback(priv, command, arg);
|
return cx88_xc2028_tuner_callback(priv, command, arg);
|
||||||
case TUNER_XC5000:
|
case TUNER_XC5000:
|
||||||
|
info_printk(core, "Calling XC5000 callback\n");
|
||||||
return cx88_xc5000_tuner_callback(priv, command, arg);
|
return cx88_xc5000_tuner_callback(priv, command, arg);
|
||||||
}
|
}
|
||||||
|
err_printk(core, "Error: Calling callback for tuner %d\n",
|
||||||
|
core->board.tuner_type);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cx88_tuner_callback);
|
EXPORT_SYMBOL(cx88_tuner_callback);
|
||||||
|
@ -2208,23 +2220,25 @@ static void cx88_card_list(struct cx88_core *core, struct pci_dev *pci)
|
||||||
|
|
||||||
if (0 == pci->subsystem_vendor &&
|
if (0 == pci->subsystem_vendor &&
|
||||||
0 == pci->subsystem_device) {
|
0 == pci->subsystem_device) {
|
||||||
printk("%s: Your board has no valid PCI Subsystem ID and thus can't\n"
|
printk(KERN_ERR
|
||||||
|
"%s: Your board has no valid PCI Subsystem ID and thus can't\n"
|
||||||
"%s: be autodetected. Please pass card=<n> insmod option to\n"
|
"%s: be autodetected. Please pass card=<n> insmod option to\n"
|
||||||
"%s: workaround that. Redirect complaints to the vendor of\n"
|
"%s: workaround that. Redirect complaints to the vendor of\n"
|
||||||
"%s: the TV card. Best regards,\n"
|
"%s: the TV card. Best regards,\n"
|
||||||
"%s: -- tux\n",
|
"%s: -- tux\n",
|
||||||
core->name,core->name,core->name,core->name,core->name);
|
core->name,core->name,core->name,core->name,core->name);
|
||||||
} else {
|
} else {
|
||||||
printk("%s: Your board isn't known (yet) to the driver. You can\n"
|
printk(KERN_ERR
|
||||||
|
"%s: Your board isn't known (yet) to the driver. You can\n"
|
||||||
"%s: try to pick one of the existing card configs via\n"
|
"%s: try to pick one of the existing card configs via\n"
|
||||||
"%s: card=<n> insmod option. Updating to the latest\n"
|
"%s: card=<n> insmod option. Updating to the latest\n"
|
||||||
"%s: version might help as well.\n",
|
"%s: version might help as well.\n",
|
||||||
core->name,core->name,core->name,core->name);
|
core->name,core->name,core->name,core->name);
|
||||||
}
|
}
|
||||||
printk("%s: Here is a list of valid choices for the card=<n> insmod option:\n",
|
err_printk(core, "Here is a list of valid choices for the card=<n> "
|
||||||
core->name);
|
"insmod option:\n");
|
||||||
for (i = 0; i < ARRAY_SIZE(cx88_boards); i++)
|
for (i = 0; i < ARRAY_SIZE(cx88_boards); i++)
|
||||||
printk("%s: card=%d -> %s\n",
|
printk(KERN_ERR "%s: card=%d -> %s\n",
|
||||||
core->name, i, cx88_boards[i].name);
|
core->name, i, cx88_boards[i].name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2335,10 +2349,8 @@ static void cx88_card_setup(struct cx88_core *core)
|
||||||
for (i = 0; i < ARRAY_SIZE(buffer); i++)
|
for (i = 0; i < ARRAY_SIZE(buffer); i++)
|
||||||
if (2 != i2c_master_send(&core->i2c_client,
|
if (2 != i2c_master_send(&core->i2c_client,
|
||||||
buffer[i],2))
|
buffer[i],2))
|
||||||
printk(KERN_WARNING
|
warn_printk(core, "Unable to enable "
|
||||||
"%s: Unable to enable "
|
"tuner(%i).\n", i);
|
||||||
"tuner(%i).\n",
|
|
||||||
core->name, i);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CX88_BOARD_MSI_TVANYWHERE_MASTER:
|
case CX88_BOARD_MSI_TVANYWHERE_MASTER:
|
||||||
|
@ -2504,9 +2516,8 @@ struct cx88_core *cx88_core_create(struct pci_dev *pci, int nr)
|
||||||
|
|
||||||
memcpy(&core->board, &cx88_boards[core->boardnr], sizeof(core->board));
|
memcpy(&core->board, &cx88_boards[core->boardnr], sizeof(core->board));
|
||||||
|
|
||||||
printk(KERN_INFO "%s: subsystem: %04x:%04x, board: %s [card=%d,%s]\n",
|
info_printk(core, "subsystem: %04x:%04x, board: %s [card=%d,%s]\n",
|
||||||
core->name,pci->subsystem_vendor,
|
pci->subsystem_vendor, pci->subsystem_device, core->board.name,
|
||||||
pci->subsystem_device, core->board.name,
|
|
||||||
core->boardnr, card[core->nr] == core->boardnr ?
|
core->boardnr, card[core->nr] == core->boardnr ?
|
||||||
"insmod option" : "autodetected");
|
"insmod option" : "autodetected");
|
||||||
|
|
||||||
|
@ -2515,8 +2526,8 @@ struct cx88_core *cx88_core_create(struct pci_dev *pci, int nr)
|
||||||
if (radio[core->nr] != UNSET)
|
if (radio[core->nr] != UNSET)
|
||||||
core->board.radio_type = radio[core->nr];
|
core->board.radio_type = radio[core->nr];
|
||||||
|
|
||||||
printk(KERN_INFO "%s: TV tuner type %d, Radio tuner type %d\n",
|
info_printk(core, "TV tuner type %d, Radio tuner type %d\n",
|
||||||
core->name, core->board.tuner_type, core->board.radio_type);
|
core->board.tuner_type, core->board.radio_type);
|
||||||
|
|
||||||
/* init hardware */
|
/* init hardware */
|
||||||
cx88_reset(core);
|
cx88_reset(core);
|
||||||
|
|
Loading…
Reference in a new issue