2 * phy-core.c -- Generic Phy framework.
4 * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com
6 * Author: Kishon Vijay Abraham I <kishon@ti.com>
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation; either version 2 of the License, or (at your
11 * option) any later version.
14 #include <linux/kernel.h>
15 #include <linux/export.h>
16 #include <linux/module.h>
17 #include <linux/err.h>
18 #include <linux/device.h>
19 #include <linux/slab.h>
21 #include <linux/phy/phy.h>
22 #include <linux/idr.h>
23 #include <linux/pm_runtime.h>
24 #include <linux/regulator/consumer.h>
26 static struct class *phy_class
;
27 static DEFINE_MUTEX(phy_provider_mutex
);
28 static LIST_HEAD(phy_provider_list
);
29 static LIST_HEAD(phys
);
30 static DEFINE_IDA(phy_ida
);
32 static void devm_phy_release(struct device
*dev
, void *res
)
34 struct phy
*phy
= *(struct phy
**)res
;
39 static void devm_phy_provider_release(struct device
*dev
, void *res
)
41 struct phy_provider
*phy_provider
= *(struct phy_provider
**)res
;
43 of_phy_provider_unregister(phy_provider
);
46 static void devm_phy_consume(struct device
*dev
, void *res
)
48 struct phy
*phy
= *(struct phy
**)res
;
53 static int devm_phy_match(struct device
*dev
, void *res
, void *match_data
)
55 struct phy
**phy
= res
;
57 return *phy
== match_data
;
61 * phy_create_lookup() - allocate and register PHY/device association
62 * @phy: the phy of the association
63 * @con_id: connection ID string on device
64 * @dev_id: the device of the association
66 * Creates and registers phy_lookup entry.
68 int phy_create_lookup(struct phy
*phy
, const char *con_id
, const char *dev_id
)
70 struct phy_lookup
*pl
;
72 if (!phy
|| !dev_id
|| !con_id
)
75 pl
= kzalloc(sizeof(*pl
), GFP_KERNEL
);
83 mutex_lock(&phy_provider_mutex
);
84 list_add_tail(&pl
->node
, &phys
);
85 mutex_unlock(&phy_provider_mutex
);
89 EXPORT_SYMBOL_GPL(phy_create_lookup
);
92 * phy_remove_lookup() - find and remove PHY/device association
93 * @phy: the phy of the association
94 * @con_id: connection ID string on device
95 * @dev_id: the device of the association
97 * Finds and unregisters phy_lookup entry that was created with
98 * phy_create_lookup().
100 void phy_remove_lookup(struct phy
*phy
, const char *con_id
, const char *dev_id
)
102 struct phy_lookup
*pl
;
104 if (!phy
|| !dev_id
|| !con_id
)
107 mutex_lock(&phy_provider_mutex
);
108 list_for_each_entry(pl
, &phys
, node
)
109 if (pl
->phy
== phy
&& !strcmp(pl
->dev_id
, dev_id
) &&
110 !strcmp(pl
->con_id
, con_id
)) {
115 mutex_unlock(&phy_provider_mutex
);
117 EXPORT_SYMBOL_GPL(phy_remove_lookup
);
119 static struct phy
*phy_find(struct device
*dev
, const char *con_id
)
121 const char *dev_id
= dev_name(dev
);
122 struct phy_lookup
*p
, *pl
= NULL
;
124 mutex_lock(&phy_provider_mutex
);
125 list_for_each_entry(p
, &phys
, node
)
126 if (!strcmp(p
->dev_id
, dev_id
) && !strcmp(p
->con_id
, con_id
)) {
130 mutex_unlock(&phy_provider_mutex
);
132 return pl
? pl
->phy
: ERR_PTR(-ENODEV
);
135 static struct phy_provider
*of_phy_provider_lookup(struct device_node
*node
)
137 struct phy_provider
*phy_provider
;
138 struct device_node
*child
;
140 list_for_each_entry(phy_provider
, &phy_provider_list
, list
) {
141 if (phy_provider
->dev
->of_node
== node
)
144 for_each_child_of_node(phy_provider
->dev
->of_node
, child
)
149 return ERR_PTR(-EPROBE_DEFER
);
152 int phy_pm_runtime_get(struct phy
*phy
)
156 if (!pm_runtime_enabled(&phy
->dev
))
159 ret
= pm_runtime_get(&phy
->dev
);
160 if (ret
< 0 && ret
!= -EINPROGRESS
)
161 pm_runtime_put_noidle(&phy
->dev
);
165 EXPORT_SYMBOL_GPL(phy_pm_runtime_get
);
167 int phy_pm_runtime_get_sync(struct phy
*phy
)
171 if (!pm_runtime_enabled(&phy
->dev
))
174 ret
= pm_runtime_get_sync(&phy
->dev
);
176 pm_runtime_put_sync(&phy
->dev
);
180 EXPORT_SYMBOL_GPL(phy_pm_runtime_get_sync
);
182 int phy_pm_runtime_put(struct phy
*phy
)
184 if (!pm_runtime_enabled(&phy
->dev
))
187 return pm_runtime_put(&phy
->dev
);
189 EXPORT_SYMBOL_GPL(phy_pm_runtime_put
);
191 int phy_pm_runtime_put_sync(struct phy
*phy
)
193 if (!pm_runtime_enabled(&phy
->dev
))
196 return pm_runtime_put_sync(&phy
->dev
);
198 EXPORT_SYMBOL_GPL(phy_pm_runtime_put_sync
);
200 void phy_pm_runtime_allow(struct phy
*phy
)
202 if (!pm_runtime_enabled(&phy
->dev
))
205 pm_runtime_allow(&phy
->dev
);
207 EXPORT_SYMBOL_GPL(phy_pm_runtime_allow
);
209 void phy_pm_runtime_forbid(struct phy
*phy
)
211 if (!pm_runtime_enabled(&phy
->dev
))
214 pm_runtime_forbid(&phy
->dev
);
216 EXPORT_SYMBOL_GPL(phy_pm_runtime_forbid
);
218 int phy_init(struct phy
*phy
)
225 ret
= phy_pm_runtime_get_sync(phy
);
226 if (ret
< 0 && ret
!= -ENOTSUPP
)
228 ret
= 0; /* Override possible ret == -ENOTSUPP */
230 mutex_lock(&phy
->mutex
);
231 if (phy
->init_count
== 0 && phy
->ops
->init
) {
232 ret
= phy
->ops
->init(phy
);
234 dev_err(&phy
->dev
, "phy init failed --> %d\n", ret
);
241 mutex_unlock(&phy
->mutex
);
242 phy_pm_runtime_put(phy
);
245 EXPORT_SYMBOL_GPL(phy_init
);
247 int phy_exit(struct phy
*phy
)
254 ret
= phy_pm_runtime_get_sync(phy
);
255 if (ret
< 0 && ret
!= -ENOTSUPP
)
257 ret
= 0; /* Override possible ret == -ENOTSUPP */
259 mutex_lock(&phy
->mutex
);
260 if (phy
->init_count
== 1 && phy
->ops
->exit
) {
261 ret
= phy
->ops
->exit(phy
);
263 dev_err(&phy
->dev
, "phy exit failed --> %d\n", ret
);
270 mutex_unlock(&phy
->mutex
);
271 phy_pm_runtime_put(phy
);
274 EXPORT_SYMBOL_GPL(phy_exit
);
276 int phy_power_on(struct phy
*phy
)
284 ret
= regulator_enable(phy
->pwr
);
289 ret
= phy_pm_runtime_get_sync(phy
);
290 if (ret
< 0 && ret
!= -ENOTSUPP
)
292 ret
= 0; /* Override possible ret == -ENOTSUPP */
294 mutex_lock(&phy
->mutex
);
295 if (phy
->power_count
== 0 && phy
->ops
->power_on
) {
296 ret
= phy
->ops
->power_on(phy
);
298 dev_err(&phy
->dev
, "phy poweron failed --> %d\n", ret
);
303 mutex_unlock(&phy
->mutex
);
307 mutex_unlock(&phy
->mutex
);
308 phy_pm_runtime_put_sync(phy
);
310 regulator_disable(phy
->pwr
);
314 EXPORT_SYMBOL_GPL(phy_power_on
);
316 int phy_power_off(struct phy
*phy
)
323 mutex_lock(&phy
->mutex
);
324 if (phy
->power_count
== 1 && phy
->ops
->power_off
) {
325 ret
= phy
->ops
->power_off(phy
);
327 dev_err(&phy
->dev
, "phy poweroff failed --> %d\n", ret
);
328 mutex_unlock(&phy
->mutex
);
333 mutex_unlock(&phy
->mutex
);
334 phy_pm_runtime_put(phy
);
337 regulator_disable(phy
->pwr
);
341 EXPORT_SYMBOL_GPL(phy_power_off
);
344 * _of_phy_get() - lookup and obtain a reference to a phy by phandle
345 * @np: device_node for which to get the phy
346 * @index: the index of the phy
348 * Returns the phy associated with the given phandle value,
349 * after getting a refcount to it or -ENODEV if there is no such phy or
350 * -EPROBE_DEFER if there is a phandle to the phy, but the device is
351 * not yet loaded. This function uses of_xlate call back function provided
352 * while registering the phy_provider to find the phy instance.
354 static struct phy
*_of_phy_get(struct device_node
*np
, int index
)
357 struct phy_provider
*phy_provider
;
358 struct phy
*phy
= NULL
;
359 struct of_phandle_args args
;
361 ret
= of_parse_phandle_with_args(np
, "phys", "#phy-cells",
364 return ERR_PTR(-ENODEV
);
366 mutex_lock(&phy_provider_mutex
);
367 phy_provider
= of_phy_provider_lookup(args
.np
);
368 if (IS_ERR(phy_provider
) || !try_module_get(phy_provider
->owner
)) {
369 phy
= ERR_PTR(-EPROBE_DEFER
);
373 if (!of_device_is_available(args
.np
)) {
374 dev_warn(phy_provider
->dev
, "Requested PHY is disabled\n");
375 phy
= ERR_PTR(-ENODEV
);
379 phy
= phy_provider
->of_xlate(phy_provider
->dev
, &args
);
382 module_put(phy_provider
->owner
);
385 mutex_unlock(&phy_provider_mutex
);
386 of_node_put(args
.np
);
392 * of_phy_get() - lookup and obtain a reference to a phy using a device_node.
393 * @np: device_node for which to get the phy
394 * @con_id: name of the phy from device's point of view
396 * Returns the phy driver, after getting a refcount to it; or
397 * -ENODEV if there is no such phy. The caller is responsible for
398 * calling phy_put() to release that count.
400 struct phy
*of_phy_get(struct device_node
*np
, const char *con_id
)
402 struct phy
*phy
= NULL
;
406 index
= of_property_match_string(np
, "phy-names", con_id
);
408 phy
= _of_phy_get(np
, index
);
412 if (!try_module_get(phy
->ops
->owner
))
413 return ERR_PTR(-EPROBE_DEFER
);
415 get_device(&phy
->dev
);
419 EXPORT_SYMBOL_GPL(of_phy_get
);
422 * phy_put() - release the PHY
423 * @phy: the phy returned by phy_get()
425 * Releases a refcount the caller received from phy_get().
427 void phy_put(struct phy
*phy
)
429 if (!phy
|| IS_ERR(phy
))
432 module_put(phy
->ops
->owner
);
433 put_device(&phy
->dev
);
435 EXPORT_SYMBOL_GPL(phy_put
);
438 * devm_phy_put() - release the PHY
439 * @dev: device that wants to release this phy
440 * @phy: the phy returned by devm_phy_get()
442 * destroys the devres associated with this phy and invokes phy_put
443 * to release the phy.
445 void devm_phy_put(struct device
*dev
, struct phy
*phy
)
452 r
= devres_destroy(dev
, devm_phy_release
, devm_phy_match
, phy
);
453 dev_WARN_ONCE(dev
, r
, "couldn't find PHY resource\n");
455 EXPORT_SYMBOL_GPL(devm_phy_put
);
458 * of_phy_simple_xlate() - returns the phy instance from phy provider
459 * @dev: the PHY provider device
460 * @args: of_phandle_args (not used here)
462 * Intended to be used by phy provider for the common case where #phy-cells is
463 * 0. For other cases where #phy-cells is greater than '0', the phy provider
464 * should provide a custom of_xlate function that reads the *args* and returns
465 * the appropriate phy.
467 struct phy
*of_phy_simple_xlate(struct device
*dev
, struct of_phandle_args
471 struct class_dev_iter iter
;
473 class_dev_iter_init(&iter
, phy_class
, NULL
, NULL
);
474 while ((dev
= class_dev_iter_next(&iter
))) {
476 if (args
->np
!= phy
->dev
.of_node
)
479 class_dev_iter_exit(&iter
);
483 class_dev_iter_exit(&iter
);
484 return ERR_PTR(-ENODEV
);
486 EXPORT_SYMBOL_GPL(of_phy_simple_xlate
);
489 * phy_get() - lookup and obtain a reference to a phy.
490 * @dev: device that requests this phy
491 * @string: the phy name as given in the dt data or the name of the controller
492 * port for non-dt case
494 * Returns the phy driver, after getting a refcount to it; or
495 * -ENODEV if there is no such phy. The caller is responsible for
496 * calling phy_put() to release that count.
498 struct phy
*phy_get(struct device
*dev
, const char *string
)
503 if (string
== NULL
) {
504 dev_WARN(dev
, "missing string\n");
505 return ERR_PTR(-EINVAL
);
509 index
= of_property_match_string(dev
->of_node
, "phy-names",
511 phy
= _of_phy_get(dev
->of_node
, index
);
513 phy
= phy_find(dev
, string
);
518 if (!try_module_get(phy
->ops
->owner
))
519 return ERR_PTR(-EPROBE_DEFER
);
521 get_device(&phy
->dev
);
525 EXPORT_SYMBOL_GPL(phy_get
);
528 * phy_optional_get() - lookup and obtain a reference to an optional phy.
529 * @dev: device that requests this phy
530 * @string: the phy name as given in the dt data or the name of the controller
531 * port for non-dt case
533 * Returns the phy driver, after getting a refcount to it; or
534 * NULL if there is no such phy. The caller is responsible for
535 * calling phy_put() to release that count.
537 struct phy
*phy_optional_get(struct device
*dev
, const char *string
)
539 struct phy
*phy
= phy_get(dev
, string
);
541 if (IS_ERR(phy
) && (PTR_ERR(phy
) == -ENODEV
))
546 EXPORT_SYMBOL_GPL(phy_optional_get
);
549 * devm_phy_get() - lookup and obtain a reference to a phy.
550 * @dev: device that requests this phy
551 * @string: the phy name as given in the dt data or phy device name
554 * Gets the phy using phy_get(), and associates a device with it using
555 * devres. On driver detach, release function is invoked on the devres data,
556 * then, devres data is freed.
558 struct phy
*devm_phy_get(struct device
*dev
, const char *string
)
560 struct phy
**ptr
, *phy
;
562 ptr
= devres_alloc(devm_phy_release
, sizeof(*ptr
), GFP_KERNEL
);
564 return ERR_PTR(-ENOMEM
);
566 phy
= phy_get(dev
, string
);
569 devres_add(dev
, ptr
);
576 EXPORT_SYMBOL_GPL(devm_phy_get
);
579 * devm_phy_optional_get() - lookup and obtain a reference to an optional phy.
580 * @dev: device that requests this phy
581 * @string: the phy name as given in the dt data or phy device name
584 * Gets the phy using phy_get(), and associates a device with it using
585 * devres. On driver detach, release function is invoked on the devres
586 * data, then, devres data is freed. This differs to devm_phy_get() in
587 * that if the phy does not exist, it is not considered an error and
588 * -ENODEV will not be returned. Instead the NULL phy is returned,
589 * which can be passed to all other phy consumer calls.
591 struct phy
*devm_phy_optional_get(struct device
*dev
, const char *string
)
593 struct phy
*phy
= devm_phy_get(dev
, string
);
595 if (IS_ERR(phy
) && (PTR_ERR(phy
) == -ENODEV
))
600 EXPORT_SYMBOL_GPL(devm_phy_optional_get
);
603 * devm_of_phy_get() - lookup and obtain a reference to a phy.
604 * @dev: device that requests this phy
605 * @np: node containing the phy
606 * @con_id: name of the phy from device's point of view
608 * Gets the phy using of_phy_get(), and associates a device with it using
609 * devres. On driver detach, release function is invoked on the devres data,
610 * then, devres data is freed.
612 struct phy
*devm_of_phy_get(struct device
*dev
, struct device_node
*np
,
615 struct phy
**ptr
, *phy
;
617 ptr
= devres_alloc(devm_phy_release
, sizeof(*ptr
), GFP_KERNEL
);
619 return ERR_PTR(-ENOMEM
);
621 phy
= of_phy_get(np
, con_id
);
624 devres_add(dev
, ptr
);
631 EXPORT_SYMBOL_GPL(devm_of_phy_get
);
634 * devm_of_phy_get_by_index() - lookup and obtain a reference to a phy by index.
635 * @dev: device that requests this phy
636 * @np: node containing the phy
637 * @index: index of the phy
639 * Gets the phy using _of_phy_get(), then gets a refcount to it,
640 * and associates a device with it using devres. On driver detach,
641 * release function is invoked on the devres data,
642 * then, devres data is freed.
645 struct phy
*devm_of_phy_get_by_index(struct device
*dev
, struct device_node
*np
,
648 struct phy
**ptr
, *phy
;
650 ptr
= devres_alloc(devm_phy_release
, sizeof(*ptr
), GFP_KERNEL
);
652 return ERR_PTR(-ENOMEM
);
654 phy
= _of_phy_get(np
, index
);
660 if (!try_module_get(phy
->ops
->owner
)) {
662 return ERR_PTR(-EPROBE_DEFER
);
665 get_device(&phy
->dev
);
668 devres_add(dev
, ptr
);
672 EXPORT_SYMBOL_GPL(devm_of_phy_get_by_index
);
675 * phy_create() - create a new phy
676 * @dev: device that is creating the new phy
677 * @node: device node of the phy
678 * @ops: function pointers for performing phy operations
680 * Called to create a phy using phy framework.
682 struct phy
*phy_create(struct device
*dev
, struct device_node
*node
,
683 const struct phy_ops
*ops
)
690 return ERR_PTR(-EINVAL
);
692 phy
= kzalloc(sizeof(*phy
), GFP_KERNEL
);
694 return ERR_PTR(-ENOMEM
);
696 id
= ida_simple_get(&phy_ida
, 0, 0, GFP_KERNEL
);
698 dev_err(dev
, "unable to get id\n");
703 device_initialize(&phy
->dev
);
704 mutex_init(&phy
->mutex
);
706 phy
->dev
.class = phy_class
;
707 phy
->dev
.parent
= dev
;
708 phy
->dev
.of_node
= node
?: dev
->of_node
;
712 ret
= dev_set_name(&phy
->dev
, "phy-%s.%d", dev_name(dev
), id
);
717 phy
->pwr
= regulator_get_optional(&phy
->dev
, "phy");
718 if (IS_ERR(phy
->pwr
)) {
719 ret
= PTR_ERR(phy
->pwr
);
720 if (ret
== -EPROBE_DEFER
)
726 ret
= device_add(&phy
->dev
);
730 if (pm_runtime_enabled(dev
)) {
731 pm_runtime_enable(&phy
->dev
);
732 pm_runtime_no_callbacks(&phy
->dev
);
738 put_device(&phy
->dev
); /* calls phy_release() which frees resources */
745 EXPORT_SYMBOL_GPL(phy_create
);
748 * devm_phy_create() - create a new phy
749 * @dev: device that is creating the new phy
750 * @node: device node of the phy
751 * @ops: function pointers for performing phy operations
753 * Creates a new PHY device adding it to the PHY class.
754 * While at that, it also associates the device with the phy using devres.
755 * On driver detach, release function is invoked on the devres data,
756 * then, devres data is freed.
758 struct phy
*devm_phy_create(struct device
*dev
, struct device_node
*node
,
759 const struct phy_ops
*ops
)
761 struct phy
**ptr
, *phy
;
763 ptr
= devres_alloc(devm_phy_consume
, sizeof(*ptr
), GFP_KERNEL
);
765 return ERR_PTR(-ENOMEM
);
767 phy
= phy_create(dev
, node
, ops
);
770 devres_add(dev
, ptr
);
777 EXPORT_SYMBOL_GPL(devm_phy_create
);
780 * phy_destroy() - destroy the phy
781 * @phy: the phy to be destroyed
783 * Called to destroy the phy.
785 void phy_destroy(struct phy
*phy
)
787 pm_runtime_disable(&phy
->dev
);
788 device_unregister(&phy
->dev
);
790 EXPORT_SYMBOL_GPL(phy_destroy
);
793 * devm_phy_destroy() - destroy the PHY
794 * @dev: device that wants to release this phy
795 * @phy: the phy returned by devm_phy_get()
797 * destroys the devres associated with this phy and invokes phy_destroy
798 * to destroy the phy.
800 void devm_phy_destroy(struct device
*dev
, struct phy
*phy
)
804 r
= devres_destroy(dev
, devm_phy_consume
, devm_phy_match
, phy
);
805 dev_WARN_ONCE(dev
, r
, "couldn't find PHY resource\n");
807 EXPORT_SYMBOL_GPL(devm_phy_destroy
);
810 * __of_phy_provider_register() - create/register phy provider with the framework
811 * @dev: struct device of the phy provider
812 * @owner: the module owner containing of_xlate
813 * @of_xlate: function pointer to obtain phy instance from phy provider
815 * Creates struct phy_provider from dev and of_xlate function pointer.
816 * This is used in the case of dt boot for finding the phy instance from
819 struct phy_provider
*__of_phy_provider_register(struct device
*dev
,
820 struct module
*owner
, struct phy
* (*of_xlate
)(struct device
*dev
,
821 struct of_phandle_args
*args
))
823 struct phy_provider
*phy_provider
;
825 phy_provider
= kzalloc(sizeof(*phy_provider
), GFP_KERNEL
);
827 return ERR_PTR(-ENOMEM
);
829 phy_provider
->dev
= dev
;
830 phy_provider
->owner
= owner
;
831 phy_provider
->of_xlate
= of_xlate
;
833 mutex_lock(&phy_provider_mutex
);
834 list_add_tail(&phy_provider
->list
, &phy_provider_list
);
835 mutex_unlock(&phy_provider_mutex
);
839 EXPORT_SYMBOL_GPL(__of_phy_provider_register
);
842 * __devm_of_phy_provider_register() - create/register phy provider with the
844 * @dev: struct device of the phy provider
845 * @owner: the module owner containing of_xlate
846 * @of_xlate: function pointer to obtain phy instance from phy provider
848 * Creates struct phy_provider from dev and of_xlate function pointer.
849 * This is used in the case of dt boot for finding the phy instance from
850 * phy provider. While at that, it also associates the device with the
851 * phy provider using devres. On driver detach, release function is invoked
852 * on the devres data, then, devres data is freed.
854 struct phy_provider
*__devm_of_phy_provider_register(struct device
*dev
,
855 struct module
*owner
, struct phy
* (*of_xlate
)(struct device
*dev
,
856 struct of_phandle_args
*args
))
858 struct phy_provider
**ptr
, *phy_provider
;
860 ptr
= devres_alloc(devm_phy_provider_release
, sizeof(*ptr
), GFP_KERNEL
);
862 return ERR_PTR(-ENOMEM
);
864 phy_provider
= __of_phy_provider_register(dev
, owner
, of_xlate
);
865 if (!IS_ERR(phy_provider
)) {
867 devres_add(dev
, ptr
);
874 EXPORT_SYMBOL_GPL(__devm_of_phy_provider_register
);
877 * of_phy_provider_unregister() - unregister phy provider from the framework
878 * @phy_provider: phy provider returned by of_phy_provider_register()
880 * Removes the phy_provider created using of_phy_provider_register().
882 void of_phy_provider_unregister(struct phy_provider
*phy_provider
)
884 if (IS_ERR(phy_provider
))
887 mutex_lock(&phy_provider_mutex
);
888 list_del(&phy_provider
->list
);
890 mutex_unlock(&phy_provider_mutex
);
892 EXPORT_SYMBOL_GPL(of_phy_provider_unregister
);
895 * devm_of_phy_provider_unregister() - remove phy provider from the framework
896 * @dev: struct device of the phy provider
898 * destroys the devres associated with this phy provider and invokes
899 * of_phy_provider_unregister to unregister the phy provider.
901 void devm_of_phy_provider_unregister(struct device
*dev
,
902 struct phy_provider
*phy_provider
) {
905 r
= devres_destroy(dev
, devm_phy_provider_release
, devm_phy_match
,
907 dev_WARN_ONCE(dev
, r
, "couldn't find PHY provider device resource\n");
909 EXPORT_SYMBOL_GPL(devm_of_phy_provider_unregister
);
912 * phy_release() - release the phy
913 * @dev: the dev member within phy
915 * When the last reference to the device is removed, it is called
916 * from the embedded kobject as release method.
918 static void phy_release(struct device
*dev
)
923 dev_vdbg(dev
, "releasing '%s'\n", dev_name(dev
));
924 regulator_put(phy
->pwr
);
925 ida_simple_remove(&phy_ida
, phy
->id
);
929 static int __init
phy_core_init(void)
931 phy_class
= class_create(THIS_MODULE
, "phy");
932 if (IS_ERR(phy_class
)) {
933 pr_err("failed to create phy class --> %ld\n",
935 return PTR_ERR(phy_class
);
938 phy_class
->dev_release
= phy_release
;
942 module_init(phy_core_init
);
944 static void __exit
phy_core_exit(void)
946 class_destroy(phy_class
);
948 module_exit(phy_core_exit
);
950 MODULE_DESCRIPTION("Generic PHY Framework");
951 MODULE_AUTHOR("Kishon Vijay Abraham I <kishon@ti.com>");
952 MODULE_LICENSE("GPL v2");