aboutsummaryrefslogtreecommitdiffstats
path: root/package/boot/uboot-oxnas/files/arch/arm/cpu/arm1136/nas782x/pinmux.c
blob: a6f5e9abc4adcb9bb5db92a32fd3619903c2de6e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include <common.h>
#include <asm/arch/pinmux.h>

void pinmux_set(int bank, int pin, int func)
{
	u32 reg;
	u32 base;
	/* TODO: check parameters */

	if (bank == PINMUX_BANK_MFA)
		base = SYS_CONTROL_BASE;
	else
		base = SEC_CONTROL_BASE;

	clrbits_le32(base + PINMUX_SECONDARY_SEL, BIT(pin));
	clrbits_le32(base + PINMUX_TERTIARY_SEL, BIT(pin));
	clrbits_le32(base + PINMUX_QUATERNARY_SEL, BIT(pin));
	clrbits_le32(base + PINMUX_DEBUG_SEL, BIT(pin));
	clrbits_le32(base + PINMUX_ALTERNATIVE_SEL, BIT(pin));

	switch (func) {
	case PINMUX_GPIO:
	default:
		return;
		break;
	case PINMUX_2:
		reg = base + PINMUX_SECONDARY_SEL;
		break;
	case PINMUX_3:
		reg = base + PINMUX_TERTIARY_SEL;
		break;
	case PINMUX_4:
		reg = base + PINMUX_QUATERNARY_SEL;
		break;
	case PINMUX_DEBUG:
		reg = base + PINMUX_DEBUG_SEL;
		break;
	case PINMUX_ALT:
		reg = base + PINMUX_ALTERNATIVE_SEL;
		break;
	}
	setbits_le32(reg, BIT(pin));
}