Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 92743
b: refs/heads/master
c: 5aa2110
h: refs/heads/master
i:
  92741: 66b87e5
  92739: 50e8dea
  92735: d918037
v: v3
  • Loading branch information
Guennadi Liakhovetski authored and Mauro Carvalho Chehab committed Apr 24, 2008
1 parent ddb3bfd commit 4dfda45
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 21 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: e7c506881973d0c762d660005be54c4095219c59
refs/heads/master: 5aa2110f3f33feb4a0c67a4996dc400dc594bc1d
35 changes: 15 additions & 20 deletions trunk/drivers/media/video/pxa_camera.c
Original file line number Diff line number Diff line change
Expand Up @@ -102,11 +102,6 @@ struct pxa_buffer {
enum pxa_camera_active_dma active_dma;
};

struct pxa_framebuffer_queue {
dma_addr_t sg_last_dma;
struct pxa_dma_desc *sg_last_cpu;
};

struct pxa_camera_dev {
struct device *dev;
/* PXA27x is only supposed to handle one camera on its Quick Capture
Expand All @@ -131,6 +126,7 @@ struct pxa_camera_dev {
spinlock_t lock;

struct pxa_buffer *active;
struct pxa_dma_desc *sg_tail[3];
};

static const char *pxa_cam_driver_description = "PXA_Camera";
Expand All @@ -144,11 +140,14 @@ static int pxa_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
unsigned int *size)
{
struct soc_camera_device *icd = vq->priv_data;
struct soc_camera_host *ici =
to_soc_camera_host(icd->dev.parent);
struct pxa_camera_dev *pcdev = ici->priv;

dev_dbg(&icd->dev, "count=%d, size=%d\n", *count, *size);

/* planar capture requires Y, U and V buffers to be page aligned */
if (icd->current_fmt->fourcc == V4L2_PIX_FMT_YUV422P) {
if (pcdev->channels == 3) {
*size = PAGE_ALIGN(icd->width * icd->height); /* Y pages */
*size += PAGE_ALIGN(icd->width * icd->height / 2); /* U pages */
*size += PAGE_ALIGN(icd->width * icd->height / 2); /* V pages */
Expand Down Expand Up @@ -296,7 +295,7 @@ static int pxa_videobuf_prepare(struct videobuf_queue *vq,
if (ret)
goto fail;

if (buf->fmt->fourcc == V4L2_PIX_FMT_YUV422P) {
if (pcdev->channels == 3) {
/* FIXME the calculations should be more precise */
sglen_y = dma->sglen / 2;
sglen_u = sglen_v = dma->sglen / 4 + 1;
Expand All @@ -318,7 +317,7 @@ static int pxa_videobuf_prepare(struct videobuf_queue *vq,
goto fail;
}

if (buf->fmt->fourcc == V4L2_PIX_FMT_YUV422P) {
if (pcdev->channels == 3) {
/* init DMA for U channel */
ret = pxa_init_dma_channel(pcdev, buf, dma, 1, sglen_u,
sglen_y, 0x30, size_u);
Expand All @@ -343,7 +342,7 @@ static int pxa_videobuf_prepare(struct videobuf_queue *vq,

buf->inwork = 0;
buf->active_dma = DMA_Y;
if (buf->fmt->fourcc == V4L2_PIX_FMT_YUV422P)
if (pcdev->channels == 3)
buf->active_dma |= DMA_U | DMA_V;

return 0;
Expand Down Expand Up @@ -371,6 +370,7 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq,
struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb);
struct pxa_buffer *active;
unsigned long flags;
int i;

dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
vb, vb->baddr, vb->bsize);
Expand All @@ -383,15 +383,11 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq,

if (!active) {
CIFR |= CIFR_RESET_F;
DDADR(pcdev->dma_chans[0]) = buf->dmas[0].sg_dma;
DCSR(pcdev->dma_chans[0]) = DCSR_RUN;

if (buf->fmt->fourcc == V4L2_PIX_FMT_YUV422P) {
DDADR(pcdev->dma_chans[1]) = buf->dmas[1].sg_dma;
DCSR(pcdev->dma_chans[1]) = DCSR_RUN;

DDADR(pcdev->dma_chans[2]) = buf->dmas[2].sg_dma;
DCSR(pcdev->dma_chans[2]) = DCSR_RUN;
for (i = 0; i < pcdev->channels; i++) {
DDADR(pcdev->dma_chans[i]) = buf->dmas[i].sg_dma;
DCSR(pcdev->dma_chans[i]) = DCSR_RUN;
pcdev->sg_tail[i] = buf->dmas[i].sg_cpu + buf->dmas[i].sglen - 1;
}

pcdev->active = buf;
Expand All @@ -400,7 +396,6 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq,
struct pxa_cam_dma *buf_dma;
struct pxa_cam_dma *act_dma;
int nents;
int i;

for (i = 0; i < pcdev->channels; i++) {
buf_dma = &buf->dmas[i];
Expand All @@ -412,8 +407,8 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq,

/* Add the descriptors we just initialized to
the currently running chain */
act_dma->sg_cpu[act_dma->sglen - 1].ddadr =
buf_dma->sg_dma;
pcdev->sg_tail[i]->ddadr = buf_dma->sg_dma;
pcdev->sg_tail[i] = buf_dma->sg_cpu + buf_dma->sglen - 1;

/* Setup a dummy descriptor with the DMA engines current
* state
Expand Down

0 comments on commit 4dfda45

Please sign in to comment.