aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteven Toth <stoth@kernellabs.com>2010-07-31 14:27:01 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2010-10-21 05:54:55 -0400
commita97781ac918073117bb8e63619c77e0380bbcc8d (patch)
tree86c1aa3ca456bd36d4fb8bc9b650c991676b4d8c
parent12d3203e39db306f56611b3f47ba425ca6a409f9 (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.c3
-rw-r--r--drivers/media/video/saa7164/saa7164-core.c60
-rw-r--r--drivers/media/video/saa7164/saa7164-encoder.c9
-rw-r--r--drivers/media/video/saa7164/saa7164.h3
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
97static 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
97static void saa7164_ts_verifier(struct saa7164_buffer *buf) 109static 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)
210static void saa7164_histogram_print(struct saa7164_port *port, 221static 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
398struct saa7164_dev { 401struct saa7164_dev {