efuse.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (C) 2015 Reinhard Pfau <reinhard.pfau@gdsys.cc>
  4. */
  5. #ifndef _MVEBU_EFUSE_H
  6. #define _MVEBU_EFUSE_H
  7. #include <common.h>
  8. struct efuse_val {
  9. union {
  10. struct {
  11. u8 d[8];
  12. } bytes;
  13. struct {
  14. u16 d[4];
  15. } words;
  16. struct {
  17. u32 d[2];
  18. } dwords;
  19. };
  20. u32 lock;
  21. };
  22. #if defined(CONFIG_ARMADA_38X)
  23. enum efuse_line {
  24. EFUSE_LINE_SECURE_BOOT = 24,
  25. EFUSE_LINE_PUBKEY_DIGEST_0 = 26,
  26. EFUSE_LINE_PUBKEY_DIGEST_1 = 27,
  27. EFUSE_LINE_PUBKEY_DIGEST_2 = 28,
  28. EFUSE_LINE_PUBKEY_DIGEST_3 = 29,
  29. EFUSE_LINE_PUBKEY_DIGEST_4 = 30,
  30. EFUSE_LINE_CSK_0_VALID = 31,
  31. EFUSE_LINE_CSK_1_VALID = 32,
  32. EFUSE_LINE_CSK_2_VALID = 33,
  33. EFUSE_LINE_CSK_3_VALID = 34,
  34. EFUSE_LINE_CSK_4_VALID = 35,
  35. EFUSE_LINE_CSK_5_VALID = 36,
  36. EFUSE_LINE_CSK_6_VALID = 37,
  37. EFUSE_LINE_CSK_7_VALID = 38,
  38. EFUSE_LINE_CSK_8_VALID = 39,
  39. EFUSE_LINE_CSK_9_VALID = 40,
  40. EFUSE_LINE_CSK_10_VALID = 41,
  41. EFUSE_LINE_CSK_11_VALID = 42,
  42. EFUSE_LINE_CSK_12_VALID = 43,
  43. EFUSE_LINE_CSK_13_VALID = 44,
  44. EFUSE_LINE_CSK_14_VALID = 45,
  45. EFUSE_LINE_CSK_15_VALID = 46,
  46. EFUSE_LINE_FLASH_ID = 47,
  47. EFUSE_LINE_BOX_ID = 48,
  48. EFUSE_LINE_MIN = 0,
  49. EFUSE_LINE_MAX = 63,
  50. };
  51. #endif
  52. int mvebu_efuse_init_hw(void);
  53. int mvebu_read_efuse(int nr, struct efuse_val *val);
  54. int mvebu_write_efuse(int nr, struct efuse_val *val);
  55. int mvebu_lock_efuse(int nr);
  56. #endif