/Linux-v5.15/drivers/clk/keystone/ |
D | sci-clk.c | 16 #include <linux/clk-provider.h> 33 * struct sci_clk_provider - TI SCI clock provider representation 36 * @dev: Device pointer for the clock provider 38 * @num_clocks: Total number of clocks for this provider 54 * @provider: Master clock provider 65 struct sci_clk_provider *provider; member 87 return clk->provider->ops->get_clock(clk->provider->sci, clk->dev_id, in sci_clk_prepare() 104 ret = clk->provider->ops->put_clock(clk->provider->sci, clk->dev_id, in sci_clk_unprepare() 107 dev_err(clk->provider->dev, in sci_clk_unprepare() 125 ret = clk->provider->ops->is_on(clk->provider->sci, clk->dev_id, in sci_clk_is_prepared() [all …]
|
/Linux-v5.15/drivers/interconnect/imx/ |
D | imx.c | 12 #include <linux/interconnect-provider.h> 30 struct device *dev = node->provider->dev; in imx_icc_node_set() 68 dev_warn(node->provider->dev, in imx_icc_node_destroy() 78 static int imx_icc_node_init_qos(struct icc_provider *provider, in imx_icc_node_init_qos() argument 83 struct device *dev = provider->dev; in imx_icc_node_init_qos() 123 static struct icc_node *imx_icc_node_add(struct icc_provider *provider, in imx_icc_node_add() argument 126 struct device *dev = provider->dev; in imx_icc_node_add() 152 icc_node_add(node, provider); in imx_icc_node_add() 155 ret = imx_icc_node_init_qos(provider, node); in imx_icc_node_add() 165 static void imx_icc_unregister_nodes(struct icc_provider *provider) in imx_icc_unregister_nodes() argument [all …]
|
/Linux-v5.15/drivers/interconnect/qcom/ |
D | icc-rpm.c | 8 #include <linux/interconnect-provider.h> 23 struct icc_provider *provider; in qcom_icc_set() local 33 provider = src->provider; in qcom_icc_set() 34 qp = to_qcom_provider(provider); in qcom_icc_set() 36 list_for_each_entry(n, &provider->nodes, node_list) in qcom_icc_set() 37 provider->aggregate(n, 0, n->avg_bw, n->peak_bw, in qcom_icc_set() 95 struct icc_provider *provider; in qnoc_probe() local 136 provider = &qp->provider; in qnoc_probe() 137 INIT_LIST_HEAD(&provider->nodes); in qnoc_probe() 138 provider->dev = dev; in qnoc_probe() [all …]
|
D | osm-l3.c | 8 #include <linux/interconnect-provider.h> 42 container_of(_provider, struct qcom_osm_l3_icc_provider, provider) 49 struct icc_provider provider; member 168 struct icc_provider *provider; in qcom_osm_l3_set() local 177 provider = src->provider; in qcom_osm_l3_set() 178 qp = to_osm_l3_provider(provider); in qcom_osm_l3_set() 180 list_for_each_entry(n, &provider->nodes, node_list) in qcom_osm_l3_set() 181 provider->aggregate(n, 0, n->avg_bw, n->peak_bw, in qcom_osm_l3_set() 202 icc_nodes_remove(&qp->provider); in qcom_osm_l3_remove() 203 return icc_provider_del(&qp->provider); in qcom_osm_l3_remove() [all …]
|
D | icc-rpmh.c | 7 #include <linux/interconnect-provider.h> 51 qp = to_qcom_provider(node->provider); in qcom_icc_aggregate() 95 qp = to_qcom_provider(node->provider); in qcom_icc_set() 131 * @dev: associated provider device 191 struct icc_provider *provider; in qcom_icc_rpmh_probe() local 213 provider = &qp->provider; in qcom_icc_rpmh_probe() 214 provider->dev = dev; in qcom_icc_rpmh_probe() 215 provider->set = qcom_icc_set; in qcom_icc_rpmh_probe() 216 provider->pre_aggregate = qcom_icc_pre_aggregate; in qcom_icc_rpmh_probe() 217 provider->aggregate = qcom_icc_aggregate; in qcom_icc_rpmh_probe() [all …]
|
D | msm8974.c | 33 #include <linux/interconnect-provider.h> 179 container_of(_provider, struct msm8974_icc_provider, provider) 187 * struct msm8974_icc_provider - Qualcomm specific interconnect provider 188 * @provider: generic interconnect provider 193 struct icc_provider provider; member 587 struct icc_provider *provider; in msm8974_icc_set() local 593 provider = src->provider; in msm8974_icc_set() 594 qp = to_msm8974_icc_provider(provider); in msm8974_icc_set() 596 list_for_each_entry(n, &provider->nodes, node_list) in msm8974_icc_set() 597 provider->aggregate(n, 0, n->avg_bw, n->peak_bw, in msm8974_icc_set() [all …]
|
D | sdm660.c | 10 #include <linux/interconnect-provider.h> 163 container_of(_provider, struct qcom_icc_provider, provider) 187 * struct qcom_icc_provider - Qualcomm specific interconnect provider 188 * @provider: generic interconnect provider 196 struct icc_provider provider; member 597 struct icc_provider *provider; in qcom_icc_set_bimc_qos() local 603 provider = src->provider; in qcom_icc_set_bimc_qos() 604 qp = to_qcom_provider(provider); in qcom_icc_set_bimc_qos() 649 struct icc_provider *provider; in qcom_icc_set_noc_qos() local 654 provider = src->provider; in qcom_icc_set_noc_qos() [all …]
|
D | icc-rpmh.h | 12 container_of(_provider, struct qcom_icc_provider, provider) 15 * struct qcom_icc_provider - Qualcomm specific interconnect provider 16 * @provider: generic interconnect provider 18 * @bcms: list of bcms that maps to the provider 20 * @voter: bcm voter targeted by this provider 23 struct icc_provider provider; member
|
D | icc-rpm.h | 15 container_of(_provider, struct qcom_icc_provider, provider) 18 * struct qcom_icc_provider - Qualcomm specific interconnect provider 19 * @provider: generic interconnect provider 24 struct icc_provider provider; member
|
/Linux-v5.15/drivers/clk/tegra/ |
D | clk-tegra210-emc.c | 8 #include <linux/clk-provider.h> 35 struct tegra210_clk_emc_provider *provider; member 93 struct tegra210_clk_emc_provider *provider = emc->provider; in tegra210_clk_emc_round_rate() local 96 if (!provider || !provider->configs || provider->num_configs == 0) in tegra210_clk_emc_round_rate() 99 for (i = 0; i < provider->num_configs; i++) { in tegra210_clk_emc_round_rate() 100 if (provider->configs[i].rate >= rate) in tegra210_clk_emc_round_rate() 101 return provider->configs[i].rate; in tegra210_clk_emc_round_rate() 104 return provider->configs[i - 1].rate; in tegra210_clk_emc_round_rate() 122 struct tegra210_clk_emc_provider *provider = emc->provider; in tegra210_clk_emc_set_rate() local 124 struct device *dev = provider->dev; in tegra210_clk_emc_set_rate() [all …]
|
/Linux-v5.15/drivers/interconnect/ |
D | core.c | 14 #include <linux/interconnect-provider.h> 45 struct icc_provider *provider; in icc_summary_show() local 52 list_for_each_entry(provider, &icc_providers, provider_list) { in icc_summary_show() 55 list_for_each_entry(n, &provider->nodes, node_list) { in icc_summary_show() 101 struct icc_provider *provider; in icc_graph_show() local 111 list_for_each_entry(provider, &icc_providers, provider_list) { in icc_graph_show() 113 if (provider->dev) in icc_graph_show() 115 dev_name(provider->dev)); in icc_graph_show() 118 list_for_each_entry(n, &provider->nodes, node_list) in icc_graph_show() 122 list_for_each_entry(n, &provider->nodes, node_list) in icc_graph_show() [all …]
|
/Linux-v5.15/drivers/interconnect/samsung/ |
D | exynos.c | 3 * Exynos generic interconnect provider driver 11 #include <linux/interconnect-provider.h> 23 /* One interconnect node per provider */ 24 struct icc_provider provider; member 105 icc_nodes_remove(&priv->provider); in exynos_generic_icc_remove() 106 icc_provider_del(&priv->provider); in exynos_generic_icc_remove() 115 struct icc_provider *provider; in exynos_generic_icc_probe() local 126 provider = &priv->provider; in exynos_generic_icc_probe() 128 provider->set = exynos_generic_icc_set; in exynos_generic_icc_probe() 129 provider->aggregate = icc_std_aggregate; in exynos_generic_icc_probe() [all …]
|
/Linux-v5.15/include/linux/ |
D | interconnect-provider.h | 43 * struct icc_provider - interconnect provider (controller) entity that might 47 * @nodes: internal list of the interconnect provider nodes 53 * @xlate: provider-specific callback for mapping nodes from phandle arguments 55 * @dev: the device this interconnect provider belongs to 57 * @inter_set: whether inter-provider pairs will be configured with @set 83 * @provider: points to the interconnect provider of this node 84 * @node_list: the list entry in the parent provider's "nodes" list 101 struct icc_provider *provider; member 122 void icc_node_add(struct icc_node *node, struct icc_provider *provider); 124 int icc_nodes_remove(struct icc_provider *provider); [all …]
|
/Linux-v5.15/drivers/clk/ti/ |
D | clkctrl.c | 18 #include <linux/clk-provider.h> 234 struct omap_clkctrl_provider *provider = data; in _ti_omap4_clkctrl_xlate() local 244 list_for_each_entry(entry, &provider->clocks, node) { in _ti_omap4_clkctrl_xlate() 290 _ti_clkctrl_clk_register(struct omap_clkctrl_provider *provider, in _ti_clkctrl_clk_register() argument 327 list_add(&clkctrl_clk->node, &provider->clocks); in _ti_clkctrl_clk_register() 338 _ti_clkctrl_setup_gate(struct omap_clkctrl_provider *provider, in _ti_clkctrl_setup_gate() argument 352 if (_ti_clkctrl_clk_register(provider, node, &clk_hw->hw, offset, in _ti_clkctrl_setup_gate() 359 _ti_clkctrl_setup_mux(struct omap_clkctrl_provider *provider, in _ti_clkctrl_setup_mux() argument 387 if (_ti_clkctrl_clk_register(provider, node, &mux->hw, offset, in _ti_clkctrl_setup_mux() 394 _ti_clkctrl_setup_div(struct omap_clkctrl_provider *provider, in _ti_clkctrl_setup_div() argument [all …]
|
/Linux-v5.15/Documentation/driver-api/pci/ |
D | p2pdma.rst | 36 * Provider - A driver which provides or publishes P2P resources like 44 it may be typical for a driver to be both a provider and a client). 48 * The NVMe PCI driver is both a client, provider and orchestrator 50 resource (provider), it accepts P2P memory pages as buffers in requests 61 memory behind it, its driver could add support as a P2P provider and 66 Provider Drivers 69 A provider simply needs to register a BAR (or a portion of a BAR) 108 a specific P2P provider to use it may check compatibility using 109 :c:func:`pci_p2pdma_distance()` otherwise it may find a memory provider 111 If more than one provider is supported, the one nearest to all the clients will [all …]
|
/Linux-v5.15/Documentation/devicetree/bindings/power/ |
D | power-domain.yaml | 20 their PM domains provided by PM domain providers. A PM domain provider can be 22 domains. A consumer node can refer to the provider by a phandle and a set of 24 \#power-domain-cells property in the PM domain provider node. 34 power-domain provider. The idle state definitions are compatible with the 47 provider. If the provider provides a single power domain only or all 48 the power domains provided by the provider have identical OPP tables, 57 by device tree binding documentation of particular provider. 66 by the given provider should be subdomains of the domain specified 82 // The node above defines a power controller that is a PM domain provider and
|
/Linux-v5.15/Documentation/devicetree/bindings/dvfs/ |
D | performance-domain.yaml | 26 providers. A performance domain provider can be represented by any node in 28 node can refer to the provider by a phandle and a set of phandle arguments 30 \#performance-domain-cells property in the performance domain provider node. 41 provider. 49 performance controller/provider specified by phandle. 62 // domain provider and expects one cell as its phandle argument.
|
/Linux-v5.15/Documentation/devicetree/bindings/reset/ |
D | reset.txt | 9 a reset provider (e.g. power management or clock module) and received by a 11 ordinate module is reset). This binding exists to represent the provider and 14 A reset signal is represented by the phandle of the provider, plus a reset 16 provider. The length (number of cells) and semantics of the reset specifier 17 are dictated by the binding of the reset provider, although common schemes 50 device manages. Note: if the reset provider specifies '0' for
|
/Linux-v5.15/drivers/phy/marvell/ |
D | phy-mmp3-hsic.c | 43 struct phy_provider *provider; in mmp3_hsic_phy_probe() local 60 provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate); in mmp3_hsic_phy_probe() 61 if (IS_ERR(provider)) { in mmp3_hsic_phy_probe() 62 dev_err(dev, "failed to register PHY provider\n"); in mmp3_hsic_phy_probe() 63 return PTR_ERR(provider); in mmp3_hsic_phy_probe()
|
/Linux-v5.15/drivers/pci/ |
D | p2pdma.c | 38 struct pci_dev *provider; member 208 p2p_pgmap->provider = pdev; in pci_p2pdma_add_resource() 450 calc_map_type_and_dist(struct pci_dev *provider, struct pci_dev *client, in calc_map_type_and_dist() argument 454 struct pci_dev *a = provider, *b = client, *bb; in calc_map_type_and_dist() 519 pci_warn(client, "ACS redirect is set between the client and provider (%s)\n", in calc_map_type_and_dist() 520 pci_name(provider)); in calc_map_type_and_dist() 528 !host_bridge_whitelist(provider, client, acs_redirects)) { in calc_map_type_and_dist() 530 …pci_warn(client, "cannot be used for peer-to-peer DMA as the client and provider (%s) do not share… in calc_map_type_and_dist() 531 pci_name(provider)); in calc_map_type_and_dist() 536 p2pdma = rcu_dereference(provider->p2pdma); in calc_map_type_and_dist() [all …]
|
/Linux-v5.15/Documentation/driver-api/phy/ |
D | phy.rst | 28 Registering/Unregistering the PHY provider 31 PHY provider refers to an entity that implements one or more PHY instances. 32 For the simple case where the PHY provider implements only a single instance of 34 of_phy_simple_xlate. If the PHY provider implements multiple instances, it 50 2 macros to register the PHY provider. 52 Often the device tree nodes associated with a PHY provider will contain a set 93 Inorder to dereference the private data (in phy_ops), the phy provider driver 167 phy_create (PHY provider device). 170 pm_runtime_get_sync of PHY provider device because of parent-child relationship.
|
/Linux-v5.15/Documentation/driver-api/ |
D | interconnect.rst | 55 Interconnect provider is the software definition of the interconnect hardware. 60 port. Each interconnect provider consists of multiple interconnect nodes, 63 called an interconnect node, which belongs to the Mem NoC interconnect provider. 81 Interconnect provider is an entity that implements methods to initialize and 82 configure interconnect bus hardware. The interconnect provider drivers should 83 be registered with the interconnect provider core. 85 .. kernel-doc:: include/linux/interconnect-provider.h 111 same provider as subgraphs. The format is human-readable and can also be piped
|
/Linux-v5.15/Documentation/devicetree/bindings/interconnect/ |
D | interconnect.txt | 1 Interconnect Provider Device Tree Bindings 10 The interconnect provider binding is intended to represent the interconnect 11 controllers in the system. Each provider registers a set of interconnect 20 - compatible : contains the interconnect provider compatible string 46 interconnects : Pairs of phandles and interconnect provider specifier to denote
|
/Linux-v5.15/drivers/phy/broadcom/ |
D | phy-bcm-ns2-pcie.c | 58 struct phy_provider *provider; in ns2_pci_phy_probe() local 69 provider = devm_of_phy_provider_register(&phy->dev, in ns2_pci_phy_probe() 71 if (IS_ERR(provider)) { in ns2_pci_phy_probe() 72 dev_err(dev, "failed to register Phy provider\n"); in ns2_pci_phy_probe() 73 return PTR_ERR(provider); in ns2_pci_phy_probe()
|
/Linux-v5.15/include/linux/soc/amlogic/ |
D | meson-canvas.h | 27 * meson_canvas_get() - get a canvas provider instance 36 * @canvas: canvas provider instance retrieved from meson_canvas_get() 44 * @canvas: canvas provider instance retrieved from meson_canvas_get() 52 * @canvas: canvas provider instance retrieved from meson_canvas_get()
|