kernel: bump 5.15 to 5.15.148
[openwrt/staging/stintel.git] / target / linux / bcm63xx / patches-5.15 / 144-add-removed-syscon_regmap_lookup_by_pdevname.patch
1 From: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2 Date: Fri, 03 Apr 2020 19:50:03 +0200
3 Subject: add removed helper syscon_regmap_lookup_by_pdevname
4
5 The helper syscon_regmap_lookup_by_pdevname has been removed in 29d14b668d2f
6 ("mfd: Remove unused helper syscon_regmap_lookup_by_pdevname") due to lack
7 of users.
8
9 Thus, we have to maintain it locally.
10
11 This patch includes a fix due to changes in driver_find_device;
12 kernel commit: 92ce7e83b4e5 ("driver_find_device: Unify the match function
13 with class_find_device()")
14
15 Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
16
17 --- a/drivers/mfd/syscon.c
18 +++ b/drivers/mfd/syscon.c
19 @@ -209,6 +209,27 @@ struct regmap *syscon_regmap_lookup_by_c
20 }
21 EXPORT_SYMBOL_GPL(syscon_regmap_lookup_by_compatible);
22
23 +static int syscon_match_pdevname(struct device *dev, const void *data)
24 +{
25 + return !strcmp(dev_name(dev), (const char *)data);
26 +}
27 +
28 +struct regmap *syscon_regmap_lookup_by_pdevname(const char *s)
29 +{
30 + struct device *dev;
31 + struct syscon *syscon;
32 +
33 + dev = driver_find_device(&syscon_driver.driver, NULL, (void *)s,
34 + syscon_match_pdevname);
35 + if (!dev)
36 + return ERR_PTR(-EPROBE_DEFER);
37 +
38 + syscon = dev_get_drvdata(dev);
39 +
40 + return syscon->regmap;
41 +}
42 +EXPORT_SYMBOL_GPL(syscon_regmap_lookup_by_pdevname);
43 +
44 struct regmap *syscon_regmap_lookup_by_phandle(struct device_node *np,
45 const char *property)
46 {
47 --- a/include/linux/mfd/syscon.h
48 +++ b/include/linux/mfd/syscon.h
49 @@ -20,6 +20,7 @@ struct device_node;
50 extern struct regmap *device_node_to_regmap(struct device_node *np);
51 extern struct regmap *syscon_node_to_regmap(struct device_node *np);
52 extern struct regmap *syscon_regmap_lookup_by_compatible(const char *s);
53 +extern struct regmap *syscon_regmap_lookup_by_pdevname(const char *s);
54 extern struct regmap *syscon_regmap_lookup_by_phandle(
55 struct device_node *np,
56 const char *property);
57 @@ -46,6 +47,11 @@ static inline struct regmap *syscon_regm
58 {
59 return ERR_PTR(-ENOTSUPP);
60 }
61 +
62 +static inline struct regmap *syscon_regmap_lookup_by_pdevname(const char *s)
63 +{
64 + return ERR_PTR(-ENOTSUPP);
65 +}
66
67 static inline struct regmap *syscon_regmap_lookup_by_phandle(
68 struct device_node *np,