fstree.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005.
  4. */
  5. #include "dtc.h"
  6. #include <dirent.h>
  7. #include <sys/stat.h>
  8. static struct node *read_fstree(const char *dirname)
  9. {
  10. DIR *d;
  11. struct dirent *de;
  12. struct stat st;
  13. struct node *tree;
  14. d = opendir(dirname);
  15. if (!d)
  16. die("Couldn't opendir() \"%s\": %s\n", dirname, strerror(errno));
  17. tree = build_node(NULL, NULL, NULL);
  18. while ((de = readdir(d)) != NULL) {
  19. char *tmpname;
  20. if (streq(de->d_name, ".")
  21. || streq(de->d_name, ".."))
  22. continue;
  23. tmpname = join_path(dirname, de->d_name);
  24. if (stat(tmpname, &st) < 0)
  25. die("stat(%s): %s\n", tmpname, strerror(errno));
  26. if (S_ISREG(st.st_mode)) {
  27. struct property *prop;
  28. FILE *pfile;
  29. pfile = fopen(tmpname, "rb");
  30. if (! pfile) {
  31. fprintf(stderr,
  32. "WARNING: Cannot open %s: %s\n",
  33. tmpname, strerror(errno));
  34. } else {
  35. prop = build_property(de->d_name,
  36. data_copy_file(pfile,
  37. st.st_size),
  38. NULL);
  39. add_property(tree, prop);
  40. fclose(pfile);
  41. }
  42. } else if (S_ISDIR(st.st_mode)) {
  43. struct node *newchild;
  44. newchild = read_fstree(tmpname);
  45. newchild = name_node(newchild, xstrdup(de->d_name));
  46. add_child(tree, newchild);
  47. }
  48. free(tmpname);
  49. }
  50. closedir(d);
  51. return tree;
  52. }
  53. struct dt_info *dt_from_fs(const char *dirname)
  54. {
  55. struct node *tree;
  56. tree = read_fstree(dirname);
  57. tree = name_node(tree, "");
  58. return build_dt_info(DTSF_V1, NULL, tree, guess_boot_cpuid(tree));
  59. }