All of lore.kernel.org
 help / color / mirror / Atom feed
From: "G, Manjunath Kondaiah" <manjugk@ti.com>
To: Paul Walmsley <paul@pwsan.com>
Cc: "G, Manjunath Kondaiah" <manjugk@ti.com>,
	linux-omap@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
	tony@atomide.com, khilman@deeprootsystems.com,
	santosh.shilimkar@ti.com, b-cousson@ti.com
Subject: Re: [PATCH v2 3/9] OMAP2420: hwmod data: add system DMA
Date: Sun, 19 Dec 2010 08:48:20 +0530	[thread overview]
Message-ID: <20101219031820.GA15568@GLPP-machine> (raw)
In-Reply-To: <alpine.DEB.2.00.1012180155260.16875@utopia.booyaka.com>

On Sat, Dec 18, 2010 at 02:03:27AM -0700, Paul Walmsley wrote:
> On Fri, 17 Dec 2010, G, Manjunath Kondaiah wrote:
> 
> > Add OMAP2420 DMA hwmod data and also add required
> > DMA device attributes.
> > 
> > Signed-off-by: G, Manjunath Kondaiah <manjugk@ti.com>
> > ---
> >  arch/arm/mach-omap2/omap_hwmod_2420_data.c |   87 ++++++++++++++++++++++++++++
> >  arch/arm/plat-omap/include/plat/dma.h      |   11 ++++
> >  2 files changed, 98 insertions(+), 0 deletions(-)
> > 
> > diff --git a/arch/arm/mach-omap2/omap_hwmod_2420_data.c b/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > index d953425..eb02fec 100644
> > --- a/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > +++ b/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > @@ -42,6 +42,7 @@ static struct omap_hwmod omap2420_gpio1_hwmod;
> >  static struct omap_hwmod omap2420_gpio2_hwmod;
> >  static struct omap_hwmod omap2420_gpio3_hwmod;
> >  static struct omap_hwmod omap2420_gpio4_hwmod;
> > +static struct omap_hwmod omap2420_dma_system_hwmod;
> >  
> >  /* L3 -> L4_CORE interface */
> >  static struct omap_hwmod_ocp_if omap2420_l3_main__l4_core = {
> > @@ -779,6 +780,89 @@ static struct omap_hwmod omap2420_gpio4_hwmod = {
> >  	.omap_chip	= OMAP_CHIP_INIT(CHIP_IS_OMAP2420),
> >  };
> >  
> > +/* system dma */
> > +static struct omap_hwmod_class_sysconfig omap2420_dma_sysc = {
> > +	.rev_offs	= 0x0000,
> > +	.sysc_offs	= 0x002c,
> > +	.syss_offs	= 0x0028,
> > +	.sysc_flags	= (SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
> 
> According to the OMAP242x TRM 2.3 Rev. X [SWPU064X] Table 10-34, the SDMA 
> has no SIDLEMODE register bitfield.  So this SYSC_HAS_SIDLEMODE appears to 
> be incorrect.  Manju, please confirm.

I verified again in 2420 TRM, this entry should not there.

> 
> > +			   SYSC_HAS_MIDLEMODE | SYSC_HAS_CLOCKACTIVITY |
> > +			   SYSC_HAS_EMUFREE | SYSC_HAS_AUTOIDLE),
> > +	.idlemodes	= (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
> 
> And if there is no SIDLEMODE register bitfield, then none of these SIDLE_* 
> modes should apply, so they should all be removed also.

correct.

> 
> > +			   MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
> > +	.sysc_fields	= &omap_hwmod_sysc_type1,
> > +};
> > +
> > +static struct omap_hwmod_class omap2420_dma_hwmod_class = {
> > +	.name = "dma",
> > +	.sysc = &omap2420_dma_sysc,
> > +};
> > +
> > +/* dma attributes */
> > +static struct omap_dma_dev_attr dma_dev_attr = {
> > +	.dev_caps  = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
> > +						IS_CSSA_32 | IS_CDSA_32,
> > +	.lch_count = 32,
> > +};
> > +
> > +static struct omap_hwmod_irq_info omap2420_dma_system_irqs[] = {
> > +	{ .name = "0", .irq = 12 }, /* INT_24XX_SDMA_IRQ0 */
> > +	{ .name = "1", .irq = 13 }, /* INT_24XX_SDMA_IRQ1 */
> > +	{ .name = "2", .irq = 14 }, /* INT_24XX_SDMA_IRQ2 */
> > +	{ .name = "3", .irq = 15 }, /* INT_24XX_SDMA_IRQ3 */
> > +};
> > +
> > +static struct omap_hwmod_addr_space omap2420_dma_system_addrs[] = {
> > +	{
> > +		.pa_start	= 0x48056000,
> > +		.pa_end		= 0x4a0560ff,
> > +		.flags		= ADDR_TYPE_RT
> > +	},
> > +};
> > +
> > +/* dma_system -> L3 */
> > +static struct omap_hwmod_ocp_if omap2420_dma_system__l3 = {
> > +	.master		= &omap2420_dma_system_hwmod,
> > +	.slave		= &omap2420_l3_main_hwmod,
> > +	.clk		= "core_l3_ck",
> > +	.user		= OCP_USER_MPU | OCP_USER_SDMA,
> > +};
> > +
> > +/* dma_system master ports */
> > +static struct omap_hwmod_ocp_if *omap2420_dma_system_masters[] = {
> > +	&omap2420_dma_system__l3,
> > +};
> > +
> > +/* l4_cfg -> dma_system */
> 
> l4_cfg should be l4_core.
ok.
> 
> > +static struct omap_hwmod_ocp_if omap2420_l4_core__dma_system = {
> > +	.master		= &omap2420_l4_core_hwmod,
> > +	.slave		= &omap2420_dma_system_hwmod,
> > +	.clk		= "sdma_ick",
> > +	.addr		= omap2420_dma_system_addrs,
> > +	.addr_cnt	= ARRAY_SIZE(omap2420_dma_system_addrs),
> > +	.user		= OCP_USER_MPU | OCP_USER_SDMA,
> > +};
> > +
> > +/* dma_system slave ports */
> > +static struct omap_hwmod_ocp_if *omap2420_dma_system_slaves[] = {
> > +	&omap2420_l4_core__dma_system,
> > +};
> > +
> > +static struct omap_hwmod omap2420_dma_system_hwmod = {
> > +	.name		= "dma",
> > +	.class		= &omap2420_dma_hwmod_class,
> > +	.mpu_irqs	= omap2420_dma_system_irqs,
> > +	.mpu_irqs_cnt	= ARRAY_SIZE(omap2420_dma_system_irqs),
> > +	.main_clk	= "core_l3_ck",
> > +	.slaves		= omap2420_dma_system_slaves,
> > +	.slaves_cnt	= ARRAY_SIZE(omap2420_dma_system_slaves),
> > +	.masters	= omap2420_dma_system_masters,
> > +	.masters_cnt	= ARRAY_SIZE(omap2420_dma_system_masters),
> > +	.dev_attr	= &dma_dev_attr,
> > +	.omap_chip	= OMAP_CHIP_INIT(CHIP_IS_OMAP2420),
> > +	.flags		= HWMOD_NO_IDLEST,
> > +};
> > +
> >  static __initdata struct omap_hwmod *omap2420_hwmods[] = {
> >  	&omap2420_l3_main_hwmod,
> >  	&omap2420_l4_core_hwmod,
> > @@ -797,6 +881,9 @@ static __initdata struct omap_hwmod *omap2420_hwmods[] = {
> >  	&omap2420_gpio2_hwmod,
> >  	&omap2420_gpio3_hwmod,
> >  	&omap2420_gpio4_hwmod,
> > +
> > +	/* dma_system class*/
> > +	&omap2420_dma_system_hwmod,
> >  	NULL,
> >  };
> >  
> > diff --git a/arch/arm/plat-omap/include/plat/dma.h b/arch/arm/plat-omap/include/plat/dma.h
> > index 2378399..c466566 100644
> > --- a/arch/arm/plat-omap/include/plat/dma.h
> > +++ b/arch/arm/plat-omap/include/plat/dma.h
> > @@ -295,6 +295,13 @@
> >  #define DMA_ERRATA_3_3			BIT(0x5)
> >  #define DMA_ROMCODE_BUG			BIT(0x6)
> >  
> > +/* Attributes for OMAP DMA Contrller */
> > +#define DMA_LINKED_LCH			BIT(0x0)
> > +#define GLOBAL_PRIORITY			BIT(0x1)
> > +#define RESERVE_CHANNEL			BIT(0x2)
> > +#define IS_CSSA_32			BIT(0x3)
> > +#define IS_CDSA_32			BIT(0x4)
> > +
> >  enum omap_reg_offsets {
> >  
> >  GCR,		GSCR,		GRST1,		HW_ID,
> > @@ -389,6 +396,10 @@ struct omap_dma_channel_params {
> >  #endif
> >  };
> >  
> > +struct omap_dma_dev_attr {
> > +	u32 dev_caps;
> > +	u16 lch_count;
> > +};
> >  
> >  extern void omap_set_dma_priority(int lch, int dst_port, int priority);
> >  extern int omap_request_dma(int dev_id, const char *dev_name,
> > -- 
> > 1.7.1
> > 
> 
> I've verified the clocks, the register addresses, and the IRQ numbers 
> against the TRM.  After the SIDLE* stuff is fixed, you can add my ack.

Thanks. I will send pull request to tony.

-Manjunath


WARNING: multiple messages have this Message-ID (diff)
From: manjugk@ti.com (G, Manjunath Kondaiah)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v2 3/9] OMAP2420: hwmod data: add system DMA
Date: Sun, 19 Dec 2010 08:48:20 +0530	[thread overview]
Message-ID: <20101219031820.GA15568@GLPP-machine> (raw)
In-Reply-To: <alpine.DEB.2.00.1012180155260.16875@utopia.booyaka.com>

On Sat, Dec 18, 2010 at 02:03:27AM -0700, Paul Walmsley wrote:
> On Fri, 17 Dec 2010, G, Manjunath Kondaiah wrote:
> 
> > Add OMAP2420 DMA hwmod data and also add required
> > DMA device attributes.
> > 
> > Signed-off-by: G, Manjunath Kondaiah <manjugk@ti.com>
> > ---
> >  arch/arm/mach-omap2/omap_hwmod_2420_data.c |   87 ++++++++++++++++++++++++++++
> >  arch/arm/plat-omap/include/plat/dma.h      |   11 ++++
> >  2 files changed, 98 insertions(+), 0 deletions(-)
> > 
> > diff --git a/arch/arm/mach-omap2/omap_hwmod_2420_data.c b/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > index d953425..eb02fec 100644
> > --- a/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > +++ b/arch/arm/mach-omap2/omap_hwmod_2420_data.c
> > @@ -42,6 +42,7 @@ static struct omap_hwmod omap2420_gpio1_hwmod;
> >  static struct omap_hwmod omap2420_gpio2_hwmod;
> >  static struct omap_hwmod omap2420_gpio3_hwmod;
> >  static struct omap_hwmod omap2420_gpio4_hwmod;
> > +static struct omap_hwmod omap2420_dma_system_hwmod;
> >  
> >  /* L3 -> L4_CORE interface */
> >  static struct omap_hwmod_ocp_if omap2420_l3_main__l4_core = {
> > @@ -779,6 +780,89 @@ static struct omap_hwmod omap2420_gpio4_hwmod = {
> >  	.omap_chip	= OMAP_CHIP_INIT(CHIP_IS_OMAP2420),
> >  };
> >  
> > +/* system dma */
> > +static struct omap_hwmod_class_sysconfig omap2420_dma_sysc = {
> > +	.rev_offs	= 0x0000,
> > +	.sysc_offs	= 0x002c,
> > +	.syss_offs	= 0x0028,
> > +	.sysc_flags	= (SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
> 
> According to the OMAP242x TRM 2.3 Rev. X [SWPU064X] Table 10-34, the SDMA 
> has no SIDLEMODE register bitfield.  So this SYSC_HAS_SIDLEMODE appears to 
> be incorrect.  Manju, please confirm.

I verified again in 2420 TRM, this entry should not there.

> 
> > +			   SYSC_HAS_MIDLEMODE | SYSC_HAS_CLOCKACTIVITY |
> > +			   SYSC_HAS_EMUFREE | SYSC_HAS_AUTOIDLE),
> > +	.idlemodes	= (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
> 
> And if there is no SIDLEMODE register bitfield, then none of these SIDLE_* 
> modes should apply, so they should all be removed also.

correct.

> 
> > +			   MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
> > +	.sysc_fields	= &omap_hwmod_sysc_type1,
> > +};
> > +
> > +static struct omap_hwmod_class omap2420_dma_hwmod_class = {
> > +	.name = "dma",
> > +	.sysc = &omap2420_dma_sysc,
> > +};
> > +
> > +/* dma attributes */
> > +static struct omap_dma_dev_attr dma_dev_attr = {
> > +	.dev_caps  = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
> > +						IS_CSSA_32 | IS_CDSA_32,
> > +	.lch_count = 32,
> > +};
> > +
> > +static struct omap_hwmod_irq_info omap2420_dma_system_irqs[] = {
> > +	{ .name = "0", .irq = 12 }, /* INT_24XX_SDMA_IRQ0 */
> > +	{ .name = "1", .irq = 13 }, /* INT_24XX_SDMA_IRQ1 */
> > +	{ .name = "2", .irq = 14 }, /* INT_24XX_SDMA_IRQ2 */
> > +	{ .name = "3", .irq = 15 }, /* INT_24XX_SDMA_IRQ3 */
> > +};
> > +
> > +static struct omap_hwmod_addr_space omap2420_dma_system_addrs[] = {
> > +	{
> > +		.pa_start	= 0x48056000,
> > +		.pa_end		= 0x4a0560ff,
> > +		.flags		= ADDR_TYPE_RT
> > +	},
> > +};
> > +
> > +/* dma_system -> L3 */
> > +static struct omap_hwmod_ocp_if omap2420_dma_system__l3 = {
> > +	.master		= &omap2420_dma_system_hwmod,
> > +	.slave		= &omap2420_l3_main_hwmod,
> > +	.clk		= "core_l3_ck",
> > +	.user		= OCP_USER_MPU | OCP_USER_SDMA,
> > +};
> > +
> > +/* dma_system master ports */
> > +static struct omap_hwmod_ocp_if *omap2420_dma_system_masters[] = {
> > +	&omap2420_dma_system__l3,
> > +};
> > +
> > +/* l4_cfg -> dma_system */
> 
> l4_cfg should be l4_core.
ok.
> 
> > +static struct omap_hwmod_ocp_if omap2420_l4_core__dma_system = {
> > +	.master		= &omap2420_l4_core_hwmod,
> > +	.slave		= &omap2420_dma_system_hwmod,
> > +	.clk		= "sdma_ick",
> > +	.addr		= omap2420_dma_system_addrs,
> > +	.addr_cnt	= ARRAY_SIZE(omap2420_dma_system_addrs),
> > +	.user		= OCP_USER_MPU | OCP_USER_SDMA,
> > +};
> > +
> > +/* dma_system slave ports */
> > +static struct omap_hwmod_ocp_if *omap2420_dma_system_slaves[] = {
> > +	&omap2420_l4_core__dma_system,
> > +};
> > +
> > +static struct omap_hwmod omap2420_dma_system_hwmod = {
> > +	.name		= "dma",
> > +	.class		= &omap2420_dma_hwmod_class,
> > +	.mpu_irqs	= omap2420_dma_system_irqs,
> > +	.mpu_irqs_cnt	= ARRAY_SIZE(omap2420_dma_system_irqs),
> > +	.main_clk	= "core_l3_ck",
> > +	.slaves		= omap2420_dma_system_slaves,
> > +	.slaves_cnt	= ARRAY_SIZE(omap2420_dma_system_slaves),
> > +	.masters	= omap2420_dma_system_masters,
> > +	.masters_cnt	= ARRAY_SIZE(omap2420_dma_system_masters),
> > +	.dev_attr	= &dma_dev_attr,
> > +	.omap_chip	= OMAP_CHIP_INIT(CHIP_IS_OMAP2420),
> > +	.flags		= HWMOD_NO_IDLEST,
> > +};
> > +
> >  static __initdata struct omap_hwmod *omap2420_hwmods[] = {
> >  	&omap2420_l3_main_hwmod,
> >  	&omap2420_l4_core_hwmod,
> > @@ -797,6 +881,9 @@ static __initdata struct omap_hwmod *omap2420_hwmods[] = {
> >  	&omap2420_gpio2_hwmod,
> >  	&omap2420_gpio3_hwmod,
> >  	&omap2420_gpio4_hwmod,
> > +
> > +	/* dma_system class*/
> > +	&omap2420_dma_system_hwmod,
> >  	NULL,
> >  };
> >  
> > diff --git a/arch/arm/plat-omap/include/plat/dma.h b/arch/arm/plat-omap/include/plat/dma.h
> > index 2378399..c466566 100644
> > --- a/arch/arm/plat-omap/include/plat/dma.h
> > +++ b/arch/arm/plat-omap/include/plat/dma.h
> > @@ -295,6 +295,13 @@
> >  #define DMA_ERRATA_3_3			BIT(0x5)
> >  #define DMA_ROMCODE_BUG			BIT(0x6)
> >  
> > +/* Attributes for OMAP DMA Contrller */
> > +#define DMA_LINKED_LCH			BIT(0x0)
> > +#define GLOBAL_PRIORITY			BIT(0x1)
> > +#define RESERVE_CHANNEL			BIT(0x2)
> > +#define IS_CSSA_32			BIT(0x3)
> > +#define IS_CDSA_32			BIT(0x4)
> > +
> >  enum omap_reg_offsets {
> >  
> >  GCR,		GSCR,		GRST1,		HW_ID,
> > @@ -389,6 +396,10 @@ struct omap_dma_channel_params {
> >  #endif
> >  };
> >  
> > +struct omap_dma_dev_attr {
> > +	u32 dev_caps;
> > +	u16 lch_count;
> > +};
> >  
> >  extern void omap_set_dma_priority(int lch, int dst_port, int priority);
> >  extern int omap_request_dma(int dev_id, const char *dev_name,
> > -- 
> > 1.7.1
> > 
> 
> I've verified the clocks, the register addresses, and the IRQ numbers 
> against the TRM.  After the SIDLE* stuff is fixed, you can add my ack.

Thanks. I will send pull request to tony.

-Manjunath

  reply	other threads:[~2010-12-19  3:17 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-12-17 15:39 [PATCH v2 0/9] OMAP: DMA: hwmod and DMA as platform device G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 1/9] OMAP: DMA: Replace read/write macros with functions G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 2/9] OMAP: DMA: Introduce errata handling feature G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 3/9] OMAP2420: hwmod data: add system DMA G, Manjunath Kondaiah
2010-12-18  6:55   ` G, Manjunath Kondaiah
2010-12-18  6:55     ` G, Manjunath Kondaiah
2010-12-18  9:23     ` Paul Walmsley
2010-12-18  9:23       ` Paul Walmsley
2010-12-18  9:03   ` Paul Walmsley
2010-12-18  9:03     ` Paul Walmsley
2010-12-19  3:18     ` G, Manjunath Kondaiah [this message]
2010-12-19  3:18       ` G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 4/9] OMAP2430: " G, Manjunath Kondaiah
2010-12-18  9:11   ` Paul Walmsley
2010-12-18  9:11     ` Paul Walmsley
2010-12-18  9:37     ` Russell King - ARM Linux
2010-12-18  9:37       ` Russell King - ARM Linux
2010-12-18  9:42       ` Paul Walmsley
2010-12-18  9:42         ` Paul Walmsley
2010-12-19  3:20     ` G, Manjunath Kondaiah
2010-12-19  3:20       ` G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 5/9] OMAP3: " G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 6/9] OMAP4: " G, Manjunath Kondaiah
2010-12-20 11:30   ` Cousson, Benoit
2010-12-20 11:30     ` Cousson, Benoit
2010-12-20 13:12     ` G, Manjunath Kondaiah
2010-12-20 13:12       ` G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 7/9] OMAP1: DMA: Implement in platform device model G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 8/9] OMAP2+: DMA: hwmod: Device registration G, Manjunath Kondaiah
2010-12-17 15:39 ` [PATCH v2 9/9] OMAP: DMA: Convert DMA library into platform driver G, Manjunath Kondaiah

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20101219031820.GA15568@GLPP-machine \
    --to=manjugk@ti.com \
    --cc=b-cousson@ti.com \
    --cc=khilman@deeprootsystems.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=paul@pwsan.com \
    --cc=santosh.shilimkar@ti.com \
    --cc=tony@atomide.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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.