diff options
author | Steven Toth <stoth@kernellabs.com> | 2010-07-31 14:27:01 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2010-10-21 05:54:55 -0400 |
commit | a97781ac918073117bb8e63619c77e0380bbcc8d (patch) | |
tree | 86c1aa3ca456bd36d4fb8bc9b650c991676b4d8c | |
parent | 12d3203e39db306f56611b3f47ba425ca6a409f9 (diff) |
[media] saa7164: adjust the PS pack size handling to fill buffers 100%
Signed-off-by: Steven Toth <stoth@kernellabs.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r-- | drivers/media/video/saa7164/saa7164-buffer.c | 3 | ||||
-rw-r--r-- | drivers/media/video/saa7164/saa7164-core.c | 60 | ||||
-rw-r--r-- | drivers/media/video/saa7164/saa7164-encoder.c | 9 | ||||
-rw-r--r-- | drivers/media/video/saa7164/saa7164.h | 3 |
4 files changed, 46 insertions, 29 deletions
diff --git a/drivers/media/video/saa7164/saa7164-buffer.c b/drivers/media/video/saa7164/saa7164-buffer.c index b75157d411dd..5f45ea7f3d7c 100644 --- a/drivers/media/video/saa7164/saa7164-buffer.c +++ b/drivers/media/video/saa7164/saa7164-buffer.c | |||
@@ -142,7 +142,8 @@ struct saa7164_buffer *saa7164_buffer_alloc(struct saa7164_port *port, | |||
142 | buf->pt_cpu, (long)buf->pt_dma, buf->pt_size); | 142 | buf->pt_cpu, (long)buf->pt_dma, buf->pt_size); |
143 | 143 | ||
144 | /* Format the Page Table Entries to point into the data buffer */ | 144 | /* Format the Page Table Entries to point into the data buffer */ |
145 | for (i = 0 ; i < SAA7164_PT_ENTRIES; i++) { | 145 | // for (i = 0 ; i < SAA7164_PT_ENTRIES; i++) { |
146 | for (i = 0 ; i < 10; i++) { | ||
146 | 147 | ||
147 | *(buf->pt_cpu + i) = buf->dma + (i * 0x1000); /* TODO */ | 148 | *(buf->pt_cpu + i) = buf->dma + (i * 0x1000); /* TODO */ |
148 | 149 | ||
diff --git a/drivers/media/video/saa7164/saa7164-core.c b/drivers/media/video/saa7164/saa7164-core.c index 79e1a2ee7e9e..fd15bf388e3b 100644 --- a/drivers/media/video/saa7164/saa7164-core.c +++ b/drivers/media/video/saa7164/saa7164-core.c | |||
@@ -94,10 +94,21 @@ void saa7164_dumphex16FF(struct saa7164_dev *dev, u8 *buf, int len) | |||
94 | } | 94 | } |
95 | } | 95 | } |
96 | 96 | ||
97 | static void saa7164_pack_verifier(struct saa7164_buffer *buf) | ||
98 | { | ||
99 | u8 *p = (u8 *)buf->cpu; | ||
100 | int i; | ||
101 | |||
102 | for (i = 0; i < buf->actual_size; i += 2048) { | ||
103 | |||
104 | if ( (*(p + i + 0) != 0x00) || (*(p + i + 1) != 0x00) || (*(p + i + 2) != 0x01) || (*(p + i + 3) != 0xBA) ) | ||
105 | printk(KERN_ERR "No pack at 0x%x\n", i); | ||
106 | } | ||
107 | } | ||
108 | |||
97 | static void saa7164_ts_verifier(struct saa7164_buffer *buf) | 109 | static void saa7164_ts_verifier(struct saa7164_buffer *buf) |
98 | { | 110 | { |
99 | struct saa7164_port *port = buf->port; | 111 | struct saa7164_port *port = buf->port; |
100 | struct saa7164_dev *dev = port->dev; | ||
101 | u32 i; | 112 | u32 i; |
102 | u8 tmp, cc, a; | 113 | u8 tmp, cc, a; |
103 | u8 *bufcpu = (u8 *)buf->cpu; | 114 | u8 *bufcpu = (u8 *)buf->cpu; |
@@ -210,7 +221,6 @@ void saa7164_histogram_update(struct saa7164_histogram *hg, u32 val) | |||
210 | static void saa7164_histogram_print(struct saa7164_port *port, | 221 | static void saa7164_histogram_print(struct saa7164_port *port, |
211 | struct saa7164_histogram *hg) | 222 | struct saa7164_histogram *hg) |
212 | { | 223 | { |
213 | struct saa7164_dev *dev = port->dev; | ||
214 | u32 entries = 0; | 224 | u32 entries = 0; |
215 | int i; | 225 | int i; |
216 | 226 | ||
@@ -296,7 +306,7 @@ static void saa7164_work_enchandler(struct work_struct *w) | |||
296 | (*(p + buf->actual_size + 0x12) != 0xff) || | 306 | (*(p + buf->actual_size + 0x12) != 0xff) || |
297 | (*(p + buf->actual_size + 0x13) != 0xff) ) | 307 | (*(p + buf->actual_size + 0x13) != 0xff) ) |
298 | { | 308 | { |
299 | printk(KERN_ERR "buf %p failed guard check\n", buf); | 309 | printk(KERN_ERR "%s() buf %p failed guard check\n", __func__, buf); |
300 | saa7164_dumphex16(dev, p + buf->actual_size - 32, 64); | 310 | saa7164_dumphex16(dev, p + buf->actual_size - 32, 64); |
301 | } | 311 | } |
302 | 312 | ||
@@ -317,6 +327,8 @@ static void saa7164_work_enchandler(struct work_struct *w) | |||
317 | /* Validate the incoming buffer content */ | 327 | /* Validate the incoming buffer content */ |
318 | if (port->encoder_params.stream_type == V4L2_MPEG_STREAM_TYPE_MPEG2_TS) | 328 | if (port->encoder_params.stream_type == V4L2_MPEG_STREAM_TYPE_MPEG2_TS) |
319 | saa7164_ts_verifier(buf); | 329 | saa7164_ts_verifier(buf); |
330 | if (port->encoder_params.stream_type == V4L2_MPEG_STREAM_TYPE_MPEG2_PS) | ||
331 | saa7164_pack_verifier(buf); | ||
320 | 332 | ||
321 | /* find a free user buffer and clone to it */ | 333 | /* find a free user buffer and clone to it */ |
322 | if (!list_empty(&port->list_buf_free.list)) { | 334 | if (!list_empty(&port->list_buf_free.list)) { |
@@ -325,8 +337,9 @@ static void saa7164_work_enchandler(struct work_struct *w) | |||
325 | ubuf = list_first_entry(&port->list_buf_free.list, | 337 | ubuf = list_first_entry(&port->list_buf_free.list, |
326 | struct saa7164_user_buffer, list); | 338 | struct saa7164_user_buffer, list); |
327 | 339 | ||
328 | if (ubuf->actual_size >= buf->actual_size) { | 340 | if (buf->actual_size <= ubuf->actual_size) { |
329 | memcpy(ubuf->data, port->shadow_buf[rp], 312 * 188); | 341 | |
342 | memcpy_fromio(ubuf->data, buf->cpu, ubuf->actual_size); | ||
330 | 343 | ||
331 | /* Throw a new checksum on the read buffer */ | 344 | /* Throw a new checksum on the read buffer */ |
332 | ubuf->crc = crc32(0, ubuf->data, ubuf->actual_size); | 345 | ubuf->crc = crc32(0, ubuf->data, ubuf->actual_size); |
@@ -342,29 +355,30 @@ static void saa7164_work_enchandler(struct work_struct *w) | |||
342 | rp, buf->crc, port->shadow_crc[rp], ubuf->crc, | 355 | rp, buf->crc, port->shadow_crc[rp], ubuf->crc, |
343 | ok ? "crcgood" : "crcbad"); | 356 | ok ? "crcgood" : "crcbad"); |
344 | 357 | ||
345 | } else { | 358 | /* Requeue the buffer on the free list */ |
346 | printk(KERN_ERR "buf %p actual fails match\n", buf); | 359 | ubuf->pos = 0; |
347 | } | ||
348 | 360 | ||
349 | /* Requeue the buffer on the free list */ | 361 | list_move_tail(&ubuf->list, |
350 | ubuf->pos = 0; | 362 | &port->list_buf_used.list); |
351 | 363 | ||
352 | list_move_tail(&ubuf->list, | 364 | /* Flag any userland waiters */ |
353 | &port->list_buf_used.list); | 365 | wake_up_interruptible(&port->wait_read); |
354 | 366 | ||
355 | /* Flag any userland waiters */ | 367 | } else { |
356 | wake_up_interruptible(&port->wait_read); | 368 | printk(KERN_ERR "buf %p bufsize fails match\n", buf); |
369 | } | ||
357 | 370 | ||
358 | } else | 371 | } else |
359 | printk(KERN_ERR "encirq no free buffers, increase param encoder_buffers\n"); | 372 | printk(KERN_ERR "encirq no free buffers, increase param encoder_buffers\n"); |
360 | 373 | ||
361 | /* Ensure offset into buffer remains 0, fill buffer | 374 | /* Ensure offset into buffer remains 0, fill buffer |
362 | * with known bad data. */ | 375 | * with known bad data. We check for this data at a later point |
376 | * in time. */ | ||
363 | saa7164_buffer_zero_offsets(port, rp); | 377 | saa7164_buffer_zero_offsets(port, rp); |
364 | memset_io(buf->cpu, 0xff, buf->pci_size); | 378 | memset_io(buf->cpu, 0xff, buf->pci_size); |
365 | buf->crc = crc32(0, buf->cpu, buf->actual_size); | 379 | buf->crc = crc32(0, buf->cpu, buf->actual_size); |
366 | 380 | ||
367 | // break; | 381 | break; |
368 | } else { | 382 | } else { |
369 | /* Validate all other checksums, on previous buffers - they should never change */ | 383 | /* Validate all other checksums, on previous buffers - they should never change */ |
370 | crc = crc32(0, buf->cpu, buf->actual_size); | 384 | crc = crc32(0, buf->cpu, buf->actual_size); |
@@ -412,7 +426,6 @@ static irqreturn_t saa7164_irq_encoder(struct saa7164_port *port) | |||
412 | { | 426 | { |
413 | struct saa7164_dev *dev = port->dev; | 427 | struct saa7164_dev *dev = port->dev; |
414 | struct saa7164_buffer *buf; | 428 | struct saa7164_buffer *buf; |
415 | struct saa7164_user_buffer *ubuf; | ||
416 | struct list_head *c, *n; | 429 | struct list_head *c, *n; |
417 | int wp, rp, i = 0; | 430 | int wp, rp, i = 0; |
418 | u8 *p; | 431 | u8 *p; |
@@ -490,10 +503,11 @@ static irqreturn_t saa7164_irq_encoder(struct saa7164_port *port) | |||
490 | 503 | ||
491 | if (buf->idx == rp) { | 504 | if (buf->idx == rp) { |
492 | 505 | ||
493 | memcpy_fromio(port->shadow_buf[rp], buf->cpu, 312 * 188); | 506 | memcpy_fromio(port->shadow_buf[rp], buf->cpu, buf->actual_size); |
494 | port->shadow_crc[rp] = crc32(0, port->shadow_buf[rp], 312 * 188); | ||
495 | 507 | ||
496 | buf->crc = crc32(0, buf->cpu, 312 * 188); | 508 | port->shadow_crc[rp] = crc32(0, port->shadow_buf[rp], buf->actual_size); |
509 | |||
510 | buf->crc = crc32(0, buf->cpu, buf->actual_size); | ||
497 | 511 | ||
498 | if (port->shadow_crc[rp] != buf->crc) | 512 | if (port->shadow_crc[rp] != buf->crc) |
499 | printk(KERN_ERR "%s() crc check failed 0x%x vs 0x%x\n", | 513 | printk(KERN_ERR "%s() crc check failed 0x%x vs 0x%x\n", |
@@ -885,12 +899,12 @@ static int saa7164_port_init(struct saa7164_dev *dev, int portnr) | |||
885 | 899 | ||
886 | if (port->type == SAA7164_MPEG_ENCODER) { | 900 | if (port->type == SAA7164_MPEG_ENCODER) { |
887 | for (i = 0; i < 8; i ++) { | 901 | for (i = 0; i < 8; i ++) { |
888 | port->shadow_buf[i] = kzalloc(312 * 188, GFP_KERNEL); | 902 | port->shadow_buf[i] = kzalloc(256 * 128, GFP_KERNEL); |
889 | if (port->shadow_buf[i] == 0) | 903 | if (port->shadow_buf[i] == 0) |
890 | printk(KERN_ERR "%s() shadow_buf ENOMEM\n", __func__); | 904 | printk(KERN_ERR "%s() shadow_buf ENOMEM\n", __func__); |
891 | else { | 905 | else { |
892 | memset(port->shadow_buf[i], 0xff, 312 * 188); | 906 | memset(port->shadow_buf[i], 0xff, 256 * 128); |
893 | port->shadow_crc[i] = crc32(0, port->shadow_buf[i], 312 * 188); | 907 | port->shadow_crc[i] = crc32(0, port->shadow_buf[i], 256 * 128); |
894 | } | 908 | } |
895 | } | 909 | } |
896 | } | 910 | } |
diff --git a/drivers/media/video/saa7164/saa7164-encoder.c b/drivers/media/video/saa7164/saa7164-encoder.c index f3ecdc93e20e..08b62e41c466 100644 --- a/drivers/media/video/saa7164/saa7164-encoder.c +++ b/drivers/media/video/saa7164/saa7164-encoder.c | |||
@@ -1314,16 +1314,15 @@ int saa7164_encoder_register(struct saa7164_port *port) | |||
1314 | /* Init and establish defaults */ | 1314 | /* Init and establish defaults */ |
1315 | /* TODO: Check the umber of lines for PS */ | 1315 | /* TODO: Check the umber of lines for PS */ |
1316 | port->hw_streamingparams.bitspersample = 8; | 1316 | port->hw_streamingparams.bitspersample = 8; |
1317 | port->hw_streamingparams.samplesperline = 188; | 1317 | port->hw_streamingparams.samplesperline = 128; |
1318 | port->hw_streamingparams.numberoflines = | 1318 | port->hw_streamingparams.numberoflines = 256; |
1319 | (SAA7164_TS_NUMBER_OF_LINES * 188) / 188; | ||
1320 | 1319 | ||
1321 | port->hw_streamingparams.pitch = 188; | 1320 | port->hw_streamingparams.pitch = 128; |
1322 | port->hw_streamingparams.linethreshold = 0; | 1321 | port->hw_streamingparams.linethreshold = 0; |
1323 | port->hw_streamingparams.pagetablelistvirt = 0; | 1322 | port->hw_streamingparams.pagetablelistvirt = 0; |
1324 | port->hw_streamingparams.pagetablelistphys = 0; | 1323 | port->hw_streamingparams.pagetablelistphys = 0; |
1325 | port->hw_streamingparams.numpagetables = 2 + | 1324 | port->hw_streamingparams.numpagetables = 2 + |
1326 | ((SAA7164_TS_NUMBER_OF_LINES * 188) / PAGE_SIZE); | 1325 | ((SAA7164_PS_NUMBER_OF_LINES * 128) / PAGE_SIZE); |
1327 | 1326 | ||
1328 | port->hw_streamingparams.numpagetableentries = port->hwcfg.buffercount; | 1327 | port->hw_streamingparams.numpagetableentries = port->hwcfg.buffercount; |
1329 | 1328 | ||
diff --git a/drivers/media/video/saa7164/saa7164.h b/drivers/media/video/saa7164/saa7164.h index a8a29e56b2ce..80571e0e3d4b 100644 --- a/drivers/media/video/saa7164/saa7164.h +++ b/drivers/media/video/saa7164/saa7164.h | |||
@@ -85,6 +85,7 @@ | |||
85 | 85 | ||
86 | #define SAA7164_MAX_UNITS 8 | 86 | #define SAA7164_MAX_UNITS 8 |
87 | #define SAA7164_TS_NUMBER_OF_LINES 312 | 87 | #define SAA7164_TS_NUMBER_OF_LINES 312 |
88 | #define SAA7164_PS_NUMBER_OF_LINES 256 | ||
88 | #define SAA7164_PT_ENTRIES 16 /* (312 * 188) / 4096 */ | 89 | #define SAA7164_PT_ENTRIES 16 /* (312 * 188) / 4096 */ |
89 | #define SAA7164_MAX_ENCODER_BUFFERS 64 /* max 5secs of latency at 6Mbps */ | 90 | #define SAA7164_MAX_ENCODER_BUFFERS 64 /* max 5secs of latency at 6Mbps */ |
90 | 91 | ||
@@ -393,6 +394,8 @@ struct saa7164_port { | |||
393 | 394 | ||
394 | u8 *shadow_buf[8]; | 395 | u8 *shadow_buf[8]; |
395 | u32 shadow_crc[8]; | 396 | u32 shadow_crc[8]; |
397 | |||
398 | u32 dvd_pack_offset; | ||
396 | }; | 399 | }; |
397 | 400 | ||
398 | struct saa7164_dev { | 401 | struct saa7164_dev { |