Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 */
0002 /*
0003  * Copyright (C) 2017-2018 MediaTek Inc.
0004  *
0005  * Author: Sean Wang <sean.wang@mediatek.com>
0006  *
0007  */
0008 #ifndef __PINCTRL_MOORE_H
0009 #define __PINCTRL_MOORE_H
0010 
0011 #include <linux/io.h>
0012 #include <linux/init.h>
0013 #include <linux/of.h>
0014 #include <linux/of_platform.h>
0015 #include <linux/platform_device.h>
0016 #include <linux/pinctrl/pinctrl.h>
0017 #include <linux/pinctrl/pinmux.h>
0018 #include <linux/pinctrl/pinconf.h>
0019 #include <linux/pinctrl/pinconf-generic.h>
0020 
0021 #include "../core.h"
0022 #include "../pinconf.h"
0023 #include "../pinmux.h"
0024 #include "mtk-eint.h"
0025 #include "pinctrl-mtk-common-v2.h"
0026 
0027 #define MTK_RANGE(_a)       { .range = (_a), .nranges = ARRAY_SIZE(_a), }
0028 
0029 #define MTK_PIN(_number, _name, _eint_m, _eint_n, _drv_n) { \
0030         .number = _number,          \
0031         .name = _name,              \
0032         .eint = {               \
0033             .eint_m = _eint_m,      \
0034             .eint_n = _eint_n,      \
0035         },                  \
0036         .drv_n = _drv_n,            \
0037         .funcs = NULL,              \
0038     }
0039 
0040 #define PINCTRL_PIN_GROUP(name, id)         \
0041     {                       \
0042         name,                   \
0043         id##_pins,              \
0044         ARRAY_SIZE(id##_pins),          \
0045         id##_funcs,             \
0046     }
0047 
0048 int mtk_moore_pinctrl_probe(struct platform_device *pdev,
0049                 const struct mtk_pin_soc *soc);
0050 
0051 #endif /* __PINCTRL_MOORE_H */