boardinfo.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/kobject.h>
  3. #include <boot_param.h>
  4. static ssize_t boardinfo_show(struct kobject *kobj,
  5. struct kobj_attribute *attr, char *buf)
  6. {
  7. char board_manufacturer[64] = {0};
  8. char *tmp_board_manufacturer = board_manufacturer;
  9. char bios_vendor[64] = {0};
  10. char *tmp_bios_vendor = bios_vendor;
  11. strcpy(board_manufacturer, eboard->name);
  12. strcpy(bios_vendor, einter->description);
  13. return sprintf(buf,
  14. "Board Info\n"
  15. "Manufacturer\t\t: %s\n"
  16. "Board Name\t\t: %s\n"
  17. "Family\t\t\t: LOONGSON3\n\n"
  18. "BIOS Info\n"
  19. "Vendor\t\t\t: %s\n"
  20. "Version\t\t\t: %s\n"
  21. "ROM Size\t\t: %d KB\n"
  22. "Release Date\t\t: %s\n",
  23. strsep(&tmp_board_manufacturer, "-"),
  24. eboard->name,
  25. strsep(&tmp_bios_vendor, "-"),
  26. einter->description,
  27. einter->size,
  28. especial->special_name);
  29. }
  30. static struct kobj_attribute boardinfo_attr = __ATTR(boardinfo, 0444,
  31. boardinfo_show, NULL);
  32. static int __init boardinfo_init(void)
  33. {
  34. struct kobject *lefi_kobj;
  35. lefi_kobj = kobject_create_and_add("lefi", firmware_kobj);
  36. if (!lefi_kobj) {
  37. pr_err("lefi: Firmware registration failed.\n");
  38. return -ENOMEM;
  39. }
  40. return sysfs_create_file(lefi_kobj, &boardinfo_attr.attr);
  41. }
  42. late_initcall(boardinfo_init);