Commit 49b97d9c8ea7b11c4fc9e457cc2cd9fd6ebf0c21

Authored by Kumar Gala
1 parent 69bcf5bc80
Exists in master and in 55 other branches 8qm-imx_v2020.04_5.4.70_2.3.0, emb_lf_v2022.04, emb_lf_v2023.04, imx_v2015.04_4.1.15_1.0.0_ga, pitx_8mp_lf_v2020.04, smarc-8m-android-10.0.0_2.6.0, smarc-8m-android-11.0.0_2.0.0, smarc-8mp-android-11.0.0_2.0.0, smarc-emmc-imx_v2014.04_3.10.53_1.1.0_ga, smarc-emmc-imx_v2014.04_3.14.28_1.0.0_ga, smarc-imx-l5.0.0_1.0.0-ga, smarc-imx6_v2018.03_4.14.98_2.0.0_ga, smarc-imx7_v2017.03_4.9.11_1.0.0_ga, smarc-imx7_v2018.03_4.14.98_2.0.0_ga, smarc-imx_v2014.04_3.14.28_1.0.0_ga, smarc-imx_v2015.04_4.1.15_1.0.0_ga, smarc-imx_v2017.03_4.9.11_1.0.0_ga, smarc-imx_v2017.03_4.9.88_2.0.0_ga, smarc-imx_v2017.03_o8.1.0_1.3.0_8m, smarc-imx_v2018.03_4.14.78_1.0.0_ga, smarc-m6.0.1_2.1.0-ga, smarc-n7.1.2_2.0.0-ga, smarc-rel_imx_4.1.15_2.0.0_ga, smarc_8m-imx_v2018.03_4.14.98_2.0.0_ga, smarc_8m-imx_v2019.04_4.19.35_1.1.0, smarc_8m_00d0-imx_v2018.03_4.14.98_2.0.0_ga, smarc_8mm-imx_v2018.03_4.14.98_2.0.0_ga, smarc_8mm-imx_v2019.04_4.19.35_1.1.0, smarc_8mm-imx_v2020.04_5.4.24_2.1.0, smarc_8mp_lf_v2020.04, smarc_8mq-imx_v2020.04_5.4.24_2.1.0, smarc_8mq_lf_v2020.04, ti-u-boot-2015.07, u-boot-2013.01.y, v2013.10, v2013.10-smarct33, v2013.10-smartmen, v2014.01, v2014.04, v2014.04-smarct33, v2014.04-smarct33-emmc, v2014.04-smartmen, v2014.07, v2014.07-smarct33, v2014.07-smartmen, v2015.07-smarct33, v2015.07-smarct33-emmc, v2015.07-smarct4x, v2016.05-dlt, v2016.05-smarct3x, v2016.05-smarct3x-emmc, v2016.05-smarct4x, v2017.01-smarct3x, v2017.01-smarct3x-emmc, v2017.01-smarct4x

fdt: Add fdt_del_node_and_alias helper

Add a helper function that given an alias will delete both the node
the alias points to and the alias itself

Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Acked-by: Gerald Van Baren <vanbaren@cideas.com>

Showing 2 changed files with 14 additions and 0 deletions Side-by-side Diff

common/fdt_support.c
... ... @@ -976,4 +976,17 @@
976 976 }
977 977 }
978 978 #endif
  979 +
  980 +void fdt_del_node_and_alias(void *blob, const char *alias)
  981 +{
  982 + int off = fdt_path_offset(blob, alias);
  983 +
  984 + if (off < 0)
  985 + return;
  986 +
  987 + fdt_del_node(blob, off);
  988 +
  989 + off = fdt_path_offset(blob, "/aliases");
  990 + fdt_delprop(blob, off, alias);
  991 +}
include/fdt_support.h
... ... @@ -82,6 +82,7 @@
82 82 int fdt_fixup_nor_flash_size(void *blob, int cs, u32 size);
83 83  
84 84 void fdt_fixup_mtdparts(void *fdt, void *node_info, int node_info_size);
  85 +void fdt_del_node_and_alias(void *blob, const char *alias);
85 86  
86 87 #endif /* ifdef CONFIG_OF_LIBFDT */
87 88 #endif /* ifndef __FDT_SUPPORT_H */