Lines Matching +full:- +full:phy
1 .. SPDX-License-Identifier: GPL-2.0
2 .. include:: ../../disclaimer-zh_CN.rst
4 :Original: Documentation/driver-api/phy/phy.rst
16 本文档解释了 PHY 的通用框架和提供的API,以及使用方法。
21 *PHY* 是物理层的缩写,它被用来把设备连接到一个物理媒介,例如USB控制器
22 有一个提供序列化、反序列化、编码、解码和负责获取所需的数据传输速率的 PHY。
23 注意,有些USB控制器内嵌了 PHY 的功能,其它的则使用了一个外置的PHY,此外
24 使用 PHY 的设备还有无线网、以太网、SATA等(控制器)。
26 创建这个框架的目的是将遍布 Linux 内核的 PHY 驱动程序融入到 drivers/phy,
29 该框架仅适用于使用外部 PHY(PHY 功能未嵌入控制器内)的设备。
34 PHY provider是指实现一个或多个 PHY 实例的实体。对于 PHY provider 仅
35 实现单个 PHY 实例的简单情况,框架在 of_phy_simple_xlate 中提供其自己
36 的 of_xlate 实现。如果 PHY provider 实现多个实例,则应提供其自己的
50 启动情况,所有 PHY provider 都应使用上述两个宏之一来注册 PHY provider。
52 与 PHY provider 关联的设备树节点通常包含一组子节点,每个子节点代表一个
53 PHY。某些绑定可能会为了上下文和可扩展性将子节点嵌套在特别的层级中,在这种
76 PHY 驱动程序应创建 PHY,以便其他外围(芯片)控制器能够使用它。PHY 框架
77 提供了 2 个 API 来创建 PHY。
81 struct phy *phy_create(struct device *dev, struct device_node *node,
83 struct phy *devm_phy_create(struct device *dev,
87 PHY 驱动程序可以使用上述两个 API 之一,通过传递设备指针和 phy_ops
88 来创建 PHY。
90 phy_ops 是一组用于执行 PHY 操作(例如 init、exit、power_on 和
93 在 phy_ops 中,PHY provider驱动程序在创建 PHY 后使用 phy_set_drvdata()
96 获取对 PHY 的引用
99 控制器必须先获取对 PHY 的引用,然后才能使用 PHY。此框架提供以下 API
100 来获取对 PHY 的引用。
104 struct phy *phy_get(struct device *dev, const char *string);
105 struct phy *devm_phy_get(struct device *dev, const char *string);
106 struct phy *devm_phy_optional_get(struct device *dev,
108 struct phy *devm_of_phy_get(struct device *dev, struct device_node *np,
110 struct phy *devm_of_phy_optional_get(struct device *dev,
113 struct phy *devm_of_phy_get_by_index(struct device *dev,
118 启动的情况下获取 PHY,字符串参数应包含 dt 数据中给出的 phy 名称,在
119 非 dt 启动的情况下,它应包含 PHY 的标签。两个 devm_phy_get 在成功
120 获取 PHY 后使用 devres 将设备与 PHY 关联。在驱动程序分离时,将在
121 devres 数据上调用 release 函数并释放 devres 数据。当 phy 是可选
122 的时,应使用 _optional_get 变体。这些函数永远不会返回 -ENODEV,而
123 是在找不到 phy 时返回 NULL。一些通用驱动程序(例如 ehci)可能使用
124 多个 phy。在这种情况下,devm_of_phy_get 或 devm_of_phy_get_by_index
125 用于根据名称或索引获取 phy 引用。
127 需要注意的是,NULL 是有效的 phy 引用。NULL phy 上的所有 phy 使用
128 者调用都将成为 NOP。也就是说释放调用,当应用于 NULL phy 时,release
130 调用都是 NOP。NULL phy 在处理可选的 phy 设备中很有用。
148 :c:func:`phy_set_mode <phy_set_mode_ext>` 而其他 PHY 可能使用
151 之后调用此函数,尽管某些 PHY 驱动程序可能随时允许调用它。
153 释放对 PHY 的引用
156 当控制器不再需要 PHY 时,它必须使用上一节中提到的 API 释放对已获得
157 的 PHY 的引用。PHY 框架提供了 2 个 API 来释放对 PHY 的引用。
161 void phy_put(struct phy *phy);
162 void devm_phy_put(struct device *dev, struct phy *phy);
164 这两个 API 都用于释放对 PHY 的引用,并且 devm_phy_put 会销毁与此
165 PHY 关联的设备资源。
167 销毁 PHY
170 当创建 PHY 的驱动程序被卸载时,它应该使用以下 2 个 API 之一销毁其创
171 建的 PHY::
173 void phy_destroy(struct phy *phy);
174 void devm_phy_destroy(struct device *dev, struct phy *phy);
176 这两个 API 都会销毁 PHY,并且 devm_phy_destroy 会销毁与此 PHY 关
183 phy 设备的 pm_runtime_enable 函数,在销毁 PHY 时,将调用
184 pm_runtime_disable。请注意,此子系统创建的 phy 设备将是调用 phy_create
185 (PHY provider 设备)的设备的子设备。
188 调用 PHY provider 设备的 pm_runtime_get_sync。还应注意,
197 为了在没有 DeviceTree 帮助的情况下获取对 PHY 的引用,框架提供了可与
198 clkdev 进行比较的查找,允许将 clk 结构体绑定到设备。当 struct phy 的
203 int phy_create_lookup(struct phy *phy, const char *con_id,
205 void phy_remove_lookup(struct phy *phy, const char *con_id,
211 PHY dt 绑定的文档可以在以下位置找到 @
212 Documentation/devicetree/bindings/phy/phy-bindings.txt