/Linux-v6.1/drivers/nvmem/ |
D | sprd-efuse.c | 39 * The Spreadtrum AP efuse contains 2 parts: normal efuse and secure efuse, 40 * and we can only access the normal efuse in kernel. So define the normal 52 * when reading or writing data to efuse memory, the controller can save double 80 * efuse controller, so we need one hardware spinlock to synchronize between 83 static int sprd_efuse_lock(struct sprd_efuse *efuse) in sprd_efuse_lock() argument 87 mutex_lock(&efuse->mutex); in sprd_efuse_lock() 89 ret = hwspin_lock_timeout_raw(efuse->hwlock, in sprd_efuse_lock() 92 dev_err(efuse->dev, "timeout get the hwspinlock\n"); in sprd_efuse_lock() 93 mutex_unlock(&efuse->mutex); in sprd_efuse_lock() 100 static void sprd_efuse_unlock(struct sprd_efuse *efuse) in sprd_efuse_unlock() argument [all …]
|
D | meson-mx-efuse.c | 3 * Amlogic Meson6, Meson8 and Meson8b eFuse Driver 51 static void meson_mx_efuse_mask_bits(struct meson_mx_efuse *efuse, u32 reg, in meson_mx_efuse_mask_bits() argument 56 data = readl(efuse->base + reg); in meson_mx_efuse_mask_bits() 60 writel(data, efuse->base + reg); in meson_mx_efuse_mask_bits() 63 static int meson_mx_efuse_hw_enable(struct meson_mx_efuse *efuse) in meson_mx_efuse_hw_enable() argument 67 err = clk_prepare_enable(efuse->core_clk); in meson_mx_efuse_hw_enable() 71 /* power up the efuse */ in meson_mx_efuse_hw_enable() 72 meson_mx_efuse_mask_bits(efuse, MESON_MX_EFUSE_CNTL1, in meson_mx_efuse_hw_enable() 75 meson_mx_efuse_mask_bits(efuse, MESON_MX_EFUSE_CNTL4, in meson_mx_efuse_hw_enable() 81 static void meson_mx_efuse_hw_disable(struct meson_mx_efuse *efuse) in meson_mx_efuse_hw_disable() argument [all …]
|
D | sc27xx-efuse.c | 17 /* Efuse controller registers definition */ 81 * efuse controller, so we need one hardware spinlock to synchronize between 84 static int sc27xx_efuse_lock(struct sc27xx_efuse *efuse) in sc27xx_efuse_lock() argument 88 mutex_lock(&efuse->mutex); in sc27xx_efuse_lock() 90 ret = hwspin_lock_timeout_raw(efuse->hwlock, in sc27xx_efuse_lock() 93 dev_err(efuse->dev, "timeout to get the hwspinlock\n"); in sc27xx_efuse_lock() 94 mutex_unlock(&efuse->mutex); in sc27xx_efuse_lock() 101 static void sc27xx_efuse_unlock(struct sc27xx_efuse *efuse) in sc27xx_efuse_unlock() argument 103 hwspin_unlock_raw(efuse->hwlock); in sc27xx_efuse_unlock() 104 mutex_unlock(&efuse->mutex); in sc27xx_efuse_unlock() [all …]
|
D | rockchip-efuse.c | 3 * Rockchip eFuse Driver 58 struct rockchip_efuse_chip *efuse = context; in rockchip_rk3288_efuse_read() local 62 ret = clk_prepare_enable(efuse->clk); in rockchip_rk3288_efuse_read() 64 dev_err(efuse->dev, "failed to prepare/enable efuse clk\n"); in rockchip_rk3288_efuse_read() 68 writel(RK3288_LOAD | RK3288_PGENB, efuse->base + REG_EFUSE_CTRL); in rockchip_rk3288_efuse_read() 71 writel(readl(efuse->base + REG_EFUSE_CTRL) & in rockchip_rk3288_efuse_read() 73 efuse->base + REG_EFUSE_CTRL); in rockchip_rk3288_efuse_read() 74 writel(readl(efuse->base + REG_EFUSE_CTRL) | in rockchip_rk3288_efuse_read() 76 efuse->base + REG_EFUSE_CTRL); in rockchip_rk3288_efuse_read() 78 writel(readl(efuse->base + REG_EFUSE_CTRL) | in rockchip_rk3288_efuse_read() [all …]
|
D | jz4780-efuse.c | 3 * JZ4780 EFUSE Memory Support driver 10 * Currently supports JZ4780 efuse which has 8K programmable bit. 11 * Efuse is separated into seven segments as below: 72 struct jz4780_efuse *efuse = context; in jz4780_efuse_read() local 87 regmap_update_bits(efuse->map, JZ_EFUCTRL, in jz4780_efuse_read() 94 ret = regmap_read_poll_timeout(efuse->map, JZ_EFUSTATE, in jz4780_efuse_read() 99 dev_err(efuse->dev, "Time out while reading efuse data"); in jz4780_efuse_read() 103 ret = regmap_bulk_read(efuse->map, JZ_EFUDATA(0), in jz4780_efuse_read() 119 .name = "jz4780-efuse", 142 struct jz4780_efuse *efuse; in jz4780_efuse_probe() local [all …]
|
D | Makefile | 23 nvmem_jz4780_efuse-y := jz4780-efuse.o 33 nvmem_meson_efuse-y := meson-efuse.o 35 nvmem_meson_mx_efuse-y := meson-mx-efuse.o 38 obj-$(CONFIG_NVMEM_MTK_EFUSE) += nvmem_mtk-efuse.o 39 nvmem_mtk-efuse-y := mtk-efuse.o 51 nvmem_rockchip_efuse-y := rockchip-efuse.o 54 obj-$(CONFIG_NVMEM_SC27XX_EFUSE) += nvmem-sc27xx-efuse.o 55 nvmem-sc27xx-efuse-y := sc27xx-efuse.o 61 nvmem_sprd_efuse-y := sprd-efuse.o 70 obj-$(CONFIG_NVMEM_UNIPHIER_EFUSE) += nvmem-uniphier-efuse.o [all …]
|
D | Kconfig | 27 tristate "Apple eFuse support" 90 tristate "JZ4780 EFUSE Memory Support" 96 Say Y here to include support for JZ4780 efuse memory found on 143 tristate "Amlogic Meson GX eFuse Support" 146 This is a driver to retrieve specific values from the eFuse found on 153 tristate "Amlogic Meson6/Meson8/Meson8b eFuse Support" 156 This is a driver to retrieve specific values from the eFuse found on 170 tristate "Mediatek SoCs EFUSE support" 178 will be called efuse-mtk. 232 tristate "Rockchip eFuse Support" [all …]
|
/Linux-v6.1/Documentation/devicetree/bindings/nvmem/ |
D | rockchip-efuse.yaml | 4 $id: http://devicetree.org/schemas/nvmem/rockchip-efuse.yaml# 7 title: Rockchip eFuse 18 - rockchip,rk3066a-efuse 19 - rockchip,rk3188-efuse 20 - rockchip,rk3228-efuse 21 - rockchip,rk3288-efuse 22 - rockchip,rk3328-efuse 23 - rockchip,rk3368-efuse 24 - rockchip,rk3399-efuse 27 - rockchip,rockchip-efuse [all …]
|
D | mediatek,efuse.yaml | 4 $id: http://devicetree.org/schemas/nvmem/mediatek,efuse.yaml# 7 title: MediaTek efuse 10 MediaTek's efuse is used for storing calibration data, it can be accessed 22 pattern: "^efuse@[0-9a-f]+$" 28 - mediatek,mt7622-efuse 29 - mediatek,mt7623-efuse 30 - mediatek,mt8173-efuse 31 - mediatek,mt8183-efuse 32 - mediatek,mt8186-efuse 33 - mediatek,mt8188-efuse [all …]
|
D | sc27xx-efuse.txt | 1 = Spreadtrum SC27XX PMIC eFuse device tree bindings = 5 "sprd,sc2720-efuse" 6 "sprd,sc2721-efuse" 7 "sprd,sc2723-efuse" 8 "sprd,sc2730-efuse" 9 "sprd,sc2731-efuse" 10 - reg: Specify the address offset of efuse controller. 14 Are child nodes of eFuse, bindings of which as described in 29 efuse@380 { 30 compatible = "sprd,sc2731-efuse";
|
D | amlogic-meson-mx-efuse.txt | 1 Amlogic Meson6/Meson8/Meson8b efuse 5 - "amlogic,meson6-efuse" 6 - "amlogic,meson8-efuse" 7 - "amlogic,meson8b-efuse" 8 - reg: base address and size of the efuse registers 9 - clocks: a reference to the efuse core gate clock 17 efuse: nvmem@0 { 18 compatible = "amlogic,meson8-efuse";
|
D | amlogic-efuse.txt | 1 = Amlogic Meson GX eFuse device tree bindings = 4 - compatible: should be "amlogic,meson-gxbb-efuse" 5 - clocks: phandle to the efuse peripheral clock provided by the 10 Are child nodes of eFuse, bindings of which as described in 15 efuse: efuse { 16 compatible = "amlogic,meson-gxbb-efuse";
|
D | socionext,uniphier-efuse.yaml | 4 $id: http://devicetree.org/schemas/nvmem/socionext,uniphier-efuse.yaml# 7 title: Socionext UniPhier eFuse bindings 21 const: socionext,uniphier-efuse 34 // The UniPhier eFuse should be a subnode of a "soc-glue" node. 42 efuse@100 { 43 compatible = "socionext,uniphier-efuse"; 47 efuse@200 { 48 compatible = "socionext,uniphier-efuse";
|
D | ingenic,jz4780-efuse.yaml | 4 $id: http://devicetree.org/schemas/nvmem/ingenic,jz4780-efuse.yaml# 7 title: Ingenic JZ EFUSE driver bindings 18 - ingenic,jz4780-efuse 24 # Handle for the ahb for the efuse. 38 efuse@134100d0 { 39 compatible = "ingenic,jz4780-efuse";
|
D | sprd-efuse.txt | 1 = Spreadtrum eFuse device tree bindings = 4 - compatible: Should be "sprd,ums312-efuse". 5 - reg: Specify the address offset of efuse controller. 11 Are child nodes of eFuse, bindings of which as described in 16 ap_efuse: efuse@32240000 { 17 compatible = "sprd,ums312-efuse";
|
/Linux-v6.1/Documentation/devicetree/bindings/fuse/ |
D | nvidia,tegra20-fuse.yaml | 17 - nvidia,tegra20-efuse 18 - nvidia,tegra30-efuse 19 - nvidia,tegra114-efuse 20 - nvidia,tegra124-efuse 21 - nvidia,tegra210-efuse 22 - nvidia,tegra186-efuse 23 - nvidia,tegra194-efuse 24 - nvidia,tegra234-efuse 27 - const: nvidia,tegra132-efuse 28 - const: nvidia,tegra124-efuse [all …]
|
/Linux-v6.1/Documentation/devicetree/bindings/regulator/ |
D | ti-abb-regulator.txt | 35 efuse: (see Optional properties) 36 RBB enable efuse Mask: (See Optional properties) 37 FBB enable efuse Mask: (See Optional properties) 38 Vset value efuse Mask: (See Optional properties) 47 - "efuse-address" - Contains efuse base address used to pick up ABB info. 49 "efuse-address" is required for this. 55 efuse: Mandatory if 'efuse-address' register is defined. Provides offset 56 from efuse-address to pick up ABB characteristics. Set to 0 if 57 'efuse-address' is not defined. 58 RBB enable efuse Mask: Optional if 'efuse-address' register is defined. [all …]
|
/Linux-v6.1/drivers/phy/mediatek/ |
D | phy-mtk-pcie.c | 36 * struct mtk_pcie_lane_efuse - eFuse data for each lane 40 * @lane_efuse_supported: software eFuse data is supported for this lane 52 * @sw_efuse_supported: support software to load eFuse data 65 * @sw_efuse_en: software eFuse enable status 67 * @efuse: pointer to eFuse data for each lane 77 struct mtk_pcie_lane_efuse *efuse; member 83 struct mtk_pcie_lane_efuse *data = &pcie_phy->efuse[lane]; in mtk_pcie_efuse_set_lane() 106 * Initialize the phy by setting the efuse data. 136 struct mtk_pcie_lane_efuse *efuse = &pcie_phy->efuse[lane]; in mtk_pcie_efuse_read_for_lane() local 142 ret = nvmem_cell_read_variable_le_u32(dev, efuse_id, &efuse->tx_pmos); in mtk_pcie_efuse_read_for_lane() [all …]
|
/Linux-v6.1/drivers/cpufreq/ |
D | ti-cpufreq.c | 49 unsigned long efuse); 66 unsigned long efuse) in amx3_efuse_xlate() argument 68 if (!efuse) in amx3_efuse_xlate() 69 efuse = opp_data->soc_data->efuse_fallback; in amx3_efuse_xlate() 71 return ~efuse; in amx3_efuse_xlate() 75 unsigned long efuse) in dra7_efuse_xlate() argument 80 * The efuse on dra7 and am57 parts contains a specific in dra7_efuse_xlate() 84 switch (efuse) { in dra7_efuse_xlate() 101 unsigned long efuse) in omap3_efuse_xlate() argument 104 return BIT(efuse); in omap3_efuse_xlate() [all …]
|
/Linux-v6.1/drivers/net/wireless/realtek/rtw88/ |
D | efuse.c | 8 #include "efuse.h" 31 /* efuse header format 43 u32 physical_size = rtwdev->efuse.physical_size; in rtw_dump_logical_efuse_map() 44 u32 protect_size = rtwdev->efuse.protect_size; in rtw_dump_logical_efuse_map() 45 u32 logical_size = rtwdev->efuse.logical_size; in rtw_dump_logical_efuse_map() 90 u32 size = rtwdev->efuse.physical_size; in rtw_dump_physical_efuse_map() 149 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw_parse_efuse_map() local 150 u32 phy_size = efuse->physical_size; in rtw_parse_efuse_map() 151 u32 log_size = efuse->logical_size; in rtw_parse_efuse_map() 165 rtw_err(rtwdev, "failed to dump efuse physical map\n"); in rtw_parse_efuse_map() [all …]
|
D | main.c | 16 #include "efuse.h" 939 WARN(1, "invalid hw configuration from efuse\n"); in rtw_hw_config_rf_ant_num() 1153 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw_update_sta_info() local 1183 if (efuse->hw_cap.nss == 1 || rtwdev->hal.txrx_1ss) in rtw_update_sta_info() 1361 wifi_only = !rtwdev->efuse.btcoex; in rtw_power_on() 1502 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw_init_ht_cap() local 1515 if (efuse->hw_cap.bw & BIT(RTW_CHANNEL_WIDTH_40)) in rtw_init_ht_cap() 1522 if (efuse->hw_cap.nss > 1) { in rtw_init_ht_cap() 1538 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw_init_vht_cap() local 1542 if (efuse->hw_cap.ptcl != EFUSE_HW_CAP_IGNORE && in rtw_init_vht_cap() [all …]
|
/Linux-v6.1/drivers/net/wireless/realtek/rtl8xxxu/ |
D | rtl8xxxu_8723a.c | 134 struct rtl8723au_efuse *efuse = &priv->efuse_wifi.efuse8723; in rtl8723au_parse_efuse() local 136 if (efuse->rtl_id != cpu_to_le16(0x8129)) in rtl8723au_parse_efuse() 139 ether_addr_copy(priv->mac_addr, efuse->mac_addr); in rtl8723au_parse_efuse() 142 efuse->cck_tx_power_index_A, in rtl8723au_parse_efuse() 143 sizeof(efuse->cck_tx_power_index_A)); in rtl8723au_parse_efuse() 145 efuse->cck_tx_power_index_B, in rtl8723au_parse_efuse() 146 sizeof(efuse->cck_tx_power_index_B)); in rtl8723au_parse_efuse() 149 efuse->ht40_1s_tx_power_index_A, in rtl8723au_parse_efuse() 150 sizeof(efuse->ht40_1s_tx_power_index_A)); in rtl8723au_parse_efuse() 152 efuse->ht40_1s_tx_power_index_B, in rtl8723au_parse_efuse() [all …]
|
/Linux-v6.1/Documentation/devicetree/bindings/opp/ |
D | ti-omap5-opp-supply.txt | 3 OMAP5, DRA7, and AM57 family of SoCs have Class0 AVS eFuse registers which 26 "ti,omap5-opp-supply" - OMAP5+ optimized voltages in efuse(class0)VDD 28 "ti,omap5-core-opp-supply" - OMAP5+ optimized voltages in efuse(class0) VDD 30 - reg: Address and length of the efuse register set for the device (mandatory 32 - ti,efuse-settings: An array of u32 tuple items providing information about 33 optimized efuse configuration. Each item consists of the following: 35 efuse_offseet: efuse offset from reg where the optimized voltage is stored. 56 ti,efuse-settings = <
|
/Linux-v6.1/drivers/net/wireless/mediatek/mt76/mt7603/ |
D | eeprom.c | 67 mt7603_has_cal_free_data(struct mt7603_dev *dev, u8 *efuse) in mt7603_has_cal_free_data() argument 69 if (!efuse[MT_EE_TEMP_SENSOR_CAL]) in mt7603_has_cal_free_data() 72 if (get_unaligned_le16(efuse + MT_EE_TX_POWER_0_START_2G) == 0) in mt7603_has_cal_free_data() 75 if (get_unaligned_le16(efuse + MT_EE_TX_POWER_1_START_2G) == 0) in mt7603_has_cal_free_data() 78 if (!efuse[MT_EE_CP_FT_VERSION]) in mt7603_has_cal_free_data() 81 if (!efuse[MT_EE_XTAL_FREQ_OFFSET]) in mt7603_has_cal_free_data() 84 if (!efuse[MT_EE_XTAL_WF_RFCAL]) in mt7603_has_cal_free_data() 91 mt7603_apply_cal_free_data(struct mt7603_dev *dev, u8 *efuse) in mt7603_apply_cal_free_data() argument 112 if (!mt7603_has_cal_free_data(dev, efuse)) in mt7603_apply_cal_free_data() 121 eeprom[offset] = efuse[offset]; in mt7603_apply_cal_free_data()
|
/Linux-v6.1/drivers/net/wireless/mediatek/mt76/mt76x2/ |
D | eeprom.c | 24 mt76x2_has_cal_free_data(struct mt76x02_dev *dev, u8 *efuse) in mt76x2_has_cal_free_data() argument 26 u16 *efuse_w = (u16 *)efuse; in mt76x2_has_cal_free_data() 50 mt76x2_apply_cal_free_data(struct mt76x02_dev *dev, u8 *efuse) in mt76x2_apply_cal_free_data() argument 94 if (!mt76x2_has_cal_free_data(dev, efuse)) in mt76x2_apply_cal_free_data() 100 eeprom[offset] = efuse[offset]; in mt76x2_apply_cal_free_data() 103 if (!(efuse[MT_EE_TX_POWER_0_START_5G] | in mt76x2_apply_cal_free_data() 104 efuse[MT_EE_TX_POWER_0_START_5G + 1])) in mt76x2_apply_cal_free_data() 106 if (!(efuse[MT_EE_TX_POWER_1_START_5G] | in mt76x2_apply_cal_free_data() 107 efuse[MT_EE_TX_POWER_1_START_5G + 1])) in mt76x2_apply_cal_free_data() 110 val = get_unaligned_le16(efuse + MT_EE_BT_RCAL_RESULT); in mt76x2_apply_cal_free_data() [all …]
|