mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-27 21:14:44 +08:00
3c910ecbdd
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation you should have received a copy of the gnu general public license along with this program if not see http www gnu org licenses extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 30 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190531190115.962665879@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
43 lines
945 B
C
43 lines
945 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* First generation of pinmux driver for Amlogic Meson SoCs
|
|
*
|
|
* Copyright (C) 2014 Beniamino Galvani <b.galvani@gmail.com>
|
|
* Copyright (C) 2017 Jerome Brunet <jbrunet@baylibre.com>
|
|
*/
|
|
|
|
struct meson8_pmx_data {
|
|
bool is_gpio;
|
|
unsigned int reg;
|
|
unsigned int bit;
|
|
};
|
|
|
|
#define PMX_DATA(r, b, g) \
|
|
{ \
|
|
.reg = r, \
|
|
.bit = b, \
|
|
.is_gpio = g, \
|
|
}
|
|
|
|
#define GROUP(grp, r, b) \
|
|
{ \
|
|
.name = #grp, \
|
|
.pins = grp ## _pins, \
|
|
.num_pins = ARRAY_SIZE(grp ## _pins), \
|
|
.data = (const struct meson8_pmx_data[]){ \
|
|
PMX_DATA(r, b, false), \
|
|
}, \
|
|
}
|
|
|
|
#define GPIO_GROUP(gpio) \
|
|
{ \
|
|
.name = #gpio, \
|
|
.pins = (const unsigned int[]){ gpio }, \
|
|
.num_pins = 1, \
|
|
.data = (const struct meson8_pmx_data[]){ \
|
|
PMX_DATA(0, 0, true), \
|
|
}, \
|
|
}
|
|
|
|
extern const struct pinmux_ops meson8_pmx_ops;
|