unsigned reserve;
        struct property *prop;
        const char *group;
+       const char *subnode_target_type = "pins";
 
        ret = of_property_read_string(np, "function", &function);
        if (ret < 0) {
                reserve++;
        if (num_configs)
                reserve++;
+
        ret = of_property_count_strings(np, "pins");
        if (ret < 0) {
-               dev_err(dev, "could not parse property pins\n");
-               goto exit;
+               ret = of_property_count_strings(np, "groups");
+               if (ret < 0) {
+                       dev_err(dev, "could not parse property pins/groups\n");
+                       goto exit;
+               }
+               if (type == PIN_MAP_TYPE_INVALID)
+                       type = PIN_MAP_TYPE_CONFIGS_GROUP;
+               subnode_target_type = "groups";
+       } else {
+               if (type == PIN_MAP_TYPE_INVALID)
+                       type = PIN_MAP_TYPE_CONFIGS_PIN;
        }
        reserve *= ret;
 
        if (ret < 0)
                goto exit;
 
-       of_property_for_each_string(np, "pins", prop, group) {
+       of_property_for_each_string(np, subnode_target_type, prop, group) {
                if (function) {
                        ret = pinctrl_utils_add_map_mux(pctldev, map,
                                        reserved_maps, num_maps, group,
 
                        PIN_MAP_TYPE_CONFIGS_PIN);
 }
 
+static inline int pinconf_generic_dt_node_to_map_all(
+               struct pinctrl_dev *pctldev, struct device_node *np_config,
+               struct pinctrl_map **map, unsigned *num_maps)
+{
+       /*
+        * passing the type as PIN_MAP_TYPE_INVALID causes the underlying parser
+        * to infer the map type from the DT properties used.
+        */
+       return pinconf_generic_dt_node_to_map(pctldev, np_config, map, num_maps,
+                       PIN_MAP_TYPE_INVALID);
+}
 #endif
 
 #endif /* CONFIG_GENERIC_PINCONF */