bcm63xx: 5.4: fix compilation for changed driver_find_device
[oweals/openwrt.git] / target / linux / bcm63xx / patches-5.4 / 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 @@ -204,6 +204,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 @@ -38,6 +39,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,