1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2018, STMicroelectronics - All Rights Reserved
10 #include <dm/device.h>
11 #include <dm/uclass.h>
12 #include <power/stpmic1.h>
14 #define STM32MP_OTP_BANK 0
15 #define STM32MP_NVM_BANK 1
18 * The 'fuse' command API
20 int fuse_read(u32 bank, u32 word, u32 *val)
26 case STM32MP_OTP_BANK:
27 ret = uclass_get_device_by_driver(UCLASS_MISC,
28 DM_GET_DRIVER(stm32mp_bsec),
32 ret = misc_read(dev, word * 4 + STM32_BSEC_SHADOW_OFFSET,
39 #ifdef CONFIG_PMIC_STPMIC1
40 case STM32MP_NVM_BANK:
42 ret = stpmic1_shadow_read_byte(word, (u8 *)val);
44 #endif /* CONFIG_PMIC_STPMIC1 */
47 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
55 int fuse_prog(u32 bank, u32 word, u32 val)
61 case STM32MP_OTP_BANK:
62 ret = uclass_get_device_by_driver(UCLASS_MISC,
63 DM_GET_DRIVER(stm32mp_bsec),
67 ret = misc_write(dev, word * 4 + STM32_BSEC_OTP_OFFSET,
74 #ifdef CONFIG_PMIC_STPMIC1
75 case STM32MP_NVM_BANK:
76 ret = stpmic1_nvm_write_byte(word, (u8 *)&val);
78 #endif /* CONFIG_PMIC_STPMIC1 */
81 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
89 int fuse_sense(u32 bank, u32 word, u32 *val)
95 case STM32MP_OTP_BANK:
96 ret = uclass_get_device_by_driver(UCLASS_MISC,
97 DM_GET_DRIVER(stm32mp_bsec),
101 ret = misc_read(dev, word * 4 + STM32_BSEC_OTP_OFFSET, val, 4);
107 #ifdef CONFIG_PMIC_STPMIC1
108 case STM32MP_NVM_BANK:
110 ret = stpmic1_nvm_read_byte(word, (u8 *)val);
112 #endif /* CONFIG_PMIC_STPMIC1 */
115 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
123 int fuse_override(u32 bank, u32 word, u32 val)
129 case STM32MP_OTP_BANK:
130 ret = uclass_get_device_by_driver(UCLASS_MISC,
131 DM_GET_DRIVER(stm32mp_bsec),
135 ret = misc_write(dev, word * 4 + STM32_BSEC_SHADOW_OFFSET,
142 #ifdef CONFIG_PMIC_STPMIC1
143 case STM32MP_NVM_BANK:
144 ret = stpmic1_shadow_write_byte(word, (u8 *)&val);
146 #endif /* CONFIG_PMIC_STPMIC1 */
149 printf("stm32mp %s: wrong value for bank %i\n",