Loading...
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 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | /* SPDX-License-Identifier: GPL-2.0 */ /* * Interconnect framework driver for i.MX SoC * * Copyright (c) 2019, BayLibre * Copyright (c) 2019-2020, NXP * Author: Alexandre Bailon <abailon@baylibre.com> * Author: Leonard Crestez <leonard.crestez@nxp.com> */ #ifndef __DRIVERS_INTERCONNECT_IMX_H #define __DRIVERS_INTERCONNECT_IMX_H #include <linux/args.h> #include <linux/bits.h> #include <linux/types.h> #include <linux/interconnect-provider.h> struct platform_device; #define IMX_ICC_MAX_LINKS 4 /* * High throughput priority level in Regulator mode * Read Priority in Fixed/Limiter mode */ #define PRIORITY0_SHIFT 0 /* * Low throughput priority level in Regulator mode * Write Priority in Fixed/Limiter mode */ #define PRIORITY1_SHIFT 8 #define PRIORITY_MASK 0x7 #define PRIORITY_COMP_MARK BIT(31) /* Must set */ #define IMX_NOC_MODE_FIXED 0 #define IMX_NOC_MODE_LIMITER 1 #define IMX_NOC_MODE_BYPASS 2 #define IMX_NOC_MODE_REGULATOR 3 #define IMX_NOC_MODE_UNCONFIGURED 0xFF #define IMX_NOC_PRIO_REG 0x8 #define IMX_NOC_MODE_REG 0xC #define IMX_NOC_BANDWIDTH_REG 0x10 #define IMX_NOC_SATURATION 0x14 #define IMX_NOC_EXT_CTL_REG 0x18 struct imx_icc_provider { void __iomem *noc_base; struct icc_provider provider; }; /* * struct imx_icc_node_adj - Describe a dynamic adjustable node */ struct imx_icc_node_adj_desc { unsigned int bw_mul, bw_div; const char *phandle_name; bool main_noc; }; /* * struct imx_icc_node - Describe an interconnect node * @name: name of the node * @id: an unique id to identify the node * @links: an array of slaves' node id * @num_links: number of id defined in links */ struct imx_icc_node_desc { const char *name; u16 id; u16 links[IMX_ICC_MAX_LINKS]; u16 num_links; const struct imx_icc_node_adj_desc *adj; }; /* * struct imx_icc_noc_setting - Describe an interconnect node setting * @reg: register offset inside the NoC * @prio_level: priority level * @mode: functional mode * @ext_control: external input control */ struct imx_icc_noc_setting { u32 reg; u32 prio_level; u32 mode; u32 ext_control; }; #define DEFINE_BUS_INTERCONNECT(_name, _id, _adj, ...) \ { \ .id = _id, \ .name = _name, \ .adj = _adj, \ .num_links = COUNT_ARGS(__VA_ARGS__), \ .links = { __VA_ARGS__ }, \ } #define DEFINE_BUS_MASTER(_name, _id, _dest_id) \ DEFINE_BUS_INTERCONNECT(_name, _id, NULL, _dest_id) #define DEFINE_BUS_SLAVE(_name, _id, _adj) \ DEFINE_BUS_INTERCONNECT(_name, _id, _adj) int imx_icc_register(struct platform_device *pdev, struct imx_icc_node_desc *nodes, int nodes_count, struct imx_icc_noc_setting *noc_settings); void imx_icc_unregister(struct platform_device *pdev); #endif /* __DRIVERS_INTERCONNECT_IMX_H */ |