提交 ce8591ff 编写于 作者: M Mauro Carvalho Chehab

[media] em28xx: convert it from pr_foo() to dev_foo()

Instead of using pr_foo(), use dev_foo(), with provides a
better output. As this device is a multi-interface one,
we'll set the device name to show the chipset and the driver
used.

While here, get rid of printk continuation messages.
Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
上级 39ad799a
...@@ -55,9 +55,10 @@ MODULE_PARM_DESC(debug, "activates debug info"); ...@@ -55,9 +55,10 @@ MODULE_PARM_DESC(debug, "activates debug info");
#define EM28XX_MIN_AUDIO_PACKETS 64 #define EM28XX_MIN_AUDIO_PACKETS 64
#define dprintk(fmt, arg...) do { \ #define dprintk(fmt, arg...) do { \
if (debug) \ if (debug) \
printk(KERN_DEBUG pr_fmt("audio: %s: " fmt), \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
__func__, ##arg); } while (0) "video: %s: " fmt, __func__, ## arg); \
} while (0)
static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
...@@ -91,7 +92,8 @@ static void em28xx_audio_isocirq(struct urb *urb) ...@@ -91,7 +92,8 @@ static void em28xx_audio_isocirq(struct urb *urb)
struct snd_pcm_runtime *runtime; struct snd_pcm_runtime *runtime;
if (dev->disconnected) { if (dev->disconnected) {
dprintk("device disconnected while streaming. URB status=%d.\n", urb->status); dprintk("device disconnected while streaming. URB status=%d.\n",
urb->status);
atomic_set(&dev->adev.stream_started, 0); atomic_set(&dev->adev.stream_started, 0);
return; return;
} }
...@@ -164,8 +166,9 @@ static void em28xx_audio_isocirq(struct urb *urb) ...@@ -164,8 +166,9 @@ static void em28xx_audio_isocirq(struct urb *urb)
status = usb_submit_urb(urb, GFP_ATOMIC); status = usb_submit_urb(urb, GFP_ATOMIC);
if (status < 0) if (status < 0)
pr_err("resubmit of audio urb failed (error=%i)\n", dev_err(&dev->udev->dev,
status); "resubmit of audio urb failed (error=%i)\n",
status);
return; return;
} }
...@@ -182,8 +185,9 @@ static int em28xx_init_audio_isoc(struct em28xx *dev) ...@@ -182,8 +185,9 @@ static int em28xx_init_audio_isoc(struct em28xx *dev)
errCode = usb_submit_urb(dev->adev.urb[i], GFP_ATOMIC); errCode = usb_submit_urb(dev->adev.urb[i], GFP_ATOMIC);
if (errCode) { if (errCode) {
pr_err("submit of audio urb failed (error=%i)\n", dev_err(&dev->udev->dev,
errCode); "submit of audio urb failed (error=%i)\n",
errCode);
em28xx_deinit_isoc_audio(dev); em28xx_deinit_isoc_audio(dev);
atomic_set(&dev->adev.stream_started, 0); atomic_set(&dev->adev.stream_started, 0);
return errCode; return errCode;
...@@ -197,6 +201,7 @@ static int em28xx_init_audio_isoc(struct em28xx *dev) ...@@ -197,6 +201,7 @@ static int em28xx_init_audio_isoc(struct em28xx *dev)
static int snd_pcm_alloc_vmalloc_buffer(struct snd_pcm_substream *subs, static int snd_pcm_alloc_vmalloc_buffer(struct snd_pcm_substream *subs,
size_t size) size_t size)
{ {
struct em28xx *dev = snd_pcm_substream_chip(subs);
struct snd_pcm_runtime *runtime = subs->runtime; struct snd_pcm_runtime *runtime = subs->runtime;
dprintk("Allocating vbuffer\n"); dprintk("Allocating vbuffer\n");
...@@ -254,7 +259,8 @@ static int snd_em28xx_capture_open(struct snd_pcm_substream *substream) ...@@ -254,7 +259,8 @@ static int snd_em28xx_capture_open(struct snd_pcm_substream *substream)
int nonblock, ret = 0; int nonblock, ret = 0;
if (!dev) { if (!dev) {
pr_err("BUG: em28xx can't find device struct. Can't proceed with open\n"); dev_err(&dev->udev->dev,
"BUG: em28xx can't find device struct. Can't proceed with open\n");
return -ENODEV; return -ENODEV;
} }
...@@ -317,7 +323,8 @@ static int snd_em28xx_capture_open(struct snd_pcm_substream *substream) ...@@ -317,7 +323,8 @@ static int snd_em28xx_capture_open(struct snd_pcm_substream *substream)
err: err:
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
pr_err("Error while configuring em28xx mixer\n"); dev_err(&dev->udev->dev,
"Error while configuring em28xx mixer\n");
return ret; return ret;
} }
...@@ -755,7 +762,7 @@ static int em28xx_audio_urb_init(struct em28xx *dev) ...@@ -755,7 +762,7 @@ static int em28xx_audio_urb_init(struct em28xx *dev)
intf = usb_ifnum_to_if(dev->udev, dev->ifnum); intf = usb_ifnum_to_if(dev->udev, dev->ifnum);
if (intf->num_altsetting <= alt) { if (intf->num_altsetting <= alt) {
pr_err("alt %d doesn't exist on interface %d\n", dev_err(&dev->udev->dev, "alt %d doesn't exist on interface %d\n",
dev->ifnum, alt); dev->ifnum, alt);
return -ENODEV; return -ENODEV;
} }
...@@ -771,18 +778,17 @@ static int em28xx_audio_urb_init(struct em28xx *dev) ...@@ -771,18 +778,17 @@ static int em28xx_audio_urb_init(struct em28xx *dev)
} }
if (!ep) { if (!ep) {
pr_err("Couldn't find an audio endpoint"); dev_err(&dev->udev->dev, "Couldn't find an audio endpoint");
return -ENODEV; return -ENODEV;
} }
ep_size = em28xx_audio_ep_packet_size(dev->udev, ep); ep_size = em28xx_audio_ep_packet_size(dev->udev, ep);
interval = 1 << (ep->bInterval - 1); interval = 1 << (ep->bInterval - 1);
pr_info("Endpoint 0x%02x %s on intf %d alt %d interval = %d, size %d\n", dev_info(&dev->udev->dev,
EM28XX_EP_AUDIO, usb_speed_string(dev->udev->speed), "Endpoint 0x%02x %s on intf %d alt %d interval = %d, size %d\n",
dev->ifnum, alt, EM28XX_EP_AUDIO, usb_speed_string(dev->udev->speed),
interval, dev->ifnum, alt, interval, ep_size);
ep_size);
/* Calculate the number and size of URBs to better fit the audio samples */ /* Calculate the number and size of URBs to better fit the audio samples */
...@@ -819,8 +825,9 @@ static int em28xx_audio_urb_init(struct em28xx *dev) ...@@ -819,8 +825,9 @@ static int em28xx_audio_urb_init(struct em28xx *dev)
if (urb_size > ep_size * npackets) if (urb_size > ep_size * npackets)
npackets = DIV_ROUND_UP(urb_size, ep_size); npackets = DIV_ROUND_UP(urb_size, ep_size);
pr_info("Number of URBs: %d, with %d packets and %d size\n", dev_info(&dev->udev->dev,
num_urb, npackets, urb_size); "Number of URBs: %d, with %d packets and %d size\n",
num_urb, npackets, urb_size);
/* Estimate the bytes per period */ /* Estimate the bytes per period */
dev->adev.period = urb_size * npackets; dev->adev.period = urb_size * npackets;
...@@ -857,7 +864,8 @@ static int em28xx_audio_urb_init(struct em28xx *dev) ...@@ -857,7 +864,8 @@ static int em28xx_audio_urb_init(struct em28xx *dev)
buf = usb_alloc_coherent(dev->udev, npackets * ep_size, GFP_ATOMIC, buf = usb_alloc_coherent(dev->udev, npackets * ep_size, GFP_ATOMIC,
&urb->transfer_dma); &urb->transfer_dma);
if (!buf) { if (!buf) {
pr_err("usb_alloc_coherent failed!\n"); dev_err(&dev->udev->dev,
"usb_alloc_coherent failed!\n");
em28xx_audio_free_urb(dev); em28xx_audio_free_urb(dev);
return -ENOMEM; return -ENOMEM;
} }
...@@ -897,12 +905,14 @@ static int em28xx_audio_init(struct em28xx *dev) ...@@ -897,12 +905,14 @@ static int em28xx_audio_init(struct em28xx *dev)
return 0; return 0;
} }
pr_info("Binding audio extension\n"); dev_info(&dev->udev->dev, "Binding audio extension\n");
kref_get(&dev->ref); kref_get(&dev->ref);
pr_info("em28xx-audio.c: Copyright (C) 2006 Markus Rechberger\n"); dev_info(&dev->udev->dev,
pr_info("em28xx-audio.c: Copyright (C) 2007-2016 Mauro Carvalho Chehab\n"); "em28xx-audio.c: Copyright (C) 2006 Markus Rechberger\n");
dev_info(&dev->udev->dev,
"em28xx-audio.c: Copyright (C) 2007-2016 Mauro Carvalho Chehab\n");
err = snd_card_new(&dev->udev->dev, index[devnr], "Em28xx Audio", err = snd_card_new(&dev->udev->dev, index[devnr], "Em28xx Audio",
THIS_MODULE, 0, &card); THIS_MODULE, 0, &card);
...@@ -952,7 +962,7 @@ static int em28xx_audio_init(struct em28xx *dev) ...@@ -952,7 +962,7 @@ static int em28xx_audio_init(struct em28xx *dev)
if (err < 0) if (err < 0)
goto urb_free; goto urb_free;
pr_info("Audio extension successfully initialized\n"); dev_info(&dev->udev->dev, "Audio extension successfully initialized\n");
return 0; return 0;
urb_free: urb_free:
...@@ -977,7 +987,7 @@ static int em28xx_audio_fini(struct em28xx *dev) ...@@ -977,7 +987,7 @@ static int em28xx_audio_fini(struct em28xx *dev)
return 0; return 0;
} }
pr_info("Closing audio extension\n"); dev_info(&dev->udev->dev, "Closing audio extension\n");
if (dev->adev.sndcard) { if (dev->adev.sndcard) {
snd_card_disconnect(dev->adev.sndcard); snd_card_disconnect(dev->adev.sndcard);
...@@ -1001,7 +1011,7 @@ static int em28xx_audio_suspend(struct em28xx *dev) ...@@ -1001,7 +1011,7 @@ static int em28xx_audio_suspend(struct em28xx *dev)
if (dev->usb_audio_type != EM28XX_USB_AUDIO_VENDOR) if (dev->usb_audio_type != EM28XX_USB_AUDIO_VENDOR)
return 0; return 0;
pr_info("Suspending audio extension\n"); dev_info(&dev->udev->dev, "Suspending audio extension\n");
em28xx_deinit_isoc_audio(dev); em28xx_deinit_isoc_audio(dev);
atomic_set(&dev->adev.stream_started, 0); atomic_set(&dev->adev.stream_started, 0);
return 0; return 0;
...@@ -1015,7 +1025,7 @@ static int em28xx_audio_resume(struct em28xx *dev) ...@@ -1015,7 +1025,7 @@ static int em28xx_audio_resume(struct em28xx *dev)
if (dev->usb_audio_type != EM28XX_USB_AUDIO_VENDOR) if (dev->usb_audio_type != EM28XX_USB_AUDIO_VENDOR)
return 0; return 0;
pr_info("Resuming audio extension\n"); dev_info(&dev->udev->dev, "Resuming audio extension\n");
/* Nothing to do other than schedule_work() ?? */ /* Nothing to do other than schedule_work() ?? */
schedule_work(&dev->adev.wq_trigger); schedule_work(&dev->adev.wq_trigger);
return 0; return 0;
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#include "em28xx.h" #include "em28xx.h"
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/usb.h>
#include <media/soc_camera.h> #include <media/soc_camera.h>
#include <media/i2c/mt9v011.h> #include <media/i2c/mt9v011.h>
#include <media/v4l2-clk.h> #include <media/v4l2-clk.h>
...@@ -120,14 +121,16 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev) ...@@ -120,14 +121,16 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev)
ret = i2c_master_send(&client, &reg, 1); ret = i2c_master_send(&client, &reg, 1);
if (ret < 0) { if (ret < 0) {
if (ret != -ENXIO) if (ret != -ENXIO)
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
"couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret); client.addr << 1, ret);
continue; continue;
} }
ret = i2c_master_recv(&client, (u8 *)&id_be, 2); ret = i2c_master_recv(&client, (u8 *)&id_be, 2);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
id = be16_to_cpu(id_be); id = be16_to_cpu(id_be);
...@@ -135,14 +138,16 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev) ...@@ -135,14 +138,16 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev)
reg = 0xff; reg = 0xff;
ret = i2c_master_send(&client, &reg, 1); ret = i2c_master_send(&client, &reg, 1);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
ret = i2c_master_recv(&client, (u8 *)&id_be, 2); ret = i2c_master_recv(&client, (u8 *)&id_be, 2);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
/* Validate chip ID to be sure we have a Micron device */ /* Validate chip ID to be sure we have a Micron device */
...@@ -180,14 +185,17 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev) ...@@ -180,14 +185,17 @@ static int em28xx_probe_sensor_micron(struct em28xx *dev)
dev->em28xx_sensor = EM28XX_MT9M001; dev->em28xx_sensor = EM28XX_MT9M001;
break; break;
default: default:
pr_info("unknown Micron sensor detected: 0x%04x\n", id); dev_info(&dev->udev->dev,
"unknown Micron sensor detected: 0x%04x\n", id);
return 0; return 0;
} }
if (dev->em28xx_sensor == EM28XX_NOSENSOR) if (dev->em28xx_sensor == EM28XX_NOSENSOR)
pr_info("unsupported sensor detected: %s\n", name); dev_info(&dev->udev->dev,
"unsupported sensor detected: %s\n", name);
else else
pr_info("sensor %s detected\n", name); dev_info(&dev->udev->dev,
"sensor %s detected\n", name);
dev->i2c_client[dev->def_i2c_bus].addr = client.addr; dev->i2c_client[dev->def_i2c_bus].addr = client.addr;
return 0; return 0;
...@@ -217,16 +225,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev) ...@@ -217,16 +225,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev)
ret = i2c_smbus_read_byte_data(&client, reg); ret = i2c_smbus_read_byte_data(&client, reg);
if (ret < 0) { if (ret < 0) {
if (ret != -ENXIO) if (ret != -ENXIO)
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
id = ret << 8; id = ret << 8;
reg = 0x1d; reg = 0x1d;
ret = i2c_smbus_read_byte_data(&client, reg); ret = i2c_smbus_read_byte_data(&client, reg);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
id += ret; id += ret;
...@@ -237,16 +247,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev) ...@@ -237,16 +247,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev)
reg = 0x0a; reg = 0x0a;
ret = i2c_smbus_read_byte_data(&client, reg); ret = i2c_smbus_read_byte_data(&client, reg);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
id = ret << 8; id = ret << 8;
reg = 0x0b; reg = 0x0b;
ret = i2c_smbus_read_byte_data(&client, reg); ret = i2c_smbus_read_byte_data(&client, reg);
if (ret < 0) { if (ret < 0) {
pr_err("couldn't read from i2c device 0x%02x: error %i\n", dev_err(&dev->udev->dev,
client.addr << 1, ret); "couldn't read from i2c device 0x%02x: error %i\n",
client.addr << 1, ret);
continue; continue;
} }
id += ret; id += ret;
...@@ -284,15 +296,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev) ...@@ -284,15 +296,18 @@ static int em28xx_probe_sensor_omnivision(struct em28xx *dev)
name = "OV9655"; name = "OV9655";
break; break;
default: default:
pr_info("unknown OmniVision sensor detected: 0x%04x\n", dev_info(&dev->udev->dev,
"unknown OmniVision sensor detected: 0x%04x\n",
id); id);
return 0; return 0;
} }
if (dev->em28xx_sensor == EM28XX_NOSENSOR) if (dev->em28xx_sensor == EM28XX_NOSENSOR)
pr_info("unsupported sensor detected: %s\n", name); dev_info(&dev->udev->dev,
"unsupported sensor detected: %s\n", name);
else else
pr_info("sensor %s detected\n", name); dev_info(&dev->udev->dev,
"sensor %s detected\n", name);
dev->i2c_client[dev->def_i2c_bus].addr = client.addr; dev->i2c_client[dev->def_i2c_bus].addr = client.addr;
return 0; return 0;
...@@ -316,7 +331,8 @@ int em28xx_detect_sensor(struct em28xx *dev) ...@@ -316,7 +331,8 @@ int em28xx_detect_sensor(struct em28xx *dev)
*/ */
if (dev->em28xx_sensor == EM28XX_NOSENSOR && ret < 0) { if (dev->em28xx_sensor == EM28XX_NOSENSOR && ret < 0) {
pr_info("No sensor detected\n"); dev_info(&dev->udev->dev,
"No sensor detected\n");
return -ENODEV; return -ENODEV;
} }
......
...@@ -2677,7 +2677,7 @@ static int em28xx_wait_until_ac97_features_equals(struct em28xx *dev, ...@@ -2677,7 +2677,7 @@ static int em28xx_wait_until_ac97_features_equals(struct em28xx *dev,
msleep(50); msleep(50);
} }
pr_warn("AC97 registers access is not reliable !\n"); dev_warn(&dev->udev->dev, "AC97 registers access is not reliable !\n");
return -ETIMEDOUT; return -ETIMEDOUT;
} }
...@@ -2831,12 +2831,13 @@ static int em28xx_hint_board(struct em28xx *dev) ...@@ -2831,12 +2831,13 @@ static int em28xx_hint_board(struct em28xx *dev)
dev->model = em28xx_eeprom_hash[i].model; dev->model = em28xx_eeprom_hash[i].model;
dev->tuner_type = em28xx_eeprom_hash[i].tuner; dev->tuner_type = em28xx_eeprom_hash[i].tuner;
pr_err("Your board has no unique USB ID.\n"); dev_err(&dev->udev->dev,
pr_err("A hint were successfully done, based on eeprom hash.\n"); "Your board has no unique USB ID.\n"
pr_err("This method is not 100%% failproof.\n"); "A hint were successfully done, based on eeprom hash.\n"
pr_err("If the board were missdetected, please email this log to:\n"); "This method is not 100%% failproof.\n"
pr_err("\tV4L Mailing List <linux-media@vger.kernel.org>\n"); "If the board were missdetected, please email this log to:\n"
pr_err("Board detected as %s\n", "\tV4L Mailing List <linux-media@vger.kernel.org>\n"
"Board detected as %s\n",
em28xx_boards[dev->model].name); em28xx_boards[dev->model].name);
return 0; return 0;
...@@ -2860,28 +2861,33 @@ static int em28xx_hint_board(struct em28xx *dev) ...@@ -2860,28 +2861,33 @@ static int em28xx_hint_board(struct em28xx *dev)
if (dev->i2c_hash == em28xx_i2c_hash[i].hash) { if (dev->i2c_hash == em28xx_i2c_hash[i].hash) {
dev->model = em28xx_i2c_hash[i].model; dev->model = em28xx_i2c_hash[i].model;
dev->tuner_type = em28xx_i2c_hash[i].tuner; dev->tuner_type = em28xx_i2c_hash[i].tuner;
pr_err("Your board has no unique USB ID.\n"); dev_err(&dev->udev->dev,
pr_err("A hint were successfully done, based on i2c devicelist hash.\n"); "Your board has no unique USB ID.\n"
pr_err("This method is not 100%% failproof.\n"); "A hint were successfully done, based on i2c devicelist hash.\n"
pr_err("If the board were missdetected, please email this log to:\n"); "This method is not 100%% failproof.\n"
pr_err("\tV4L Mailing List <linux-media@vger.kernel.org>\n"); "If the board were missdetected, please email this log to:\n"
pr_err("Board detected as %s\n", "\tV4L Mailing List <linux-media@vger.kernel.org>\n"
em28xx_boards[dev->model].name); "Board detected as %s\n",
em28xx_boards[dev->model].name);
return 0; return 0;
} }
} }
pr_err("Your board has no unique USB ID and thus need a hint to be detected.\n"); dev_err(&dev->udev->dev,
pr_err("You may try to use card=<n> insmod option to workaround that.\n"); "Your board has no unique USB ID and thus need a hint to be detected.\n"
pr_err("Please send an email with this log to:\n"); "You may try to use card=<n> insmod option to workaround that.\n"
pr_err("\tV4L Mailing List <linux-media@vger.kernel.org>\n"); "Please send an email with this log to:\n"
pr_err("Board eeprom hash is 0x%08lx\n", dev->hash); "\tV4L Mailing List <linux-media@vger.kernel.org>\n"
pr_err("Board i2c devicelist hash is 0x%08lx\n", dev->i2c_hash); "Board eeprom hash is 0x%08lx\n"
"Board i2c devicelist hash is 0x%08lx\n",
pr_err("Here is a list of valid choices for the card=<n> insmod option:\n"); dev->hash, dev->i2c_hash);
dev_err(&dev->udev->dev,
"Here is a list of valid choices for the card=<n> insmod option:\n");
for (i = 0; i < em28xx_bcount; i++) { for (i = 0; i < em28xx_bcount; i++) {
pr_err(" card=%d -> %s\n", i, em28xx_boards[i].name); dev_err(&dev->udev->dev,
" card=%d -> %s\n", i, em28xx_boards[i].name);
} }
return -1; return -1;
} }
...@@ -2915,7 +2921,7 @@ static void em28xx_card_setup(struct em28xx *dev) ...@@ -2915,7 +2921,7 @@ static void em28xx_card_setup(struct em28xx *dev)
* hash identities which has not been determined as yet. * hash identities which has not been determined as yet.
*/ */
if (em28xx_hint_board(dev) < 0) if (em28xx_hint_board(dev) < 0)
pr_err("Board not discovered\n"); dev_err(&dev->udev->dev, "Board not discovered\n");
else { else {
em28xx_set_model(dev); em28xx_set_model(dev);
em28xx_pre_card_setup(dev); em28xx_pre_card_setup(dev);
...@@ -2925,7 +2931,7 @@ static void em28xx_card_setup(struct em28xx *dev) ...@@ -2925,7 +2931,7 @@ static void em28xx_card_setup(struct em28xx *dev)
em28xx_set_model(dev); em28xx_set_model(dev);
} }
pr_info("Identified as %s (card=%d)\n", dev_info(&dev->udev->dev, "Identified as %s (card=%d)\n",
dev->board.name, dev->model); dev->board.name, dev->model);
dev->tuner_type = em28xx_boards[dev->model].tuner_type; dev->tuner_type = em28xx_boards[dev->model].tuner_type;
...@@ -3024,10 +3030,11 @@ static void em28xx_card_setup(struct em28xx *dev) ...@@ -3024,10 +3030,11 @@ static void em28xx_card_setup(struct em28xx *dev)
} }
if (dev->board.valid == EM28XX_BOARD_NOT_VALIDATED) { if (dev->board.valid == EM28XX_BOARD_NOT_VALIDATED) {
pr_err("\n\n"); dev_err(&dev->udev->dev,
pr_err("The support for this board weren't valid yet.\n"); "\n\n"
pr_err("Please send a report of having this working\n"); "The support for this board weren't valid yet.\n"
pr_err("not to V4L mailing list (and/or to other addresses)\n\n"); "Please send a report of having this working\n"
"not to V4L mailing list (and/or to other addresses)\n\n");
} }
/* Free eeprom data memory */ /* Free eeprom data memory */
...@@ -3154,7 +3161,7 @@ static int em28xx_media_device_init(struct em28xx *dev, ...@@ -3154,7 +3161,7 @@ static int em28xx_media_device_init(struct em28xx *dev,
else if (udev->manufacturer) else if (udev->manufacturer)
media_device_usb_init(mdev, udev, udev->manufacturer); media_device_usb_init(mdev, udev, udev->manufacturer);
else else
media_device_usb_init(mdev, udev, dev->name); media_device_usb_init(mdev, udev, dev_name(&dev->udev->dev));
dev->media_dev = mdev; dev->media_dev = mdev;
#endif #endif
...@@ -3210,7 +3217,7 @@ void em28xx_free_device(struct kref *ref) ...@@ -3210,7 +3217,7 @@ void em28xx_free_device(struct kref *ref)
{ {
struct em28xx *dev = kref_to_dev(ref); struct em28xx *dev = kref_to_dev(ref);
pr_info("Freeing device\n"); dev_info(&dev->udev->dev, "Freeing device\n");
if (!dev->disconnected) if (!dev->disconnected)
em28xx_release_resources(dev); em28xx_release_resources(dev);
...@@ -3315,19 +3322,18 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev, ...@@ -3315,19 +3322,18 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev,
dev->wait_after_write = 0; dev->wait_after_write = 0;
dev->eeprom_addrwidth_16bit = 1; dev->eeprom_addrwidth_16bit = 1;
break; break;
default:
pr_info("unknown em28xx chip ID (%d)\n", dev->chip_id);
} }
} }
if (chip_name != default_chip_name) dev_set_name(&dev->udev->dev, "%d-%s: %s#%d",
pr_info("chip ID is %s\n", chip_name); dev->udev->bus->busnum, dev->udev->devpath,
chip_name, dev->devno);
/* if (chip_name == default_chip_name)
* For em2820/em2710, the name may change latter, after checking dev_info(&dev->udev->dev,
* if the device has a sensor (so, it is em2710) or not. "unknown em28xx chip ID (%d)\n", dev->chip_id);
*/ else
snprintf(dev->name, sizeof(dev->name), "%s #%d", chip_name, dev->devno); dev_info(&dev->udev->dev, "chip ID is %s\n", chip_name);
em28xx_media_device_init(dev, udev); em28xx_media_device_init(dev, udev);
...@@ -3346,7 +3352,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev, ...@@ -3346,7 +3352,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev,
/* Resets I2C speed */ /* Resets I2C speed */
retval = em28xx_write_reg(dev, EM28XX_R06_I2C_CLK, dev->board.i2c_speed); retval = em28xx_write_reg(dev, EM28XX_R06_I2C_CLK, dev->board.i2c_speed);
if (retval < 0) { if (retval < 0) {
pr_err("%s: em28xx_write_reg failed! retval [%d]\n", dev_err(&dev->udev->dev,
"%s: em28xx_write_reg failed! retval [%d]\n",
__func__, retval); __func__, retval);
return retval; return retval;
} }
...@@ -3360,7 +3367,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev, ...@@ -3360,7 +3367,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev,
else else
retval = em28xx_i2c_register(dev, 0, EM28XX_I2C_ALGO_EM28XX); retval = em28xx_i2c_register(dev, 0, EM28XX_I2C_ALGO_EM28XX);
if (retval < 0) { if (retval < 0) {
pr_err("%s: em28xx_i2c_register bus 0 - error [%d]!\n", dev_err(&dev->udev->dev,
"%s: em28xx_i2c_register bus 0 - error [%d]!\n",
__func__, retval); __func__, retval);
return retval; return retval;
} }
...@@ -3374,7 +3382,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev, ...@@ -3374,7 +3382,8 @@ static int em28xx_init_dev(struct em28xx *dev, struct usb_device *udev,
retval = em28xx_i2c_register(dev, 1, retval = em28xx_i2c_register(dev, 1,
EM28XX_I2C_ALGO_EM28XX); EM28XX_I2C_ALGO_EM28XX);
if (retval < 0) { if (retval < 0) {
pr_err("%s: em28xx_i2c_register bus 1 - error [%d]!\n", dev_err(&dev->udev->dev,
"%s: em28xx_i2c_register bus 1 - error [%d]!\n",
__func__, retval); __func__, retval);
em28xx_i2c_unregister(dev, 0); em28xx_i2c_unregister(dev, 0);
...@@ -3414,7 +3423,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3414,7 +3423,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
nr = find_first_zero_bit(em28xx_devused, EM28XX_MAXBOARDS); nr = find_first_zero_bit(em28xx_devused, EM28XX_MAXBOARDS);
if (nr >= EM28XX_MAXBOARDS) { if (nr >= EM28XX_MAXBOARDS) {
/* No free device slots */ /* No free device slots */
pr_err("Driver supports up to %i em28xx boards.\n", dev_err(&udev->dev,
"Driver supports up to %i em28xx boards.\n",
EM28XX_MAXBOARDS); EM28XX_MAXBOARDS);
retval = -ENOMEM; retval = -ENOMEM;
goto err_no_slot; goto err_no_slot;
...@@ -3423,7 +3433,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3423,7 +3433,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
/* Don't register audio interfaces */ /* Don't register audio interfaces */
if (interface->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) { if (interface->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) {
pr_err("audio device (%04x:%04x): interface %i, class %i\n", dev_err(&udev->dev,
"audio device (%04x:%04x): interface %i, class %i\n",
le16_to_cpu(udev->descriptor.idVendor), le16_to_cpu(udev->descriptor.idVendor),
le16_to_cpu(udev->descriptor.idProduct), le16_to_cpu(udev->descriptor.idProduct),
ifnum, ifnum,
...@@ -3483,7 +3494,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3483,7 +3494,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
if (usb_endpoint_xfer_isoc(e)) { if (usb_endpoint_xfer_isoc(e)) {
has_vendor_audio = true; has_vendor_audio = true;
} else { } else {
pr_err("error: skipping audio endpoint 0x83, because it uses bulk transfers !\n"); dev_err(&udev->dev,
"error: skipping audio endpoint 0x83, because it uses bulk transfers !\n");
} }
break; break;
case 0x84: case 0x84:
...@@ -3556,7 +3568,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3556,7 +3568,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
speed = "unknown"; speed = "unknown";
} }
pr_info("New device %s %s @ %s Mbps (%04x:%04x, interface %d, class %d)\n", dev_err(&udev->dev,
"New device %s %s @ %s Mbps (%04x:%04x, interface %d, class %d)\n",
udev->manufacturer ? udev->manufacturer : "", udev->manufacturer ? udev->manufacturer : "",
udev->product ? udev->product : "", udev->product ? udev->product : "",
speed, speed,
...@@ -3571,8 +3584,9 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3571,8 +3584,9 @@ static int em28xx_usb_probe(struct usb_interface *interface,
* not enough even for most Digital TV streams. * not enough even for most Digital TV streams.
*/ */
if (udev->speed != USB_SPEED_HIGH && disable_usb_speed_check == 0) { if (udev->speed != USB_SPEED_HIGH && disable_usb_speed_check == 0) {
pr_err("Device initialization failed.\n"); dev_err(&udev->dev, "Device initialization failed.\n");
pr_err("Device must be connected to a high-speed USB 2.0 port.\n"); dev_err(&udev->dev,
"Device must be connected to a high-speed USB 2.0 port.\n");
retval = -ENODEV; retval = -ENODEV;
goto err_free; goto err_free;
} }
...@@ -3585,7 +3599,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3585,7 +3599,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
dev->ifnum = ifnum; dev->ifnum = ifnum;
if (has_vendor_audio) { if (has_vendor_audio) {
pr_info("Audio interface %i found (Vendor Class)\n", ifnum); dev_err(&udev->dev,
"Audio interface %i found (Vendor Class)\n", ifnum);
dev->usb_audio_type = EM28XX_USB_AUDIO_VENDOR; dev->usb_audio_type = EM28XX_USB_AUDIO_VENDOR;
} }
/* Checks if audio is provided by a USB Audio Class interface */ /* Checks if audio is provided by a USB Audio Class interface */
...@@ -3594,7 +3609,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3594,7 +3609,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
if (uif->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) { if (uif->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) {
if (has_vendor_audio) if (has_vendor_audio)
pr_err("em28xx: device seems to have vendor AND usb audio class interfaces !\n" dev_err(&udev->dev,
"em28xx: device seems to have vendor AND usb audio class interfaces !\n"
"\t\tThe vendor interface will be ignored. Please contact the developers <linux-media@vger.kernel.org>\n"); "\t\tThe vendor interface will be ignored. Please contact the developers <linux-media@vger.kernel.org>\n");
dev->usb_audio_type = EM28XX_USB_AUDIO_CLASS; dev->usb_audio_type = EM28XX_USB_AUDIO_CLASS;
break; break;
...@@ -3602,12 +3618,12 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3602,12 +3618,12 @@ static int em28xx_usb_probe(struct usb_interface *interface,
} }
if (has_video) if (has_video)
pr_info("Video interface %i found:%s%s\n", dev_err(&udev->dev, "Video interface %i found:%s%s\n",
ifnum, ifnum,
dev->analog_ep_bulk ? " bulk" : "", dev->analog_ep_bulk ? " bulk" : "",
dev->analog_ep_isoc ? " isoc" : ""); dev->analog_ep_isoc ? " isoc" : "");
if (has_dvb) if (has_dvb)
pr_info("DVB interface %i found:%s%s\n", dev_err(&udev->dev, "DVB interface %i found:%s%s\n",
ifnum, ifnum,
dev->dvb_ep_bulk ? " bulk" : "", dev->dvb_ep_bulk ? " bulk" : "",
dev->dvb_ep_isoc ? " isoc" : ""); dev->dvb_ep_isoc ? " isoc" : "");
...@@ -3639,7 +3655,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3639,7 +3655,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
/* Disable V4L2 if the device doesn't have a decoder */ /* Disable V4L2 if the device doesn't have a decoder */
if (has_video && if (has_video &&
dev->board.decoder == EM28XX_NODECODER && !dev->board.is_webcam) { dev->board.decoder == EM28XX_NODECODER && !dev->board.is_webcam) {
pr_err("Currently, V4L2 is not supported on this model\n"); dev_err(&udev->dev,
"Currently, V4L2 is not supported on this model\n");
has_video = false; has_video = false;
dev->has_video = false; dev->has_video = false;
} }
...@@ -3648,13 +3665,13 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -3648,13 +3665,13 @@ static int em28xx_usb_probe(struct usb_interface *interface,
if (has_video) { if (has_video) {
if (!dev->analog_ep_isoc || (try_bulk && dev->analog_ep_bulk)) if (!dev->analog_ep_isoc || (try_bulk && dev->analog_ep_bulk))
dev->analog_xfer_bulk = 1; dev->analog_xfer_bulk = 1;
pr_info("analog set to %s mode.\n", dev_err(&udev->dev, "analog set to %s mode.\n",
dev->analog_xfer_bulk ? "bulk" : "isoc"); dev->analog_xfer_bulk ? "bulk" : "isoc");
} }
if (has_dvb) { if (has_dvb) {
if (!dev->dvb_ep_isoc || (try_bulk && dev->dvb_ep_bulk)) if (!dev->dvb_ep_isoc || (try_bulk && dev->dvb_ep_bulk))
dev->dvb_xfer_bulk = 1; dev->dvb_xfer_bulk = 1;
pr_info("dvb set to %s mode.\n", dev_err(&udev->dev, "dvb set to %s mode.\n",
dev->dvb_xfer_bulk ? "bulk" : "isoc"); dev->dvb_xfer_bulk ? "bulk" : "isoc");
} }
...@@ -3702,7 +3719,7 @@ static void em28xx_usb_disconnect(struct usb_interface *interface) ...@@ -3702,7 +3719,7 @@ static void em28xx_usb_disconnect(struct usb_interface *interface)
dev->disconnected = 1; dev->disconnected = 1;
pr_info("Disconnecting %s\n", dev->name); dev_err(&dev->udev->dev, "Disconnecting\n");
flush_request_modules(dev); flush_request_modules(dev);
......
...@@ -50,25 +50,29 @@ static unsigned int core_debug; ...@@ -50,25 +50,29 @@ static unsigned int core_debug;
module_param(core_debug, int, 0644); module_param(core_debug, int, 0644);
MODULE_PARM_DESC(core_debug, "enable debug messages [core and isoc]"); MODULE_PARM_DESC(core_debug, "enable debug messages [core and isoc]");
#define em28xx_coredbg(fmt, arg...) do {\ #define em28xx_coredbg(fmt, arg...) do { \
if (core_debug) \ if (core_debug) \
printk(KERN_DEBUG pr_fmt("core: %s: " fmt), \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
__func__, ##arg); } while (0) "core: %s: " fmt, __func__, ## arg); \
} while (0)
static unsigned int reg_debug; static unsigned int reg_debug;
module_param(reg_debug, int, 0644); module_param(reg_debug, int, 0644);
MODULE_PARM_DESC(reg_debug, "enable debug messages [URB reg]"); MODULE_PARM_DESC(reg_debug, "enable debug messages [URB reg]");
#define em28xx_regdbg(fmt, arg...) do {\
if (reg_debug) \
printk(KERN_DEBUG pr_fmt("reg: %s: " fmt), \
__func__, ##arg); } while (0)
/* FIXME */ #define em28xx_regdbg(fmt, arg...) do { \
#define em28xx_isocdbg(fmt, arg...) do {\ if (reg_debug) \
if (core_debug) \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
printk(KERN_DEBUG pr_fmt("isoc: %s: " fmt), \ "reg: %s: " fmt, __func__, ## arg); \
__func__, ##arg); } while (0) } while (0)
/* FIXME: don't abuse core_debug */
#define em28xx_isocdbg(fmt, arg...) do { \
if (core_debug) \
dev_printk(KERN_DEBUG, &dev->udev->dev, \
"core: %s: " fmt, __func__, ## arg); \
} while (0)
/* /*
* em28xx_read_reg_req() * em28xx_read_reg_req()
...@@ -86,23 +90,22 @@ int em28xx_read_reg_req_len(struct em28xx *dev, u8 req, u16 reg, ...@@ -86,23 +90,22 @@ int em28xx_read_reg_req_len(struct em28xx *dev, u8 req, u16 reg,
if (len > URB_MAX_CTRL_SIZE) if (len > URB_MAX_CTRL_SIZE)
return -EINVAL; return -EINVAL;
if (reg_debug) { em28xx_regdbg("(pipe 0x%08x): IN: %02x %02x %02x %02x %02x %02x %02x %02x ",
printk(KERN_DEBUG pipe, USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
"(pipe 0x%08x): IN: %02x %02x %02x %02x %02x %02x %02x %02x ", req, 0, 0,
pipe, reg & 0xff, reg >> 8,
USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE, len & 0xff, len >> 8);
req, 0, 0,
reg & 0xff, reg >> 8,
len & 0xff, len >> 8);
}
mutex_lock(&dev->ctrl_urb_lock); mutex_lock(&dev->ctrl_urb_lock);
ret = usb_control_msg(dev->udev, pipe, req, ret = usb_control_msg(dev->udev, pipe, req,
USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE, USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
0x0000, reg, dev->urb_buf, len, HZ); 0x0000, reg, dev->urb_buf, len, HZ);
if (ret < 0) { if (ret < 0) {
if (reg_debug) em28xx_regdbg("(pipe 0x%08x): IN: %02x %02x %02x %02x %02x %02x %02x %02x failed\n",
pr_cont(" failed!\n"); pipe, USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
req, 0, 0,
reg & 0xff, reg >> 8,
len & 0xff, len >> 8);
mutex_unlock(&dev->ctrl_urb_lock); mutex_unlock(&dev->ctrl_urb_lock);
return usb_translate_errors(ret); return usb_translate_errors(ret);
} }
...@@ -112,14 +115,11 @@ int em28xx_read_reg_req_len(struct em28xx *dev, u8 req, u16 reg, ...@@ -112,14 +115,11 @@ int em28xx_read_reg_req_len(struct em28xx *dev, u8 req, u16 reg,
mutex_unlock(&dev->ctrl_urb_lock); mutex_unlock(&dev->ctrl_urb_lock);
if (reg_debug) { em28xx_regdbg("(pipe 0x%08x): IN: %02x %02x %02x %02x %02x %02x %02x %02x failed <<< %*ph\n",
int byte; pipe, USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
req, 0, 0,
pr_cont("<<<"); reg & 0xff, reg >> 8,
for (byte = 0; byte < len; byte++) len & 0xff, len >> 8, len, buf);
pr_cont(" %02x", (unsigned char)buf[byte]);
pr_cont("\n");
}
return ret; return ret;
} }
...@@ -162,21 +162,12 @@ int em28xx_write_regs_req(struct em28xx *dev, u8 req, u16 reg, char *buf, ...@@ -162,21 +162,12 @@ int em28xx_write_regs_req(struct em28xx *dev, u8 req, u16 reg, char *buf,
if ((len < 1) || (len > URB_MAX_CTRL_SIZE)) if ((len < 1) || (len > URB_MAX_CTRL_SIZE))
return -EINVAL; return -EINVAL;
if (reg_debug) { em28xx_regdbg("(pipe 0x%08x): OUT: %02x %02x %02x %02x %02x %02x %02x %02x >>> %*ph\n",
int byte; pipe,
USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
printk(KERN_DEBUG req, 0, 0,
"(pipe 0x%08x): OUT: %02x %02x %02x %02x %02x %02x %02x %02x >>>", reg & 0xff, reg >> 8,
pipe, len & 0xff, len >> 8, len, buf);
USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
req, 0, 0,
reg & 0xff, reg >> 8,
len & 0xff, len >> 8);
for (byte = 0; byte < len; byte++)
pr_cont(" %02x", (unsigned char)buf[byte]);
pr_cont("\n");
}
mutex_lock(&dev->ctrl_urb_lock); mutex_lock(&dev->ctrl_urb_lock);
memcpy(dev->urb_buf, buf, len); memcpy(dev->urb_buf, buf, len);
...@@ -267,7 +258,8 @@ static int em28xx_is_ac97_ready(struct em28xx *dev) ...@@ -267,7 +258,8 @@ static int em28xx_is_ac97_ready(struct em28xx *dev)
msleep(5); msleep(5);
} }
pr_warn("AC97 command still being executed: not handled properly!\n"); dev_warn(&dev->udev->dev,
"AC97 command still being executed: not handled properly!\n");
return -EBUSY; return -EBUSY;
} }
...@@ -360,8 +352,9 @@ static int set_ac97_input(struct em28xx *dev) ...@@ -360,8 +352,9 @@ static int set_ac97_input(struct em28xx *dev)
ret = em28xx_write_ac97(dev, inputs[i].reg, 0x8000); ret = em28xx_write_ac97(dev, inputs[i].reg, 0x8000);
if (ret < 0) if (ret < 0)
pr_warn("couldn't setup AC97 register %d\n", dev_warn(&dev->udev->dev,
inputs[i].reg); "couldn't setup AC97 register %d\n",
inputs[i].reg);
} }
return 0; return 0;
} }
...@@ -444,8 +437,9 @@ int em28xx_audio_analog_set(struct em28xx *dev) ...@@ -444,8 +437,9 @@ int em28xx_audio_analog_set(struct em28xx *dev)
for (i = 0; i < ARRAY_SIZE(outputs); i++) { for (i = 0; i < ARRAY_SIZE(outputs); i++) {
ret = em28xx_write_ac97(dev, outputs[i].reg, 0x8000); ret = em28xx_write_ac97(dev, outputs[i].reg, 0x8000);
if (ret < 0) if (ret < 0)
pr_warn("couldn't setup AC97 register %d\n", dev_warn(&dev->udev->dev,
outputs[i].reg); "couldn't setup AC97 register %d\n",
outputs[i].reg);
} }
} }
...@@ -482,8 +476,9 @@ int em28xx_audio_analog_set(struct em28xx *dev) ...@@ -482,8 +476,9 @@ int em28xx_audio_analog_set(struct em28xx *dev)
ret = em28xx_write_ac97(dev, outputs[i].reg, ret = em28xx_write_ac97(dev, outputs[i].reg,
vol); vol);
if (ret < 0) if (ret < 0)
pr_warn("couldn't setup AC97 register %d\n", dev_warn(&dev->udev->dev,
outputs[i].reg); "couldn't setup AC97 register %d\n",
outputs[i].reg);
} }
if (dev->ctl_aoutput & EM28XX_AOUT_PCM_IN) { if (dev->ctl_aoutput & EM28XX_AOUT_PCM_IN) {
...@@ -519,7 +514,7 @@ int em28xx_audio_setup(struct em28xx *dev) ...@@ -519,7 +514,7 @@ int em28xx_audio_setup(struct em28xx *dev)
/* See how this device is configured */ /* See how this device is configured */
cfg = em28xx_read_reg(dev, EM28XX_R00_CHIPCFG); cfg = em28xx_read_reg(dev, EM28XX_R00_CHIPCFG);
pr_info("Config register raw data: 0x%02x\n", cfg); dev_info(&dev->udev->dev, "Config register raw data: 0x%02x\n", cfg);
if (cfg < 0) { /* Register read error */ if (cfg < 0) { /* Register read error */
/* Be conservative */ /* Be conservative */
dev->int_audio_type = EM28XX_INT_AUDIO_AC97; dev->int_audio_type = EM28XX_INT_AUDIO_AC97;
...@@ -540,7 +535,7 @@ int em28xx_audio_setup(struct em28xx *dev) ...@@ -540,7 +535,7 @@ int em28xx_audio_setup(struct em28xx *dev)
i2s_samplerates = 5; i2s_samplerates = 5;
else else
i2s_samplerates = 3; i2s_samplerates = 3;
pr_info("I2S Audio (%d sample rate(s))\n", dev_info(&dev->udev->dev, "I2S Audio (%d sample rate(s))\n",
i2s_samplerates); i2s_samplerates);
/* Skip the code that does AC97 vendor detection */ /* Skip the code that does AC97 vendor detection */
dev->audio_mode.ac97 = EM28XX_NO_AC97; dev->audio_mode.ac97 = EM28XX_NO_AC97;
...@@ -558,7 +553,8 @@ int em28xx_audio_setup(struct em28xx *dev) ...@@ -558,7 +553,8 @@ int em28xx_audio_setup(struct em28xx *dev)
* Note: (some) em2800 devices without eeprom reports 0x91 on * Note: (some) em2800 devices without eeprom reports 0x91 on
* CHIPCFG register, even not having an AC97 chip * CHIPCFG register, even not having an AC97 chip
*/ */
pr_warn("AC97 chip type couldn't be determined\n"); dev_warn(&dev->udev->dev,
"AC97 chip type couldn't be determined\n");
dev->audio_mode.ac97 = EM28XX_NO_AC97; dev->audio_mode.ac97 = EM28XX_NO_AC97;
if (dev->usb_audio_type == EM28XX_USB_AUDIO_VENDOR) if (dev->usb_audio_type == EM28XX_USB_AUDIO_VENDOR)
dev->usb_audio_type = EM28XX_USB_AUDIO_NONE; dev->usb_audio_type = EM28XX_USB_AUDIO_NONE;
...@@ -571,13 +567,13 @@ int em28xx_audio_setup(struct em28xx *dev) ...@@ -571,13 +567,13 @@ int em28xx_audio_setup(struct em28xx *dev)
goto init_audio; goto init_audio;
vid = vid1 << 16 | vid2; vid = vid1 << 16 | vid2;
pr_warn("AC97 vendor ID = 0x%08x\n", vid); dev_warn(&dev->udev->dev, "AC97 vendor ID = 0x%08x\n", vid);
feat = em28xx_read_ac97(dev, AC97_RESET); feat = em28xx_read_ac97(dev, AC97_RESET);
if (feat < 0) if (feat < 0)
goto init_audio; goto init_audio;
pr_warn("AC97 features = 0x%04x\n", feat); dev_warn(&dev->udev->dev, "AC97 features = 0x%04x\n", feat);
/* Try to identify what audio processor we have */ /* Try to identify what audio processor we have */
if (((vid == 0xffffffff) || (vid == 0x83847650)) && (feat == 0x6a90)) if (((vid == 0xffffffff) || (vid == 0x83847650)) && (feat == 0x6a90))
...@@ -589,17 +585,20 @@ int em28xx_audio_setup(struct em28xx *dev) ...@@ -589,17 +585,20 @@ int em28xx_audio_setup(struct em28xx *dev)
/* Reports detected AC97 processor */ /* Reports detected AC97 processor */
switch (dev->audio_mode.ac97) { switch (dev->audio_mode.ac97) {
case EM28XX_NO_AC97: case EM28XX_NO_AC97:
pr_info("No AC97 audio processor\n"); dev_info(&dev->udev->dev, "No AC97 audio processor\n");
break; break;
case EM28XX_AC97_EM202: case EM28XX_AC97_EM202:
pr_info("Empia 202 AC97 audio processor detected\n"); dev_info(&dev->udev->dev,
"Empia 202 AC97 audio processor detected\n");
break; break;
case EM28XX_AC97_SIGMATEL: case EM28XX_AC97_SIGMATEL:
pr_info("Sigmatel audio processor detected (stac 97%02x)\n", dev_info(&dev->udev->dev,
vid & 0xff); "Sigmatel audio processor detected (stac 97%02x)\n",
vid & 0xff);
break; break;
case EM28XX_AC97_OTHER: case EM28XX_AC97_OTHER:
pr_warn("Unknown AC97 audio processor detected!\n"); dev_warn(&dev->udev->dev,
"Unknown AC97 audio processor detected!\n");
break; break;
default: default:
break; break;
...@@ -883,21 +882,23 @@ int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk, ...@@ -883,21 +882,23 @@ int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk,
if (mode == EM28XX_DIGITAL_MODE) { if (mode == EM28XX_DIGITAL_MODE) {
if ((xfer_bulk && !dev->dvb_ep_bulk) || if ((xfer_bulk && !dev->dvb_ep_bulk) ||
(!xfer_bulk && !dev->dvb_ep_isoc)) { (!xfer_bulk && !dev->dvb_ep_isoc)) {
pr_err("no endpoint for DVB mode and transfer type %d\n", dev_err(&dev->udev->dev,
xfer_bulk > 0); "no endpoint for DVB mode and transfer type %d\n",
xfer_bulk > 0);
return -EINVAL; return -EINVAL;
} }
usb_bufs = &dev->usb_ctl.digital_bufs; usb_bufs = &dev->usb_ctl.digital_bufs;
} else if (mode == EM28XX_ANALOG_MODE) { } else if (mode == EM28XX_ANALOG_MODE) {
if ((xfer_bulk && !dev->analog_ep_bulk) || if ((xfer_bulk && !dev->analog_ep_bulk) ||
(!xfer_bulk && !dev->analog_ep_isoc)) { (!xfer_bulk && !dev->analog_ep_isoc)) {
pr_err("no endpoint for analog mode and transfer type %d\n", dev_err(&dev->udev->dev,
xfer_bulk > 0); "no endpoint for analog mode and transfer type %d\n",
xfer_bulk > 0);
return -EINVAL; return -EINVAL;
} }
usb_bufs = &dev->usb_ctl.analog_bufs; usb_bufs = &dev->usb_ctl.analog_bufs;
} else { } else {
pr_err("invalid mode selected\n"); dev_err(&dev->udev->dev, "invalid mode selected\n");
return -EINVAL; return -EINVAL;
} }
...@@ -939,7 +940,8 @@ int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk, ...@@ -939,7 +940,8 @@ int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk,
usb_bufs->transfer_buffer[i] = usb_alloc_coherent(dev->udev, usb_bufs->transfer_buffer[i] = usb_alloc_coherent(dev->udev,
sb_size, GFP_KERNEL, &urb->transfer_dma); sb_size, GFP_KERNEL, &urb->transfer_dma);
if (!usb_bufs->transfer_buffer[i]) { if (!usb_bufs->transfer_buffer[i]) {
pr_err("unable to allocate %i bytes for transfer buffer %i%s\n", dev_err(&dev->udev->dev,
"unable to allocate %i bytes for transfer buffer %i%s\n",
sb_size, i, sb_size, i,
in_interrupt() ? " while in int" : ""); in_interrupt() ? " while in int" : "");
em28xx_uninit_usb_xfer(dev, mode); em28xx_uninit_usb_xfer(dev, mode);
...@@ -1021,7 +1023,8 @@ int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode, ...@@ -1021,7 +1023,8 @@ int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode,
if (xfer_bulk) { if (xfer_bulk) {
rc = usb_clear_halt(dev->udev, usb_bufs->urb[0]->pipe); rc = usb_clear_halt(dev->udev, usb_bufs->urb[0]->pipe);
if (rc < 0) { if (rc < 0) {
pr_err("failed to clear USB bulk endpoint stall/halt condition (error=%i)\n", dev_err(&dev->udev->dev,
"failed to clear USB bulk endpoint stall/halt condition (error=%i)\n",
rc); rc);
em28xx_uninit_usb_xfer(dev, mode); em28xx_uninit_usb_xfer(dev, mode);
return rc; return rc;
...@@ -1037,7 +1040,8 @@ int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode, ...@@ -1037,7 +1040,8 @@ int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode,
for (i = 0; i < usb_bufs->num_bufs; i++) { for (i = 0; i < usb_bufs->num_bufs; i++) {
rc = usb_submit_urb(usb_bufs->urb[i], GFP_ATOMIC); rc = usb_submit_urb(usb_bufs->urb[i], GFP_ATOMIC);
if (rc) { if (rc) {
pr_err("submit of urb %i failed (error=%i)\n", i, rc); dev_err(&dev->udev->dev,
"submit of urb %i failed (error=%i)\n", i, rc);
em28xx_uninit_usb_xfer(dev, mode); em28xx_uninit_usb_xfer(dev, mode);
return rc; return rc;
} }
...@@ -1085,7 +1089,7 @@ void em28xx_unregister_extension(struct em28xx_ops *ops) ...@@ -1085,7 +1089,7 @@ void em28xx_unregister_extension(struct em28xx_ops *ops)
} }
list_del(&ops->next); list_del(&ops->next);
mutex_unlock(&em28xx_devlist_mutex); mutex_unlock(&em28xx_devlist_mutex);
pr_info("Em28xx: Removed (%s) extension\n", ops->name); pr_info("em28xx: Removed (%s) extension\n", ops->name);
} }
EXPORT_SYMBOL(em28xx_unregister_extension); EXPORT_SYMBOL(em28xx_unregister_extension);
...@@ -1119,7 +1123,7 @@ int em28xx_suspend_extension(struct em28xx *dev) ...@@ -1119,7 +1123,7 @@ int em28xx_suspend_extension(struct em28xx *dev)
{ {
const struct em28xx_ops *ops = NULL; const struct em28xx_ops *ops = NULL;
pr_info("Suspending extensions\n"); dev_info(&dev->udev->dev, "Suspending extensions\n");
mutex_lock(&em28xx_devlist_mutex); mutex_lock(&em28xx_devlist_mutex);
list_for_each_entry(ops, &em28xx_extension_devlist, next) { list_for_each_entry(ops, &em28xx_extension_devlist, next) {
if (ops->suspend) if (ops->suspend)
...@@ -1133,7 +1137,7 @@ int em28xx_resume_extension(struct em28xx *dev) ...@@ -1133,7 +1137,7 @@ int em28xx_resume_extension(struct em28xx *dev)
{ {
const struct em28xx_ops *ops = NULL; const struct em28xx_ops *ops = NULL;
pr_info("Resuming extensions\n"); dev_info(&dev->udev->dev, "Resuming extensions\n");
mutex_lock(&em28xx_devlist_mutex); mutex_lock(&em28xx_devlist_mutex);
list_for_each_entry(ops, &em28xx_extension_devlist, next) { list_for_each_entry(ops, &em28xx_extension_devlist, next) {
if (ops->resume) if (ops->resume)
......
...@@ -73,9 +73,10 @@ MODULE_PARM_DESC(debug, "enable debug messages [dvb]"); ...@@ -73,9 +73,10 @@ MODULE_PARM_DESC(debug, "enable debug messages [dvb]");
DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr); DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
#define dprintk(level, fmt, arg...) do { \ #define dprintk(level, fmt, arg...) do { \
if (debug >= level) \ if (debug >= level) \
printk(KERN_DEBUG "%s/2-dvb: " fmt, dev->name, ## arg); \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
"dvb: " fmt, ## arg); \
} while (0) } while (0)
struct em28xx_dvb { struct em28xx_dvb {
...@@ -735,7 +736,7 @@ static int em28xx_pctv_290e_set_lna(struct dvb_frontend *fe) ...@@ -735,7 +736,7 @@ static int em28xx_pctv_290e_set_lna(struct dvb_frontend *fe)
ret = gpio_request_one(dvb->lna_gpio, flags, NULL); ret = gpio_request_one(dvb->lna_gpio, flags, NULL);
if (ret) if (ret)
pr_err("gpio request failed %d\n", ret); dev_err(&dev->udev->dev, "gpio request failed %d\n", ret);
else else
gpio_free(dvb->lna_gpio); gpio_free(dvb->lna_gpio);
...@@ -935,19 +936,20 @@ static int em28xx_attach_xc3028(u8 addr, struct em28xx *dev) ...@@ -935,19 +936,20 @@ static int em28xx_attach_xc3028(u8 addr, struct em28xx *dev)
cfg.ctrl = &ctl; cfg.ctrl = &ctl;
if (!dev->dvb->fe[0]) { if (!dev->dvb->fe[0]) {
pr_err("dvb frontend not attached. Can't attach xc3028\n"); dev_err(&dev->udev->dev,
"dvb frontend not attached. Can't attach xc3028\n");
return -EINVAL; return -EINVAL;
} }
fe = dvb_attach(xc2028_attach, dev->dvb->fe[0], &cfg); fe = dvb_attach(xc2028_attach, dev->dvb->fe[0], &cfg);
if (!fe) { if (!fe) {
pr_err("xc3028 attach failed\n"); dev_err(&dev->udev->dev, "xc3028 attach failed\n");
dvb_frontend_detach(dev->dvb->fe[0]); dvb_frontend_detach(dev->dvb->fe[0]);
dev->dvb->fe[0] = NULL; dev->dvb->fe[0] = NULL;
return -EINVAL; return -EINVAL;
} }
pr_info("xc3028 attached\n"); dev_info(&dev->udev->dev, "xc3028 attached\n");
return 0; return 0;
} }
...@@ -963,11 +965,13 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module, ...@@ -963,11 +965,13 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module,
mutex_init(&dvb->lock); mutex_init(&dvb->lock);
/* register adapter */ /* register adapter */
result = dvb_register_adapter(&dvb->adapter, dev->name, module, device, result = dvb_register_adapter(&dvb->adapter,
adapter_nr); dev_name(&dev->udev->dev), module,
device, adapter_nr);
if (result < 0) { if (result < 0) {
pr_warn("dvb_register_adapter failed (errno = %d)\n", dev_warn(&dev->udev->dev,
result); "dvb_register_adapter failed (errno = %d)\n",
result);
goto fail_adapter; goto fail_adapter;
} }
#ifdef CONFIG_MEDIA_CONTROLLER_DVB #ifdef CONFIG_MEDIA_CONTROLLER_DVB
...@@ -984,8 +988,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module, ...@@ -984,8 +988,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module,
/* register frontend */ /* register frontend */
result = dvb_register_frontend(&dvb->adapter, dvb->fe[0]); result = dvb_register_frontend(&dvb->adapter, dvb->fe[0]);
if (result < 0) { if (result < 0) {
pr_warn("dvb_register_frontend failed (errno = %d)\n", dev_warn(&dev->udev->dev,
result); "dvb_register_frontend failed (errno = %d)\n",
result);
goto fail_frontend0; goto fail_frontend0;
} }
...@@ -993,8 +998,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module, ...@@ -993,8 +998,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module,
if (dvb->fe[1]) { if (dvb->fe[1]) {
result = dvb_register_frontend(&dvb->adapter, dvb->fe[1]); result = dvb_register_frontend(&dvb->adapter, dvb->fe[1]);
if (result < 0) { if (result < 0) {
pr_warn("2nd dvb_register_frontend failed (errno = %d)\n", dev_warn(&dev->udev->dev,
result); "2nd dvb_register_frontend failed (errno = %d)\n",
result);
goto fail_frontend1; goto fail_frontend1;
} }
} }
...@@ -1011,7 +1017,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module, ...@@ -1011,7 +1017,9 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module,
result = dvb_dmx_init(&dvb->demux); result = dvb_dmx_init(&dvb->demux);
if (result < 0) { if (result < 0) {
pr_warn("dvb_dmx_init failed (errno = %d)\n", result); dev_warn(&dev->udev->dev,
"dvb_dmx_init failed (errno = %d)\n",
result);
goto fail_dmx; goto fail_dmx;
} }
...@@ -1020,29 +1028,35 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module, ...@@ -1020,29 +1028,35 @@ static int em28xx_register_dvb(struct em28xx_dvb *dvb, struct module *module,
dvb->dmxdev.capabilities = 0; dvb->dmxdev.capabilities = 0;
result = dvb_dmxdev_init(&dvb->dmxdev, &dvb->adapter); result = dvb_dmxdev_init(&dvb->dmxdev, &dvb->adapter);
if (result < 0) { if (result < 0) {
pr_warn("dvb_dmxdev_init failed (errno = %d)\n", result); dev_warn(&dev->udev->dev,
"dvb_dmxdev_init failed (errno = %d)\n",
result);
goto fail_dmxdev; goto fail_dmxdev;
} }
dvb->fe_hw.source = DMX_FRONTEND_0; dvb->fe_hw.source = DMX_FRONTEND_0;
result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_hw); result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_hw);
if (result < 0) { if (result < 0) {
pr_warn("add_frontend failed (DMX_FRONTEND_0, errno = %d)\n", dev_warn(&dev->udev->dev,
result); "add_frontend failed (DMX_FRONTEND_0, errno = %d)\n",
result);
goto fail_fe_hw; goto fail_fe_hw;
} }
dvb->fe_mem.source = DMX_MEMORY_FE; dvb->fe_mem.source = DMX_MEMORY_FE;
result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_mem); result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_mem);
if (result < 0) { if (result < 0) {
pr_warn("add_frontend failed (DMX_MEMORY_FE, errno = %d)\n", dev_warn(&dev->udev->dev,
result); "add_frontend failed (DMX_MEMORY_FE, errno = %d)\n",
result);
goto fail_fe_mem; goto fail_fe_mem;
} }
result = dvb->demux.dmx.connect_frontend(&dvb->demux.dmx, &dvb->fe_hw); result = dvb->demux.dmx.connect_frontend(&dvb->demux.dmx, &dvb->fe_hw);
if (result < 0) { if (result < 0) {
pr_warn("connect_frontend failed (errno = %d)\n", result); dev_warn(&dev->udev->dev,
"connect_frontend failed (errno = %d)\n",
result);
goto fail_fe_conn; goto fail_fe_conn;
} }
...@@ -1114,7 +1128,7 @@ static int em28xx_dvb_init(struct em28xx *dev) ...@@ -1114,7 +1128,7 @@ static int em28xx_dvb_init(struct em28xx *dev)
return 0; return 0;
} }
pr_info("Binding DVB extension\n"); dev_info(&dev->udev->dev, "Binding DVB extension\n");
dvb = kzalloc(sizeof(struct em28xx_dvb), GFP_KERNEL); dvb = kzalloc(sizeof(struct em28xx_dvb), GFP_KERNEL);
if (!dvb) if (!dvb)
...@@ -1138,7 +1152,8 @@ static int em28xx_dvb_init(struct em28xx *dev) ...@@ -1138,7 +1152,8 @@ static int em28xx_dvb_init(struct em28xx *dev)
EM28XX_DVB_NUM_ISOC_PACKETS); EM28XX_DVB_NUM_ISOC_PACKETS);
} }
if (result) { if (result) {
pr_err("em28xx_dvb: failed to pre-allocate USB transfer buffers for DVB.\n"); dev_err(&dev->udev->dev,
"failed to pre-allocate USB transfer buffers for DVB.\n");
kfree(dvb); kfree(dvb);
dev->dvb = NULL; dev->dvb = NULL;
return result; return result;
...@@ -1317,8 +1332,9 @@ static int em28xx_dvb_init(struct em28xx *dev) ...@@ -1317,8 +1332,9 @@ static int em28xx_dvb_init(struct em28xx *dev)
result = gpio_request_one(dvb->lna_gpio, result = gpio_request_one(dvb->lna_gpio,
GPIOF_OUT_INIT_LOW, NULL); GPIOF_OUT_INIT_LOW, NULL);
if (result) if (result)
pr_err("gpio request failed %d\n", dev_err(&dev->udev->dev,
result); "gpio request failed %d\n",
result);
else else
gpio_free(dvb->lna_gpio); gpio_free(dvb->lna_gpio);
...@@ -1933,11 +1949,12 @@ static int em28xx_dvb_init(struct em28xx *dev) ...@@ -1933,11 +1949,12 @@ static int em28xx_dvb_init(struct em28xx *dev)
} }
break; break;
default: default:
pr_err("The frontend of your DVB/ATSC card isn't supported yet\n"); dev_err(&dev->udev->dev,
"The frontend of your DVB/ATSC card isn't supported yet\n");
break; break;
} }
if (NULL == dvb->fe[0]) { if (NULL == dvb->fe[0]) {
pr_err("frontend initialization failed\n"); dev_err(&dev->udev->dev, "frontend initialization failed\n");
result = -EINVAL; result = -EINVAL;
goto out_free; goto out_free;
} }
...@@ -1952,7 +1969,7 @@ static int em28xx_dvb_init(struct em28xx *dev) ...@@ -1952,7 +1969,7 @@ static int em28xx_dvb_init(struct em28xx *dev)
if (result < 0) if (result < 0)
goto out_free; goto out_free;
pr_info("DVB extension successfully initialized\n"); dev_info(&dev->udev->dev, "DVB extension successfully initialized\n");
kref_get(&dev->ref); kref_get(&dev->ref);
...@@ -1992,7 +2009,7 @@ static int em28xx_dvb_fini(struct em28xx *dev) ...@@ -1992,7 +2009,7 @@ static int em28xx_dvb_fini(struct em28xx *dev)
if (!dev->dvb) if (!dev->dvb)
return 0; return 0;
pr_info("Closing DVB extension\n"); dev_info(&dev->udev->dev, "Closing DVB extension\n");
dvb = dev->dvb; dvb = dev->dvb;
...@@ -2050,17 +2067,17 @@ static int em28xx_dvb_suspend(struct em28xx *dev) ...@@ -2050,17 +2067,17 @@ static int em28xx_dvb_suspend(struct em28xx *dev)
if (!dev->board.has_dvb) if (!dev->board.has_dvb)
return 0; return 0;
pr_info("Suspending DVB extension\n"); dev_info(&dev->udev->dev, "Suspending DVB extension\n");
if (dev->dvb) { if (dev->dvb) {
struct em28xx_dvb *dvb = dev->dvb; struct em28xx_dvb *dvb = dev->dvb;
if (dvb->fe[0]) { if (dvb->fe[0]) {
ret = dvb_frontend_suspend(dvb->fe[0]); ret = dvb_frontend_suspend(dvb->fe[0]);
pr_info("fe0 suspend %d\n", ret); dev_info(&dev->udev->dev, "fe0 suspend %d\n", ret);
} }
if (dvb->fe[1]) { if (dvb->fe[1]) {
dvb_frontend_suspend(dvb->fe[1]); dvb_frontend_suspend(dvb->fe[1]);
pr_info("fe1 suspend %d\n", ret); dev_info(&dev->udev->dev, "fe1 suspend %d\n", ret);
} }
} }
...@@ -2077,18 +2094,18 @@ static int em28xx_dvb_resume(struct em28xx *dev) ...@@ -2077,18 +2094,18 @@ static int em28xx_dvb_resume(struct em28xx *dev)
if (!dev->board.has_dvb) if (!dev->board.has_dvb)
return 0; return 0;
pr_info("Resuming DVB extension\n"); dev_info(&dev->udev->dev, "Resuming DVB extension\n");
if (dev->dvb) { if (dev->dvb) {
struct em28xx_dvb *dvb = dev->dvb; struct em28xx_dvb *dvb = dev->dvb;
if (dvb->fe[0]) { if (dvb->fe[0]) {
ret = dvb_frontend_resume(dvb->fe[0]); ret = dvb_frontend_resume(dvb->fe[0]);
pr_info("fe0 resume %d\n", ret); dev_info(&dev->udev->dev, "fe0 resume %d\n", ret);
} }
if (dvb->fe[1]) { if (dvb->fe[1]) {
ret = dvb_frontend_resume(dvb->fe[1]); ret = dvb_frontend_resume(dvb->fe[1]);
pr_info("fe1 resume %d\n", ret); dev_info(&dev->udev->dev, "fe1 resume %d\n", ret);
} }
} }
......
...@@ -44,6 +44,13 @@ static unsigned int i2c_debug; ...@@ -44,6 +44,13 @@ static unsigned int i2c_debug;
module_param(i2c_debug, int, 0644); module_param(i2c_debug, int, 0644);
MODULE_PARM_DESC(i2c_debug, "i2c debug message level (1: normal debug, 2: show I2C transfers)"); MODULE_PARM_DESC(i2c_debug, "i2c debug message level (1: normal debug, 2: show I2C transfers)");
#define dprintk(level, fmt, arg...) do { \
if (i2c_debug > level) \
dev_printk(KERN_DEBUG, &dev->udev->dev, \
"i2c: %s: " fmt, __func__, ## arg); \
} while (0)
/* /*
* em2800_i2c_send_bytes() * em2800_i2c_send_bytes()
* send up to 4 bytes to the em2800 i2c device * send up to 4 bytes to the em2800 i2c device
...@@ -71,7 +78,8 @@ static int em2800_i2c_send_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len) ...@@ -71,7 +78,8 @@ static int em2800_i2c_send_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len)
/* trigger write */ /* trigger write */
ret = dev->em28xx_write_regs(dev, 4 - len, &b2[4 - len], 2 + len); ret = dev->em28xx_write_regs(dev, 4 - len, &b2[4 - len], 2 + len);
if (ret != 2 + len) { if (ret != 2 + len) {
pr_warn("failed to trigger write to i2c address 0x%x (error=%i)\n", dev_warn(&dev->udev->dev,
"failed to trigger write to i2c address 0x%x (error=%i)\n",
addr, ret); addr, ret);
return (ret < 0) ? ret : -EIO; return (ret < 0) ? ret : -EIO;
} }
...@@ -81,20 +89,18 @@ static int em2800_i2c_send_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len) ...@@ -81,20 +89,18 @@ static int em2800_i2c_send_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len)
if (ret == 0x80 + len - 1) if (ret == 0x80 + len - 1)
return len; return len;
if (ret == 0x94 + len - 1) { if (ret == 0x94 + len - 1) {
if (i2c_debug == 1) dprintk(1, "R05 returned 0x%02x: I2C ACK error\n", ret);
pr_warn("R05 returned 0x%02x: I2C ACK error\n",
ret);
return -ENXIO; return -ENXIO;
} }
if (ret < 0) { if (ret < 0) {
pr_warn("failed to get i2c transfer status from bridge register (error=%i)\n", dev_warn(&dev->udev->dev,
"failed to get i2c transfer status from bridge register (error=%i)\n",
ret); ret);
return ret; return ret;
} }
msleep(5); msleep(5);
} }
if (i2c_debug) dprintk(0, "write to i2c device at 0x%x timed out\n", addr);
pr_warn("write to i2c device at 0x%x timed out\n", addr);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
...@@ -117,8 +123,9 @@ static int em2800_i2c_recv_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len) ...@@ -117,8 +123,9 @@ static int em2800_i2c_recv_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len)
buf2[0] = addr; buf2[0] = addr;
ret = dev->em28xx_write_regs(dev, 0x04, buf2, 2); ret = dev->em28xx_write_regs(dev, 0x04, buf2, 2);
if (ret != 2) { if (ret != 2) {
pr_warn("failed to trigger read from i2c address 0x%x (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "failed to trigger read from i2c address 0x%x (error=%i)\n",
addr, ret);
return (ret < 0) ? ret : -EIO; return (ret < 0) ? ret : -EIO;
} }
...@@ -128,29 +135,28 @@ static int em2800_i2c_recv_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len) ...@@ -128,29 +135,28 @@ static int em2800_i2c_recv_bytes(struct em28xx *dev, u8 addr, u8 *buf, u16 len)
if (ret == 0x84 + len - 1) if (ret == 0x84 + len - 1)
break; break;
if (ret == 0x94 + len - 1) { if (ret == 0x94 + len - 1) {
if (i2c_debug == 1) dprintk(1, "R05 returned 0x%02x: I2C ACK error\n",
pr_warn("R05 returned 0x%02x: I2C ACK error\n", ret);
ret);
return -ENXIO; return -ENXIO;
} }
if (ret < 0) { if (ret < 0) {
pr_warn("failed to get i2c transfer status from bridge register (error=%i)\n", dev_warn(&dev->udev->dev,
ret); "failed to get i2c transfer status from bridge register (error=%i)\n",
ret);
return ret; return ret;
} }
msleep(5); msleep(5);
} }
if (ret != 0x84 + len - 1) { if (ret != 0x84 + len - 1) {
if (i2c_debug) dprintk(0, "read from i2c device at 0x%x timed out\n", addr);
pr_warn("read from i2c device at 0x%x timed out\n",
addr);
} }
/* get the received message */ /* get the received message */
ret = dev->em28xx_read_reg_req_len(dev, 0x00, 4-len, buf2, len); ret = dev->em28xx_read_reg_req_len(dev, 0x00, 4-len, buf2, len);
if (ret != len) { if (ret != len) {
pr_warn("reading from i2c device at 0x%x failed: couldn't get the received message from the bridge (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "reading from i2c device at 0x%x failed: couldn't get the received message from the bridge (error=%i)\n",
addr, ret);
return (ret < 0) ? ret : -EIO; return (ret < 0) ? ret : -EIO;
} }
for (i = 0; i < len; i++) for (i = 0; i < len; i++)
...@@ -194,12 +200,14 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -194,12 +200,14 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf,
ret = dev->em28xx_write_regs_req(dev, stop ? 2 : 3, addr, buf, len); ret = dev->em28xx_write_regs_req(dev, stop ? 2 : 3, addr, buf, len);
if (ret != len) { if (ret != len) {
if (ret < 0) { if (ret < 0) {
pr_warn("writing to i2c device at 0x%x failed (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "writing to i2c device at 0x%x failed (error=%i)\n",
addr, ret);
return ret; return ret;
} else { } else {
pr_warn("%i bytes write to i2c device at 0x%x requested, but %i bytes written\n", dev_warn(&dev->udev->dev,
len, addr, ret); "%i bytes write to i2c device at 0x%x requested, but %i bytes written\n",
len, addr, ret);
return -EIO; return -EIO;
} }
} }
...@@ -210,14 +218,14 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -210,14 +218,14 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf,
if (ret == 0) /* success */ if (ret == 0) /* success */
return len; return len;
if (ret == 0x10) { if (ret == 0x10) {
if (i2c_debug == 1) dprintk(1, "I2C ACK error on writing to addr 0x%02x\n",
pr_warn("I2C ACK error on writing to addr 0x%02x\n", addr);
addr);
return -ENXIO; return -ENXIO;
} }
if (ret < 0) { if (ret < 0) {
pr_warn("failed to get i2c transfer status from bridge register (error=%i)\n", dev_warn(&dev->udev->dev,
ret); "failed to get i2c transfer status from bridge register (error=%i)\n",
ret);
return ret; return ret;
} }
msleep(5); msleep(5);
...@@ -230,14 +238,15 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -230,14 +238,15 @@ static int em28xx_i2c_send_bytes(struct em28xx *dev, u16 addr, u8 *buf,
if (ret == 0x02 || ret == 0x04) { if (ret == 0x02 || ret == 0x04) {
/* NOTE: these errors seem to be related to clock stretching */ /* NOTE: these errors seem to be related to clock stretching */
if (i2c_debug) dprintk(0,
pr_warn("write to i2c device at 0x%x timed out (status=%i)\n", "write to i2c device at 0x%x timed out (status=%i)\n",
addr, ret); addr, ret);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
pr_warn("write to i2c device at 0x%x failed with unknown error (status=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "write to i2c device at 0x%x failed with unknown error (status=%i)\n",
addr, ret);
return -EIO; return -EIO;
} }
...@@ -259,8 +268,9 @@ static int em28xx_i2c_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, u16 len) ...@@ -259,8 +268,9 @@ static int em28xx_i2c_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, u16 len)
/* Read data from i2c device */ /* Read data from i2c device */
ret = dev->em28xx_read_reg_req_len(dev, 2, addr, buf, len); ret = dev->em28xx_read_reg_req_len(dev, 2, addr, buf, len);
if (ret < 0) { if (ret < 0) {
pr_warn("reading from i2c device at 0x%x failed (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "reading from i2c device at 0x%x failed (error=%i)\n",
addr, ret);
return ret; return ret;
} }
/* /*
...@@ -277,27 +287,28 @@ static int em28xx_i2c_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, u16 len) ...@@ -277,27 +287,28 @@ static int em28xx_i2c_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, u16 len)
if (ret == 0) /* success */ if (ret == 0) /* success */
return len; return len;
if (ret < 0) { if (ret < 0) {
pr_warn("failed to get i2c transfer status from bridge register (error=%i)\n", dev_warn(&dev->udev->dev,
ret); "failed to get i2c transfer status from bridge register (error=%i)\n",
ret);
return ret; return ret;
} }
if (ret == 0x10) { if (ret == 0x10) {
if (i2c_debug == 1) dprintk(1, "I2C ACK error on writing to addr 0x%02x\n",
pr_warn("I2C ACK error on writing to addr 0x%02x\n", addr);
addr);
return -ENXIO; return -ENXIO;
} }
if (ret == 0x02 || ret == 0x04) { if (ret == 0x02 || ret == 0x04) {
/* NOTE: these errors seem to be related to clock stretching */ /* NOTE: these errors seem to be related to clock stretching */
if (i2c_debug) dprintk(0,
pr_warn("write to i2c device at 0x%x timed out (status=%i)\n", "write to i2c device at 0x%x timed out (status=%i)\n",
addr, ret); addr, ret);
return -ETIMEDOUT; return -ETIMEDOUT;
} }
pr_warn("write to i2c device at 0x%x failed with unknown error (status=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "write to i2c device at 0x%x failed with unknown error (status=%i)\n",
addr, ret);
return -EIO; return -EIO;
} }
...@@ -336,12 +347,14 @@ static int em25xx_bus_B_send_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -336,12 +347,14 @@ static int em25xx_bus_B_send_bytes(struct em28xx *dev, u16 addr, u8 *buf,
ret = dev->em28xx_write_regs_req(dev, 0x06, addr, buf, len); ret = dev->em28xx_write_regs_req(dev, 0x06, addr, buf, len);
if (ret != len) { if (ret != len) {
if (ret < 0) { if (ret < 0) {
pr_warn("writing to i2c device at 0x%x failed (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "writing to i2c device at 0x%x failed (error=%i)\n",
addr, ret);
return ret; return ret;
} else { } else {
pr_warn("%i bytes write to i2c device at 0x%x requested, but %i bytes written\n", dev_warn(&dev->udev->dev,
len, addr, ret); "%i bytes write to i2c device at 0x%x requested, but %i bytes written\n",
len, addr, ret);
return -EIO; return -EIO;
} }
} }
...@@ -354,9 +367,7 @@ static int em25xx_bus_B_send_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -354,9 +367,7 @@ static int em25xx_bus_B_send_bytes(struct em28xx *dev, u16 addr, u8 *buf,
if (!ret) if (!ret)
return len; return len;
else if (ret > 0) { else if (ret > 0) {
if (i2c_debug == 1) dprintk(1, "Bus B R08 returned 0x%02x: I2C ACK error\n", ret);
pr_warn("Bus B R08 returned 0x%02x: I2C ACK error\n",
ret);
return -ENXIO; return -ENXIO;
} }
...@@ -387,8 +398,9 @@ static int em25xx_bus_B_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -387,8 +398,9 @@ static int em25xx_bus_B_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf,
/* Read value */ /* Read value */
ret = dev->em28xx_read_reg_req_len(dev, 0x06, addr, buf, len); ret = dev->em28xx_read_reg_req_len(dev, 0x06, addr, buf, len);
if (ret < 0) { if (ret < 0) {
pr_warn("reading from i2c device at 0x%x failed (error=%i)\n", dev_warn(&dev->udev->dev,
addr, ret); "reading from i2c device at 0x%x failed (error=%i)\n",
addr, ret);
return ret; return ret;
} }
/* /*
...@@ -409,9 +421,7 @@ static int em25xx_bus_B_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf, ...@@ -409,9 +421,7 @@ static int em25xx_bus_B_recv_bytes(struct em28xx *dev, u16 addr, u8 *buf,
if (!ret) if (!ret)
return len; return len;
else if (ret > 0) { else if (ret > 0) {
if (i2c_debug == 1) dprintk(1, "Bus B R08 returned 0x%02x: I2C ACK error\n", ret);
pr_warn("Bus B R08 returned 0x%02x: I2C ACK error\n",
ret);
return -ENXIO; return -ENXIO;
} }
...@@ -529,57 +539,46 @@ static int em28xx_i2c_xfer(struct i2c_adapter *i2c_adap, ...@@ -529,57 +539,46 @@ static int em28xx_i2c_xfer(struct i2c_adapter *i2c_adap,
} }
for (i = 0; i < num; i++) { for (i = 0; i < num; i++) {
addr = msgs[i].addr << 1; addr = msgs[i].addr << 1;
if (i2c_debug > 1)
printk(KERN_DEBUG "%s at %s: %s %s addr=%02x len=%d:",
dev->name, __func__ ,
(msgs[i].flags & I2C_M_RD) ? "read" : "write",
i == num - 1 ? "stop" : "nonstop",
addr, msgs[i].len);
if (!msgs[i].len) { if (!msgs[i].len) {
/* /*
* no len: check only for device presence * no len: check only for device presence
* This code is only called during device probe. * This code is only called during device probe.
*/ */
rc = i2c_check_for_device(i2c_bus, addr); rc = i2c_check_for_device(i2c_bus, addr);
if (rc < 0) {
if (rc == -ENXIO) { if (rc == -ENXIO)
if (i2c_debug > 1) rc = -ENODEV;
pr_cont(" no device\n");
rc = -ENODEV;
} else {
if (i2c_debug > 1)
pr_cont(" ERROR: %i\n", rc);
}
rt_mutex_unlock(&dev->i2c_bus_lock);
return rc;
}
} else if (msgs[i].flags & I2C_M_RD) { } else if (msgs[i].flags & I2C_M_RD) {
/* read bytes */ /* read bytes */
rc = i2c_recv_bytes(i2c_bus, msgs[i]); rc = i2c_recv_bytes(i2c_bus, msgs[i]);
if (i2c_debug > 1 && rc >= 0)
pr_cont(" %*ph",
msgs[i].len, msgs[i].buf);
} else { } else {
if (i2c_debug > 1)
pr_cont(" %*ph",
msgs[i].len, msgs[i].buf);
/* write bytes */ /* write bytes */
rc = i2c_send_bytes(i2c_bus, msgs[i], i == num - 1); rc = i2c_send_bytes(i2c_bus, msgs[i], i == num - 1);
} }
if (rc < 0) {
if (i2c_debug > 1) if (rc < 0)
pr_cont(" ERROR: %i\n", rc); goto error;
rt_mutex_unlock(&dev->i2c_bus_lock);
return rc; dprintk(2, "%s %s addr=%02x len=%d: %*ph\n",
} (msgs[i].flags & I2C_M_RD) ? "read" : "write",
if (i2c_debug > 1) i == num - 1 ? "stop" : "nonstop",
pr_cont("\n"); addr, msgs[i].len,
msgs[i].len, msgs[i].buf);
} }
rt_mutex_unlock(&dev->i2c_bus_lock); rt_mutex_unlock(&dev->i2c_bus_lock);
return num; return num;
error:
dprintk(2, "%s %s addr=%02x len=%d: %sERROR: %i\n",
(msgs[i].flags & I2C_M_RD) ? "read" : "write",
i == num - 1 ? "stop" : "nonstop",
addr, msgs[i].len,
(rc == -ENODEV) ? "no device " : "",
rc);
rt_mutex_unlock(&dev->i2c_bus_lock);
return rc;
} }
/* /*
...@@ -673,7 +672,7 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -673,7 +672,7 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
/* Check if board has eeprom */ /* Check if board has eeprom */
err = i2c_master_recv(&dev->i2c_client[bus], &buf, 0); err = i2c_master_recv(&dev->i2c_client[bus], &buf, 0);
if (err < 0) { if (err < 0) {
pr_info("board has no eeprom\n"); dev_info(&dev->udev->dev, "board has no eeprom\n");
return -ENODEV; return -ENODEV;
} }
...@@ -686,17 +685,19 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -686,17 +685,19 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
dev->eeprom_addrwidth_16bit, dev->eeprom_addrwidth_16bit,
len, data); len, data);
if (err != len) { if (err != len) {
pr_err("failed to read eeprom (err=%d)\n", err); dev_err(&dev->udev->dev,
"failed to read eeprom (err=%d)\n", err);
goto error; goto error;
} }
if (i2c_debug) { if (i2c_debug) {
/* Display eeprom content */ /* Display eeprom content */
print_hex_dump(KERN_INFO, "eeprom ", DUMP_PREFIX_OFFSET, print_hex_dump(KERN_DEBUG, "em28xx eeprom ", DUMP_PREFIX_OFFSET,
16, 1, data, len, true); 16, 1, data, len, true);
if (dev->eeprom_addrwidth_16bit) if (dev->eeprom_addrwidth_16bit)
pr_info("eeprom %06x: ... (skipped)\n", 256); dev_info(&dev->udev->dev,
"eeprom %06x: ... (skipped)\n", 256);
} }
if (dev->eeprom_addrwidth_16bit && if (dev->eeprom_addrwidth_16bit &&
...@@ -708,11 +709,14 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -708,11 +709,14 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
dev->hash = em28xx_hash_mem(data, len, 32); dev->hash = em28xx_hash_mem(data, len, 32);
mc_start = (data[1] << 8) + 4; /* usually 0x0004 */ mc_start = (data[1] << 8) + 4; /* usually 0x0004 */
pr_info("EEPROM ID = %02x %02x %02x %02x, EEPROM hash = 0x%08lx\n", dev_info(&dev->udev->dev,
data[0], data[1], data[2], data[3], dev->hash); "EEPROM ID = %02x %02x %02x %02x, EEPROM hash = 0x%08lx\n",
pr_info("EEPROM info:\n"); data[0], data[1], data[2], data[3], dev->hash);
pr_info("\tmicrocode start address = 0x%04x, boot configuration = 0x%02x\n", dev_info(&dev->udev->dev,
mc_start, data[2]); "EEPROM info:\n");
dev_info(&dev->udev->dev,
"\tmicrocode start address = 0x%04x, boot configuration = 0x%02x\n",
mc_start, data[2]);
/* /*
* boot configuration (address 0x0002): * boot configuration (address 0x0002):
* [0] microcode download speed: 1 = 400 kHz; 0 = 100 kHz * [0] microcode download speed: 1 = 400 kHz; 0 = 100 kHz
...@@ -730,8 +734,9 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -730,8 +734,9 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
err = em28xx_i2c_read_block(dev, bus, mc_start + 46, 1, 2, err = em28xx_i2c_read_block(dev, bus, mc_start + 46, 1, 2,
data); data);
if (err != 2) { if (err != 2) {
pr_err("failed to read hardware configuration data from eeprom (err=%d)\n", dev_err(&dev->udev->dev,
err); "failed to read hardware configuration data from eeprom (err=%d)\n",
err);
goto error; goto error;
} }
...@@ -748,8 +753,9 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -748,8 +753,9 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
err = em28xx_i2c_read_block(dev, bus, hwconf_offset, 1, len, err = em28xx_i2c_read_block(dev, bus, hwconf_offset, 1, len,
data); data);
if (err != len) { if (err != len) {
pr_err("failed to read hardware configuration data from eeprom (err=%d)\n", dev_err(&dev->udev->dev,
err); "failed to read hardware configuration data from eeprom (err=%d)\n",
err);
goto error; goto error;
} }
...@@ -757,7 +763,8 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -757,7 +763,8 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
/* NOTE: not all devices provide this type of dataset */ /* NOTE: not all devices provide this type of dataset */
if (data[0] != 0x1a || data[1] != 0xeb || if (data[0] != 0x1a || data[1] != 0xeb ||
data[2] != 0x67 || data[3] != 0x95) { data[2] != 0x67 || data[3] != 0x95) {
pr_info("\tno hardware configuration dataset found in eeprom\n"); dev_info(&dev->udev->dev,
"\tno hardware configuration dataset found in eeprom\n");
kfree(data); kfree(data);
return 0; return 0;
} }
...@@ -768,11 +775,14 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -768,11 +775,14 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
data[0] == 0x1a && data[1] == 0xeb && data[0] == 0x1a && data[1] == 0xeb &&
data[2] == 0x67 && data[3] == 0x95) { data[2] == 0x67 && data[3] == 0x95) {
dev->hash = em28xx_hash_mem(data, len, 32); dev->hash = em28xx_hash_mem(data, len, 32);
pr_info("EEPROM ID = %02x %02x %02x %02x, EEPROM hash = 0x%08lx\n", dev_info(&dev->udev->dev,
data[0], data[1], data[2], data[3], dev->hash); "EEPROM ID = %02x %02x %02x %02x, EEPROM hash = 0x%08lx\n",
pr_info("EEPROM info:\n"); data[0], data[1], data[2], data[3], dev->hash);
dev_info(&dev->udev->dev,
"EEPROM info:\n");
} else { } else {
pr_info("unknown eeprom format or eeprom corrupted !\n"); dev_info(&dev->udev->dev,
"unknown eeprom format or eeprom corrupted !\n");
err = -ENODEV; err = -ENODEV;
goto error; goto error;
} }
...@@ -783,50 +793,55 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus, ...@@ -783,50 +793,55 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
switch (le16_to_cpu(dev_config->chip_conf) >> 4 & 0x3) { switch (le16_to_cpu(dev_config->chip_conf) >> 4 & 0x3) {
case 0: case 0:
pr_info("\tNo audio on board.\n"); dev_info(&dev->udev->dev, "\tNo audio on board.\n");
break; break;
case 1: case 1:
pr_info("\tAC97 audio (5 sample rates)\n"); dev_info(&dev->udev->dev, "\tAC97 audio (5 sample rates)\n");
break; break;
case 2: case 2:
if (dev->chip_id < CHIP_ID_EM2860) if (dev->chip_id < CHIP_ID_EM2860)
pr_info("\tI2S audio, sample rate=32k\n"); dev_info(&dev->udev->dev,
"\tI2S audio, sample rate=32k\n");
else else
pr_info("\tI2S audio, 3 sample rates\n"); dev_info(&dev->udev->dev,
"\tI2S audio, 3 sample rates\n");
break; break;
case 3: case 3:
if (dev->chip_id < CHIP_ID_EM2860) if (dev->chip_id < CHIP_ID_EM2860)
pr_info("\tI2S audio, 3 sample rates\n"); dev_info(&dev->udev->dev,
"\tI2S audio, 3 sample rates\n");
else else
pr_info("\tI2S audio, 5 sample rates\n"); dev_info(&dev->udev->dev,
"\tI2S audio, 5 sample rates\n");
break; break;
} }
if (le16_to_cpu(dev_config->chip_conf) & 1 << 3) if (le16_to_cpu(dev_config->chip_conf) & 1 << 3)
pr_info("\tUSB Remote wakeup capable\n"); dev_info(&dev->udev->dev, "\tUSB Remote wakeup capable\n");
if (le16_to_cpu(dev_config->chip_conf) & 1 << 2) if (le16_to_cpu(dev_config->chip_conf) & 1 << 2)
pr_info("\tUSB Self power capable\n"); dev_info(&dev->udev->dev, "\tUSB Self power capable\n");
switch (le16_to_cpu(dev_config->chip_conf) & 0x3) { switch (le16_to_cpu(dev_config->chip_conf) & 0x3) {
case 0: case 0:
pr_info("\t500mA max power\n"); dev_info(&dev->udev->dev, "\t500mA max power\n");
break; break;
case 1: case 1:
pr_info("\t400mA max power\n"); dev_info(&dev->udev->dev, "\t400mA max power\n");
break; break;
case 2: case 2:
pr_info("\t300mA max power\n"); dev_info(&dev->udev->dev, "\t300mA max power\n");
break; break;
case 3: case 3:
pr_info("\t200mA max power\n"); dev_info(&dev->udev->dev, "\t200mA max power\n");
break; break;
} }
pr_info("\tTable at offset 0x%02x, strings=0x%04x, 0x%04x, 0x%04x\n", dev_info(&dev->udev->dev,
dev_config->string_idx_table, "\tTable at offset 0x%02x, strings=0x%04x, 0x%04x, 0x%04x\n",
le16_to_cpu(dev_config->string1), dev_config->string_idx_table,
le16_to_cpu(dev_config->string2), le16_to_cpu(dev_config->string1),
le16_to_cpu(dev_config->string3)); le16_to_cpu(dev_config->string2),
le16_to_cpu(dev_config->string3));
return 0; return 0;
...@@ -915,8 +930,9 @@ void em28xx_do_i2c_scan(struct em28xx *dev, unsigned bus) ...@@ -915,8 +930,9 @@ void em28xx_do_i2c_scan(struct em28xx *dev, unsigned bus)
if (rc < 0) if (rc < 0)
continue; continue;
i2c_devicelist[i] = i; i2c_devicelist[i] = i;
pr_info("found i2c device @ 0x%x on bus %d [%s]\n", dev_info(&dev->udev->dev,
i << 1, bus, i2c_devs[i] ? i2c_devs[i] : "???"); "found i2c device @ 0x%x on bus %d [%s]\n",
i << 1, bus, i2c_devs[i] ? i2c_devs[i] : "???");
} }
if (bus == dev->def_i2c_bus) if (bus == dev->def_i2c_bus)
...@@ -941,7 +957,7 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus, ...@@ -941,7 +957,7 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus,
dev->i2c_adap[bus] = em28xx_adap_template; dev->i2c_adap[bus] = em28xx_adap_template;
dev->i2c_adap[bus].dev.parent = &dev->udev->dev; dev->i2c_adap[bus].dev.parent = &dev->udev->dev;
strcpy(dev->i2c_adap[bus].name, dev->name); strcpy(dev->i2c_adap[bus].name, dev_name(&dev->udev->dev));
dev->i2c_bus[bus].bus = bus; dev->i2c_bus[bus].bus = bus;
dev->i2c_bus[bus].algo_type = algo_type; dev->i2c_bus[bus].algo_type = algo_type;
...@@ -950,8 +966,9 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus, ...@@ -950,8 +966,9 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus,
retval = i2c_add_adapter(&dev->i2c_adap[bus]); retval = i2c_add_adapter(&dev->i2c_adap[bus]);
if (retval < 0) { if (retval < 0) {
pr_err("%s: i2c_add_adapter failed! retval [%d]\n", dev_err(&dev->udev->dev,
__func__, retval); "%s: i2c_add_adapter failed! retval [%d]\n",
__func__, retval);
return retval; return retval;
} }
...@@ -962,8 +979,9 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus, ...@@ -962,8 +979,9 @@ int em28xx_i2c_register(struct em28xx *dev, unsigned bus,
if (!bus) { if (!bus) {
retval = em28xx_i2c_eeprom(dev, bus, &dev->eedata, &dev->eedata_len); retval = em28xx_i2c_eeprom(dev, bus, &dev->eedata, &dev->eedata_len);
if ((retval < 0) && (retval != -ENODEV)) { if ((retval < 0) && (retval != -ENODEV)) {
pr_err("%s: em28xx_i2_eeprom failed! retval [%d]\n", dev_err(&dev->udev->dev,
__func__, retval); "%s: em28xx_i2_eeprom failed! retval [%d]\n",
__func__, retval);
return retval; return retval;
} }
......
...@@ -41,10 +41,11 @@ MODULE_PARM_DESC(ir_debug, "enable debug messages [IR]"); ...@@ -41,10 +41,11 @@ MODULE_PARM_DESC(ir_debug, "enable debug messages [IR]");
#define MODULE_NAME "em28xx" #define MODULE_NAME "em28xx"
#define dprintk(fmt, arg...) \ #define dprintk( fmt, arg...) do { \
if (ir_debug) { \ if (ir_debug) \
printk(KERN_DEBUG "%s/ir: " fmt, ir->name , ## arg); \ dev_printk(KERN_DEBUG, &ir->dev->udev->dev, \
} "input: %s: " fmt, __func__, ## arg); \
} while (0)
/********************************************************** /**********************************************************
Polling structure used by em28xx IR's Polling structure used by em28xx IR's
...@@ -458,8 +459,9 @@ static int em28xx_ir_change_protocol(struct rc_dev *rc_dev, u64 *rc_type) ...@@ -458,8 +459,9 @@ static int em28xx_ir_change_protocol(struct rc_dev *rc_dev, u64 *rc_type)
case CHIP_ID_EM28178: case CHIP_ID_EM28178:
return em2874_ir_change_protocol(rc_dev, rc_type); return em2874_ir_change_protocol(rc_dev, rc_type);
default: default:
pr_err("Unrecognized em28xx chip id 0x%02x: IR not supported\n", dev_err(&ir->dev->udev->dev,
dev->chip_id); "Unrecognized em28xx chip id 0x%02x: IR not supported\n",
dev->chip_id);
return -EINVAL; return -EINVAL;
} }
} }
...@@ -567,7 +569,7 @@ static int em28xx_register_snapshot_button(struct em28xx *dev) ...@@ -567,7 +569,7 @@ static int em28xx_register_snapshot_button(struct em28xx *dev)
struct input_dev *input_dev; struct input_dev *input_dev;
int err; int err;
pr_info("Registering snapshot button...\n"); dev_info(&dev->udev->dev, "Registering snapshot button...\n");
input_dev = input_allocate_device(); input_dev = input_allocate_device();
if (!input_dev) if (!input_dev)
return -ENOMEM; return -ENOMEM;
...@@ -591,7 +593,7 @@ static int em28xx_register_snapshot_button(struct em28xx *dev) ...@@ -591,7 +593,7 @@ static int em28xx_register_snapshot_button(struct em28xx *dev)
err = input_register_device(input_dev); err = input_register_device(input_dev);
if (err) { if (err) {
pr_err("input_register_device failed\n"); dev_err(&dev->udev->dev, "input_register_device failed\n");
input_free_device(input_dev); input_free_device(input_dev);
return err; return err;
} }
...@@ -631,7 +633,8 @@ static void em28xx_init_buttons(struct em28xx *dev) ...@@ -631,7 +633,8 @@ static void em28xx_init_buttons(struct em28xx *dev)
} else if (button->role == EM28XX_BUTTON_ILLUMINATION) { } else if (button->role == EM28XX_BUTTON_ILLUMINATION) {
/* Check sanity */ /* Check sanity */
if (!em28xx_find_led(dev, EM28XX_LED_ILLUMINATION)) { if (!em28xx_find_led(dev, EM28XX_LED_ILLUMINATION)) {
pr_err("BUG: illumination button defined, but no illumination LED.\n"); dev_err(&dev->udev->dev,
"BUG: illumination button defined, but no illumination LED.\n");
goto next_button; goto next_button;
} }
} }
...@@ -667,7 +670,7 @@ static void em28xx_shutdown_buttons(struct em28xx *dev) ...@@ -667,7 +670,7 @@ static void em28xx_shutdown_buttons(struct em28xx *dev)
dev->num_button_polling_addresses = 0; dev->num_button_polling_addresses = 0;
/* Deregister input devices */ /* Deregister input devices */
if (dev->sbutton_input_dev != NULL) { if (dev->sbutton_input_dev != NULL) {
pr_info("Deregistering snapshot button\n"); dev_info(&dev->udev->dev, "Deregistering snapshot button\n");
input_unregister_device(dev->sbutton_input_dev); input_unregister_device(dev->sbutton_input_dev);
dev->sbutton_input_dev = NULL; dev->sbutton_input_dev = NULL;
} }
...@@ -696,18 +699,20 @@ static int em28xx_ir_init(struct em28xx *dev) ...@@ -696,18 +699,20 @@ static int em28xx_ir_init(struct em28xx *dev)
i2c_rc_dev_addr = em28xx_probe_i2c_ir(dev); i2c_rc_dev_addr = em28xx_probe_i2c_ir(dev);
if (!i2c_rc_dev_addr) { if (!i2c_rc_dev_addr) {
dev->board.has_ir_i2c = 0; dev->board.has_ir_i2c = 0;
pr_warn("No i2c IR remote control device found.\n"); dev_warn(&dev->udev->dev,
"No i2c IR remote control device found.\n");
return -ENODEV; return -ENODEV;
} }
} }
if (dev->board.ir_codes == NULL && !dev->board.has_ir_i2c) { if (dev->board.ir_codes == NULL && !dev->board.has_ir_i2c) {
/* No remote control support */ /* No remote control support */
pr_warn("Remote control support is not available for this card.\n"); dev_warn(&dev->udev->dev,
"Remote control support is not available for this card.\n");
return 0; return 0;
} }
pr_info("Registering input extension\n"); dev_info(&dev->udev->dev, "Registering input extension\n");
ir = kzalloc(sizeof(*ir), GFP_KERNEL); ir = kzalloc(sizeof(*ir), GFP_KERNEL);
if (!ir) if (!ir)
...@@ -791,7 +796,8 @@ static int em28xx_ir_init(struct em28xx *dev) ...@@ -791,7 +796,8 @@ static int em28xx_ir_init(struct em28xx *dev)
ir->polling = 100; /* ms */ ir->polling = 100; /* ms */
/* init input device */ /* init input device */
snprintf(ir->name, sizeof(ir->name), "em28xx IR (%s)", dev->name); snprintf(ir->name, sizeof(ir->name), "%s IR",
dev_name(&dev->udev->dev));
usb_make_path(dev->udev, ir->phys, sizeof(ir->phys)); usb_make_path(dev->udev, ir->phys, sizeof(ir->phys));
strlcat(ir->phys, "/input0", sizeof(ir->phys)); strlcat(ir->phys, "/input0", sizeof(ir->phys));
...@@ -810,7 +816,7 @@ static int em28xx_ir_init(struct em28xx *dev) ...@@ -810,7 +816,7 @@ static int em28xx_ir_init(struct em28xx *dev)
if (err) if (err)
goto error; goto error;
pr_info("Input extension successfully initalized\n"); dev_info(&dev->udev->dev, "Input extension successfully initalized\n");
return 0; return 0;
...@@ -831,7 +837,7 @@ static int em28xx_ir_fini(struct em28xx *dev) ...@@ -831,7 +837,7 @@ static int em28xx_ir_fini(struct em28xx *dev)
return 0; return 0;
} }
pr_info("Closing input extension\n"); dev_info(&dev->udev->dev, "Closing input extension\n");
em28xx_shutdown_buttons(dev); em28xx_shutdown_buttons(dev);
...@@ -860,7 +866,7 @@ static int em28xx_ir_suspend(struct em28xx *dev) ...@@ -860,7 +866,7 @@ static int em28xx_ir_suspend(struct em28xx *dev)
if (dev->is_audio_only) if (dev->is_audio_only)
return 0; return 0;
pr_info("Suspending input extension\n"); dev_info(&dev->udev->dev, "Suspending input extension\n");
if (ir) if (ir)
cancel_delayed_work_sync(&ir->work); cancel_delayed_work_sync(&ir->work);
cancel_delayed_work_sync(&dev->buttons_query_work); cancel_delayed_work_sync(&dev->buttons_query_work);
...@@ -877,7 +883,7 @@ static int em28xx_ir_resume(struct em28xx *dev) ...@@ -877,7 +883,7 @@ static int em28xx_ir_resume(struct em28xx *dev)
if (dev->is_audio_only) if (dev->is_audio_only)
return 0; return 0;
pr_info("Resuming input extension\n"); dev_info(&dev->udev->dev, "Resuming input extension\n");
/* if suspend calls ir_raw_event_unregister(), the should call /* if suspend calls ir_raw_event_unregister(), the should call
ir_raw_event_register() */ ir_raw_event_register() */
if (ir) if (ir)
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/hardirq.h> #include <linux/hardirq.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/usb.h>
#include "em28xx-v4l.h" #include "em28xx-v4l.h"
...@@ -64,8 +65,9 @@ static int vbi_buffer_prepare(struct vb2_buffer *vb) ...@@ -64,8 +65,9 @@ static int vbi_buffer_prepare(struct vb2_buffer *vb)
size = v4l2->vbi_width * v4l2->vbi_height * 2; size = v4l2->vbi_width * v4l2->vbi_height * 2;
if (vb2_plane_size(vb, 0) < size) { if (vb2_plane_size(vb, 0) < size) {
pr_info("%s data will not fit into plane (%lu < %lu)\n", dev_info(&dev->udev->dev,
__func__, vb2_plane_size(vb, 0), size); "%s data will not fit into plane (%lu < %lu)\n",
__func__, vb2_plane_size(vb, 0), size);
return -EINVAL; return -EINVAL;
} }
vb2_set_plane_payload(vb, 0, size); vb2_set_plane_payload(vb, 0, size);
......
...@@ -64,15 +64,17 @@ static int alt; ...@@ -64,15 +64,17 @@ static int alt;
module_param(alt, int, 0644); module_param(alt, int, 0644);
MODULE_PARM_DESC(alt, "alternate setting to use for video endpoint"); MODULE_PARM_DESC(alt, "alternate setting to use for video endpoint");
#define em28xx_videodbg(fmt, arg...) do {\ #define em28xx_videodbg(fmt, arg...) do { \
if (video_debug) \ if (video_debug) \
printk(KERN_DEBUG pr_fmt("video: %s: " fmt), \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
__func__, ##arg); } while (0) "video: %s: " fmt, __func__, ## arg); \
} while (0)
#define em28xx_isocdbg(fmt, arg...) do {\ #define em28xx_isocdbg(fmt, arg...) do {\
if (isoc_debug) \ if (isoc_debug) \
printk(KERN_DEBUG pr_fmt("isoc: %s: " fmt), \ dev_printk(KERN_DEBUG, &dev->udev->dev, \
__func__, ##arg); } while (0) "isoc: %s: " fmt, __func__, ## arg); \
} while (0)
MODULE_AUTHOR(DRIVER_AUTHOR); MODULE_AUTHOR(DRIVER_AUTHOR);
MODULE_DESCRIPTION(DRIVER_DESC " - v4l2 interface"); MODULE_DESCRIPTION(DRIVER_DESC " - v4l2 interface");
...@@ -411,8 +413,9 @@ static int em28xx_set_alternate(struct em28xx *dev) ...@@ -411,8 +413,9 @@ static int em28xx_set_alternate(struct em28xx *dev)
dev->alt, dev->max_pkt_size); dev->alt, dev->max_pkt_size);
errCode = usb_set_interface(dev->udev, dev->ifnum, dev->alt); errCode = usb_set_interface(dev->udev, dev->ifnum, dev->alt);
if (errCode < 0) { if (errCode < 0) {
pr_err("cannot change alternate number to %d (error=%i)\n", dev_err(&dev->udev->dev,
dev->alt, errCode); "cannot change alternate number to %d (error=%i)\n",
dev->alt, errCode);
return errCode; return errCode;
} }
return 0; return 0;
...@@ -923,10 +926,11 @@ static int em28xx_enable_analog_tuner(struct em28xx *dev) ...@@ -923,10 +926,11 @@ static int em28xx_enable_analog_tuner(struct em28xx *dev)
ret = media_entity_setup_link(link, flags); ret = media_entity_setup_link(link, flags);
if (ret) { if (ret) {
pr_err("Couldn't change link %s->%s to %s. Error %d\n", dev_err(&dev->udev->dev,
source->name, sink->name, "Couldn't change link %s->%s to %s. Error %d\n",
flags ? "enabled" : "disabled", source->name, sink->name,
ret); flags ? "enabled" : "disabled",
ret);
return ret; return ret;
} else } else
em28xx_videodbg("link %s->%s was %s\n", em28xx_videodbg("link %s->%s was %s\n",
...@@ -954,14 +958,16 @@ static void em28xx_v4l2_create_entities(struct em28xx *dev) ...@@ -954,14 +958,16 @@ static void em28xx_v4l2_create_entities(struct em28xx *dev)
v4l2->video_pad.flags = MEDIA_PAD_FL_SINK; v4l2->video_pad.flags = MEDIA_PAD_FL_SINK;
ret = media_entity_pads_init(&v4l2->vdev.entity, 1, &v4l2->video_pad); ret = media_entity_pads_init(&v4l2->vdev.entity, 1, &v4l2->video_pad);
if (ret < 0) if (ret < 0)
pr_err("failed to initialize video media entity!\n"); dev_err(&dev->udev->dev,
"failed to initialize video media entity!\n");
if (em28xx_vbi_supported(dev)) { if (em28xx_vbi_supported(dev)) {
v4l2->vbi_pad.flags = MEDIA_PAD_FL_SINK; v4l2->vbi_pad.flags = MEDIA_PAD_FL_SINK;
ret = media_entity_pads_init(&v4l2->vbi_dev.entity, 1, ret = media_entity_pads_init(&v4l2->vbi_dev.entity, 1,
&v4l2->vbi_pad); &v4l2->vbi_pad);
if (ret < 0) if (ret < 0)
pr_err("failed to initialize vbi media entity!\n"); dev_err(&dev->udev->dev,
"failed to initialize vbi media entity!\n");
} }
/* Webcams don't have input connectors */ /* Webcams don't have input connectors */
...@@ -994,11 +1000,13 @@ static void em28xx_v4l2_create_entities(struct em28xx *dev) ...@@ -994,11 +1000,13 @@ static void em28xx_v4l2_create_entities(struct em28xx *dev)
ret = media_entity_pads_init(ent, 1, &dev->input_pad[i]); ret = media_entity_pads_init(ent, 1, &dev->input_pad[i]);
if (ret < 0) if (ret < 0)
pr_err("failed to initialize input pad[%d]!\n", i); dev_err(&dev->udev->dev,
"failed to initialize input pad[%d]!\n", i);
ret = media_device_register_entity(dev->media_dev, ent); ret = media_device_register_entity(dev->media_dev, ent);
if (ret < 0) if (ret < 0)
pr_err("failed to register input entity %d!\n", i); dev_err(&dev->udev->dev,
"failed to register input entity %d!\n", i);
} }
#endif #endif
} }
...@@ -2045,7 +2053,8 @@ static int em28xx_v4l2_open(struct file *filp) ...@@ -2045,7 +2053,8 @@ static int em28xx_v4l2_open(struct file *filp)
ret = v4l2_fh_open(filp); ret = v4l2_fh_open(filp);
if (ret) { if (ret) {
pr_err("%s: v4l2_fh_open() returned error %d\n", dev_err(&dev->udev->dev,
"%s: v4l2_fh_open() returned error %d\n",
__func__, ret); __func__, ret);
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return ret; return ret;
...@@ -2100,7 +2109,7 @@ static int em28xx_v4l2_fini(struct em28xx *dev) ...@@ -2100,7 +2109,7 @@ static int em28xx_v4l2_fini(struct em28xx *dev)
if (v4l2 == NULL) if (v4l2 == NULL)
return 0; return 0;
pr_info("Closing video extension\n"); dev_info(&dev->udev->dev, "Closing video extension\n");
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
...@@ -2111,17 +2120,17 @@ static int em28xx_v4l2_fini(struct em28xx *dev) ...@@ -2111,17 +2120,17 @@ static int em28xx_v4l2_fini(struct em28xx *dev)
em28xx_v4l2_media_release(dev); em28xx_v4l2_media_release(dev);
if (video_is_registered(&v4l2->radio_dev)) { if (video_is_registered(&v4l2->radio_dev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev, "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->radio_dev)); video_device_node_name(&v4l2->radio_dev));
video_unregister_device(&v4l2->radio_dev); video_unregister_device(&v4l2->radio_dev);
} }
if (video_is_registered(&v4l2->vbi_dev)) { if (video_is_registered(&v4l2->vbi_dev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev, "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->vbi_dev)); video_device_node_name(&v4l2->vbi_dev));
video_unregister_device(&v4l2->vbi_dev); video_unregister_device(&v4l2->vbi_dev);
} }
if (video_is_registered(&v4l2->vdev)) { if (video_is_registered(&v4l2->vdev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev, "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->vdev)); video_device_node_name(&v4l2->vdev));
video_unregister_device(&v4l2->vdev); video_unregister_device(&v4l2->vdev);
} }
...@@ -2151,7 +2160,7 @@ static int em28xx_v4l2_suspend(struct em28xx *dev) ...@@ -2151,7 +2160,7 @@ static int em28xx_v4l2_suspend(struct em28xx *dev)
if (!dev->has_video) if (!dev->has_video)
return 0; return 0;
pr_info("Suspending video extension\n"); dev_info(&dev->udev->dev, "Suspending video extension\n");
em28xx_stop_urbs(dev); em28xx_stop_urbs(dev);
return 0; return 0;
} }
...@@ -2164,7 +2173,7 @@ static int em28xx_v4l2_resume(struct em28xx *dev) ...@@ -2164,7 +2173,7 @@ static int em28xx_v4l2_resume(struct em28xx *dev)
if (!dev->has_video) if (!dev->has_video)
return 0; return 0;
pr_info("Resuming video extension\n"); dev_info(&dev->udev->dev, "Resuming video extension\n");
/* what do we do here */ /* what do we do here */
return 0; return 0;
} }
...@@ -2201,8 +2210,9 @@ static int em28xx_v4l2_close(struct file *filp) ...@@ -2201,8 +2210,9 @@ static int em28xx_v4l2_close(struct file *filp)
em28xx_videodbg("setting alternate 0\n"); em28xx_videodbg("setting alternate 0\n");
errCode = usb_set_interface(dev->udev, 0, 0); errCode = usb_set_interface(dev->udev, 0, 0);
if (errCode < 0) { if (errCode < 0) {
pr_err("cannot change alternate number to 0 (error=%i)\n", dev_err(&dev->udev->dev,
errCode); "cannot change alternate number to 0 (error=%i)\n",
errCode);
} }
} }
...@@ -2335,7 +2345,7 @@ static void em28xx_vdev_init(struct em28xx *dev, ...@@ -2335,7 +2345,7 @@ static void em28xx_vdev_init(struct em28xx *dev,
vfd->tvnorms = 0; vfd->tvnorms = 0;
snprintf(vfd->name, sizeof(vfd->name), "%s %s", snprintf(vfd->name, sizeof(vfd->name), "%s %s",
dev->name, type_name); dev_name(&dev->udev->dev), type_name);
video_set_drvdata(vfd, dev); video_set_drvdata(vfd, dev);
} }
...@@ -2419,7 +2429,7 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2419,7 +2429,7 @@ static int em28xx_v4l2_init(struct em28xx *dev)
return 0; return 0;
} }
pr_info("Registering V4L2 extension\n"); dev_info(&dev->udev->dev, "Registering V4L2 extension\n");
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
...@@ -2437,7 +2447,8 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2437,7 +2447,8 @@ static int em28xx_v4l2_init(struct em28xx *dev)
#endif #endif
ret = v4l2_device_register(&dev->udev->dev, &v4l2->v4l2_dev); ret = v4l2_device_register(&dev->udev->dev, &v4l2->v4l2_dev);
if (ret < 0) { if (ret < 0) {
pr_err("Call to v4l2_device_register() failed!\n"); dev_err(&dev->udev->dev,
"Call to v4l2_device_register() failed!\n");
goto err; goto err;
} }
...@@ -2521,8 +2532,9 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2521,8 +2532,9 @@ static int em28xx_v4l2_init(struct em28xx *dev)
/* Configure audio */ /* Configure audio */
ret = em28xx_audio_setup(dev); ret = em28xx_audio_setup(dev);
if (ret < 0) { if (ret < 0) {
pr_err("%s: Error while setting audio - error [%d]!\n", dev_err(&dev->udev->dev,
__func__, ret); "%s: Error while setting audio - error [%d]!\n",
__func__, ret);
goto unregister_dev; goto unregister_dev;
} }
if (dev->audio_mode.ac97 != EM28XX_NO_AC97) { if (dev->audio_mode.ac97 != EM28XX_NO_AC97) {
...@@ -2549,16 +2561,18 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2549,16 +2561,18 @@ static int em28xx_v4l2_init(struct em28xx *dev)
/* Send a reset to other chips via gpio */ /* Send a reset to other chips via gpio */
ret = em28xx_write_reg(dev, EM2820_R08_GPIO_CTRL, 0xf7); ret = em28xx_write_reg(dev, EM2820_R08_GPIO_CTRL, 0xf7);
if (ret < 0) { if (ret < 0) {
pr_err("%s: em28xx_write_reg - msp34xx(1) failed! error [%d]\n", dev_err(&dev->udev->dev,
__func__, ret); "%s: em28xx_write_reg - msp34xx(1) failed! error [%d]\n",
__func__, ret);
goto unregister_dev; goto unregister_dev;
} }
msleep(3); msleep(3);
ret = em28xx_write_reg(dev, EM2820_R08_GPIO_CTRL, 0xff); ret = em28xx_write_reg(dev, EM2820_R08_GPIO_CTRL, 0xff);
if (ret < 0) { if (ret < 0) {
pr_err("%s: em28xx_write_reg - msp34xx(2) failed! error [%d]\n", dev_err(&dev->udev->dev,
__func__, ret); "%s: em28xx_write_reg - msp34xx(2) failed! error [%d]\n",
__func__, ret);
goto unregister_dev; goto unregister_dev;
} }
msleep(3); msleep(3);
...@@ -2659,7 +2673,8 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2659,7 +2673,8 @@ static int em28xx_v4l2_init(struct em28xx *dev)
ret = video_register_device(&v4l2->vdev, VFL_TYPE_GRABBER, ret = video_register_device(&v4l2->vdev, VFL_TYPE_GRABBER,
video_nr[dev->devno]); video_nr[dev->devno]);
if (ret) { if (ret) {
pr_err("unable to register video device (error=%i).\n", ret); dev_err(&dev->udev->dev,
"unable to register video device (error=%i).\n", ret);
goto unregister_dev; goto unregister_dev;
} }
...@@ -2688,7 +2703,8 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2688,7 +2703,8 @@ static int em28xx_v4l2_init(struct em28xx *dev)
ret = video_register_device(&v4l2->vbi_dev, VFL_TYPE_VBI, ret = video_register_device(&v4l2->vbi_dev, VFL_TYPE_VBI,
vbi_nr[dev->devno]); vbi_nr[dev->devno]);
if (ret < 0) { if (ret < 0) {
pr_err("unable to register vbi device\n"); dev_err(&dev->udev->dev,
"unable to register vbi device\n");
goto unregister_dev; goto unregister_dev;
} }
} }
...@@ -2699,11 +2715,13 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2699,11 +2715,13 @@ static int em28xx_v4l2_init(struct em28xx *dev)
ret = video_register_device(&v4l2->radio_dev, VFL_TYPE_RADIO, ret = video_register_device(&v4l2->radio_dev, VFL_TYPE_RADIO,
radio_nr[dev->devno]); radio_nr[dev->devno]);
if (ret < 0) { if (ret < 0) {
pr_err("can't register radio device\n"); dev_err(&dev->udev->dev,
"can't register radio device\n");
goto unregister_dev; goto unregister_dev;
} }
pr_info("Registered radio device as %s\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->radio_dev)); "Registered radio device as %s\n",
video_device_node_name(&v4l2->radio_dev));
} }
/* Init entities at the Media Controller */ /* Init entities at the Media Controller */
...@@ -2712,18 +2730,21 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2712,18 +2730,21 @@ static int em28xx_v4l2_init(struct em28xx *dev)
#ifdef CONFIG_MEDIA_CONTROLLER #ifdef CONFIG_MEDIA_CONTROLLER
ret = v4l2_mc_create_media_graph(dev->media_dev); ret = v4l2_mc_create_media_graph(dev->media_dev);
if (ret) { if (ret) {
pr_err("failed to create media graph\n"); dev_err(&dev->udev->dev,
"failed to create media graph\n");
em28xx_v4l2_media_release(dev); em28xx_v4l2_media_release(dev);
goto unregister_dev; goto unregister_dev;
} }
#endif #endif
pr_info("V4L2 video device registered as %s\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->vdev)); "V4L2 video device registered as %s\n",
video_device_node_name(&v4l2->vdev));
if (video_is_registered(&v4l2->vbi_dev)) if (video_is_registered(&v4l2->vbi_dev))
pr_info("V4L2 VBI device registered as %s\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->vbi_dev)); "V4L2 VBI device registered as %s\n",
video_device_node_name(&v4l2->vbi_dev));
/* Save some power by putting tuner to sleep */ /* Save some power by putting tuner to sleep */
v4l2_device_call_all(&v4l2->v4l2_dev, 0, core, s_power, 0); v4l2_device_call_all(&v4l2->v4l2_dev, 0, core, s_power, 0);
...@@ -2731,7 +2752,8 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2731,7 +2752,8 @@ static int em28xx_v4l2_init(struct em28xx *dev)
/* initialize videobuf2 stuff */ /* initialize videobuf2 stuff */
em28xx_vb2_setup(dev); em28xx_vb2_setup(dev);
pr_info("V4L2 extension successfully initialized\n"); dev_info(&dev->udev->dev,
"V4L2 extension successfully initialized\n");
kref_get(&dev->ref); kref_get(&dev->ref);
...@@ -2740,18 +2762,21 @@ static int em28xx_v4l2_init(struct em28xx *dev) ...@@ -2740,18 +2762,21 @@ static int em28xx_v4l2_init(struct em28xx *dev)
unregister_dev: unregister_dev:
if (video_is_registered(&v4l2->radio_dev)) { if (video_is_registered(&v4l2->radio_dev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->radio_dev)); "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->radio_dev));
video_unregister_device(&v4l2->radio_dev); video_unregister_device(&v4l2->radio_dev);
} }
if (video_is_registered(&v4l2->vbi_dev)) { if (video_is_registered(&v4l2->vbi_dev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->vbi_dev)); "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->vbi_dev));
video_unregister_device(&v4l2->vbi_dev); video_unregister_device(&v4l2->vbi_dev);
} }
if (video_is_registered(&v4l2->vdev)) { if (video_is_registered(&v4l2->vdev)) {
pr_info("V4L2 device %s deregistered\n", dev_info(&dev->udev->dev,
video_device_node_name(&v4l2->vdev)); "V4L2 device %s deregistered\n",
video_device_node_name(&v4l2->vdev));
video_unregister_device(&v4l2->vdev); video_unregister_device(&v4l2->vdev);
} }
......
...@@ -29,8 +29,6 @@ ...@@ -29,8 +29,6 @@
#define EM28XX_VERSION "0.2.2" #define EM28XX_VERSION "0.2.2"
#define DRIVER_DESC "Empia em28xx device driver" #define DRIVER_DESC "Empia em28xx device driver"
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/mutex.h> #include <linux/mutex.h>
...@@ -612,7 +610,6 @@ struct em28xx { ...@@ -612,7 +610,6 @@ struct em28xx {
struct em28xx_IR *ir; struct em28xx_IR *ir;
/* generic device properties */ /* generic device properties */
char name[30]; /* name (including minor) of the device */
int model; /* index in the device_data struct */ int model; /* index in the device_data struct */
int devno; /* marks the number of this device */ int devno; /* marks the number of this device */
enum em28xx_chip_id chip_id; enum em28xx_chip_id chip_id;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册