Commit a95b077d authored by Geert Uytterhoeven's avatar Geert Uytterhoeven

pinctrl: sh-pfc: checker: Improve pin function checks

Improve the checks for pin function descriptors:
  1. Merge declaration and assignment of the local variable for the
     current pin function,
  2. Pin function names must be unique.
Signed-off-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: default avatarNiklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Link: https://lore.kernel.org/r/20200110131927.1029-8-geert+renesas@glider.be
parent 4ef30dc7
...@@ -849,7 +849,6 @@ static void __init sh_pfc_check_cfg_reg(const char *drvname, ...@@ -849,7 +849,6 @@ static void __init sh_pfc_check_cfg_reg(const char *drvname,
static void __init sh_pfc_check_info(const struct sh_pfc_soc_info *info) static void __init sh_pfc_check_info(const struct sh_pfc_soc_info *info)
{ {
const struct sh_pfc_function *func;
const char *drvname = info->name; const char *drvname = info->name;
unsigned int *refcnts; unsigned int *refcnts;
unsigned int i, j, k; unsigned int i, j, k;
...@@ -890,11 +889,17 @@ static void __init sh_pfc_check_info(const struct sh_pfc_soc_info *info) ...@@ -890,11 +889,17 @@ static void __init sh_pfc_check_info(const struct sh_pfc_soc_info *info)
return; return;
for (i = 0; i < info->nr_functions; i++) { for (i = 0; i < info->nr_functions; i++) {
func = &info->functions[i]; const struct sh_pfc_function *func = &info->functions[i];
if (!func->name) { if (!func->name) {
sh_pfc_err("empty function %u\n", i); sh_pfc_err("empty function %u\n", i);
continue; continue;
} }
for (j = 0; j < i; j++) {
if (same_name(func->name, info->functions[j].name))
sh_pfc_err("function %s: name conflict\n",
func->name);
}
for (j = 0; j < func->nr_groups; j++) { for (j = 0; j < func->nr_groups; j++) {
for (k = 0; k < info->nr_groups; k++) { for (k = 0; k < info->nr_groups; k++) {
if (same_name(func->groups[j], if (same_name(func->groups[j],
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment