forked from Minki/linux
3de68d331c
The Marvell Berlin boards have a group based pinmuxing mechanism. This adds the core driver support. We actually do not need any information about the pins here and only have the definition of the groups. Let's take the example of the uart0 pinmuxing on the BG2Q. Balls BK4 and BH6 are muxed to respectively UART0 RX and TX if the group GSM12 is set to mode 0: Group Modes Offset Base Offset LSB Bit Width GSM12 3 sm_base 0x40 0x10 0x2 Ball Group Mode 0 Mode 1 Mode 2 BK4 GSM12 UART0_RX IrDA0_RX GPIO9 BH6 GSM12 UART0_TX IrDA0_TX GPIO10 So in order to configure BK4 -> UART0_TX and BH6 -> UART0_RX, we need to set (sm_base + 0x40 + 0x10) &= ff3fffff. As pin control registers are part of either chip control or system control registers, that deal with a bunch of other functions we rely on a regmap instead of exclusively remapping any resources. Signed-off-by: Antoine Tenart <antoine.tenart@free-electrons.com> Acked-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
62 lines
1.3 KiB
C
62 lines
1.3 KiB
C
/*
|
|
* Marvell Berlin SoC pinctrl driver.
|
|
*
|
|
* Copyright (C) 2014 Marvell Technology Group Ltd.
|
|
*
|
|
* Antoine Ténart <antoine.tenart@free-electrons.com>
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*/
|
|
|
|
#ifndef __PINCTRL_BERLIN_H
|
|
#define __PINCTRL_BERLIN_H
|
|
|
|
struct berlin_desc_function {
|
|
const char *name;
|
|
u8 muxval;
|
|
};
|
|
|
|
struct berlin_desc_group {
|
|
const char *name;
|
|
u8 offset;
|
|
u8 bit_width;
|
|
u8 lsb;
|
|
struct berlin_desc_function *functions;
|
|
};
|
|
|
|
struct berlin_pinctrl_desc {
|
|
const struct berlin_desc_group *groups;
|
|
unsigned ngroups;
|
|
};
|
|
|
|
struct berlin_pinctrl_function {
|
|
const char *name;
|
|
const char **groups;
|
|
unsigned ngroups;
|
|
};
|
|
|
|
#define BERLIN_PINCTRL_GROUP(_name, _offset, _width, _lsb, ...) \
|
|
{ \
|
|
.name = _name, \
|
|
.offset = _offset, \
|
|
.bit_width = _width, \
|
|
.lsb = _lsb, \
|
|
.functions = (struct berlin_desc_function[]){ \
|
|
__VA_ARGS__, { } }, \
|
|
}
|
|
|
|
#define BERLIN_PINCTRL_FUNCTION(_muxval, _name) \
|
|
{ \
|
|
.name = _name, \
|
|
.muxval = _muxval, \
|
|
}
|
|
|
|
#define BERLIN_PINCTRL_FUNCTION_UNKNOWN {}
|
|
|
|
int berlin_pinctrl_probe(struct platform_device *pdev,
|
|
const struct berlin_pinctrl_desc *desc);
|
|
|
|
#endif /* __PINCTRL_BERLIN_H */
|