* [PATCH v3 0/4] Use dma_mmap_coherent to support IOMMU mapper @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU There is a dma_mmap_coherent() API in some architectures. This API provides a mmap function for memory allocated by dma_alloc_coherent(). Some drivers mmap a dma_addr_t returned by dma_alloc_coherent() as a physical address. But such drivers do not work correctly when IOMMU mapper is used. v3: - Remove an unnecessary line which sets page protection bits. v2: - Rebase on fbdev-next branch of git://github.com/schandinat/linux-2.6.git. - Initialize .fb_mmap in both sh_mobile_lcdc_overlay_ops and sh_mobile_lcdc_ops. - Add Laurent's clean up patch. Hideki EIRAKU (3): ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT media: videobuf2-dma-contig: use dma_mmap_coherent if available fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available Laurent Pinchart (1): ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM arch/arm/include/asm/dma-mapping.h | 1 + drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ sound/core/pcm_native.c | 7 ------- 4 files changed, 46 insertions(+), 7 deletions(-) ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 0/4] Use dma_mmap_coherent to support IOMMU mapper @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: linux-arm-kernel There is a dma_mmap_coherent() API in some architectures. This API provides a mmap function for memory allocated by dma_alloc_coherent(). Some drivers mmap a dma_addr_t returned by dma_alloc_coherent() as a physical address. But such drivers do not work correctly when IOMMU mapper is used. v3: - Remove an unnecessary line which sets page protection bits. v2: - Rebase on fbdev-next branch of git://github.com/schandinat/linux-2.6.git. - Initialize .fb_mmap in both sh_mobile_lcdc_overlay_ops and sh_mobile_lcdc_ops. - Add Laurent's clean up patch. Hideki EIRAKU (3): ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT media: videobuf2-dma-contig: use dma_mmap_coherent if available fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available Laurent Pinchart (1): ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM arch/arm/include/asm/dma-mapping.h | 1 + drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ sound/core/pcm_native.c | 7 ------- 4 files changed, 46 insertions(+), 7 deletions(-) ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 0/4] Use dma_mmap_coherent to support IOMMU mapper @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU There is a dma_mmap_coherent() API in some architectures. This API provides a mmap function for memory allocated by dma_alloc_coherent(). Some drivers mmap a dma_addr_t returned by dma_alloc_coherent() as a physical address. But such drivers do not work correctly when IOMMU mapper is used. v3: - Remove an unnecessary line which sets page protection bits. v2: - Rebase on fbdev-next branch of git://github.com/schandinat/linux-2.6.git. - Initialize .fb_mmap in both sh_mobile_lcdc_overlay_ops and sh_mobile_lcdc_ops. - Add Laurent's clean up patch. Hideki EIRAKU (3): ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT media: videobuf2-dma-contig: use dma_mmap_coherent if available fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available Laurent Pinchart (1): ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM arch/arm/include/asm/dma-mapping.h | 1 + drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ sound/core/pcm_native.c | 7 ------- 4 files changed, 46 insertions(+), 7 deletions(-) ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT 2012-08-06 9:55 ` Hideki EIRAKU (?) @ 2012-08-06 9:55 ` Hideki EIRAKU -1 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API in this architecture. The name is already defined in PowerPC. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- arch/arm/include/asm/dma-mapping.h | 1 + 1 files changed, 1 insertions(+), 0 deletions(-) diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h index bbef15d..f41cd30 100644 --- a/arch/arm/include/asm/dma-mapping.h +++ b/arch/arm/include/asm/dma-mapping.h @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, struct dma_attrs *attrs); #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) +#define ARCH_HAS_DMA_MMAP_COHERENT static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, void *cpu_addr, dma_addr_t dma_addr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: linux-arm-kernel ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API in this architecture. The name is already defined in PowerPC. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- arch/arm/include/asm/dma-mapping.h | 1 + 1 files changed, 1 insertions(+), 0 deletions(-) diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h index bbef15d..f41cd30 100644 --- a/arch/arm/include/asm/dma-mapping.h +++ b/arch/arm/include/asm/dma-mapping.h @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, struct dma_attrs *attrs); #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) +#define ARCH_HAS_DMA_MMAP_COHERENT static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, void *cpu_addr, dma_addr_t dma_addr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API in this architecture. The name is already defined in PowerPC. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- arch/arm/include/asm/dma-mapping.h | 1 + 1 files changed, 1 insertions(+), 0 deletions(-) diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h index bbef15d..f41cd30 100644 --- a/arch/arm/include/asm/dma-mapping.h +++ b/arch/arm/include/asm/dma-mapping.h @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, struct dma_attrs *attrs); #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) +#define ARCH_HAS_DMA_MMAP_COHERENT static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, void *cpu_addr, dma_addr_t dma_addr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* RE: [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT 2012-08-06 9:55 ` Hideki EIRAKU (?) @ 2012-08-07 15:22 ` Marek Szyprowski -1 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 15:22 UTC (permalink / raw) To: 'Hideki EIRAKU', 'Russell King', 'Pawel Osciak', 'Kyungmin Park', 'Mauro Carvalho Chehab', 'Florian Tobias Schandinat', 'Jaroslav Kysela', 'Takashi Iwai' Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, 'Katsuya MATSUBARA' Hi Hideki, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API > in this architecture. The name is already defined in PowerPC. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > --- > arch/arm/include/asm/dma-mapping.h | 1 + > 1 files changed, 1 insertions(+), 0 deletions(-) > > diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h > index bbef15d..f41cd30 100644 > --- a/arch/arm/include/asm/dma-mapping.h > +++ b/arch/arm/include/asm/dma-mapping.h > @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, > struct dma_attrs *attrs); > > #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) > +#define ARCH_HAS_DMA_MMAP_COHERENT > > static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, > void *cpu_addr, dma_addr_t dma_addr, > -- > 1.7.0.4 I will take this patch to my dma-mapping kernel tree, to the fixes branch. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT @ 2012-08-07 15:22 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 15:22 UTC (permalink / raw) To: linux-arm-kernel Hi Hideki, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API > in this architecture. The name is already defined in PowerPC. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > --- > arch/arm/include/asm/dma-mapping.h | 1 + > 1 files changed, 1 insertions(+), 0 deletions(-) > > diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h > index bbef15d..f41cd30 100644 > --- a/arch/arm/include/asm/dma-mapping.h > +++ b/arch/arm/include/asm/dma-mapping.h > @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, > struct dma_attrs *attrs); > > #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) > +#define ARCH_HAS_DMA_MMAP_COHERENT > > static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, > void *cpu_addr, dma_addr_t dma_addr, > -- > 1.7.0.4 I will take this patch to my dma-mapping kernel tree, to the fixes branch. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* RE: [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT @ 2012-08-07 15:22 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 15:22 UTC (permalink / raw) To: 'Hideki EIRAKU', 'Russell King', 'Pawel Osciak', 'Kyungmin Park', 'Mauro Carvalho Chehab', 'Florian Tobias Schandinat', 'Jaroslav Kysela', 'Takashi Iwai' Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, 'Katsuya MATSUBARA' Hi Hideki, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > ARCH_HAS_DMA_MMAP_COHERENT indicates that there is dma_mmap_coherent() API > in this architecture. The name is already defined in PowerPC. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > --- > arch/arm/include/asm/dma-mapping.h | 1 + > 1 files changed, 1 insertions(+), 0 deletions(-) > > diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h > index bbef15d..f41cd30 100644 > --- a/arch/arm/include/asm/dma-mapping.h > +++ b/arch/arm/include/asm/dma-mapping.h > @@ -187,6 +187,7 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, > struct dma_attrs *attrs); > > #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) > +#define ARCH_HAS_DMA_MMAP_COHERENT > > static inline int dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, > void *cpu_addr, dma_addr_t dma_addr, > -- > 1.7.0.4 I will take this patch to my dma-mapping kernel tree, to the fixes branch. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 2/4] ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM 2012-08-06 9:55 ` Hideki EIRAKU (?) (?) @ 2012-08-06 9:55 ` Hideki EIRAKU -1 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: Katsuya MATSUBARA, linux-fbdev, alsa-devel, linux-kernel, Laurent Pinchart, linux-arm-kernel, linux-media From: Laurent Pinchart <laurent.pinchart@ideasonboard.com> The ARM architecture now defines ARCH_HAS_DMA_MMAP_COHERENT, there's no need to define it privately anymore. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- sound/core/pcm_native.c | 7 ------- 1 files changed, 0 insertions(+), 7 deletions(-) diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 53b5ada..84ead60 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c @@ -3156,13 +3156,6 @@ static const struct vm_operations_struct snd_pcm_vm_ops_data_fault = { .fault = snd_pcm_mmap_data_fault, }; -#ifndef ARCH_HAS_DMA_MMAP_COHERENT -/* This should be defined / handled globally! */ -#ifdef CONFIG_ARM -#define ARCH_HAS_DMA_MMAP_COHERENT -#endif -#endif - /* * mmap the DMA buffer on RAM */ -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 2/4] ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Laurent Pinchart From: Laurent Pinchart <laurent.pinchart@ideasonboard.com> The ARM architecture now defines ARCH_HAS_DMA_MMAP_COHERENT, there's no need to define it privately anymore. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- sound/core/pcm_native.c | 7 ------- 1 files changed, 0 insertions(+), 7 deletions(-) diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 53b5ada..84ead60 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c @@ -3156,13 +3156,6 @@ static const struct vm_operations_struct snd_pcm_vm_ops_data_fault = { .fault = snd_pcm_mmap_data_fault, }; -#ifndef ARCH_HAS_DMA_MMAP_COHERENT -/* This should be defined / handled globally! */ -#ifdef CONFIG_ARM -#define ARCH_HAS_DMA_MMAP_COHERENT -#endif -#endif - /* * mmap the DMA buffer on RAM */ -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 2/4] ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: linux-arm-kernel From: Laurent Pinchart <laurent.pinchart@ideasonboard.com> The ARM architecture now defines ARCH_HAS_DMA_MMAP_COHERENT, there's no need to define it privately anymore. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- sound/core/pcm_native.c | 7 ------- 1 files changed, 0 insertions(+), 7 deletions(-) diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 53b5ada..84ead60 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c @@ -3156,13 +3156,6 @@ static const struct vm_operations_struct snd_pcm_vm_ops_data_fault = { .fault = snd_pcm_mmap_data_fault, }; -#ifndef ARCH_HAS_DMA_MMAP_COHERENT -/* This should be defined / handled globally! */ -#ifdef CONFIG_ARM -#define ARCH_HAS_DMA_MMAP_COHERENT -#endif -#endif - /* * mmap the DMA buffer on RAM */ -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 2/4] ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: Katsuya MATSUBARA, linux-fbdev, alsa-devel, linux-kernel, Laurent Pinchart, linux-arm-kernel, linux-media From: Laurent Pinchart <laurent.pinchart@ideasonboard.com> The ARM architecture now defines ARCH_HAS_DMA_MMAP_COHERENT, there's no need to define it privately anymore. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- sound/core/pcm_native.c | 7 ------- 1 files changed, 0 insertions(+), 7 deletions(-) diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 53b5ada..84ead60 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c @@ -3156,13 +3156,6 @@ static const struct vm_operations_struct snd_pcm_vm_ops_data_fault = { .fault = snd_pcm_mmap_data_fault, }; -#ifndef ARCH_HAS_DMA_MMAP_COHERENT -/* This should be defined / handled globally! */ -#ifdef CONFIG_ARM -#define ARCH_HAS_DMA_MMAP_COHERENT -#endif -#endif - /* * mmap the DMA buffer on RAM */ -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available 2012-08-06 9:55 ` Hideki EIRAKU (?) (?) @ 2012-08-06 9:55 ` Hideki EIRAKU -1 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: Katsuya MATSUBARA, linux-fbdev, Hideki EIRAKU, alsa-devel, linux-kernel, linux-arm-kernel, linux-media Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a physical address. The two addressses are not necessarily the same. For example, when using the IOMMU funtion on certain platforms, dma_addr_t addresses are not directly mappable physical address. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ 1 files changed, 17 insertions(+), 0 deletions(-) diff --git a/drivers/media/video/videobuf2-dma-contig.c b/drivers/media/video/videobuf2-dma-contig.c index 4b71326..7eee9c5 100644 --- a/drivers/media/video/videobuf2-dma-contig.c +++ b/drivers/media/video/videobuf2-dma-contig.c @@ -101,14 +101,31 @@ static unsigned int vb2_dma_contig_num_users(void *buf_priv) static int vb2_dma_contig_mmap(void *buf_priv, struct vm_area_struct *vma) { struct vb2_dc_buf *buf = buf_priv; +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + int ret; +#endif if (!buf) { printk(KERN_ERR "No buffer to map\n"); return -EINVAL; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + ret = dma_mmap_coherent(buf->conf->dev, vma, buf->vaddr, buf->dma_addr, + buf->size); + if (ret) { + pr_err("Remapping memory failed, error: %d\n", ret); + return ret; + } + vma->vm_flags |= VM_DONTEXPAND | VM_RESERVED; + vma->vm_private_data = &buf->handler; + vma->vm_ops = &vb2_common_vm_ops; + vma->vm_ops->open(vma); + return 0; +#else return vb2_mmap_pfn_range(vma, buf->dma_addr, buf->size, &vb2_common_vm_ops, &buf->handler); +#endif } static void *vb2_dma_contig_get_userptr(void *alloc_ctx, unsigned long vaddr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a physical address. The two addressses are not necessarily the same. For example, when using the IOMMU funtion on certain platforms, dma_addr_t addresses are not directly mappable physical address. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ 1 files changed, 17 insertions(+), 0 deletions(-) diff --git a/drivers/media/video/videobuf2-dma-contig.c b/drivers/media/video/videobuf2-dma-contig.c index 4b71326..7eee9c5 100644 --- a/drivers/media/video/videobuf2-dma-contig.c +++ b/drivers/media/video/videobuf2-dma-contig.c @@ -101,14 +101,31 @@ static unsigned int vb2_dma_contig_num_users(void *buf_priv) static int vb2_dma_contig_mmap(void *buf_priv, struct vm_area_struct *vma) { struct vb2_dc_buf *buf = buf_priv; +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + int ret; +#endif if (!buf) { printk(KERN_ERR "No buffer to map\n"); return -EINVAL; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + ret = dma_mmap_coherent(buf->conf->dev, vma, buf->vaddr, buf->dma_addr, + buf->size); + if (ret) { + pr_err("Remapping memory failed, error: %d\n", ret); + return ret; + } + vma->vm_flags |= VM_DONTEXPAND | VM_RESERVED; + vma->vm_private_data = &buf->handler; + vma->vm_ops = &vb2_common_vm_ops; + vma->vm_ops->open(vma); + return 0; +#else return vb2_mmap_pfn_range(vma, buf->dma_addr, buf->size, &vb2_common_vm_ops, &buf->handler); +#endif } static void *vb2_dma_contig_get_userptr(void *alloc_ctx, unsigned long vaddr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: linux-arm-kernel Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a physical address. The two addressses are not necessarily the same. For example, when using the IOMMU funtion on certain platforms, dma_addr_t addresses are not directly mappable physical address. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ 1 files changed, 17 insertions(+), 0 deletions(-) diff --git a/drivers/media/video/videobuf2-dma-contig.c b/drivers/media/video/videobuf2-dma-contig.c index 4b71326..7eee9c5 100644 --- a/drivers/media/video/videobuf2-dma-contig.c +++ b/drivers/media/video/videobuf2-dma-contig.c @@ -101,14 +101,31 @@ static unsigned int vb2_dma_contig_num_users(void *buf_priv) static int vb2_dma_contig_mmap(void *buf_priv, struct vm_area_struct *vma) { struct vb2_dc_buf *buf = buf_priv; +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + int ret; +#endif if (!buf) { printk(KERN_ERR "No buffer to map\n"); return -EINVAL; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + ret = dma_mmap_coherent(buf->conf->dev, vma, buf->vaddr, buf->dma_addr, + buf->size); + if (ret) { + pr_err("Remapping memory failed, error: %d\n", ret); + return ret; + } + vma->vm_flags |= VM_DONTEXPAND | VM_RESERVED; + vma->vm_private_data = &buf->handler; + vma->vm_ops = &vb2_common_vm_ops; + vma->vm_ops->open(vma); + return 0; +#else return vb2_mmap_pfn_range(vma, buf->dma_addr, buf->size, &vb2_common_vm_ops, &buf->handler); +#endif } static void *vb2_dma_contig_get_userptr(void *alloc_ctx, unsigned long vaddr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: Katsuya MATSUBARA, linux-fbdev, Hideki EIRAKU, alsa-devel, linux-kernel, linux-arm-kernel, linux-media Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a physical address. The two addressses are not necessarily the same. For example, when using the IOMMU funtion on certain platforms, dma_addr_t addresses are not directly mappable physical address. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/media/video/videobuf2-dma-contig.c | 17 +++++++++++++++++ 1 files changed, 17 insertions(+), 0 deletions(-) diff --git a/drivers/media/video/videobuf2-dma-contig.c b/drivers/media/video/videobuf2-dma-contig.c index 4b71326..7eee9c5 100644 --- a/drivers/media/video/videobuf2-dma-contig.c +++ b/drivers/media/video/videobuf2-dma-contig.c @@ -101,14 +101,31 @@ static unsigned int vb2_dma_contig_num_users(void *buf_priv) static int vb2_dma_contig_mmap(void *buf_priv, struct vm_area_struct *vma) { struct vb2_dc_buf *buf = buf_priv; +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + int ret; +#endif if (!buf) { printk(KERN_ERR "No buffer to map\n"); return -EINVAL; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + ret = dma_mmap_coherent(buf->conf->dev, vma, buf->vaddr, buf->dma_addr, + buf->size); + if (ret) { + pr_err("Remapping memory failed, error: %d\n", ret); + return ret; + } + vma->vm_flags |= VM_DONTEXPAND | VM_RESERVED; + vma->vm_private_data = &buf->handler; + vma->vm_ops = &vb2_common_vm_ops; + vma->vm_ops->open(vma); + return 0; +#else return vb2_mmap_pfn_range(vma, buf->dma_addr, buf->size, &vb2_common_vm_ops, &buf->handler); +#endif } static void *vb2_dma_contig_get_userptr(void *alloc_ctx, unsigned long vaddr, -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available 2012-08-06 9:55 ` Hideki EIRAKU (?) @ 2012-08-07 14:53 ` Marek Szyprowski -1 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 14:53 UTC (permalink / raw) To: 'Hideki EIRAKU', 'Russell King', 'Pawel Osciak', 'Kyungmin Park', 'Mauro Carvalho Chehab', 'Florian Tobias Schandinat', 'Jaroslav Kysela', 'Takashi Iwai', Tomasz Stanislawski Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, 'Katsuya MATSUBARA' Hello, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a > physical address. The two addressses are not necessarily the same. > For example, when using the IOMMU funtion on certain platforms, dma_addr_t > addresses are not directly mappable physical address. > dma_mmap_coherent() maps the address correctly. > It is available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> I'm sorry for bringing this issue now, once you have already created v3 of your patches, but similar patch has been already proposed some time ago. It is already processed together with general videobuf2-dma-contig redesign and dma-buf extensions by Tomasz Stanislawski. See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 It doesn't use conditional code inside videobuf2 allocator and rely entirely on dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() function. When it was posted, it relied on the dma-mapping extensions, which now have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, which don't use dma_map_ops based dma-mapping framework, which might use videobuf2-dma-conting module. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-07 14:53 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 14:53 UTC (permalink / raw) To: linux-arm-kernel Hello, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a > physical address. The two addressses are not necessarily the same. > For example, when using the IOMMU funtion on certain platforms, dma_addr_t > addresses are not directly mappable physical address. > dma_mmap_coherent() maps the address correctly. > It is available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> I'm sorry for bringing this issue now, once you have already created v3 of your patches, but similar patch has been already proposed some time ago. It is already processed together with general videobuf2-dma-contig redesign and dma-buf extensions by Tomasz Stanislawski. See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 It doesn't use conditional code inside videobuf2 allocator and rely entirely on dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() function. When it was posted, it relied on the dma-mapping extensions, which now have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, which don't use dma_map_ops based dma-mapping framework, which might use videobuf2-dma-conting module. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-07 14:53 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-07 14:53 UTC (permalink / raw) To: 'Hideki EIRAKU', 'Russell King', 'Pawel Osciak', 'Kyungmin Park', 'Mauro Carvalho Chehab', 'Florian Tobias Schandinat', 'Jaroslav Kysela', 'Takashi Iwai', Tomasz Stanislawski Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, 'Katsuya MATSUBARA' Hello, On Monday, August 06, 2012 11:55 AM Hideki EIRAKU wrote: > Previously the vb2_dma_contig_mmap() function was using a dma_addr_t as a > physical address. The two addressses are not necessarily the same. > For example, when using the IOMMU funtion on certain platforms, dma_addr_t > addresses are not directly mappable physical address. > dma_mmap_coherent() maps the address correctly. > It is available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> I'm sorry for bringing this issue now, once you have already created v3 of your patches, but similar patch has been already proposed some time ago. It is already processed together with general videobuf2-dma-contig redesign and dma-buf extensions by Tomasz Stanislawski. See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focusI461 and http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 It doesn't use conditional code inside videobuf2 allocator and rely entirely on dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() function. When it was posted, it relied on the dma-mapping extensions, which now have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, which don't use dma_map_ops based dma-mapping framework, which might use videobuf2-dma-conting module. Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available 2012-08-07 14:53 ` Marek Szyprowski (?) @ 2012-08-16 10:13 ` Hideki EIRAKU -1 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-16 10:13 UTC (permalink / raw) To: m.szyprowski Cc: laurent.pinchart, linux, pawel, kyungmin.park, mchehab, FlorianSchandinat, perex, tiwai, t.stanislaws, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, matsu, dhobsong Hello, From: Marek Szyprowski <m.szyprowski@samsung.com> Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available Date: Tue, 07 Aug 2012 16:53:25 +0200 > I'm sorry for bringing this issue now, once you have already created v3 of your > patches, but similar patch has been already proposed some time ago. It is already > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > by Tomasz Stanislawski. > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > function. When it was posted, it relied on the dma-mapping extensions, which now > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > which don't use dma_map_ops based dma-mapping framework, which might use > videobuf2-dma-conting module. Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The videobuf2-dma-contig patch I sent is now unnecessary. So I will remove the patch. I will remove the patch defining ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic dma_mmap_coherent() API for every architecture. I will also remove the Laurent's patch I sent because it was related to ARCH_HAS_DMA_MMAP_COHERENT. The remaining patch is sh_mobile_lcdc. I will remove ifdefs from the patch and re-post it as a patch v4. -- Hideki EIRAKU <hdk@igel.co.jp> ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-16 10:13 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-16 10:13 UTC (permalink / raw) To: linux-arm-kernel Hello, From: Marek Szyprowski <m.szyprowski@samsung.com> Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available Date: Tue, 07 Aug 2012 16:53:25 +0200 > I'm sorry for bringing this issue now, once you have already created v3 of your > patches, but similar patch has been already proposed some time ago. It is already > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > by Tomasz Stanislawski. > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > function. When it was posted, it relied on the dma-mapping extensions, which now > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > which don't use dma_map_ops based dma-mapping framework, which might use > videobuf2-dma-conting module. Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The videobuf2-dma-contig patch I sent is now unnecessary. So I will remove the patch. I will remove the patch defining ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic dma_mmap_coherent() API for every architecture. I will also remove the Laurent's patch I sent because it was related to ARCH_HAS_DMA_MMAP_COHERENT. The remaining patch is sh_mobile_lcdc. I will remove ifdefs from the patch and re-post it as a patch v4. -- Hideki EIRAKU <hdk@igel.co.jp> ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-16 10:13 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-16 10:13 UTC (permalink / raw) To: m.szyprowski Cc: laurent.pinchart, linux, pawel, kyungmin.park, mchehab, FlorianSchandinat, perex, tiwai, t.stanislaws, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, matsu, dhobsong Hello, From: Marek Szyprowski <m.szyprowski@samsung.com> Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available Date: Tue, 07 Aug 2012 16:53:25 +0200 > I'm sorry for bringing this issue now, once you have already created v3 of your > patches, but similar patch has been already proposed some time ago. It is already > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > by Tomasz Stanislawski. > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focusI461 and > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > function. When it was posted, it relied on the dma-mapping extensions, which now > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > which don't use dma_map_ops based dma-mapping framework, which might use > videobuf2-dma-conting module. Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The videobuf2-dma-contig patch I sent is now unnecessary. So I will remove the patch. I will remove the patch defining ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic dma_mmap_coherent() API for every architecture. I will also remove the Laurent's patch I sent because it was related to ARCH_HAS_DMA_MMAP_COHERENT. The remaining patch is sh_mobile_lcdc. I will remove ifdefs from the patch and re-post it as a patch v4. -- Hideki EIRAKU <hdk@igel.co.jp> ^ permalink raw reply [flat|nested] 37+ messages in thread
* RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available 2012-08-16 10:13 ` Hideki EIRAKU (?) @ 2012-08-16 10:39 ` Marek Szyprowski -1 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-16 10:39 UTC (permalink / raw) To: 'Hideki EIRAKU' Cc: laurent.pinchart, linux, pawel, kyungmin.park, mchehab, FlorianSchandinat, perex, tiwai, Tomasz Stanislawski, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, matsu, dhobsong Hello, On Thursday, August 16, 2012 12:14 PM Hideki EIRAKU wrote: > From: Marek Szyprowski <m.szyprowski@samsung.com> > Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available > Date: Tue, 07 Aug 2012 16:53:25 +0200 > > > I'm sorry for bringing this issue now, once you have already created v3 of your > > patches, but similar patch has been already proposed some time ago. It is already > > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > > by Tomasz Stanislawski. > > > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and > > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > > function. When it was posted, it relied on the dma-mapping extensions, which now > > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > > which don't use dma_map_ops based dma-mapping framework, which might use > > videobuf2-dma-conting module. > > Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The > videobuf2-dma-contig patch I sent is now unnecessary. So I will > remove the patch. I will remove the patch defining > ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic > dma_mmap_coherent() API for every architecture. Just to let you know - Tomasz has posted an updated version of the dma-buf/vb2-dma-contig patches: http://www.spinics.net/lists/linux-media/msg51768.html Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-16 10:39 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-16 10:39 UTC (permalink / raw) To: linux-arm-kernel Hello, On Thursday, August 16, 2012 12:14 PM Hideki EIRAKU wrote: > From: Marek Szyprowski <m.szyprowski@samsung.com> > Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available > Date: Tue, 07 Aug 2012 16:53:25 +0200 > > > I'm sorry for bringing this issue now, once you have already created v3 of your > > patches, but similar patch has been already proposed some time ago. It is already > > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > > by Tomasz Stanislawski. > > > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focus=49461 and > > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > > function. When it was posted, it relied on the dma-mapping extensions, which now > > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > > which don't use dma_map_ops based dma-mapping framework, which might use > > videobuf2-dma-conting module. > > Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The > videobuf2-dma-contig patch I sent is now unnecessary. So I will > remove the patch. I will remove the patch defining > ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic > dma_mmap_coherent() API for every architecture. Just to let you know - Tomasz has posted an updated version of the dma-buf/vb2-dma-contig patches: http://www.spinics.net/lists/linux-media/msg51768.html Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available @ 2012-08-16 10:39 ` Marek Szyprowski 0 siblings, 0 replies; 37+ messages in thread From: Marek Szyprowski @ 2012-08-16 10:39 UTC (permalink / raw) To: 'Hideki EIRAKU' Cc: laurent.pinchart, linux, pawel, kyungmin.park, mchehab, FlorianSchandinat, perex, tiwai, Tomasz Stanislawski, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, matsu, dhobsong Hello, On Thursday, August 16, 2012 12:14 PM Hideki EIRAKU wrote: > From: Marek Szyprowski <m.szyprowski@samsung.com> > Subject: RE: [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available > Date: Tue, 07 Aug 2012 16:53:25 +0200 > > > I'm sorry for bringing this issue now, once you have already created v3 of your > > patches, but similar patch has been already proposed some time ago. It is already > > processed together with general videobuf2-dma-contig redesign and dma-buf extensions > > by Tomasz Stanislawski. > > > > See post http://thread.gmane.org/gmane.comp.video.dri.devel/70402/focusI461 and > > http://thread.gmane.org/gmane.linux.drivers.video-input-infrastructure/49438 > > > > It doesn't use conditional code inside videobuf2 allocator and rely entirely on > > dma-mapping subsystem to provide a working dma_mmap_coherent/writecombine/attrs() > > function. When it was posted, it relied on the dma-mapping extensions, which now > > have been finally merged to v3.6-rc1. Now I wonder if there are any architectures, > > which don't use dma_map_ops based dma-mapping framework, which might use > > videobuf2-dma-conting module. > > Thank you for telling me about videobuf2-dma-contig and v3.6-rc1. The > videobuf2-dma-contig patch I sent is now unnecessary. So I will > remove the patch. I will remove the patch defining > ARCH_HAS_DMA_MMAP_COHERENT too because the v3.6-rc1 kernel has generic > dma_mmap_coherent() API for every architecture. Just to let you know - Tomasz has posted an updated version of the dma-buf/vb2-dma-contig patches: http://www.spinics.net/lists/linux-media/msg51768.html Best regards -- Marek Szyprowski Samsung Poland R&D Center ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available 2012-08-06 9:55 ` Hideki EIRAKU (?) @ 2012-08-06 9:55 ` Hideki EIRAKU -1 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU fb_mmap() implemented in fbmem.c uses smem_start as the physical address of the frame buffer. In the sh_mobile_lcdc driver, the smem_start is a dma_addr_t that is not a physical address when IOMMU is enabled. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ 1 files changed, 28 insertions(+), 0 deletions(-) diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, struct fb_info *info) return 1; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_overlay *ovl = info->par; + + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, + ovl->dma_handle, ovl->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_overlay_ops = { .owner = THIS_MODULE, .fb_read = fb_sys_read, @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, .fb_check_var = sh_mobile_lcdc_overlay_check_var, .fb_set_par = sh_mobile_lcdc_overlay_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_overlay_mmap, +#endif }; static void @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct fb_info *info) return 0; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_chan *ch = info->par; + + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, + ch->dma_handle, ch->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_ops = { .owner = THIS_MODULE, .fb_setcolreg = sh_mobile_lcdc_setcolreg, @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { .fb_release = sh_mobile_lcdc_release, .fb_check_var = sh_mobile_lcdc_check_var, .fb_set_par = sh_mobile_lcdc_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_mmap, +#endif }; static void -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: linux-arm-kernel fb_mmap() implemented in fbmem.c uses smem_start as the physical address of the frame buffer. In the sh_mobile_lcdc driver, the smem_start is a dma_addr_t that is not a physical address when IOMMU is enabled. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ 1 files changed, 28 insertions(+), 0 deletions(-) diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, struct fb_info *info) return 1; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_overlay *ovl = info->par; + + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, + ovl->dma_handle, ovl->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_overlay_ops = { .owner = THIS_MODULE, .fb_read = fb_sys_read, @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, .fb_check_var = sh_mobile_lcdc_overlay_check_var, .fb_set_par = sh_mobile_lcdc_overlay_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_overlay_mmap, +#endif }; static void @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct fb_info *info) return 0; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_chan *ch = info->par; + + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, + ch->dma_handle, ch->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_ops = { .owner = THIS_MODULE, .fb_setcolreg = sh_mobile_lcdc_setcolreg, @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { .fb_release = sh_mobile_lcdc_release, .fb_check_var = sh_mobile_lcdc_check_var, .fb_set_par = sh_mobile_lcdc_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_mmap, +#endif }; static void -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-06 9:55 ` Hideki EIRAKU 0 siblings, 0 replies; 37+ messages in thread From: Hideki EIRAKU @ 2012-08-06 9:55 UTC (permalink / raw) To: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai Cc: linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA, Hideki EIRAKU fb_mmap() implemented in fbmem.c uses smem_start as the physical address of the frame buffer. In the sh_mobile_lcdc driver, the smem_start is a dma_addr_t that is not a physical address when IOMMU is enabled. dma_mmap_coherent() maps the address correctly. It is available on ARM platforms. Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> --- drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ 1 files changed, 28 insertions(+), 0 deletions(-) diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, struct fb_info *info) return 1; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_overlay *ovl = info->par; + + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, + ovl->dma_handle, ovl->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_overlay_ops = { .owner = THIS_MODULE, .fb_read = fb_sys_read, @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, .fb_check_var = sh_mobile_lcdc_overlay_check_var, .fb_set_par = sh_mobile_lcdc_overlay_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_overlay_mmap, +#endif }; static void @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct fb_info *info) return 0; } +#ifdef ARCH_HAS_DMA_MMAP_COHERENT +static int +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) +{ + struct sh_mobile_lcdc_chan *ch = info->par; + + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, + ch->dma_handle, ch->fb_size); +} +#endif + static struct fb_ops sh_mobile_lcdc_ops = { .owner = THIS_MODULE, .fb_setcolreg = sh_mobile_lcdc_setcolreg, @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { .fb_release = sh_mobile_lcdc_release, .fb_check_var = sh_mobile_lcdc_check_var, .fb_set_par = sh_mobile_lcdc_set_par, +#ifdef ARCH_HAS_DMA_MMAP_COHERENT + .fb_mmap = sh_mobile_lcdc_mmap, +#endif }; static void -- 1.7.0.4 ^ permalink raw reply related [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available 2012-08-06 9:55 ` Hideki EIRAKU (?) (?) @ 2012-08-07 12:01 ` Laurent Pinchart -1 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:01 UTC (permalink / raw) To: Hideki EIRAKU Cc: alsa-devel, Katsuya MATSUBARA, linux-fbdev, Russell King, linux-media, Pawel Osciak, Florian Tobias Schandinat, Takashi Iwai, linux-kernel, Mauro Carvalho Chehab, Kyungmin Park, linux-arm-kernel, Marek Szyprowski Hi Eiraku-san, On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > fb_mmap() implemented in fbmem.c uses smem_start as the physical > address of the frame buffer. In the sh_mobile_lcdc driver, the > smem_start is a dma_addr_t that is not a physical address when IOMMU is > enabled. dma_mmap_coherent() maps the address correctly. It is > available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> Acked-by: Hideki EIRAKU <hdk@igel.co.jp> As this patch doesn't depend on any other patch in your series (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch will be a no-op until then), I've applied it to my tree and will push it to avoid merge conflicts, unless you would prefer to push it yourself. > --- > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > 1 files changed, 28 insertions(+), 0 deletions(-) > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > --- a/drivers/video/sh_mobile_lcdcfb.c > +++ b/drivers/video/sh_mobile_lcdcfb.c > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > struct fb_info *info) return 1; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > *vma) +{ > + struct sh_mobile_lcdc_overlay *ovl = info->par; > + > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > + ovl->dma_handle, ovl->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .owner = THIS_MODULE, > .fb_read = fb_sys_read, > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > +#endif > }; > > static void > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > fb_info *info) return 0; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > +{ > + struct sh_mobile_lcdc_chan *ch = info->par; > + > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > + ch->dma_handle, ch->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_ops = { > .owner = THIS_MODULE, > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > .fb_release = sh_mobile_lcdc_release, > .fb_check_var = sh_mobile_lcdc_check_var, > .fb_set_par = sh_mobile_lcdc_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_mmap, > +#endif > }; > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:01 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:01 UTC (permalink / raw) To: Hideki EIRAKU Cc: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA Hi Eiraku-san, On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > fb_mmap() implemented in fbmem.c uses smem_start as the physical > address of the frame buffer. In the sh_mobile_lcdc driver, the > smem_start is a dma_addr_t that is not a physical address when IOMMU is > enabled. dma_mmap_coherent() maps the address correctly. It is > available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> Acked-by: Hideki EIRAKU <hdk@igel.co.jp> As this patch doesn't depend on any other patch in your series (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch will be a no-op until then), I've applied it to my tree and will push it to avoid merge conflicts, unless you would prefer to push it yourself. > --- > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > 1 files changed, 28 insertions(+), 0 deletions(-) > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > --- a/drivers/video/sh_mobile_lcdcfb.c > +++ b/drivers/video/sh_mobile_lcdcfb.c > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > struct fb_info *info) return 1; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > *vma) +{ > + struct sh_mobile_lcdc_overlay *ovl = info->par; > + > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > + ovl->dma_handle, ovl->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .owner = THIS_MODULE, > .fb_read = fb_sys_read, > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > +#endif > }; > > static void > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > fb_info *info) return 0; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > +{ > + struct sh_mobile_lcdc_chan *ch = info->par; > + > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > + ch->dma_handle, ch->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_ops = { > .owner = THIS_MODULE, > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > .fb_release = sh_mobile_lcdc_release, > .fb_check_var = sh_mobile_lcdc_check_var, > .fb_set_par = sh_mobile_lcdc_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_mmap, > +#endif > }; > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:01 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:01 UTC (permalink / raw) To: linux-arm-kernel Hi Eiraku-san, On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > fb_mmap() implemented in fbmem.c uses smem_start as the physical > address of the frame buffer. In the sh_mobile_lcdc driver, the > smem_start is a dma_addr_t that is not a physical address when IOMMU is > enabled. dma_mmap_coherent() maps the address correctly. It is > available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> Acked-by: Hideki EIRAKU <hdk@igel.co.jp> As this patch doesn't depend on any other patch in your series (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch will be a no-op until then), I've applied it to my tree and will push it to avoid merge conflicts, unless you would prefer to push it yourself. > --- > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > 1 files changed, 28 insertions(+), 0 deletions(-) > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > --- a/drivers/video/sh_mobile_lcdcfb.c > +++ b/drivers/video/sh_mobile_lcdcfb.c > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > struct fb_info *info) return 1; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > *vma) +{ > + struct sh_mobile_lcdc_overlay *ovl = info->par; > + > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > + ovl->dma_handle, ovl->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .owner = THIS_MODULE, > .fb_read = fb_sys_read, > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > +#endif > }; > > static void > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > fb_info *info) return 0; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > +{ > + struct sh_mobile_lcdc_chan *ch = info->par; > + > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > + ch->dma_handle, ch->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_ops = { > .owner = THIS_MODULE, > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > .fb_release = sh_mobile_lcdc_release, > .fb_check_var = sh_mobile_lcdc_check_var, > .fb_set_par = sh_mobile_lcdc_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_mmap, > +#endif > }; > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:01 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:01 UTC (permalink / raw) To: Hideki EIRAKU Cc: alsa-devel, Katsuya MATSUBARA, linux-fbdev, Russell King, linux-media, Pawel Osciak, Florian Tobias Schandinat, Takashi Iwai, linux-kernel, Mauro Carvalho Chehab, Kyungmin Park, linux-arm-kernel, Marek Szyprowski Hi Eiraku-san, On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > fb_mmap() implemented in fbmem.c uses smem_start as the physical > address of the frame buffer. In the sh_mobile_lcdc driver, the > smem_start is a dma_addr_t that is not a physical address when IOMMU is > enabled. dma_mmap_coherent() maps the address correctly. It is > available on ARM platforms. > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> Acked-by: Hideki EIRAKU <hdk@igel.co.jp> As this patch doesn't depend on any other patch in your series (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch will be a no-op until then), I've applied it to my tree and will push it to avoid merge conflicts, unless you would prefer to push it yourself. > --- > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > 1 files changed, 28 insertions(+), 0 deletions(-) > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > --- a/drivers/video/sh_mobile_lcdcfb.c > +++ b/drivers/video/sh_mobile_lcdcfb.c > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > struct fb_info *info) return 1; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > *vma) +{ > + struct sh_mobile_lcdc_overlay *ovl = info->par; > + > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > + ovl->dma_handle, ovl->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .owner = THIS_MODULE, > .fb_read = fb_sys_read, > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > +#endif > }; > > static void > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > fb_info *info) return 0; > } > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > +static int > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > +{ > + struct sh_mobile_lcdc_chan *ch = info->par; > + > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > + ch->dma_handle, ch->fb_size); > +} > +#endif > + > static struct fb_ops sh_mobile_lcdc_ops = { > .owner = THIS_MODULE, > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > .fb_release = sh_mobile_lcdc_release, > .fb_check_var = sh_mobile_lcdc_check_var, > .fb_set_par = sh_mobile_lcdc_set_par, > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > + .fb_mmap = sh_mobile_lcdc_mmap, > +#endif > }; > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available 2012-08-07 12:01 ` Laurent Pinchart (?) (?) @ 2012-08-07 12:15 ` Laurent Pinchart -1 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:15 UTC (permalink / raw) To: Hideki EIRAKU Cc: alsa-devel, Katsuya MATSUBARA, linux-fbdev, Russell King, linux-media, Pawel Osciak, Florian Tobias Schandinat, Takashi Iwai, linux-kernel, Mauro Carvalho Chehab, Kyungmin Park, linux-arm-kernel, Marek Szyprowski On Tuesday 07 August 2012 14:01:43 Laurent Pinchart wrote: > Hi Eiraku-san, > > On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > > fb_mmap() implemented in fbmem.c uses smem_start as the physical > > address of the frame buffer. In the sh_mobile_lcdc driver, the > > smem_start is a dma_addr_t that is not a physical address when IOMMU is > > enabled. dma_mmap_coherent() maps the address correctly. It is > > available on ARM platforms. > > > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > > Acked-by: Hideki EIRAKU <hdk@igel.co.jp> I obviously meant Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > As this patch doesn't depend on any other patch in your series > (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch > will be a no-op until then), I've applied it to my tree and will push it to > avoid merge conflicts, unless you would prefer to push it yourself. > > > --- > > > > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > > 1 files changed, 28 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > > --- a/drivers/video/sh_mobile_lcdcfb.c > > +++ b/drivers/video/sh_mobile_lcdcfb.c > > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > > struct fb_info *info) return 1; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > > *vma) +{ > > + struct sh_mobile_lcdc_overlay *ovl = info->par; > > + > > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > > + ovl->dma_handle, ovl->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .owner = THIS_MODULE, > > .fb_read = fb_sys_read, > > > > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > > +#endif > > > > }; > > > > static void > > > > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > > fb_info *info) return 0; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > > +{ > > + struct sh_mobile_lcdc_chan *ch = info->par; > > + > > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > > + ch->dma_handle, ch->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_ops = { > > > > .owner = THIS_MODULE, > > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > > > > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > > > > .fb_release = sh_mobile_lcdc_release, > > .fb_check_var = sh_mobile_lcdc_check_var, > > .fb_set_par = sh_mobile_lcdc_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_mmap, > > +#endif > > > > }; > > > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:15 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:15 UTC (permalink / raw) To: Hideki EIRAKU Cc: Russell King, Pawel Osciak, Marek Szyprowski, Kyungmin Park, Mauro Carvalho Chehab, Florian Tobias Schandinat, Jaroslav Kysela, Takashi Iwai, linux-arm-kernel, linux-kernel, linux-media, linux-fbdev, alsa-devel, Katsuya MATSUBARA On Tuesday 07 August 2012 14:01:43 Laurent Pinchart wrote: > Hi Eiraku-san, > > On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > > fb_mmap() implemented in fbmem.c uses smem_start as the physical > > address of the frame buffer. In the sh_mobile_lcdc driver, the > > smem_start is a dma_addr_t that is not a physical address when IOMMU is > > enabled. dma_mmap_coherent() maps the address correctly. It is > > available on ARM platforms. > > > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > > Acked-by: Hideki EIRAKU <hdk@igel.co.jp> I obviously meant Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > As this patch doesn't depend on any other patch in your series > (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch > will be a no-op until then), I've applied it to my tree and will push it to > avoid merge conflicts, unless you would prefer to push it yourself. > > > --- > > > > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > > 1 files changed, 28 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > > --- a/drivers/video/sh_mobile_lcdcfb.c > > +++ b/drivers/video/sh_mobile_lcdcfb.c > > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > > struct fb_info *info) return 1; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > > *vma) +{ > > + struct sh_mobile_lcdc_overlay *ovl = info->par; > > + > > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > > + ovl->dma_handle, ovl->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .owner = THIS_MODULE, > > .fb_read = fb_sys_read, > > > > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > > +#endif > > > > }; > > > > static void > > > > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > > fb_info *info) return 0; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > > +{ > > + struct sh_mobile_lcdc_chan *ch = info->par; > > + > > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > > + ch->dma_handle, ch->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_ops = { > > > > .owner = THIS_MODULE, > > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > > > > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > > > > .fb_release = sh_mobile_lcdc_release, > > .fb_check_var = sh_mobile_lcdc_check_var, > > .fb_set_par = sh_mobile_lcdc_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_mmap, > > +#endif > > > > }; > > > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:15 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:15 UTC (permalink / raw) To: linux-arm-kernel On Tuesday 07 August 2012 14:01:43 Laurent Pinchart wrote: > Hi Eiraku-san, > > On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > > fb_mmap() implemented in fbmem.c uses smem_start as the physical > > address of the frame buffer. In the sh_mobile_lcdc driver, the > > smem_start is a dma_addr_t that is not a physical address when IOMMU is > > enabled. dma_mmap_coherent() maps the address correctly. It is > > available on ARM platforms. > > > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > > Acked-by: Hideki EIRAKU <hdk@igel.co.jp> I obviously meant Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > As this patch doesn't depend on any other patch in your series > (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch > will be a no-op until then), I've applied it to my tree and will push it to > avoid merge conflicts, unless you would prefer to push it yourself. > > > --- > > > > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > > 1 files changed, 28 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > > --- a/drivers/video/sh_mobile_lcdcfb.c > > +++ b/drivers/video/sh_mobile_lcdcfb.c > > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > > struct fb_info *info) return 1; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > > *vma) +{ > > + struct sh_mobile_lcdc_overlay *ovl = info->par; > > + > > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > > + ovl->dma_handle, ovl->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .owner = THIS_MODULE, > > .fb_read = fb_sys_read, > > > > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > > +#endif > > > > }; > > > > static void > > > > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > > fb_info *info) return 0; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > > +{ > > + struct sh_mobile_lcdc_chan *ch = info->par; > > + > > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > > + ch->dma_handle, ch->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_ops = { > > > > .owner = THIS_MODULE, > > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > > > > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > > > > .fb_release = sh_mobile_lcdc_release, > > .fb_check_var = sh_mobile_lcdc_check_var, > > .fb_set_par = sh_mobile_lcdc_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_mmap, > > +#endif > > > > }; > > > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
* Re: [PATCH v3 4/4] fbdev: sh_mobile_lcdc: use dma_mmap_coherent if available @ 2012-08-07 12:15 ` Laurent Pinchart 0 siblings, 0 replies; 37+ messages in thread From: Laurent Pinchart @ 2012-08-07 12:15 UTC (permalink / raw) To: Hideki EIRAKU Cc: alsa-devel, Katsuya MATSUBARA, linux-fbdev, Russell King, linux-media, Pawel Osciak, Florian Tobias Schandinat, Takashi Iwai, linux-kernel, Mauro Carvalho Chehab, Kyungmin Park, linux-arm-kernel, Marek Szyprowski On Tuesday 07 August 2012 14:01:43 Laurent Pinchart wrote: > Hi Eiraku-san, > > On Monday 06 August 2012 18:55:24 Hideki EIRAKU wrote: > > fb_mmap() implemented in fbmem.c uses smem_start as the physical > > address of the frame buffer. In the sh_mobile_lcdc driver, the > > smem_start is a dma_addr_t that is not a physical address when IOMMU is > > enabled. dma_mmap_coherent() maps the address correctly. It is > > available on ARM platforms. > > > > Signed-off-by: Hideki EIRAKU <hdk@igel.co.jp> > > Acked-by: Hideki EIRAKU <hdk@igel.co.jp> I obviously meant Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> > As this patch doesn't depend on any other patch in your series > (ARCH_HAS_DMA_MMAP_COHERENT will not be defined without 1/4, so this patch > will be a no-op until then), I've applied it to my tree and will push it to > avoid merge conflicts, unless you would prefer to push it yourself. > > > --- > > > > drivers/video/sh_mobile_lcdcfb.c | 28 ++++++++++++++++++++++++++++ > > 1 files changed, 28 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/video/sh_mobile_lcdcfb.c > > b/drivers/video/sh_mobile_lcdcfb.c index 8cb653b..c8cba7a 100644 > > --- a/drivers/video/sh_mobile_lcdcfb.c > > +++ b/drivers/video/sh_mobile_lcdcfb.c > > @@ -1614,6 +1614,17 @@ static int sh_mobile_lcdc_overlay_blank(int blank, > > struct fb_info *info) return 1; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_overlay_mmap(struct fb_info *info, struct vm_area_struct > > *vma) +{ > > + struct sh_mobile_lcdc_overlay *ovl = info->par; > > + > > + return dma_mmap_coherent(ovl->channel->lcdc->dev, vma, ovl->fb_mem, > > + ovl->dma_handle, ovl->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .owner = THIS_MODULE, > > .fb_read = fb_sys_read, > > > > @@ -1626,6 +1637,9 @@ static struct fb_ops sh_mobile_lcdc_overlay_ops = { > > > > .fb_ioctl = sh_mobile_lcdc_overlay_ioctl, > > .fb_check_var = sh_mobile_lcdc_overlay_check_var, > > .fb_set_par = sh_mobile_lcdc_overlay_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_overlay_mmap, > > +#endif > > > > }; > > > > static void > > > > @@ -2093,6 +2107,17 @@ static int sh_mobile_lcdc_blank(int blank, struct > > fb_info *info) return 0; > > > > } > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > +static int > > +sh_mobile_lcdc_mmap(struct fb_info *info, struct vm_area_struct *vma) > > +{ > > + struct sh_mobile_lcdc_chan *ch = info->par; > > + > > + return dma_mmap_coherent(ch->lcdc->dev, vma, ch->fb_mem, > > + ch->dma_handle, ch->fb_size); > > +} > > +#endif > > + > > > > static struct fb_ops sh_mobile_lcdc_ops = { > > > > .owner = THIS_MODULE, > > .fb_setcolreg = sh_mobile_lcdc_setcolreg, > > > > @@ -2108,6 +2133,9 @@ static struct fb_ops sh_mobile_lcdc_ops = { > > > > .fb_release = sh_mobile_lcdc_release, > > .fb_check_var = sh_mobile_lcdc_check_var, > > .fb_set_par = sh_mobile_lcdc_set_par, > > > > +#ifdef ARCH_HAS_DMA_MMAP_COHERENT > > + .fb_mmap = sh_mobile_lcdc_mmap, > > +#endif > > > > }; > > > > static void -- Regards, Laurent Pinchart ^ permalink raw reply [flat|nested] 37+ messages in thread
end of thread, other threads:[~2012-08-16 10:39 UTC | newest] Thread overview: 37+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2012-08-06 9:55 [PATCH v3 0/4] Use dma_mmap_coherent to support IOMMU mapper Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` [PATCH v3 1/4] ARM: dma-mapping: define ARCH_HAS_DMA_MMAP_COHERENT Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-07 15:22 ` Marek Szyprowski 2012-08-07 15:22 ` Marek Szyprowski 2012-08-07 15:22 ` Marek Szyprowski 2012-08-06 9:55 ` [PATCH v3 2/4] ALSA: pcm - Don't define ARCH_HAS_DMA_MMAP_COHERENT privately for ARM Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` [PATCH v3 3/4] media: videobuf2-dma-contig: use dma_mmap_coherent if available Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-07 14:53 ` Marek Szyprowski 2012-08-07 14:53 ` Marek Szyprowski 2012-08-07 14:53 ` Marek Szyprowski 2012-08-16 10:13 ` Hideki EIRAKU 2012-08-16 10:13 ` Hideki EIRAKU 2012-08-16 10:13 ` Hideki EIRAKU 2012-08-16 10:39 ` Marek Szyprowski 2012-08-16 10:39 ` Marek Szyprowski 2012-08-16 10:39 ` Marek Szyprowski 2012-08-06 9:55 ` [PATCH v3 4/4] fbdev: sh_mobile_lcdc: " Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-06 9:55 ` Hideki EIRAKU 2012-08-07 12:01 ` Laurent Pinchart 2012-08-07 12:01 ` Laurent Pinchart 2012-08-07 12:01 ` Laurent Pinchart 2012-08-07 12:01 ` Laurent Pinchart 2012-08-07 12:15 ` Laurent Pinchart 2012-08-07 12:15 ` Laurent Pinchart 2012-08-07 12:15 ` Laurent Pinchart 2012-08-07 12:15 ` Laurent Pinchart
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.