diff options
author | Scott Wood <scottwood@freescale.com> | 2007-07-16 14:32:24 -0400 |
---|---|---|
committer | Kumar Gala <galak@kernel.crashing.org> | 2007-10-04 12:02:18 -0400 |
commit | 7f21f52940212c25b4387c2450018e161043549a (patch) | |
tree | 9df63e5508151be0c6fd9e02b692f5ca1edf4394 | |
parent | 2652d4ec4a363487d0106a8bf51f1b081dd7e397 (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.c | 33 | ||||
-rw-r--r-- | include/asm-powerpc/cpm2.h | 9 |
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 | } |
424 | EXPORT_SYMBOL(cpm_dpram_addr); | 424 | EXPORT_SYMBOL(cpm_dpram_addr); |
425 | |||
426 | struct cpm2_ioports { | ||
427 | u32 dir, par, sor, odr, dat; | ||
428 | u32 res[3]; | ||
429 | }; | ||
430 | |||
431 | void 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 { | |||
1247 | extern int cpm2_clk_setup(enum cpm_clk_target target, int clock, int mode); | 1247 | extern int cpm2_clk_setup(enum cpm_clk_target target, int clock, int mode); |
1248 | extern int cpm2_smc_clk_setup(enum cpm_clk_target target, int clock); | 1248 | extern 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 | |||
1257 | void cpm2_set_pin(int port, int pin, int flags); | ||
1258 | |||
1250 | #endif /* __CPM2__ */ | 1259 | #endif /* __CPM2__ */ |
1251 | #endif /* __KERNEL__ */ | 1260 | #endif /* __KERNEL__ */ |