Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

nvmem: qfprom: Add support for fuse blowing on sc7280

Handle the differences across LDO voltage needed for blowing fuses,
and the blow timer value, identified using a minor version of 15
on sc7280.

Signed-off-by: Rajendra Nayak <rnayak@codeaurora.org>
Signed-off-by: Ravi Kumar Bokka <rbokka@codeaurora.org>
Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
Link: https://lore.kernel.org/r/20210330111241.19401-11-srinivas.kandagatla@linaro.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

authored by

Rajendra Nayak and committed by
Greg Kroah-Hartman
5a1bea2a b1f20fd0

+25 -2
+25 -2
drivers/nvmem/qfprom.c
··· 45 45 * @qfprom_blow_timer_value: The timer value of qfprom when doing efuse blow. 46 46 * @qfprom_blow_set_freq: The frequency required to set when we start the 47 47 * fuse blowing. 48 + * @qfprom_blow_uV: LDO voltage to be set when doing efuse blow 48 49 */ 49 50 struct qfprom_soc_data { 50 51 u32 accel_value; 51 52 u32 qfprom_blow_timer_value; 52 53 u32 qfprom_blow_set_freq; 54 + int qfprom_blow_uV; 53 55 }; 54 56 55 57 /** ··· 113 111 .nkeepout = ARRAY_SIZE(sc7180_qfprom_keepout) 114 112 }; 115 113 114 + static const struct nvmem_keepout sc7280_qfprom_keepout[] = { 115 + {.start = 0x128, .end = 0x148}, 116 + {.start = 0x238, .end = 0x248} 117 + }; 118 + 119 + static const struct qfprom_soc_compatible_data sc7280_qfprom = { 120 + .keepout = sc7280_qfprom_keepout, 121 + .nkeepout = ARRAY_SIZE(sc7280_qfprom_keepout) 122 + }; 116 123 /** 117 124 * qfprom_disable_fuse_blowing() - Undo enabling of fuse blowing. 118 125 * @priv: Our driver data. ··· 179 168 struct qfprom_touched_values *old) 180 169 { 181 170 int ret; 171 + int qfprom_blow_uV = priv->soc_data->qfprom_blow_uV; 182 172 183 173 ret = clk_prepare_enable(priv->secclk); 184 174 if (ret) { ··· 199 187 * a rail shared do don't specify a max--regulator constraints 200 188 * will handle. 201 189 */ 202 - ret = regulator_set_voltage(priv->vcc, 1800000, INT_MAX); 190 + ret = regulator_set_voltage(priv->vcc, qfprom_blow_uV, INT_MAX); 203 191 if (ret) { 204 - dev_err(priv->dev, "Failed to set 1.8 voltage\n"); 192 + dev_err(priv->dev, "Failed to set %duV\n", qfprom_blow_uV); 205 193 goto err_clk_rate_set; 206 194 } 207 195 ··· 323 311 .accel_value = 0xD10, 324 312 .qfprom_blow_timer_value = 25, 325 313 .qfprom_blow_set_freq = 4800000, 314 + .qfprom_blow_uV = 1800000, 315 + }; 316 + 317 + static const struct qfprom_soc_data qfprom_7_15_data = { 318 + .accel_value = 0xD08, 319 + .qfprom_blow_timer_value = 24, 320 + .qfprom_blow_set_freq = 4800000, 321 + .qfprom_blow_uV = 1900000, 326 322 }; 327 323 328 324 static int qfprom_probe(struct platform_device *pdev) ··· 399 379 400 380 if (major_version == 7 && minor_version == 8) 401 381 priv->soc_data = &qfprom_7_8_data; 382 + if (major_version == 7 && minor_version == 15) 383 + priv->soc_data = &qfprom_7_15_data; 402 384 403 385 priv->vcc = devm_regulator_get(&pdev->dev, "vcc"); 404 386 if (IS_ERR(priv->vcc)) ··· 427 405 static const struct of_device_id qfprom_of_match[] = { 428 406 { .compatible = "qcom,qfprom",}, 429 407 { .compatible = "qcom,sc7180-qfprom", .data = &sc7180_qfprom}, 408 + { .compatible = "qcom,sc7280-qfprom", .data = &sc7280_qfprom}, 430 409 {/* sentinel */}, 431 410 }; 432 411 MODULE_DEVICE_TABLE(of, qfprom_of_match);