1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2018, STMicroelectronics - All Rights Reserved
11 #include <dm/device.h>
12 #include <dm/uclass.h>
13 #include <power/stpmic1.h>
15 #define STM32MP_OTP_BANK 0
16 #define STM32MP_NVM_BANK 1
19 * The 'fuse' command API
21 int fuse_read(u32 bank, u32 word, u32 *val)
27 case STM32MP_OTP_BANK:
28 ret = uclass_get_device_by_driver(UCLASS_MISC,
29 DM_GET_DRIVER(stm32mp_bsec),
33 ret = misc_read(dev, word * 4 + STM32_BSEC_SHADOW_OFFSET,
41 #ifdef CONFIG_PMIC_STPMIC1
42 case STM32MP_NVM_BANK:
44 ret = stpmic1_shadow_read_byte(word, (u8 *)val);
46 #endif /* CONFIG_PMIC_STPMIC1 */
49 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
57 int fuse_prog(u32 bank, u32 word, u32 val)
63 case STM32MP_OTP_BANK:
64 ret = uclass_get_device_by_driver(UCLASS_MISC,
65 DM_GET_DRIVER(stm32mp_bsec),
69 ret = misc_write(dev, word * 4 + STM32_BSEC_OTP_OFFSET,
77 #ifdef CONFIG_PMIC_STPMIC1
78 case STM32MP_NVM_BANK:
79 ret = stpmic1_nvm_write_byte(word, (u8 *)&val);
81 #endif /* CONFIG_PMIC_STPMIC1 */
84 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
92 int fuse_sense(u32 bank, u32 word, u32 *val)
98 case STM32MP_OTP_BANK:
99 ret = uclass_get_device_by_driver(UCLASS_MISC,
100 DM_GET_DRIVER(stm32mp_bsec),
104 ret = misc_read(dev, word * 4 + STM32_BSEC_OTP_OFFSET, val, 4);
111 #ifdef CONFIG_PMIC_STPMIC1
112 case STM32MP_NVM_BANK:
114 ret = stpmic1_nvm_read_byte(word, (u8 *)val);
116 #endif /* CONFIG_PMIC_STPMIC1 */
119 printf("stm32mp %s: wrong value for bank %i\n", __func__, bank);
127 int fuse_override(u32 bank, u32 word, u32 val)
133 case STM32MP_OTP_BANK:
134 ret = uclass_get_device_by_driver(UCLASS_MISC,
135 DM_GET_DRIVER(stm32mp_bsec),
139 ret = misc_write(dev, word * 4 + STM32_BSEC_SHADOW_OFFSET,
147 #ifdef CONFIG_PMIC_STPMIC1
148 case STM32MP_NVM_BANK:
149 ret = stpmic1_shadow_write_byte(word, (u8 *)&val);
151 #endif /* CONFIG_PMIC_STPMIC1 */
154 printf("stm32mp %s: wrong value for bank %i\n",