aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorScott Wood <scottwood@freescale.com>2007-07-16 14:32:24 -0400
committerKumar Gala <galak@kernel.crashing.org>2007-10-04 12:02:18 -0400
commit7f21f52940212c25b4387c2450018e161043549a (patch)
tree9df63e5508151be0c6fd9e02b692f5ca1edf4394
parent2652d4ec4a363487d0106a8bf51f1b081dd7e397 (diff)
[POWERPC] cpm2: Add cpm2_set_pin().
This provides a generic way for board code to set up CPM pins, rather than directly poking magic values into registers. Signed-off-by: Scott Wood <scottwood@freescale.com> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
-rw-r--r--arch/powerpc/sysdev/cpm2_common.c33
-rw-r--r--include/asm-powerpc/cpm2.h9
2 files changed, 42 insertions, 0 deletions
diff --git a/arch/powerpc/sysdev/cpm2_common.c b/arch/powerpc/sysdev/cpm2_common.c
index c6dc0bf614b3..fc4c99565381 100644
--- a/arch/powerpc/sysdev/cpm2_common.c
+++ b/arch/powerpc/sysdev/cpm2_common.c
@@ -422,3 +422,36 @@ void *cpm_dpram_addr(unsigned long offset)
422 return (void *)(im_dprambase + offset); 422 return (void *)(im_dprambase + offset);
423} 423}
424EXPORT_SYMBOL(cpm_dpram_addr); 424EXPORT_SYMBOL(cpm_dpram_addr);
425
426struct cpm2_ioports {
427 u32 dir, par, sor, odr, dat;
428 u32 res[3];
429};
430
431void cpm2_set_pin(int port, int pin, int flags)
432{
433 struct cpm2_ioports __iomem *iop =
434 (struct cpm2_ioports __iomem *)&cpm2_immr->im_ioport;
435
436 pin = 1 << (31 - pin);
437
438 if (flags & CPM_PIN_OUTPUT)
439 setbits32(&iop[port].dir, pin);
440 else
441 clrbits32(&iop[port].dir, pin);
442
443 if (!(flags & CPM_PIN_GPIO))
444 setbits32(&iop[port].par, pin);
445 else
446 clrbits32(&iop[port].par, pin);
447
448 if (flags & CPM_PIN_SECONDARY)
449 setbits32(&iop[port].sor, pin);
450 else
451 clrbits32(&iop[port].sor, pin);
452
453 if (flags & CPM_PIN_OPENDRAIN)
454 setbits32(&iop[port].odr, pin);
455 else
456 clrbits32(&iop[port].odr, pin);
457}
diff --git a/include/asm-powerpc/cpm2.h b/include/asm-powerpc/cpm2.h
index 41a45db0c8b1..d7b57ac55892 100644
--- a/include/asm-powerpc/cpm2.h
+++ b/include/asm-powerpc/cpm2.h
@@ -1247,5 +1247,14 @@ enum cpm_clk {
1247extern int cpm2_clk_setup(enum cpm_clk_target target, int clock, int mode); 1247extern int cpm2_clk_setup(enum cpm_clk_target target, int clock, int mode);
1248extern int cpm2_smc_clk_setup(enum cpm_clk_target target, int clock); 1248extern int cpm2_smc_clk_setup(enum cpm_clk_target target, int clock);
1249 1249
1250#define CPM_PIN_INPUT 0
1251#define CPM_PIN_OUTPUT 1
1252#define CPM_PIN_PRIMARY 0
1253#define CPM_PIN_SECONDARY 2
1254#define CPM_PIN_GPIO 4
1255#define CPM_PIN_OPENDRAIN 8
1256
1257void cpm2_set_pin(int port, int pin, int flags);
1258
1250#endif /* __CPM2__ */ 1259#endif /* __CPM2__ */
1251#endif /* __KERNEL__ */ 1260#endif /* __KERNEL__ */