diff options
32 files changed, 456 insertions, 301 deletions
diff --git a/linux/drivers/media/video/cs53l32a.c b/linux/drivers/media/video/cs53l32a.c index 07644a97d..f0240e079 100644 --- a/linux/drivers/media/video/cs53l32a.c +++ b/linux/drivers/media/video/cs53l32a.c @@ -28,6 +28,7 @@ #include <linux/i2c-id.h> #include <linux/videodev.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) #include "i2c-compat.h" #include <linux/slab.h> @@ -115,6 +116,9 @@ static int cs53l32a_command(struct i2c_client *client, unsigned int cmd, cs53l32a_write(client, 0x05, (u8) ctrl->value); break; + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_CS53l32A, 0); + case VIDIOC_LOG_STATUS: { u8 v = cs53l32a_read(client, 0x01); diff --git a/linux/drivers/media/video/cx25840/cx25840-core.c b/linux/drivers/media/video/cx25840/cx25840-core.c index d5a0789bc..c401c1ee7 100644 --- a/linux/drivers/media/video/cx25840/cx25840-core.c +++ b/linux/drivers/media/video/cx25840/cx25840-core.c @@ -840,15 +840,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd, break; case VIDIOC_G_CHIP_IDENT: - { - struct v4l2_chip_ident *chip = arg; - - if (!v4l2_chip_match_i2c_client(client, chip->match_type, chip->match_chip)) - return -EINVAL; - chip->ident = state->id; - chip->revision = state->rev; - break; - } + return v4l2_chip_ident_i2c_client(client, arg, state->id, state->rev); default: return -EINVAL; diff --git a/linux/drivers/media/video/ivtv/ivtv-cards.c b/linux/drivers/media/video/ivtv/ivtv-cards.c index 2ee7b8701..8eab02083 100644 --- a/linux/drivers/media/video/ivtv/ivtv-cards.c +++ b/linux/drivers/media/video/ivtv/ivtv-cards.c @@ -604,8 +604,8 @@ static const struct ivtv_card ivtv_card_cx23416gyc_nogrycs = { static const struct ivtv_card_pci_info ivtv_pci_gv_mvprx[] = { { PCI_DEVICE_ID_IVTV16, IVTV_PCI_ID_IODATA, 0xd01e }, - { PCI_DEVICE_ID_IVTV16, IVTV_PCI_ID_IODATA, 0xd038 }, //2W#1 - { PCI_DEVICE_ID_IVTV16, IVTV_PCI_ID_IODATA, 0xd039 }, //2W#2 + { PCI_DEVICE_ID_IVTV16, IVTV_PCI_ID_IODATA, 0xd038 }, /* 2W unit #1 */ + { PCI_DEVICE_ID_IVTV16, IVTV_PCI_ID_IODATA, 0xd039 }, /* 2W unit #2 */ { 0, 0, 0 } }; @@ -651,7 +651,7 @@ static const struct ivtv_card ivtv_card_gv_mvprx2e = { .name = "I/O Data GV-MVP/RX2E", .v4l2_capabilities = IVTV_CAP_ENCODER, .hw_video = IVTV_HW_SAA7115, - .hw_audio = IVTV_HW_GPIO, // |IVTV_HW_WM8739, + .hw_audio = IVTV_HW_GPIO, .hw_audio_ctrl = IVTV_HW_WM8739, .hw_all = IVTV_HW_GPIO | IVTV_HW_SAA7115 | IVTV_HW_TUNER | IVTV_HW_TVAUDIO | IVTV_HW_WM8739, diff --git a/linux/drivers/media/video/ivtv/ivtv-controls.c b/linux/drivers/media/video/ivtv/ivtv-controls.c index d0e39ba2b..7a876c3e5 100644 --- a/linux/drivers/media/video/ivtv/ivtv-controls.c +++ b/linux/drivers/media/video/ivtv/ivtv-controls.c @@ -158,12 +158,12 @@ static int ivtv_setup_vbi_fmt(struct ivtv *itv, enum v4l2_mpeg_stream_vbi_fmt fm if (atomic_read(&itv->capturing) > 0) return -EBUSY; - // First try to allocate sliced VBI buffers if needed. + /* First try to allocate sliced VBI buffers if needed. */ if (fmt && itv->vbi.sliced_mpeg_data[0] == NULL) { int i; for (i = 0; i < IVTV_VBI_FRAMES; i++) { - // Yuck, hardcoded. Needs to be a define + /* Yuck, hardcoded. Needs to be a define */ itv->vbi.sliced_mpeg_data[i] = kmalloc(2049, GFP_KERNEL); if (itv->vbi.sliced_mpeg_data[i] == NULL) { while (--i >= 0) { @@ -246,13 +246,7 @@ int ivtv_control_ioctls(struct ivtv *itv, unsigned int cmd, void *arg) fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; fmt.fmt.pix.width = itv->params.width / (is_mpeg1 ? 2 : 1); fmt.fmt.pix.height = itv->params.height; -// if (atomic_read(&itv->capturing) > 0) { -// IVTV_DEBUG_WARN( -// "v4l2 ioctl: set size failed, " -// "capture in progress\n"); -// } else { - itv->video_dec_func(itv, VIDIOC_S_FMT, &fmt); -// } + itv->video_dec_func(itv, VIDIOC_S_FMT, &fmt); } err = cx2341x_update(itv, ivtv_api_func, &itv->params, &p); if (!err && itv->params.stream_vbi_fmt != p.stream_vbi_fmt) { diff --git a/linux/drivers/media/video/ivtv/ivtv-driver.c b/linux/drivers/media/video/ivtv/ivtv-driver.c index 60fdefd02..83102b4f5 100644 --- a/linux/drivers/media/video/ivtv/ivtv-driver.c +++ b/linux/drivers/media/video/ivtv/ivtv-driver.c @@ -119,7 +119,7 @@ static int ivtv_yuv_mode = 0; static int ivtv_yuv_threshold=480; static int ivtv_pci_latency = 1; -int ivtv_debug = IVTV_DBGFLG_WARN; +int ivtv_debug = 0; int newi2c = -1; @@ -336,9 +336,9 @@ static void ivtv_process_eeprom(struct ivtv *itv) /* Many thanks to Steven Toth from Hauppauge for providing the model numbers */ switch (tv.model) { - // In a few cases the PCI subsystem IDs do not correctly - // identify the card. A better method is to check the - // model number from the eeprom instead. + /* In a few cases the PCI subsystem IDs do not correctly + identify the card. A better method is to check the + model number from the eeprom instead. */ case 32000 ... 32999: case 48000 ... 48099: /* 48??? range are PVR250s with a cx23415 */ case 48400 ... 48599: @@ -433,7 +433,7 @@ static void ivtv_process_eeprom(struct ivtv *itv) } if (itv->std != 0) - // user specified tuner standard + /* user specified tuner standard */ return; /* autodetect tuner standard */ @@ -677,6 +677,7 @@ static int __devinit ivtv_init_struct1(struct ivtv *itv) /* OSD */ itv->osd_global_alpha_state = 1; + itv->osd_global_alpha = 255; /* YUV */ atomic_set(&itv->yuv_info.next_dma_frame, -1); @@ -685,8 +686,8 @@ static int __devinit ivtv_init_struct1(struct ivtv *itv) return 0; } -// Second initialization part. Here the card type has been -// autodetected. +/* Second initialization part. Here the card type has been + autodetected. */ static void __devinit ivtv_init_struct2(struct ivtv *itv) { int i; @@ -709,9 +710,9 @@ static void __devinit ivtv_init_struct2(struct ivtv *itv) itv->digitizer = 0x140; if (itv->card->hw_all & IVTV_HW_CX25840) { - itv->vbi.sliced_size = 288; // multiple of 16, real size = 284 + itv->vbi.sliced_size = 288; /* multiple of 16, real size = 284 */ } else { - itv->vbi.sliced_size = 64; // multiple of 16, real size = 52 + itv->vbi.sliced_size = 64; /* multiple of 16, real size = 52 */ } /* Find tuner input */ @@ -1077,8 +1078,8 @@ static int __devinit ivtv_probe(struct pci_dev *dev, #ifdef CONFIG_VIDEO_TVEEPROM_MODULE ivtv_request_module(itv, "tveeprom"); #endif - // Based on the model number the cardtype may be changed. - // The PCI IDs are not always reliable. + /* Based on the model number the cardtype may be changed. + The PCI IDs are not always reliable. */ ivtv_process_eeprom(itv); } @@ -1104,8 +1105,8 @@ static int __devinit ivtv_probe(struct pci_dev *dev, if (itv->options.radio == -1) itv->options.radio = (itv->card->radio_input.audio_type != 0); - // The card is now fully identified, continue with card-specific - // initialization. + /* The card is now fully identified, continue with card-specific + initialization. */ ivtv_init_struct2(itv); ivtv_load_and_init_modules(itv); @@ -1131,14 +1132,14 @@ static int __devinit ivtv_probe(struct pci_dev *dev, /* Setup VBI Raw Size. Should be big enough to hold PAL. It is possible to switch between PAL and NTSC, so we need to take the largest size here. */ - // 1456 is multiple of 16, real size = 1444 + /* 1456 is multiple of 16, real size = 1444 */ itv->vbi.raw_size = 1456; - // We use a buffer size of 1/2 of the total size needed for a - // frame. This is actually very useful, since we now receive - // a field at a time and that makes 'compressing' the raw data - // down to size by stripping off the SAV codes a lot easier. - // Note: having two different buffer sizes prevents standard - // switching on the fly. We need to find a better solution... + /* We use a buffer size of 1/2 of the total size needed for a + frame. This is actually very useful, since we now receive + a field at a time and that makes 'compressing' the raw data + down to size by stripping off the SAV codes a lot easier. + Note: having two different buffer sizes prevents standard + switching on the fly. We need to find a better solution... */ vbi_buf_size = itv->vbi.raw_size * (itv->is_60hz ? 24 : 36) / 2; itv->stream_buf_size[IVTV_ENC_STREAM_TYPE_VBI] = vbi_buf_size; itv->stream_buf_size[IVTV_DEC_STREAM_TYPE_VBI] = sizeof(struct v4l2_sliced_vbi_data) * 36; @@ -1220,7 +1221,7 @@ static int __devinit ivtv_probe(struct pci_dev *dev, /* Let the VIDIOC_S_STD ioctl do all the work, keeps the code in one place. */ - itv->std++; // Force full standard initialization + itv->std++; /* Force full standard initialization */ itv->std_out = itv->std; ivtv_v4l2_ioctls(itv, NULL, VIDIOC_S_STD, &itv->tuner_std); ivtv_v4l2_ioctls(itv, NULL, VIDIOC_S_FREQUENCY, &vf); @@ -1344,7 +1345,7 @@ static int module_start(void) } if (ivtv_debug < 0 || ivtv_debug > 511) { - ivtv_debug = 1; + ivtv_debug = 0; printk(KERN_INFO "ivtv: debug value must be >= 0 and <= 511!\n"); } diff --git a/linux/drivers/media/video/ivtv/ivtv-driver.h b/linux/drivers/media/video/ivtv/ivtv-driver.h index 389eded7f..3daf1a9fc 100644 --- a/linux/drivers/media/video/ivtv/ivtv-driver.h +++ b/linux/drivers/media/video/ivtv/ivtv-driver.h @@ -53,7 +53,9 @@ #include <linux/byteorder/swab.h> #include <linux/pagemap.h> #include <linux/workqueue.h> +#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,15) #include <linux/mutex.h> +#endif #include <asm/uaccess.h> #include <asm/system.h> @@ -63,7 +65,7 @@ #include <media/tuner.h> #include <media/cx2341x.h> -//#define HAVE_XC3028 1 +/* #define HAVE_XC3028 1 */ #include <media/ivtv.h> @@ -97,13 +99,13 @@ extern const u32 yuv_offset[4]; -// Maximum ivtv driver instances. -// Based on 6 PVR500s each with two PVR15s... -// TODO: make this dynamic. I believe it is only a global in order to support -// ivtv-fb. There must be a better way to do that. +/* Maximum ivtv driver instances. + Based on 6 PVR500s each with two PVR15s... + TODO: make this dynamic. I believe it is only a global in order to support + ivtv-fb. There must be a better way to do that. */ #define IVTV_MAX_CARDS 12 -// Supported cards +/* Supported cards */ #define IVTV_CARD_PVR_250 0 /* WinTV PVR 250 */ #define IVTV_CARD_PVR_350 1 /* encoder, decoder, tv-out */ #define IVTV_CARD_PVR_150 2 /* WinTV PVR 150 and PVR 500 (really just two @@ -413,7 +415,11 @@ struct ivtv_SG_element { }; struct ivtv_user_dma { +#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,15) struct mutex lock; +#else + struct semaphore lock; +#endif int page_count; struct page *map[IVTV_DMA_SG_OSD_ENT]; @@ -703,7 +709,7 @@ struct ivtv { u32 v4l2_cap; /* V4L2 capabilities of card */ u32 hw_flags; /* Hardware description of the board */ - // controlling Video decoder function + /* controlling Video decoder function */ int (*video_dec_func)(struct ivtv *, unsigned int, void *); struct ivtv_options options; /* User options */ @@ -778,7 +784,11 @@ struct ivtv { struct i2c_adapter i2c_adap; struct i2c_algo_bit_data i2c_algo; struct i2c_client i2c_client; +#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,15) struct mutex i2c_bus_lock; +#else + struct semaphore i2c_bus_lock; +#endif int i2c_state; struct i2c_client *i2c_clients[I2C_CLIENTS_MAX]; diff --git a/linux/drivers/media/video/ivtv/ivtv-fileops.c b/linux/drivers/media/video/ivtv/ivtv-fileops.c index d7bb76931..90e0f51e6 100644 --- a/linux/drivers/media/video/ivtv/ivtv-fileops.c +++ b/linux/drivers/media/video/ivtv/ivtv-fileops.c @@ -46,9 +46,9 @@ int ivtv_claim_stream(struct ivtv_open_id *id, int type) int vbi_type; if (test_and_set_bit(IVTV_F_S_CLAIMED, &s->s_flags)) { - // someone already claimed this stream + /* someone already claimed this stream */ if (s->id == id->open_id) { - // yes, this file descriptor did. So that's OK. + /* yes, this file descriptor did. So that's OK. */ return 0; } if (s->id == -1 && (type == IVTV_DEC_STREAM_TYPE_VBI || @@ -66,7 +66,7 @@ int ivtv_claim_stream(struct ivtv_open_id *id, int type) } s->id = id->open_id; if (type == IVTV_DEC_STREAM_TYPE_VBI) { - // Enable reinsertion interrupt + /* Enable reinsertion interrupt */ ivtv_clear_irq_mask(itv, IVTV_IRQ_DEC_VBI_RE_INSERT); } @@ -85,11 +85,11 @@ int ivtv_claim_stream(struct ivtv_open_id *id, int type) s_vbi = &itv->streams[vbi_type]; if (!test_and_set_bit(IVTV_F_S_CLAIMED, &s_vbi->s_flags)) { - // Enable reinsertion interrupt + /* Enable reinsertion interrupt */ if (vbi_type == IVTV_DEC_STREAM_TYPE_VBI) ivtv_clear_irq_mask(itv, IVTV_IRQ_DEC_VBI_RE_INSERT); } - // mark that it is used internally + /* mark that it is used internally */ set_bit(IVTV_F_S_INTERNAL_USE, &s_vbi->s_flags); return 0; } @@ -104,7 +104,7 @@ void ivtv_release_stream(struct ivtv_stream *s) s->id = -1; if ((s->type == IVTV_DEC_STREAM_TYPE_VBI || s->type == IVTV_ENC_STREAM_TYPE_VBI) && test_bit(IVTV_F_S_INTERNAL_USE, &s->s_flags)) { - // this stream is still in use internally + /* this stream is still in use internally */ return; } if (!test_and_clear_bit(IVTV_F_S_CLAIMED, &s->s_flags)) { @@ -114,7 +114,7 @@ void ivtv_release_stream(struct ivtv_stream *s) ivtv_flush_queues(s); - // disable reinsertion interrupt + /* disable reinsertion interrupt */ if (s->type == IVTV_DEC_STREAM_TYPE_VBI) ivtv_set_irq_mask(itv, IVTV_IRQ_DEC_VBI_RE_INSERT); @@ -128,16 +128,16 @@ void ivtv_release_stream(struct ivtv_stream *s) else return; - // clear internal use flag + /* clear internal use flag */ if (!test_and_clear_bit(IVTV_F_S_INTERNAL_USE, &s_vbi->s_flags)) { - // was already cleared + /* was already cleared */ return; } if (s_vbi->id != -1) { - // VBI stream still claimed by a file descriptor + /* VBI stream still claimed by a file descriptor */ return; } - // disable reinsertion interrupt + /* disable reinsertion interrupt */ if (s_vbi->type == IVTV_DEC_STREAM_TYPE_VBI) ivtv_set_irq_mask(itv, IVTV_IRQ_DEC_VBI_RE_INSERT); clear_bit(IVTV_F_S_CLAIMED, &s_vbi->s_flags); @@ -776,7 +776,7 @@ int ivtv_v4l2_close(struct inode *inode, struct file *filp) /* Stop radio */ if (id->type == IVTV_ENC_STREAM_TYPE_RAD) { - // Closing radio device, return to TV mode + /* Closing radio device, return to TV mode */ ivtv_mute(itv); /* Mark that the radio is no longer in use */ clear_bit(IVTV_F_I_RADIO_USER, &itv->i_flags); @@ -836,12 +836,12 @@ int ivtv_v4l2_open(struct inode *inode, struct file *filp) if (y == IVTV_DEC_STREAM_TYPE_YUV) { if (read_reg(0x82c) == 0) { IVTV_ERR("Tried to open YUV output device but need to send data to mpeg decoder before it can be used\n"); - // return -ENODEV; + /* return -ENODEV; */ } ivtv_udma_alloc(itv); } - // Allocate memory + /* Allocate memory */ item = kmalloc(sizeof(struct ivtv_open_id), GFP_KERNEL); if (NULL == item) { IVTV_DEBUG_WARN("nomem on v4l2 open\n"); diff --git a/linux/drivers/media/video/ivtv/ivtv-firmware.c b/linux/drivers/media/video/ivtv/ivtv-firmware.c index 544406523..d4c910b78 100644 --- a/linux/drivers/media/video/ivtv/ivtv-firmware.c +++ b/linux/drivers/media/video/ivtv/ivtv-firmware.c @@ -59,10 +59,10 @@ retry: /* temporarily allow 256 KB encoding firmwares as well for compatibility with blackbird cards */ if (fw->size != size && fw->size != 256 * 1024) { - // Due to race conditions in firmware loading (esp. with udev <0.95) - // the wrong file was sometimes loaded. So we check filesizes to - // see if at least the right-sized file was loaded. If not, then we - // retry. + /* Due to race conditions in firmware loading (esp. with udev <0.95) + the wrong file was sometimes loaded. So we check filesizes to + see if at least the right-sized file was loaded. If not, then we + retry. */ IVTV_INFO("retry: file loaded was not %s (expected size %ld, got %zd)\n", fn, size, fw->size); release_firmware(fw); retries--; @@ -78,8 +78,8 @@ retry: IVTV_INFO("loaded %s firmware (%zd bytes)\n", fn, fw->size); return size; } - IVTV_INFO("unable to open firmware %s (must be %ld bytes)\n", fn, size); - IVTV_INFO("did you put the firmware in the hotplug firmware directory?\n"); + IVTV_ERR("unable to open firmware %s (must be %ld bytes)\n", fn, size); + IVTV_ERR("did you put the firmware in the hotplug firmware directory?\n"); return -ENOMEM; } @@ -216,9 +216,9 @@ int ivtv_firmware_init(struct ivtv *itv) /* find mailboxes and ping firmware */ itv->enc_mbox.mbox = ivtv_search_mailbox(itv->enc_mem, IVTV_ENCODER_SIZE); if (itv->enc_mbox.mbox == NULL) - IVTV_DEBUG_WARN("Encoder mailbox not found\n"); + IVTV_ERR("Encoder mailbox not found\n"); else if (ivtv_vapi(itv, CX2341X_ENC_PING_FW, 0)) { - IVTV_DEBUG_WARN("Encoder firmware dead!\n"); + IVTV_ERR("Encoder firmware dead!\n"); itv->enc_mbox.mbox = NULL; } if (itv->enc_mbox.mbox == NULL) @@ -229,9 +229,9 @@ int ivtv_firmware_init(struct ivtv *itv) itv->dec_mbox.mbox = ivtv_search_mailbox(itv->dec_mem, IVTV_DECODER_SIZE); if (itv->dec_mbox.mbox == NULL) - IVTV_DEBUG_WARN("Decoder mailbox not found\n"); + IVTV_ERR("Decoder mailbox not found\n"); else if (itv->has_cx23415 && ivtv_vapi(itv, CX2341X_DEC_PING_FW, 0)) { - IVTV_DEBUG_WARN("Decoder firmware dead!\n"); + IVTV_ERR("Decoder firmware dead!\n"); itv->dec_mbox.mbox = NULL; } return itv->dec_mbox.mbox ? 0 : -ENODEV; @@ -262,7 +262,7 @@ void ivtv_init_mpeg_decoder(struct ivtv *itv) if ((readbytes = load_fw_direct(IVTV_DECODE_INIT_MPEG_FILENAME, mem_offset, itv, IVTV_DECODE_INIT_MPEG_SIZE)) <= 0) { - IVTV_INFO("failed to read mpeg decoder initialisation file %s\n", + IVTV_DEBUG_WARN("failed to read mpeg decoder initialisation file %s\n", IVTV_DECODE_INIT_MPEG_FILENAME); } else { ivtv_vapi(itv, CX2341X_DEC_SCHED_DMA_FROM_HOST, 3, 0, readbytes, 0); diff --git a/linux/drivers/media/video/ivtv/ivtv-gpio.c b/linux/drivers/media/video/ivtv/ivtv-gpio.c index 598e76575..bc8f8ca29 100644 --- a/linux/drivers/media/video/ivtv/ivtv-gpio.c +++ b/linux/drivers/media/video/ivtv/ivtv-gpio.c @@ -114,7 +114,7 @@ void ivtv_reset_ir_gpio(struct ivtv *itv) write_reg(curdir, IVTV_REG_GPIO_DIR); curout = (curout & ~0xF) | 1; write_reg(curout, IVTV_REG_GPIO_OUT); - // We could use something else for smaller time + /* We could use something else for smaller time */ current->state = TASK_INTERRUPTIBLE; schedule_timeout(1); curout |= 2; @@ -287,7 +287,7 @@ int ivtv_gpio(struct ivtv *itv, unsigned int command, void *arg) return 0; case VIDIOC_INT_S_VIDEO_ROUTING: - if (route->input > 2) // 0:Tuner 1:Composite 2:S-Video + if (route->input > 2) /* 0:Tuner 1:Composite 2:S-Video */ return -EINVAL; mask = itv->card->gpio_video_input.mask; if (route->input == 0) diff --git a/linux/drivers/media/video/ivtv/ivtv-i2c.c b/linux/drivers/media/video/ivtv/ivtv-i2c.c index 146a30979..464ee5bae 100644 --- a/linux/drivers/media/video/ivtv/ivtv-i2c.c +++ b/linux/drivers/media/video/ivtv/ivtv-i2c.c @@ -570,7 +570,8 @@ int ivtv_call_i2c_client(struct ivtv *itv, int addr, unsigned int cmd, void *arg return retval; } } - IVTV_ERR("i2c addr 0x%02x not found for command 0x%x!\n", addr, cmd); + if (cmd != VIDIOC_G_CHIP_IDENT) + IVTV_ERR("i2c addr 0x%02x not found for command 0x%x!\n", addr, cmd); return -ENODEV; } @@ -655,7 +656,8 @@ int ivtv_i2c_id(struct ivtv *itv, u32 id, unsigned int cmd, void *arg) addr = ivtv_i2c_id_addr(itv, id); if (addr < 0) { - IVTV_ERR("i2c ID 0x%08x (%s) not found for command 0x%x!\n", + if (cmd != VIDIOC_G_CHIP_IDENT) + IVTV_ERR("i2c ID 0x%08x (%s) not found for command 0x%x!\n", id, ivtv_i2c_id_name(id), cmd); return addr; } diff --git a/linux/drivers/media/video/ivtv/ivtv-ioctl.c b/linux/drivers/media/video/ivtv/ivtv-ioctl.c index a5560abd3..f8107e337 100644 --- a/linux/drivers/media/video/ivtv/ivtv-ioctl.c +++ b/linux/drivers/media/video/ivtv/ivtv-ioctl.c @@ -554,7 +554,7 @@ static int ivtv_try_or_set_fmt(struct ivtv *itv, int streamtype, return 0; } - // set window size + /* set window size */ if (fmt->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) { int w = fmt->fmt.pix.width; int h = fmt->fmt.pix.height; @@ -588,7 +588,7 @@ static int ivtv_try_or_set_fmt(struct ivtv *itv, int streamtype, return ivtv_get_fmt(itv, streamtype, fmt); } - // set raw VBI format + /* set raw VBI format */ if (fmt->type == V4L2_BUF_TYPE_VBI_CAPTURE) { if (set_fmt && streamtype == IVTV_ENC_STREAM_TYPE_VBI && itv->vbi.sliced_in->service_set && @@ -602,22 +602,22 @@ static int ivtv_try_or_set_fmt(struct ivtv *itv, int streamtype, return ivtv_get_fmt(itv, streamtype, fmt); } - // set sliced VBI output - // In principle the user could request that only certain - // VBI types are output and that the others are ignored. - // I.e., suppress CC in the even fields or only output - // WSS and no VPS. Currently though there is no choice. + /* set sliced VBI output + In principle the user could request that only certain + VBI types are output and that the others are ignored. + I.e., suppress CC in the even fields or only output + WSS and no VPS. Currently though there is no choice. */ if (fmt->type == V4L2_BUF_TYPE_SLICED_VBI_OUTPUT) return ivtv_get_fmt(itv, streamtype, fmt); - // any else but sliced VBI capture is an error + /* any else but sliced VBI capture is an error */ if (fmt->type != V4L2_BUF_TYPE_SLICED_VBI_CAPTURE) return -EINVAL; if (streamtype == IVTV_DEC_STREAM_TYPE_VBI) return ivtv_get_fmt(itv, streamtype, fmt); - // set sliced VBI capture format + /* set sliced VBI capture format */ vbifmt->io_size = sizeof(struct v4l2_sliced_vbi_data) * 36; memset(vbifmt->reserved, 0, sizeof(vbifmt->reserved)); @@ -662,18 +662,26 @@ static int ivtv_internal_ioctls(struct file *filp, unsigned int cmd, void *arg) return ivtv_i2c_id(itv, reg->match_chip, cmd, arg); return ivtv_call_i2c_client(itv, reg->match_chip, cmd, arg); - case VIDIOC_G_CHIP_IDENT: + case VIDIOC_G_CHIP_IDENT: { + struct v4l2_chip_ident *chip = arg; + IVTV_DEBUG_IOCTL("VIDIOC_G_CHIP_IDENT\n"); - if (v4l2_chip_match_host(reg->match_type, reg->match_chip)) { - struct v4l2_chip_ident *chip = arg; + chip->ident = V4L2_IDENT_NONE; + chip->revision = 0; + if (reg->match_type == V4L2_CHIP_MATCH_HOST) { + if (v4l2_chip_match_host(reg->match_type, reg->match_chip)) { + struct v4l2_chip_ident *chip = arg; - chip->ident = itv->has_cx23415 ? V4L2_IDENT_CX23415 : V4L2_IDENT_CX23416; - chip->revision = 0; + chip->ident = itv->has_cx23415 ? V4L2_IDENT_CX23415 : V4L2_IDENT_CX23416; + } return 0; } if (reg->match_type == V4L2_CHIP_MATCH_I2C_DRIVER) return ivtv_i2c_id(itv, reg->match_chip, cmd, arg); - return ivtv_call_i2c_client(itv, reg->match_chip, cmd, arg); + if (reg->match_type == V4L2_CHIP_MATCH_I2C_ADDR) + return ivtv_call_i2c_client(itv, reg->match_chip, cmd, arg); + return -EINVAL; + } case VIDIOC_INT_S_AUDIO_ROUTING: { struct v4l2_routing *route = arg; @@ -689,7 +697,6 @@ static int ivtv_internal_ioctls(struct file *filp, unsigned int cmd, void *arg) break; default: - IVTV_DEBUG_IOCTL( "Unknown internal IVTV command %08x\n", cmd); return -EINVAL; } return 0; @@ -1160,7 +1167,6 @@ int ivtv_v4l2_ioctls(struct ivtv *itv, struct file *filp, unsigned int cmd, void } default: - IVTV_DEBUG_WARN("unknown VIDIOC command %08x\n", cmd); return -EINVAL; } return 0; @@ -1433,7 +1439,6 @@ static int ivtv_ivtv_ioctls(struct file *filp, unsigned int cmd, void *arg) } default: - IVTV_DEBUG_WARN("unknown IVTV command %08x\n", cmd); return -EINVAL; } return 0; diff --git a/linux/drivers/media/video/ivtv/ivtv-irq.c b/linux/drivers/media/video/ivtv/ivtv-irq.c index 21bb88a2f..da00d7c9a 100644 --- a/linux/drivers/media/video/ivtv/ivtv-irq.c +++ b/linux/drivers/media/video/ivtv/ivtv-irq.c @@ -487,7 +487,7 @@ static void ivtv_irq_dma_err(struct ivtv *itv) itv->cur_dma_stream >= 0 && itv->cur_dma_stream < IVTV_MAX_STREAMS) { struct ivtv_stream *s = &itv->streams[itv->cur_dma_stream]; - // retry + /* retry */ write_reg(read_reg(IVTV_REG_DMASTATUS) & 3, IVTV_REG_DMASTATUS); if (s->type >= IVTV_DEC_STREAM_TYPE_MPG) ivtv_dma_dec_start(s); @@ -772,7 +772,7 @@ irqreturn_t ivtv_irq_handler(int irq, void *dev_id) if (combo & IVTV_IRQ_ENC_VIM_RST) { IVTV_DEBUG_IRQ("VIM RST\n"); - //ivtv_vapi(itv, CX2341X_ENC_REFRESH_INPUT, 0); + /*ivtv_vapi(itv, CX2341X_ENC_REFRESH_INPUT, 0); */ } if (combo & IVTV_IRQ_DEC_AUD_MODE_CHG) { diff --git a/linux/drivers/media/video/ivtv/ivtv-mailbox.c b/linux/drivers/media/video/ivtv/ivtv-mailbox.c index 131a5a404..6ae42a3b0 100644 --- a/linux/drivers/media/video/ivtv/ivtv-mailbox.c +++ b/linux/drivers/media/video/ivtv/ivtv-mailbox.c @@ -90,7 +90,7 @@ static const struct ivtv_api_info api_info[256] = { API_ENTRY(CX2341X_ENC_MUTE_AUDIO, API_RESULT), API_ENTRY(CX2341X_ENC_SET_VERT_CROP_LINE, API_FAST_RESULT), API_ENTRY(CX2341X_ENC_MISC, API_FAST_RESULT), - // Obsolete PULLDOWN API command + /* Obsolete PULLDOWN API command */ API_ENTRY(0xb1, API_CACHE), /* MPEG decoder API */ diff --git a/linux/drivers/media/video/ivtv/ivtv-streams.c b/linux/drivers/media/video/ivtv/ivtv-streams.c index c5704ff1f..73a1c933d 100644 --- a/linux/drivers/media/video/ivtv/ivtv-streams.c +++ b/linux/drivers/media/video/ivtv/ivtv-streams.c @@ -315,7 +315,7 @@ static void ivtv_vbi_setup(struct ivtv *itv) int i; /* If Embed then streamtype must be Program */ - // TODO: should we really do this? + /* TODO: should we really do this? */ if (0 && !raw && itv->vbi.insert_mpeg) { itv->params.stream_type = 0; @@ -336,14 +336,14 @@ static void ivtv_vbi_setup(struct ivtv *itv) itv->vbi.start[1] = 318; } - // setup VBI registers + /* setup VBI registers */ itv->video_dec_func(itv, VIDIOC_S_FMT, &itv->vbi.in); - // determine number of lines and total number of VBI bytes. - // A raw line takes 1443 bytes: 2 * 720 + 4 byte frame header - 1 - // The '- 1' byte is probably an unused U or V byte. Or something... - // A sliced line takes 51 bytes: 4 byte frame header, 4 byte internal - // header, 42 data bytes + checksum (to be confirmed) + /* determine number of lines and total number of VBI bytes. + A raw line takes 1443 bytes: 2 * 720 + 4 byte frame header - 1 + The '- 1' byte is probably an unused U or V byte. Or something... + A sliced line takes 51 bytes: 4 byte frame header, 4 byte internal + header, 42 data bytes + checksum (to be confirmed) */ if (raw) { lines = itv->vbi.count * 2; } else { @@ -354,21 +354,21 @@ static void ivtv_vbi_setup(struct ivtv *itv) itv->vbi.enc_size = lines * (raw ? itv->vbi.raw_size : itv->vbi.sliced_size); - // Note: sliced vs raw flag doesn't seem to have any effect - // TODO: check mode (0x02) value with older ivtv versions. + /* Note: sliced vs raw flag doesn't seem to have any effect + TODO: check mode (0x02) value with older ivtv versions. */ data[0] = raw | 0x02 | (0xbd << 8); - // Every X number of frames a VBI interrupt arrives (frames as in 25 or 30 fps) + /* Every X number of frames a VBI interrupt arrives (frames as in 25 or 30 fps) */ data[1] = 1; - // The VBI frames are stored in a ringbuffer with this size (with a VBI frame as unit) + /* The VBI frames are stored in a ringbuffer with this size (with a VBI frame as unit) */ data[2] = raw ? 4 : 8; - // The start/stop codes determine which VBI lines end up in the raw VBI data area. - // The codes are from table 24 in the saa7115 datasheet. Each raw/sliced/video line - // is framed with codes FF0000XX where XX is the SAV/EAV (Start/End of Active Video) - // code. These values for raw VBI are obtained from a driver disassembly. The sliced - // start/stop codes was deduced from this, but they do not appear in the driver. - // Other code pairs that I found are: 0x250E6249/0x13545454 and 0x25256262/0x38137F54. - // However, I have no idea what these values are for. + /* The start/stop codes determine which VBI lines end up in the raw VBI data area. + The codes are from table 24 in the saa7115 datasheet. Each raw/sliced/video line + is framed with codes FF0000XX where XX is the SAV/EAV (Start/End of Active Video) + code. These values for raw VBI are obtained from a driver disassembly. The sliced + start/stop codes was deduced from this, but they do not appear in the driver. + Other code pairs that I found are: 0x250E6249/0x13545454 and 0x25256262/0x38137F54. + However, I have no idea what these values are for. */ if (itv->hw_flags & IVTV_HW_CX25840) { /* Setup VBI for the cx25840 digitizer */ if (raw) { @@ -378,9 +378,9 @@ static void ivtv_vbi_setup(struct ivtv *itv) data[3] = 0xB0F0B0F0; data[4] = 0xA0E0A0E0; } - // Lines per frame + /* Lines per frame */ data[5] = lines; - // bytes per line + /* bytes per line */ data[6] = (raw ? itv->vbi.raw_size : itv->vbi.sliced_size); } else { /* Setup VBI for the saa7115 digitizer */ @@ -391,9 +391,9 @@ static void ivtv_vbi_setup(struct ivtv *itv) data[3] = 0xABABECEC; data[4] = 0xB6F1F1F1; } - // Lines per frame + /* Lines per frame */ data[5] = lines; - // bytes per line + /* bytes per line */ data[6] = itv->vbi.enc_size / lines; } @@ -403,7 +403,7 @@ static void ivtv_vbi_setup(struct ivtv *itv) ivtv_api(itv, CX2341X_ENC_SET_VBI_CONFIG, 7, data); - // returns the VBI encoder memory area. + /* returns the VBI encoder memory area. */ itv->vbi.enc_start = data[2]; itv->vbi.fpi = data[0]; if (!itv->vbi.fpi) @@ -412,8 +412,8 @@ static void ivtv_vbi_setup(struct ivtv *itv) IVTV_DEBUG_INFO("Setup VBI start 0x%08x frames %d fpi %d lines 0x%08x\n", itv->vbi.enc_start, data[1], itv->vbi.fpi, itv->digitizer); - // select VBI lines. - // Note that the sliced argument seems to have no effect. + /* select VBI lines. + Note that the sliced argument seems to have no effect. */ for (i = 2; i <= 24; i++) { int valid; @@ -428,12 +428,12 @@ static void ivtv_vbi_setup(struct ivtv *itv) valid, 0, 0, 0); } - // Remaining VBI questions: - // - Is it possible to select particular VBI lines only for inclusion in the MPEG - // stream? Currently you can only get the first X lines. - // - Is mixed raw and sliced VBI possible? - // - What's the meaning of the raw/sliced flag? - // - What's the meaning of params 2, 3 & 4 of the Select VBI command? + /* Remaining VBI questions: + - Is it possible to select particular VBI lines only for inclusion in the MPEG + stream? Currently you can only get the first X lines. + - Is mixed raw and sliced VBI possible? + - What's the meaning of the raw/sliced flag? + - What's the meaning of params 2, 3 & 4 of the Select VBI command? */ } int ivtv_start_v4l2_encode_stream(struct ivtv_stream *s) @@ -504,7 +504,7 @@ int ivtv_start_v4l2_encode_stream(struct ivtv_stream *s) but occasionally. Many thanks go to Leonard Orb who spent a lot of effort and time trying to trace the cause of the drop outs. */ /* 1 frame per DMA */ - //ivtv_vapi(itv, CX2341X_ENC_SET_DMA_BLOCK_SIZE, 2, 128, 0); + /*ivtv_vapi(itv, CX2341X_ENC_SET_DMA_BLOCK_SIZE, 2, 128, 0); */ ivtv_vapi(itv, CX2341X_ENC_SET_DMA_BLOCK_SIZE, 2, 1, 1); /* Stuff from Windows, we don't know what it is */ @@ -646,7 +646,7 @@ int ivtv_start_v4l2_decode_stream(struct ivtv_stream *s, int gop_offset) return -EINVAL; if (test_and_set_bit(IVTV_F_S_STREAMING, &s->s_flags)) - return 0; // already started + return 0; /* already started */ IVTV_DEBUG_INFO("Starting decode stream %s (gop_offset %d)\n", s->name, gop_offset); diff --git a/linux/drivers/media/video/ivtv/ivtv-vbi.c b/linux/drivers/media/video/ivtv/ivtv-vbi.c index 747827b2e..71acc97b1 100644 --- a/linux/drivers/media/video/ivtv/ivtv-vbi.c +++ b/linux/drivers/media/video/ivtv/ivtv-vbi.c @@ -218,7 +218,7 @@ static int ivtv_convert_ivtv_vbi(struct ivtv *itv, u8 *p) ssize_t ivtv_write_vbi(struct ivtv *itv, const char __user *ubuf, size_t count) { - // Should be a __user pointer, but sparse doesn't parse this bit correctly. + /* Should be a __user pointer, but sparse doesn't parse this bit correctly. */ const struct v4l2_sliced_vbi_data *p = (const struct v4l2_sliced_vbi_data *)ubuf; u8 cc[4] = { 0x80, 0x80, 0x80, 0x80 }; int found_cc = 0; @@ -262,7 +262,7 @@ ssize_t ivtv_write_vbi(struct ivtv *itv, const char __user *ubuf, size_t count) case V4L2_SLICED_WSS_625: if (p->line == 23 && p->field == 0 && (itv->vbi.service_set_out & V4L2_SLICED_WSS_625)) { - // No lock needed for WSS + /* No lock needed for WSS */ itv->vbi.wss = p->data[0] | (p->data[1] << 8); itv->vbi.wss_found = 1; set_bit(IVTV_F_I_UPDATE_WSS, &itv->i_flags); @@ -288,9 +288,9 @@ ssize_t ivtv_write_vbi(struct ivtv *itv, const char __user *ubuf, size_t count) return (const char __user *)p - ubuf; } -// Compress raw VBI format, removes leading SAV codes and surplus space after the -// field. -// Returns new compressed size. +/* Compress raw VBI format, removes leading SAV codes and surplus space after the + field. + Returns new compressed size. */ static u32 compress_raw_buf(struct ivtv *itv, u8 *buf, u32 size) { u32 line_size = itv->vbi.raw_decoder_line_size; @@ -304,7 +304,7 @@ static u32 compress_raw_buf(struct ivtv *itv, u8 *buf, u32 size) for (i = 0; i < lines; i++) { p = buf + i * line_size; - // Look for SAV code + /* Look for SAV code */ if (p[0] != 0xff || p[1] || p[2] || (p[3] != sav1 && p[3] != sav2)) { break; } @@ -315,15 +315,15 @@ static u32 compress_raw_buf(struct ivtv *itv, u8 *buf, u32 size) } -// Compressed VBI format, all found sliced blocks put next to one another -// Returns new compressed size +/* Compressed VBI format, all found sliced blocks put next to one another + Returns new compressed size */ static u32 compress_sliced_buf(struct ivtv *itv, u32 line, u8 *buf, u32 size, u8 sav) { u32 line_size = itv->vbi.sliced_decoder_line_size; struct v4l2_decode_vbi_line vbi; int i; - // find the first valid line + /* find the first valid line */ for (i = 0; i < size; i++, buf++) { if (buf[0] == 0xff && !buf[1] && !buf[2] && buf[3] == sav) break; @@ -336,7 +336,7 @@ static u32 compress_sliced_buf(struct ivtv *itv, u32 line, u8 *buf, u32 size, u8 for (i = 0; i < size / line_size; i++) { u8 *p = buf + i * line_size; - // Look for SAV code + /* Look for SAV code */ if (p[0] != 0xff || p[1] || p[2] || p[3] != sav) { continue; } @@ -360,7 +360,7 @@ void ivtv_process_vbi_data(struct ivtv *itv, struct ivtv_buffer *buf, u32 size = buf->bytesused; int y; - // Raw VBI data + /* Raw VBI data */ if (streamtype == IVTV_ENC_STREAM_TYPE_VBI && itv->vbi.sliced_in->service_set == 0) { u8 type; @@ -370,7 +370,7 @@ void ivtv_process_vbi_data(struct ivtv *itv, struct ivtv_buffer *buf, size = buf->bytesused = compress_raw_buf(itv, p, size); - // second field of the frame? + /* second field of the frame? */ if (type == itv->vbi.raw_decoder_sav_even_field) { /* Dirty hack needed for backwards compatibility of old VBI software. */ @@ -381,21 +381,21 @@ void ivtv_process_vbi_data(struct ivtv *itv, struct ivtv_buffer *buf, return; } - // Sliced VBI data with data insertion + /* Sliced VBI data with data insertion */ if (streamtype == IVTV_ENC_STREAM_TYPE_VBI) { int lines; ivtv_buf_swap(buf); - // first field + /* first field */ lines = compress_sliced_buf(itv, 0, p, size / 2, itv->vbi.sliced_decoder_sav_odd_field); - // second field - // experimentation shows that the second half does not always begin - // at the exact address. So start a bit earlier (hence 32). + /* second field */ + /* experimentation shows that the second half does not always begin + at the exact address. So start a bit earlier (hence 32). */ lines = compress_sliced_buf(itv, lines, p + size / 2 - 32, size / 2 + 32, itv->vbi.sliced_decoder_sav_even_field); - // always return at least one empty line + /* always return at least one empty line */ if (lines == 0) { itv->vbi.sliced_data[0].id = 0; itv->vbi.sliced_data[0].line = 0; @@ -412,7 +412,7 @@ void ivtv_process_vbi_data(struct ivtv *itv, struct ivtv_buffer *buf, return; } - // Sliced VBI re-inserted from an MPEG stream + /* Sliced VBI re-inserted from an MPEG stream */ if (streamtype == IVTV_DEC_STREAM_TYPE_VBI) { /* If the size is not 4-byte aligned, then the starting address for the swapping is also shifted. After swapping the data the diff --git a/linux/drivers/media/video/ivtv/ivtv-yuv.c b/linux/drivers/media/video/ivtv/ivtv-yuv.c index caf7e27a1..04d93a753 100644 --- a/linux/drivers/media/video/ivtv/ivtv-yuv.c +++ b/linux/drivers/media/video/ivtv/ivtv-yuv.c @@ -124,7 +124,7 @@ static void ivtv_yuv_filter(struct ivtv *itv, int h_filter, int v_filter_1, int { int filter_index, filter_line; - // If any filter is -1, then don't update it + /* If any filter is -1, then don't update it */ if (h_filter > -1) { if (h_filter > 4) h_filter = 4; filter_index = h_filter * 384; @@ -196,25 +196,25 @@ static void ivtv_yuv_handle_horizontal(struct ivtv *itv, struct yuv_frame_info * IVTV_DEBUG_WARN( "Need to adjust to width %d src_w %d dst_w %d src_x %d dst_x %d\n", window->tru_w, window->src_w, window->dst_w,window->src_x, window->dst_x); - // How wide is the src image + /* How wide is the src image */ x_cutoff = window->src_w + window->src_x; - // Set the display width + /* Set the display width */ reg_2834 = window->dst_w; reg_2838 = reg_2834; - // Set the display position + /* Set the display position */ reg_2890 = window->dst_x; - // Index into the image horizontally + /* Index into the image horizontally */ reg_2870 = 0; - // 2870 is normally fudged to align video coords with osd coords. - // If running full screen, it causes an unwanted left shift - // Remove the fudge if we almost fill the screen. - // Gradually adjust the offset to avoid the video 'snapping' - // left/right if it gets dragged through this region. - // Only do this if osd is full width. + /* 2870 is normally fudged to align video coords with osd coords. + If running full screen, it causes an unwanted left shift + Remove the fudge if we almost fill the screen. + Gradually adjust the offset to avoid the video 'snapping' + left/right if it gets dragged through this region. + Only do this if osd is full width. */ if (window->vis_w == 720) { if ((window->tru_x - window->pan_x > -1) && (window->tru_x - window->pan_x <= 40) && (window->dst_w >= 680)){ reg_2870 = 10 - (window->tru_x - window->pan_x) / 4; @@ -234,7 +234,7 @@ static void ivtv_yuv_handle_horizontal(struct ivtv *itv, struct yuv_frame_info * else reg_2870 = 0x0012000e - reg_2870; - // We're also using 2870 to shift the image left (src_x & negative dst_x) + /* We're also using 2870 to shift the image left (src_x & negative dst_x) */ reg_2870_offset = (window->src_x*((window->dst_w << 21)/window->src_w))>>19; if (window->dst_w >= window->src_w) { @@ -249,8 +249,8 @@ static void ivtv_yuv_handle_horizontal(struct ivtv *itv, struct yuv_frame_info * reg_285c = master_width >> 1; reg_2864 = master_width >> 1; - // We also need to factor in the scaling - // (src_w - dst_w) / (src_w / 4) + /* We also need to factor in the scaling + (src_w - dst_w) / (src_w / 4) */ if (window->dst_w > window->src_w) reg_2870_base = ((window->dst_w - window->src_w)<<16) / (window->src_w <<14); else @@ -288,16 +288,16 @@ static void ivtv_yuv_handle_horizontal(struct ivtv *itv, struct yuv_frame_info * reg_2874 = 0x00000001; } - // Select the horizontal filter + /* Select the horizontal filter */ if (window->src_w == window->dst_w) { - // An exact size match uses filter 0 + /* An exact size match uses filter 0 */ h_filter = 0; } else { - // Figure out which filter to use + /* Figure out which filter to use */ h_filter = ((window->src_w << 16) / window->dst_w) >> 15; h_filter = (h_filter >> 1) + (h_filter & 1); - // Only an exact size match can use filter 0 + /* Only an exact size match can use filter 0 */ if (h_filter == 0) h_filter = 1; } @@ -330,7 +330,7 @@ static void ivtv_yuv_handle_horizontal(struct ivtv *itv, struct yuv_frame_info * write_reg( reg_2890,0x02890); IVTV_DEBUG_YUV("Update reg 0x2890 %08x->%08x\n",itv->yuv_info.reg_2890, reg_2890); - // Only update the filter if we really need to + /* Only update the filter if we really need to */ if (h_filter != itv->yuv_info.h_filter) { ivtv_yuv_filter (itv,h_filter,-1,-1); itv->yuv_info.h_filter = h_filter; @@ -354,7 +354,7 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi IVTV_DEBUG_WARN("Need to adjust to height %d src_h %d dst_h %d src_y %d dst_y %d\n", window->tru_h, window->src_h, window->dst_h,window->src_y, window->dst_y); - // What scaling mode is being used... + /* What scaling mode is being used... */ if (window->interlaced_y) { IVTV_DEBUG_YUV("Scaling mode Y: Interlaced\n"); } @@ -369,7 +369,7 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi IVTV_DEBUG_YUV("Scaling mode UV: Progressive\n"); } - // What is the source video being treated as... + /* What is the source video being treated as... */ if (itv->yuv_info.frame_interlaced) { IVTV_DEBUG_WARN("Source video: Interlaced\n"); } @@ -377,8 +377,8 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi IVTV_DEBUG_WARN("Source video: Non-interlaced\n"); } - // We offset into the image using two different index methods, so split - // the y source coord into two parts. + /* We offset into the image using two different index methods, so split + the y source coord into two parts. */ if (window->src_y < 8) { src_y_minor_uv = window->src_y; src_y_major_uv = 0; @@ -465,8 +465,8 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi reg_296c = 0x00000102; } - // FIXME These registers change depending on scaled / unscaled output - // We really need to work out what they should be + /* FIXME These registers change depending on scaled / unscaled output + We really need to work out what they should be */ if (window->src_h == window->dst_h){ reg_2934 = 0x00020000; reg_293c = 0x00100000; @@ -480,7 +480,7 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi reg_294c = 0x00000FF0; } - // The first line to be displayed + /* The first line to be displayed */ reg_2950 = 0x00010000 + src_y_major_y; if (window->interlaced_y) reg_2950 += 0x00010000; reg_2954 = reg_2950 + 1; @@ -499,12 +499,12 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi else reg_289c = (reg_289c + ((window->dst_y & ~1)<<15))+(window->dst_y >>1); - // How much of the source to decode. - // Take into account the source offset + /* How much of the source to decode. + Take into account the source offset */ reg_2960 = ((src_y_minor_y + window->src_h + src_y_major_y) - 1 ) | ((((src_y_minor_uv + window->src_h + src_y_major_uv) - 1) & ~1) << 15); - // Calculate correct value for register 2964 + /* Calculate correct value for register 2964 */ if (window->src_h == window->dst_h) reg_2964 = 1; else { @@ -514,15 +514,15 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi reg_2968 = (reg_2964 << 16) + reg_2964 + (reg_2964 >> 1); reg_2964 = (reg_2964 << 16) + reg_2964 + (reg_2964 * 46 / 94); - // Okay, we've wasted time working out the correct value, - // but if we use it, it fouls the the window alignment. - // Fudge it to what we want... + /* Okay, we've wasted time working out the correct value, + but if we use it, it fouls the the window alignment. + Fudge it to what we want... */ reg_2964 = 0x00010001 + ((reg_2964 & 0x0000FFFF) - (reg_2964 >> 16)); reg_2968 = 0x00010001 + ((reg_2968 & 0x0000FFFF) - (reg_2968 >> 16)); - // Deviate further from what it should be. I find the flicker headache - // inducing so try to reduce it slightly. Leave 2968 as-is otherwise - // colours foul. + /* Deviate further from what it should be. I find the flicker headache + inducing so try to reduce it slightly. Leave 2968 as-is otherwise + colours foul. */ if ((reg_2964 != 0x00010001) && (window->dst_h / 2 <= window->src_h)) reg_2964 = (reg_2964 & 0xFFFF0000) + ((reg_2964 & 0x0000FFFF)/2); @@ -532,17 +532,17 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi reg_2964 += ((reg_2964_base << 16) | reg_2964_base); reg_2968 += ((reg_2968_base << 16) | reg_2968_base); - // Select the vertical filter + /* Select the vertical filter */ if (window->src_h == window->dst_h) { - // An exact size match uses filter 0/1 + /* An exact size match uses filter 0/1 */ v_filter_1 = 0; v_filter_2 = 1; } else { - // Figure out which filter to use + /* Figure out which filter to use */ v_filter_1 = ((window->src_h << 16) / window->dst_h) >> 15; v_filter_1 = (v_filter_1 >> 1) + (v_filter_1 & 1); - // Only an exact size match can use filter 0 + /* Only an exact size match can use filter 0 */ if (v_filter_1 == 0) v_filter_1 = 1; v_filter_2 = v_filter_1; } @@ -554,9 +554,9 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi write_reg(reg_294c, 0x0294c); IVTV_DEBUG_YUV("Update reg 0x2944 %08x->%08x 0x294c %08x->%08x\n",itv->yuv_info.reg_2944, reg_2944, itv->yuv_info.reg_294c, reg_294c); - // Ensure 2970 is 0 (does it ever change ?) -// write_reg(0,0x02970); -// IVTV_DEBUG_YUV("Update reg 0x2970 %08x->%08x\n",itv->yuv_info.reg_2970, 0); + /* Ensure 2970 is 0 (does it ever change ?) */ +/* write_reg(0,0x02970); */ +/* IVTV_DEBUG_YUV("Update reg 0x2970 %08x->%08x\n",itv->yuv_info.reg_2970, 0); */ write_reg(reg_2930, 0x02938); write_reg(reg_2930, 0x02930); @@ -599,13 +599,13 @@ static void ivtv_yuv_handle_vertical(struct ivtv *itv, struct yuv_frame_info *wi write_reg( reg_289c,0x0289c); IVTV_DEBUG_YUV("Update reg 0x289c %08x->%08x\n",itv->yuv_info.reg_289c, reg_289c); - // Only update filter 1 if we really need to + /* Only update filter 1 if we really need to */ if (v_filter_1 != itv->yuv_info.v_filter_1) { ivtv_yuv_filter (itv,-1,v_filter_1,-1); itv->yuv_info.v_filter_1 = v_filter_1; } - // Only update filter 2 if we really need to + /* Only update filter 2 if we really need to */ if (v_filter_2 != itv->yuv_info.v_filter_2) { ivtv_yuv_filter (itv,-1,-1,v_filter_2); itv->yuv_info.v_filter_2 = v_filter_2; @@ -622,9 +622,9 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo u32 osd_scale; u32 yuv_update = 0; - // Work out the lace settings + /* Work out the lace settings */ switch (itv->yuv_info.lace_mode) { - case IVTV_YUV_MODE_PROGRESSIVE: // Progressive mode + case IVTV_YUV_MODE_PROGRESSIVE: /* Progressive mode */ itv->yuv_info.frame_interlaced = 0; if (window->tru_h < 512 || (window->tru_h > 576 && window->tru_h < 1021)) window->interlaced_y = 0; @@ -659,7 +659,7 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo } break; - case IVTV_YUV_MODE_INTERLACED: // Interlace mode + case IVTV_YUV_MODE_INTERLACED: /* Interlace mode */ default: itv->yuv_info.frame_interlaced = 1; window->interlaced_y = 1; @@ -667,11 +667,11 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo break; } - // Sorry, but no negative coords for src + /* Sorry, but no negative coords for src */ if (window->src_x < 0) window->src_x = 0; if (window->src_y < 0) window->src_y = 0; - // Can only reduce width down to 1/4 original size + /* Can only reduce width down to 1/4 original size */ if ((osd_crop = window->src_w - ( 4 * window->dst_w )) > 0) { window->src_x += osd_crop / 2; window->src_w = (window->src_w - osd_crop) & ~3; @@ -679,13 +679,13 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo window->dst_w += window->dst_w & 1; } - // Can only reduce height down to 1/4 original size + /* Can only reduce height down to 1/4 original size */ if (window->src_h / window->dst_h >= 2) { - // Overflow may be because we're running progressive, so force mode switch + /* Overflow may be because we're running progressive, so force mode switch */ window->interlaced_y = 1; - // Make sure we're still within limits for interlace + /* Make sure we're still within limits for interlace */ if ((osd_crop = window->src_h - ( 4 * window->dst_h )) > 0) { - // If we reach here we'll have to force the height. + /* If we reach here we'll have to force the height. */ window->src_y += osd_crop / 2; window->src_h = (window->src_h - osd_crop) & ~3; window->dst_h = window->src_h / 4; @@ -693,16 +693,16 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo } } - // If there's nothing to safe to display, we may as well stop now + /* If there's nothing to safe to display, we may as well stop now */ if ((int)window->dst_w <= 2 || (int)window->dst_h <= 2 || (int)window->src_w <= 2 || (int)window->src_h <= 2) { return 0; } - // Ensure video remains inside OSD area + /* Ensure video remains inside OSD area */ osd_scale = (window->src_h << 16) / window->dst_h; if ((osd_crop = window->pan_y - window->dst_y) > 0) { - // Falls off the upper edge - crop + /* Falls off the upper edge - crop */ window->src_y += (osd_scale * osd_crop) >> 16; window->src_h -= (osd_scale * osd_crop) >> 16; window->dst_h -= osd_crop; @@ -713,7 +713,7 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo } if ((osd_crop = window->dst_h + window->dst_y - window->vis_h) > 0) { - // Falls off the lower edge - crop + /* Falls off the lower edge - crop */ window->dst_h -= osd_crop; window->src_h -= (osd_scale * osd_crop) >> 16; } @@ -721,7 +721,7 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo osd_scale = (window->src_w << 16) / window->dst_w; if ((osd_crop = window->pan_x - window->dst_x) > 0) { - // Fall off the left edge - crop + /* Fall off the left edge - crop */ window->src_x += (osd_scale * osd_crop) >> 16; window->src_w -= (osd_scale * osd_crop) >> 16; window->dst_w -= osd_crop; @@ -732,17 +732,17 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo } if ((osd_crop = window->dst_w + window->dst_x - window->vis_w) > 0) { - // Falls off the right edge - crop + /* Falls off the right edge - crop */ window->dst_w -= osd_crop; window->src_w -= (osd_scale * osd_crop) >> 16; } - // The OSD can be moved. Track to it + /* The OSD can be moved. Track to it */ window->dst_x += itv->yuv_info.osd_x_offset; window->dst_y += itv->yuv_info.osd_y_offset; - // Width & height for both src & dst must be even. - // Same for coordinates. + /* Width & height for both src & dst must be even. + Same for coordinates. */ window->dst_w &= ~1; window->dst_x &= ~1; @@ -761,8 +761,8 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo window->src_h &= ~1; window->dst_h &= ~1; - // Due to rounding, we may have reduced the output size to <1/4 of the source - // Check again, but this time just resize. Don't change source coordinates + /* Due to rounding, we may have reduced the output size to <1/4 of the source + Check again, but this time just resize. Don't change source coordinates */ if (window->dst_w < window->src_w / 4) { window->src_w &= ~3; window->dst_w = window->src_w / 4; @@ -774,12 +774,12 @@ static u32 ivtv_yuv_window_setup (struct ivtv *itv, struct yuv_frame_info *windo window->dst_h += window->dst_h & 1; } - // Check again. If there's nothing to safe to display, stop now + /* Check again. If there's nothing to safe to display, stop now */ if ((int)window->dst_w <= 2 || (int)window->dst_h <= 2 || (int)window->src_w <= 2 || (int)window->src_h <= 2) { return 0; } - // Both x offset & width are linked, so they have to be done together + /* Both x offset & width are linked, so they have to be done together */ if ((itv->yuv_info.old_frame_info.dst_w != window->dst_w) || (itv->yuv_info.old_frame_info.src_w != window->src_w) || (itv->yuv_info.old_frame_info.dst_x != window->dst_x) || @@ -821,7 +821,7 @@ void ivtv_yuv_work_handler (void *arg) int frame = itv->yuv_info.update_frame; -// IVTV_DEBUG_YUV("Update yuv registers for frame %d\n",frame); +/* IVTV_DEBUG_YUV("Update yuv registers for frame %d\n",frame); */ memcpy(&window, &itv->yuv_info.new_frame_info[frame], sizeof (window)); /* Update the osd pan info */ @@ -848,7 +848,7 @@ static void ivtv_yuv_init (struct ivtv *itv) { IVTV_DEBUG_YUV("ivtv_yuv_init\n"); - // Take a snapshot of the current register settings + /* Take a snapshot of the current register settings */ itv->yuv_info.reg_2834 = read_reg(0x02834); itv->yuv_info.reg_2838 = read_reg(0x02838); itv->yuv_info.reg_283c = read_reg(0x0283c); @@ -892,22 +892,22 @@ static void ivtv_yuv_init (struct ivtv *itv) itv->yuv_info.v_filter_2 = -1; itv->yuv_info.h_filter = -1; - // Set some valid size info + /* Set some valid size info */ itv->yuv_info.osd_x_offset = read_reg(0x02a04) & 0x00000FFF; itv->yuv_info.osd_y_offset = (read_reg(0x02a04) >> 16) & 0x00000FFF; - // Bit 2 of reg 2878 indicates current decoder output format - // 0 : NTSC 1 : PAL + /* Bit 2 of reg 2878 indicates current decoder output format + 0 : NTSC 1 : PAL */ if (read_reg(0x2878) & 4) itv->yuv_info.decode_height = 576; else itv->yuv_info.decode_height = 480; - // If no visible size set, assume full size + /* If no visible size set, assume full size */ if (!itv->yuv_info.osd_vis_w) itv->yuv_info.osd_vis_w = 720 - itv->yuv_info.osd_x_offset; if (!itv->yuv_info.osd_vis_h) itv->yuv_info.osd_vis_h = itv->yuv_info.decode_height - itv->yuv_info.osd_y_offset; - // We need a buffer for blanking when Y plane is offset - non-fatal if we can't get one + /* We need a buffer for blanking when Y plane is offset - non-fatal if we can't get one */ itv->yuv_info.blanking_ptr = kzalloc(720*16,GFP_KERNEL); if (itv->yuv_info.blanking_ptr) { itv->yuv_info.blanking_dmaptr = pci_map_single(itv->dev, itv->yuv_info.blanking_ptr, 720*16, PCI_DMA_TODEVICE); @@ -943,7 +943,7 @@ int ivtv_yuv_prep_frame(struct ivtv *itv, struct ivtv_dma_frame *args) last_fill_frame = (atomic_read(&itv->yuv_info.next_dma_frame)+1) & 0x3; if (next_fill_frame != last_fill_frame && last_fill_frame != frame) { - // Buffers are full - Overwrite the last frame */ + /* Buffers are full - Overwrite the last frame */ next_fill_frame = frame; frame = (frame - 1) & 3; } @@ -981,7 +981,7 @@ int ivtv_yuv_prep_frame(struct ivtv *itv, struct ivtv_dma_frame *args) sizeof (itv->yuv_info.new_frame_info[frame]))) { memcpy(&itv->yuv_info.old_frame_info_args, &itv->yuv_info.new_frame_info[frame], sizeof (itv->yuv_info.old_frame_info_args)); itv->yuv_info.new_frame_info[frame].update = 1; -// IVTV_DEBUG_YUV ("Requesting register update for frame %d\n",frame); +/* IVTV_DEBUG_YUV ("Requesting register update for frame %d\n",frame); */ } /* DMA the frame */ @@ -1034,9 +1034,9 @@ void ivtv_yuv_close(struct ivtv *itv) /* Reset registers we have changed so mpeg playback works */ - // If we fully restore this register, the display may remain active. - // Restore, but set one bit to blank the video. Firmware will always - // clear this bit when needed, so not a problem. + /* If we fully restore this register, the display may remain active. + Restore, but set one bit to blank the video. Firmware will always + clear this bit when needed, so not a problem. */ write_reg(itv->yuv_info.reg_2898 | 0x01000000, 0x2898); write_reg(itv->yuv_info.reg_2834, 0x02834); @@ -1077,59 +1077,59 @@ void ivtv_yuv_close(struct ivtv *itv) write_reg(itv->yuv_info.reg_296c, 0x0296c); write_reg(itv->yuv_info.reg_2970, 0x02970); - // Prepare to restore filters + /* Prepare to restore filters */ - // First the horizontal filter + /* First the horizontal filter */ if ((itv->yuv_info.reg_2834 & 0x0000FFFF) == (itv->yuv_info.reg_2834 >> 16)) { - // An exact size match uses filter 0 + /* An exact size match uses filter 0 */ h_filter = 0; } else { - // Figure out which filter to use + /* Figure out which filter to use */ h_filter = ((itv->yuv_info.reg_2834 << 16) / (itv->yuv_info.reg_2834 >> 16)) >> 15; h_filter = (h_filter >> 1) + (h_filter & 1); - // Only an exact size match can use filter 0. + /* Only an exact size match can use filter 0. */ if (h_filter < 1) h_filter = 1; } - // Now the vertical filter + /* Now the vertical filter */ if ((itv->yuv_info.reg_2918 & 0x0000FFFF) == (itv->yuv_info.reg_2918 >> 16)) { - // An exact size match uses filter 0/1 + /* An exact size match uses filter 0/1 */ v_filter_1 = 0; v_filter_2 = 1; } else { - // Figure out which filter to use + /* Figure out which filter to use */ v_filter_1 = ((itv->yuv_info.reg_2918 << 16) / (itv->yuv_info.reg_2918 >> 16)) >> 15; v_filter_1 = (v_filter_1 >> 1) + (v_filter_1 & 1); - // Only an exact size match can use filter 0 + /* Only an exact size match can use filter 0 */ if (v_filter_1 == 0) v_filter_1 = 1; v_filter_2 = v_filter_1; } - // Now restore the filters + /* Now restore the filters */ ivtv_yuv_filter (itv,h_filter,v_filter_1,v_filter_2); - // and clear a few registers + /* and clear a few registers */ write_reg(0, 0x02814); write_reg(0, 0x0282c); write_reg(0, 0x02904); write_reg(0, 0x02910); - // Release the blanking buffer + /* Release the blanking buffer */ if (itv->yuv_info.blanking_ptr) { kfree (itv->yuv_info.blanking_ptr); itv->yuv_info.blanking_ptr = NULL; pci_unmap_single(itv->dev, itv->yuv_info.blanking_dmaptr, 720*16, PCI_DMA_TODEVICE); } - // Invalidate the old dimension information + /* Invalidate the old dimension information */ itv->yuv_info.old_frame_info.src_w = 0; itv->yuv_info.old_frame_info.src_h = 0; itv->yuv_info.old_frame_info_args.src_w = 0; itv->yuv_info.old_frame_info_args.src_h = 0; - // All done. + /* All done. */ clear_bit(IVTV_F_I_DECODING_YUV, &itv->i_flags); } diff --git a/linux/drivers/media/video/msp3400-driver.c b/linux/drivers/media/video/msp3400-driver.c index 9958e2570..0e21a5b57 100644 --- a/linux/drivers/media/video/msp3400-driver.c +++ b/linux/drivers/media/video/msp3400-driver.c @@ -817,6 +817,9 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg) break; } + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, state->ident, (state->rev1 << 16) | state->rev2); + default: /* unknown */ return -EINVAL; @@ -944,6 +947,8 @@ static int msp_attach(struct i2c_adapter *adapter, int address, int kind) snprintf(client->name, sizeof(client->name), "MSP%d4%02d%c-%c%d", msp_family, msp_product, msp_revision, msp_hard, msp_rom); + /* Rev B=2, C=3, D=4, G=7 */ + state->ident = msp_family * 10000 + 4000 + msp_product * 10 + msp_revision - '@'; /* Has NICAM support: all mspx41x and mspx45x products have NICAM */ state->has_nicam = msp_prod_hi == 1 || msp_prod_hi == 5; diff --git a/linux/drivers/media/video/msp3400-driver.h b/linux/drivers/media/video/msp3400-driver.h index a783277ab..cbd4a91f5 100644 --- a/linux/drivers/media/video/msp3400-driver.h +++ b/linux/drivers/media/video/msp3400-driver.h @@ -50,6 +50,7 @@ extern int msp_stereo_thresh; struct msp_state { int rev1, rev2; + int ident; u8 has_nicam; u8 has_radio; u8 has_headphones; diff --git a/linux/drivers/media/video/ov7670.c b/linux/drivers/media/video/ov7670.c index d68f36851..b033bf334 100644 --- a/linux/drivers/media/video/ov7670.c +++ b/linux/drivers/media/video/ov7670.c @@ -1316,15 +1316,7 @@ static int ov7670_command(struct i2c_client *client, unsigned int cmd, { switch (cmd) { case VIDIOC_G_CHIP_IDENT: - { - struct v4l2_chip_ident *chip = arg; - - if (!v4l2_chip_match_i2c_client(client, chip->match_type, chip->match_chip)) - return -EINVAL; - chip->ident = V4L2_IDENT_OV7670; - chip->revision = 0; - return 0; - } + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_OV7670, 0); case VIDIOC_INT_RESET: ov7670_reset(client); diff --git a/linux/drivers/media/video/saa7115.c b/linux/drivers/media/video/saa7115.c index 8b4abb3a1..064a81334 100644 --- a/linux/drivers/media/video/saa7115.c +++ b/linux/drivers/media/video/saa7115.c @@ -1449,15 +1449,7 @@ static int saa711x_command(struct i2c_client *client, unsigned int cmd, void *ar #endif case VIDIOC_G_CHIP_IDENT: - { - struct v4l2_chip_ident *chip = arg; - - if (!v4l2_chip_match_i2c_client(client, chip->match_type, chip->match_chip)) - return -EINVAL; - chip->ident = state->ident; - chip->revision = 0; - break; - } + return v4l2_chip_ident_i2c_client(client, arg, state->ident, 0); default: return -EINVAL; diff --git a/linux/drivers/media/video/saa7127.c b/linux/drivers/media/video/saa7127.c index 28306f15d..185eb7e9d 100644 --- a/linux/drivers/media/video/saa7127.c +++ b/linux/drivers/media/video/saa7127.c @@ -664,15 +664,7 @@ static int saa7127_command(struct i2c_client *client, } case VIDIOC_G_CHIP_IDENT: - { - struct v4l2_chip_ident *chip = arg; - - if (!v4l2_chip_match_i2c_client(client, chip->match_type, chip->match_chip)) - return -EINVAL; - chip->ident = state->ident; - chip->revision = 0; - break; - } + return v4l2_chip_ident_i2c_client(client, arg, state->ident, 0); default: return -EINVAL; diff --git a/linux/drivers/media/video/tvaudio.c b/linux/drivers/media/video/tvaudio.c index e08484fd2..cc885951e 100644 --- a/linux/drivers/media/video/tvaudio.c +++ b/linux/drivers/media/video/tvaudio.c @@ -40,6 +40,7 @@ #endif #include <media/tvaudio.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #include <media/i2c-addr.h> @@ -1814,6 +1815,9 @@ static int chip_command(struct i2c_client *client, /* the thread will call checkmode() later */ } break; + + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_TVAUDIO, 0); } return 0; } diff --git a/linux/drivers/media/video/upd64031a.c b/linux/drivers/media/video/upd64031a.c index 3a7db9f7a..bd6a50ec7 100644 --- a/linux/drivers/media/video/upd64031a.c +++ b/linux/drivers/media/video/upd64031a.c @@ -27,6 +27,7 @@ #include <linux/i2c.h> #include <linux/videodev2.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #include <media/upd64031a.h> #include "compat.h" @@ -187,6 +188,9 @@ static int upd64031a_command(struct i2c_client *client, unsigned int cmd, void * } #endif + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_UPD64031A, 0); + default: break; } diff --git a/linux/drivers/media/video/upd64083.c b/linux/drivers/media/video/upd64083.c index 317baed46..ccf340a5b 100644 --- a/linux/drivers/media/video/upd64083.c +++ b/linux/drivers/media/video/upd64083.c @@ -26,6 +26,7 @@ #include <linux/i2c.h> #include <linux/videodev2.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #include <media/upd64083.h> #include "compat.h" @@ -163,6 +164,10 @@ static int upd64083_command(struct i2c_client *client, unsigned int cmd, void *a break; } #endif + + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_UPD64083, 0); + default: break; } diff --git a/linux/drivers/media/video/v4l2-common.c b/linux/drivers/media/video/v4l2-common.c index 60c56a8b0..0a45e19cb 100644 --- a/linux/drivers/media/video/v4l2-common.c +++ b/linux/drivers/media/video/v4l2-common.c @@ -60,6 +60,7 @@ #include <linux/video_decoder.h> #define __OLD_VIDIOC_ /* To allow fixing old calls*/ #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #ifdef CONFIG_KMOD #include <linux/kmod.h> @@ -1605,6 +1606,22 @@ int v4l2_chip_match_i2c_client(struct i2c_client *c, u32 match_type, u32 match_c } } +int v4l2_chip_ident_i2c_client(struct i2c_client *c, struct v4l2_chip_ident *chip, + u32 ident, u32 revision) +{ + if (!v4l2_chip_match_i2c_client(c, chip->match_type, chip->match_chip)) + return 0; + if (chip->ident == V4L2_IDENT_NONE) { + chip->ident = ident; + chip->revision = revision; + } + else { + chip->ident = V4L2_IDENT_AMBIGUOUS; + chip->revision = 0; + } + return 0; +} + int v4l2_chip_match_host(u32 match_type, u32 match_chip) { switch (match_type) { @@ -1639,6 +1656,7 @@ EXPORT_SYMBOL(v4l2_ctrl_query_fill); EXPORT_SYMBOL(v4l2_ctrl_query_fill_std); EXPORT_SYMBOL(v4l2_chip_match_i2c_client); +EXPORT_SYMBOL(v4l2_chip_ident_i2c_client); EXPORT_SYMBOL(v4l2_chip_match_host); /* diff --git a/linux/drivers/media/video/wm8739.c b/linux/drivers/media/video/wm8739.c index 4b4e5277f..da14fa401 100644 --- a/linux/drivers/media/video/wm8739.c +++ b/linux/drivers/media/video/wm8739.c @@ -29,6 +29,7 @@ #include <linux/i2c-id.h> #include <linux/videodev.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) #include "i2c-compat.h" #include <linux/slab.h> @@ -248,6 +249,9 @@ static int wm8739_command(struct i2c_client *client, unsigned int cmd, void *arg return -EINVAL; } + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_WM8739, 0); + case VIDIOC_LOG_STATUS: v4l_info(client, "Frequency: %u Hz\n", state->clock_freq); v4l_info(client, "Volume L: %02x%s\n", state->vol_l & 0x1f, diff --git a/linux/drivers/media/video/wm8775.c b/linux/drivers/media/video/wm8775.c index d64f9c534..4727cbd6d 100644 --- a/linux/drivers/media/video/wm8775.c +++ b/linux/drivers/media/video/wm8775.c @@ -33,6 +33,7 @@ #include <linux/i2c-id.h> #include <linux/videodev.h> #include <media/v4l2-common.h> +#include <media/v4l2-chip-ident.h> #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) #include "i2c-compat.h" #include <linux/slab.h> @@ -132,6 +133,9 @@ static int wm8775_command(struct i2c_client *client, unsigned int cmd, wm8775_write(client, R21, 0x100 + state->input); break; + case VIDIOC_G_CHIP_IDENT: + return v4l2_chip_ident_i2c_client(client, arg, V4L2_IDENT_WM8775, 0); + case VIDIOC_LOG_STATUS: v4l_info(client, "Input: %d%s\n", state->input, state->muted ? " (muted)" : ""); diff --git a/linux/include/media/v4l2-chip-ident.h b/linux/include/media/v4l2-chip-ident.h index 5698fcd1d..09d16c4f0 100644 --- a/linux/include/media/v4l2-chip-ident.h +++ b/linux/include/media/v4l2-chip-ident.h @@ -27,12 +27,17 @@ /* VIDIOC_G_CHIP_IDENT: identifies the actual chip installed on the board */ enum { /* general idents: reserved range 0-49 */ - V4L2_IDENT_UNKNOWN = 0, + V4L2_IDENT_NONE = 0, /* No chip matched */ + V4L2_IDENT_AMBIGUOUS = 1, /* Match too general, multiple chips matched */ + V4L2_IDENT_UNKNOWN = 2, /* Chip found, but cannot identify */ - /* module saa7110: just ident= 100 */ + /* module tvaudio: reserved range 50-99 */ + V4L2_IDENT_TVAUDIO = 50, /* A tvaudio chip, unknown which it is exactly */ + + /* module saa7110: just ident 100 */ V4L2_IDENT_SAA7110 = 100, - /* module saa7111: just ident= 101 */ + /* module saa7111: just ident 101 */ V4L2_IDENT_SAA7111 = 101, /* module saa7115: reserved range 102-149 */ @@ -53,12 +58,92 @@ enum { V4L2_IDENT_CX25842 = 242, V4L2_IDENT_CX25843 = 243, - /* OmniVision sensors - range 250-299 */ + /* OmniVision sensors: reserved range 250-299 */ V4L2_IDENT_OV7670 = 250, - /* Conexant MPEG encoder/decoders: range 410-420 */ + /* Conexant MPEG encoder/decoders: reserved range 410-420 */ V4L2_IDENT_CX23415 = 415, V4L2_IDENT_CX23416 = 416, + + /* module wm8739: just ident 8739 */ + V4L2_IDENT_WM8739 = 8739, + + /* module wm8775: just ident 8775 */ + V4L2_IDENT_WM8775 = 8775, + + /* module cs53132a: just ident 53132 */ + V4L2_IDENT_CS53l32A = 53132, + + /* module upd64031a: just ident 64031 */ + V4L2_IDENT_UPD64031A = 64031, + + /* module upd64083: just ident 64083 */ + V4L2_IDENT_UPD64083 = 64083, + + /* module msp34xx: reserved range 34000-34999 */ + V4L2_IDENT_MSP3400B = 34002, + V4L2_IDENT_MSP3410B = 34102, + + V4L2_IDENT_MSP3400C = 34003, + V4L2_IDENT_MSP3410C = 34103, + + V4L2_IDENT_MSP3400D = 34004, + V4L2_IDENT_MSP3410D = 34104, + V4L2_IDENT_MSP3405D = 34054, + V4L2_IDENT_MSP3415D = 34154, + V4L2_IDENT_MSP3407D = 34074, + V4L2_IDENT_MSP3417D = 34174, + + V4L2_IDENT_MSP3400G = 34007, + V4L2_IDENT_MSP3410G = 34107, + V4L2_IDENT_MSP3420G = 34207, + V4L2_IDENT_MSP3430G = 34307, + V4L2_IDENT_MSP3440G = 34407, + V4L2_IDENT_MSP3450G = 34507, + V4L2_IDENT_MSP3460G = 34607, + + V4L2_IDENT_MSP3401G = 34017, + V4L2_IDENT_MSP3411G = 34117, + V4L2_IDENT_MSP3421G = 34217, + V4L2_IDENT_MSP3431G = 34317, + V4L2_IDENT_MSP3441G = 34417, + V4L2_IDENT_MSP3451G = 34517, + V4L2_IDENT_MSP3461G = 34617, + + V4L2_IDENT_MSP3402G = 34027, + V4L2_IDENT_MSP3412G = 34127, + V4L2_IDENT_MSP3422G = 34227, + V4L2_IDENT_MSP3442G = 34427, + V4L2_IDENT_MSP3452G = 34527, + + V4L2_IDENT_MSP3405G = 34057, + V4L2_IDENT_MSP3415G = 34157, + V4L2_IDENT_MSP3425G = 34257, + V4L2_IDENT_MSP3435G = 34357, + V4L2_IDENT_MSP3445G = 34457, + V4L2_IDENT_MSP3455G = 34557, + V4L2_IDENT_MSP3465G = 34657, + + V4L2_IDENT_MSP3407G = 34077, + V4L2_IDENT_MSP3417G = 34177, + V4L2_IDENT_MSP3427G = 34277, + V4L2_IDENT_MSP3437G = 34377, + V4L2_IDENT_MSP3447G = 34477, + V4L2_IDENT_MSP3457G = 34577, + V4L2_IDENT_MSP3467G = 34677, + + /* module msp44xx: reserved range 44000-44999 */ + V4L2_IDENT_MSP4400G = 44007, + V4L2_IDENT_MSP4410G = 44107, + V4L2_IDENT_MSP4420G = 44207, + V4L2_IDENT_MSP4440G = 44407, + V4L2_IDENT_MSP4450G = 44507, + + V4L2_IDENT_MSP4408G = 44087, + V4L2_IDENT_MSP4418G = 44187, + V4L2_IDENT_MSP4428G = 44287, + V4L2_IDENT_MSP4448G = 44487, + V4L2_IDENT_MSP4458G = 44587, }; #endif diff --git a/linux/include/media/v4l2-common.h b/linux/include/media/v4l2-common.h index cc2ab055a..579835f92 100644 --- a/linux/include/media/v4l2-common.h +++ b/linux/include/media/v4l2-common.h @@ -104,6 +104,8 @@ u32 v4l2_ctrl_next(const u32 * const *ctrl_classes, u32 id); struct i2c_client; /* forward reference */ int v4l2_chip_match_i2c_client(struct i2c_client *c, u32 id_type, u32 chip_id); +int v4l2_chip_ident_i2c_client(struct i2c_client *c, struct v4l2_chip_ident *chip, + u32 ident, u32 revision); int v4l2_chip_match_host(u32 id_type, u32 chip_id); /* ------------------------------------------------------------------------- */ diff --git a/v4l/versions.txt b/v4l/versions.txt index f29387417..e6c2de7c2 100644 --- a/v4l/versions.txt +++ b/v4l/versions.txt @@ -84,6 +84,7 @@ VIDEO_SAA711X VIDEO_SAA7127 VIDEO_UPD64031A VIDEO_UPD64083 +VIDEO_IVTV VIDEO_PVRUSB2 VIDEO_PVRUSB2_24XXX VIDEO_PVRUSB2_SYSFS diff --git a/v4l2-apps/util/Makefile b/v4l2-apps/util/Makefile index f13773c70..fcc193a09 100644 --- a/v4l2-apps/util/Makefile +++ b/v4l2-apps/util/Makefile @@ -9,7 +9,7 @@ binaries = v4l2-ctl v4l2-dbg all: $(binaries) qv4l2 keytable clean:: - rm -f $(binaries) + rm -f $(binaries) v4l2-driverids.cpp v4l2-chipids.cpp -if [ -f qv4l2/Makefile ]; then make -C qv4l2 $@; fi -rm -f qv4l2/qv4l2 qv4l2/Makefile @@ -17,6 +17,9 @@ qv4l2: if [ ! -f qv4l2/Makefile ]; then (cd qv4l2; qmake); fi make -C qv4l2 +v4l2-dbg: v4l2-dbg.o v4l2-driverids.o v4l2-chipids.o + $(CXX) $^ -o $@ + install: include ../Make.rules @@ -39,3 +42,13 @@ keytables: ./gen_keytables.pl ../../linux/drivers/media/common/ir-keymaps.c keytable: keytable.c parse.h keytables + +v4l2-driverids.cpp: ../../linux/include/linux/i2c-id.h + @echo "struct driverid { const char *name; unsigned id; } driverids[] = {" >$@ + @grep I2C_DRIVERID_ $^ | sed -e 's/.*I2C_DRIVERID_\([0-9A-Z_]*\)[^0-9]*\([0-9]*\).*/{ "\1", \2 },/' | tr A-Z a-z >>$@ + @echo "{ 0, 0 }};" >>$@ + +v4l2-chipids.cpp: ../../linux/include/media/v4l2-chip-ident.h + @echo "struct chipid { const char *name; unsigned id; } chipids[] = {" >$@ + @grep V4L2_IDENT_ $^ | sed -e 's/.*V4L2_IDENT_\([0-9A-Z_]*\)[^=]*=[^0-9]*\([0-9]*\).*/{ "\1", \2 },/' | tr A-Z a-z >>$@ + @echo "{ 0, 0 }};" >>$@ diff --git a/v4l2-apps/util/v4l2-dbg.cpp b/v4l2-apps/util/v4l2-dbg.cpp index 70d465dea..6f373281e 100644 --- a/v4l2-apps/util/v4l2-dbg.cpp +++ b/v4l2-apps/util/v4l2-dbg.cpp @@ -34,12 +34,27 @@ #include <sys/klog.h> #include <linux/videodev2.h> +#include <linux/i2c-id.h> #include <list> #include <vector> #include <map> #include <string> +struct driverid { + const char *name; + unsigned id; +}; + +extern struct driverid driverids[]; + +struct chipid { + const char *name; + unsigned id; +}; + +extern struct chipid chipids[]; + /* Short option list Please keep in alphabetical order. @@ -53,12 +68,13 @@ enum Option { OptSetSlicedVbiFormat = 'b', OptSetDevice = 'd', OptGetDriverInfo = 'D', - OptListChipIdents = 'C', + OptScanChipIdents = 'C', OptGetChipIdent = 'c', OptHelp = 'h', OptLogStatus = 128, OptVerbose, + OptListDriverIDs, OptLast = 256 }; @@ -71,11 +87,12 @@ static struct option long_options[] = { {"help", no_argument, 0, OptHelp}, {"list-registers", required_argument, 0, OptListRegisters}, {"set-register", required_argument, 0, OptSetRegister}, - {"list-chip-idents", no_argument, 0, OptListChipIdents}, + {"scan-chip-idents", no_argument, 0, OptScanChipIdents}, {"get-chip-ident", required_argument, 0, OptGetChipIdent}, {"info", no_argument, 0, OptGetDriverInfo}, {"verbose", no_argument, 0, OptVerbose}, {"log-status", no_argument, 0, OptLogStatus}, + {"list-driverids", no_argument, 0, OptListDriverIDs}, {0, 0, 0, 0} }; @@ -91,11 +108,12 @@ static void usage(void) printf(" dump registers from <min> to <max> [VIDIOC_DBG_G_REGISTER]\n"); printf(" -r, --set-register=type=<host/i2cdrv/i2caddr>,chip=<chip>,reg=<addr>,val=<val>\n"); printf(" set the register [VIDIOC_DBG_S_REGISTER]\n"); - printf(" -C, --list-chip-idents\n"); - printf(" List the available host and i2c chips [VIDIOC_G_CHIP_IDENT]\n"); + printf(" -C, --scan-chip-idents\n"); + printf(" Scan the available host and i2c chips [VIDIOC_G_CHIP_IDENT]\n"); printf(" -c, --get-chip-ident=type=<host/i2cdrv/i2caddr>,chip=<chip>\n"); printf(" Get the chip identifier [VIDIOC_G_CHIP_IDENT]\n"); printf(" --log-status log the board status in the kernel log [VIDIOC_LOG_STATUS]\n"); + printf(" --list-driverids list the known I2C driver IDs for use with the i2cdrv type\n"); printf("\n"); printf(" if type == host, then <chip> is the host's chip ID (default 0)\n"); printf(" if type == i2cdrv (default), then <chip> is the I2C driver name or ID\n"); @@ -110,24 +128,13 @@ static unsigned parse_type(const std::string &s) return V4L2_CHIP_MATCH_I2C_DRIVER; } -/* Copied from <linux/i2c-id.h> */ -#define I2C_DRIVERID_SAA711X 73 /* saa711x video encoders */ -#define I2C_DRIVERID_SAA717X 80 /* saa717x video encoder */ -#define I2C_DRIVERID_SAA7127 72 /* saa7124 video encoder */ -#define I2C_DRIVERID_CX25840 71 /* cx2584x video encoder */ - static unsigned parse_chip(int type, const std::string &s) { if (type == V4L2_CHIP_MATCH_HOST || type == V4L2_CHIP_MATCH_I2C_ADDR || isdigit(s[0])) return strtoul(s.c_str(), 0, 0); - if (s == "saa711x") - return I2C_DRIVERID_SAA711X; - if (s == "saa717x") - return I2C_DRIVERID_SAA717X; - if (s == "saa7127") - return I2C_DRIVERID_SAA7127; - if (s == "cx2584x") - return I2C_DRIVERID_CX25840; + for (int i = 0; driverids[i].name; i++) + if (!strcasecmp(s.c_str(), driverids[i].name)) + return driverids[i].id; return 0; } @@ -206,7 +213,18 @@ static void print_regs(int fd, struct v4l2_register *reg, unsigned long min, uns static void print_chip(struct v4l2_chip_ident *chip) { - printf("Chip %d, revision 0x%08x\n", chip->ident, chip->revision); + const char *name = NULL; + + for (int i = 0; chipids[i].name; i++) { + if (chipids[i].id == chip->ident) { + name = chipids[i].name; + break; + } + } + if (name) + printf("%-10s revision 0x%08x\n", name, chip->revision); + else + printf("%-10d revision 0x%08x\n", chip->ident, chip->revision); } static int doioctl(int fd, int request, void *parm, const char *name) @@ -429,22 +447,23 @@ int main(int argc, char **argv) print_chip(&chip_id); } - if (options[OptListChipIdents]) { + if (options[OptScanChipIdents]) { int i; chip_id.match_type = V4L2_CHIP_MATCH_HOST; chip_id.match_chip = 0; - chip_id.ident = 0; - if (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident) + while (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident) { + printf("host 0x%x: ", chip_id.match_chip); print_chip(&chip_id); + chip_id.match_chip++; + } chip_id.match_type = V4L2_CHIP_MATCH_I2C_ADDR; for (i = 0; i < 128; i++) { chip_id.match_chip = i; - chip_id.ident = 0; if (doioctl(fd, VIDIOC_G_CHIP_IDENT, &chip_id, "VIDIOC_G_CHIP_IDENT") == 0 && chip_id.ident) { - printf("0x%02x: ", i); + printf("i2c 0x%02x: ", i); print_chip(&chip_id); } } @@ -511,6 +530,12 @@ int main(int argc, char **argv) } } + if (options[OptListDriverIDs]) { + printf("Known I2C driver IDs:\n"); + for (int i = 0; driverids[i].name; i++) + printf("%s\n", driverids[i].name); + } + close(fd); exit(0); } |