diff options
Diffstat (limited to 'drivers/regulator/palmas-regulator.c')
-rw-r--r-- | drivers/regulator/palmas-regulator.c | 248 |
1 files changed, 112 insertions, 136 deletions
diff --git a/drivers/regulator/palmas-regulator.c b/drivers/regulator/palmas-regulator.c index d6b734f397dc..ae0f639096fb 100644 --- a/drivers/regulator/palmas-regulator.c +++ b/drivers/regulator/palmas-regulator.c | |||
@@ -866,6 +866,7 @@ static int palmas_ldo_registration(struct palmas_pmic *pmic, | |||
866 | struct regulator_dev *rdev; | 866 | struct regulator_dev *rdev; |
867 | struct palmas_reg_init *reg_init; | 867 | struct palmas_reg_init *reg_init; |
868 | struct palmas_regs_info *rinfo; | 868 | struct palmas_regs_info *rinfo; |
869 | struct regulator_desc *desc; | ||
869 | 870 | ||
870 | for (id = ddata->ldo_begin; id < ddata->max_reg; id++) { | 871 | for (id = ddata->ldo_begin; id < ddata->max_reg; id++) { |
871 | if (pdata && pdata->reg_init[id]) | 872 | if (pdata && pdata->reg_init[id]) |
@@ -879,57 +880,51 @@ static int palmas_ldo_registration(struct palmas_pmic *pmic, | |||
879 | */ | 880 | */ |
880 | 881 | ||
881 | /* Register the regulators */ | 882 | /* Register the regulators */ |
882 | pmic->desc[id].name = rinfo->name; | 883 | desc = &pmic->desc[id]; |
883 | pmic->desc[id].id = id; | 884 | desc->name = rinfo->name; |
884 | pmic->desc[id].type = REGULATOR_VOLTAGE; | 885 | desc->id = id; |
885 | pmic->desc[id].owner = THIS_MODULE; | 886 | desc->type = REGULATOR_VOLTAGE; |
887 | desc->owner = THIS_MODULE; | ||
886 | 888 | ||
887 | if (id < PALMAS_REG_REGEN1) { | 889 | if (id < PALMAS_REG_REGEN1) { |
888 | pmic->desc[id].n_voltages = PALMAS_LDO_NUM_VOLTAGES; | 890 | desc->n_voltages = PALMAS_LDO_NUM_VOLTAGES; |
889 | if (reg_init && reg_init->roof_floor) | 891 | if (reg_init && reg_init->roof_floor) |
890 | pmic->desc[id].ops = | 892 | desc->ops = &palmas_ops_ext_control_ldo; |
891 | &palmas_ops_ext_control_ldo; | ||
892 | else | 893 | else |
893 | pmic->desc[id].ops = &palmas_ops_ldo; | 894 | desc->ops = &palmas_ops_ldo; |
894 | pmic->desc[id].min_uV = 900000; | 895 | desc->min_uV = 900000; |
895 | pmic->desc[id].uV_step = 50000; | 896 | desc->uV_step = 50000; |
896 | pmic->desc[id].linear_min_sel = 1; | 897 | desc->linear_min_sel = 1; |
897 | pmic->desc[id].enable_time = 500; | 898 | desc->enable_time = 500; |
898 | pmic->desc[id].vsel_reg = | 899 | desc->vsel_reg = PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, |
899 | PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, | 900 | rinfo->vsel_addr); |
900 | rinfo->vsel_addr); | 901 | desc->vsel_mask = PALMAS_LDO1_VOLTAGE_VSEL_MASK; |
901 | pmic->desc[id].vsel_mask = | 902 | desc->enable_reg = PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, |
902 | PALMAS_LDO1_VOLTAGE_VSEL_MASK; | 903 | rinfo->ctrl_addr); |
903 | pmic->desc[id].enable_reg = | 904 | desc->enable_mask = PALMAS_LDO1_CTRL_MODE_ACTIVE; |
904 | PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, | ||
905 | rinfo->ctrl_addr); | ||
906 | pmic->desc[id].enable_mask = | ||
907 | PALMAS_LDO1_CTRL_MODE_ACTIVE; | ||
908 | 905 | ||
909 | /* Check if LDO8 is in tracking mode or not */ | 906 | /* Check if LDO8 is in tracking mode or not */ |
910 | if (pdata && (id == PALMAS_REG_LDO8) && | 907 | if (pdata && (id == PALMAS_REG_LDO8) && |
911 | pdata->enable_ldo8_tracking) { | 908 | pdata->enable_ldo8_tracking) { |
912 | palmas_enable_ldo8_track(pmic->palmas); | 909 | palmas_enable_ldo8_track(pmic->palmas); |
913 | pmic->desc[id].min_uV = 450000; | 910 | desc->min_uV = 450000; |
914 | pmic->desc[id].uV_step = 25000; | 911 | desc->uV_step = 25000; |
915 | } | 912 | } |
916 | 913 | ||
917 | /* LOD6 in vibrator mode will have enable time 2000us */ | 914 | /* LOD6 in vibrator mode will have enable time 2000us */ |
918 | if (pdata && pdata->ldo6_vibrator && | 915 | if (pdata && pdata->ldo6_vibrator && |
919 | (id == PALMAS_REG_LDO6)) | 916 | (id == PALMAS_REG_LDO6)) |
920 | pmic->desc[id].enable_time = 2000; | 917 | desc->enable_time = 2000; |
921 | } else { | 918 | } else { |
922 | pmic->desc[id].n_voltages = 1; | 919 | desc->n_voltages = 1; |
923 | if (reg_init && reg_init->roof_floor) | 920 | if (reg_init && reg_init->roof_floor) |
924 | pmic->desc[id].ops = | 921 | desc->ops = &palmas_ops_ext_control_extreg; |
925 | &palmas_ops_ext_control_extreg; | ||
926 | else | 922 | else |
927 | pmic->desc[id].ops = &palmas_ops_extreg; | 923 | desc->ops = &palmas_ops_extreg; |
928 | pmic->desc[id].enable_reg = | 924 | desc->enable_reg = |
929 | PALMAS_BASE_TO_REG(PALMAS_RESOURCE_BASE, | 925 | PALMAS_BASE_TO_REG(PALMAS_RESOURCE_BASE, |
930 | rinfo->ctrl_addr); | 926 | rinfo->ctrl_addr); |
931 | pmic->desc[id].enable_mask = | 927 | desc->enable_mask = PALMAS_REGEN1_CTRL_MODE_ACTIVE; |
932 | PALMAS_REGEN1_CTRL_MODE_ACTIVE; | ||
933 | } | 928 | } |
934 | 929 | ||
935 | if (pdata) | 930 | if (pdata) |
@@ -937,11 +932,10 @@ static int palmas_ldo_registration(struct palmas_pmic *pmic, | |||
937 | else | 932 | else |
938 | config.init_data = NULL; | 933 | config.init_data = NULL; |
939 | 934 | ||
940 | pmic->desc[id].supply_name = rinfo->sname; | 935 | desc->supply_name = rinfo->sname; |
941 | config.of_node = ddata->palmas_matches[id].of_node; | 936 | config.of_node = ddata->palmas_matches[id].of_node; |
942 | 937 | ||
943 | rdev = devm_regulator_register(pmic->dev, &pmic->desc[id], | 938 | rdev = devm_regulator_register(pmic->dev, desc, &config); |
944 | &config); | ||
945 | if (IS_ERR(rdev)) { | 939 | if (IS_ERR(rdev)) { |
946 | dev_err(pmic->dev, | 940 | dev_err(pmic->dev, |
947 | "failed to register %s regulator\n", | 941 | "failed to register %s regulator\n", |
@@ -981,6 +975,7 @@ static int tps65917_ldo_registration(struct palmas_pmic *pmic, | |||
981 | struct regulator_dev *rdev; | 975 | struct regulator_dev *rdev; |
982 | struct palmas_reg_init *reg_init; | 976 | struct palmas_reg_init *reg_init; |
983 | struct palmas_regs_info *rinfo; | 977 | struct palmas_regs_info *rinfo; |
978 | struct regulator_desc *desc; | ||
984 | 979 | ||
985 | for (id = ddata->ldo_begin; id < ddata->max_reg; id++) { | 980 | for (id = ddata->ldo_begin; id < ddata->max_reg; id++) { |
986 | if (pdata && pdata->reg_init[id]) | 981 | if (pdata && pdata->reg_init[id]) |
@@ -994,49 +989,43 @@ static int tps65917_ldo_registration(struct palmas_pmic *pmic, | |||
994 | rinfo = &ddata->palmas_regs_info[id]; | 989 | rinfo = &ddata->palmas_regs_info[id]; |
995 | 990 | ||
996 | /* Register the regulators */ | 991 | /* Register the regulators */ |
997 | pmic->desc[id].name = rinfo->name; | 992 | desc = &pmic->desc[id]; |
998 | pmic->desc[id].id = id; | 993 | desc->name = rinfo->name; |
999 | pmic->desc[id].type = REGULATOR_VOLTAGE; | 994 | desc->id = id; |
1000 | pmic->desc[id].owner = THIS_MODULE; | 995 | desc->type = REGULATOR_VOLTAGE; |
996 | desc->owner = THIS_MODULE; | ||
1001 | 997 | ||
1002 | if (id < TPS65917_REG_REGEN1) { | 998 | if (id < TPS65917_REG_REGEN1) { |
1003 | pmic->desc[id].n_voltages = PALMAS_LDO_NUM_VOLTAGES; | 999 | desc->n_voltages = PALMAS_LDO_NUM_VOLTAGES; |
1004 | if (reg_init && reg_init->roof_floor) | 1000 | if (reg_init && reg_init->roof_floor) |
1005 | pmic->desc[id].ops = | 1001 | desc->ops = &palmas_ops_ext_control_ldo; |
1006 | &palmas_ops_ext_control_ldo; | ||
1007 | else | 1002 | else |
1008 | pmic->desc[id].ops = &tps65917_ops_ldo; | 1003 | desc->ops = &tps65917_ops_ldo; |
1009 | pmic->desc[id].min_uV = 900000; | 1004 | desc->min_uV = 900000; |
1010 | pmic->desc[id].uV_step = 50000; | 1005 | desc->uV_step = 50000; |
1011 | pmic->desc[id].linear_min_sel = 1; | 1006 | desc->linear_min_sel = 1; |
1012 | pmic->desc[id].enable_time = 500; | 1007 | desc->enable_time = 500; |
1013 | pmic->desc[id].vsel_reg = | 1008 | desc->vsel_reg = PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, |
1014 | PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, | 1009 | rinfo->vsel_addr); |
1015 | rinfo->vsel_addr); | 1010 | desc->vsel_mask = PALMAS_LDO1_VOLTAGE_VSEL_MASK; |
1016 | pmic->desc[id].vsel_mask = | 1011 | desc->enable_reg = PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, |
1017 | PALMAS_LDO1_VOLTAGE_VSEL_MASK; | 1012 | rinfo->ctrl_addr); |
1018 | pmic->desc[id].enable_reg = | 1013 | desc->enable_mask = PALMAS_LDO1_CTRL_MODE_ACTIVE; |
1019 | PALMAS_BASE_TO_REG(PALMAS_LDO_BASE, | ||
1020 | rinfo->ctrl_addr); | ||
1021 | pmic->desc[id].enable_mask = | ||
1022 | PALMAS_LDO1_CTRL_MODE_ACTIVE; | ||
1023 | /* | 1014 | /* |
1024 | * To be confirmed. Discussion on going with PMIC Team. | 1015 | * To be confirmed. Discussion on going with PMIC Team. |
1025 | * It is of the order of ~60mV/uS. | 1016 | * It is of the order of ~60mV/uS. |
1026 | */ | 1017 | */ |
1027 | pmic->desc[id].ramp_delay = 2500; | 1018 | desc->ramp_delay = 2500; |
1028 | } else { | 1019 | } else { |
1029 | pmic->desc[id].n_voltages = 1; | 1020 | desc->n_voltages = 1; |
1030 | if (reg_init && reg_init->roof_floor) | 1021 | if (reg_init && reg_init->roof_floor) |
1031 | pmic->desc[id].ops = | 1022 | desc->ops = &palmas_ops_ext_control_extreg; |
1032 | &palmas_ops_ext_control_extreg; | ||
1033 | else | 1023 | else |
1034 | pmic->desc[id].ops = &palmas_ops_extreg; | 1024 | desc->ops = &palmas_ops_extreg; |
1035 | pmic->desc[id].enable_reg = | 1025 | desc->enable_reg = |
1036 | PALMAS_BASE_TO_REG(PALMAS_RESOURCE_BASE, | 1026 | PALMAS_BASE_TO_REG(PALMAS_RESOURCE_BASE, |
1037 | rinfo->ctrl_addr); | 1027 | rinfo->ctrl_addr); |
1038 | pmic->desc[id].enable_mask = | 1028 | desc->enable_mask = PALMAS_REGEN1_CTRL_MODE_ACTIVE; |
1039 | PALMAS_REGEN1_CTRL_MODE_ACTIVE; | ||
1040 | } | 1029 | } |
1041 | 1030 | ||
1042 | if (pdata) | 1031 | if (pdata) |
@@ -1044,11 +1033,10 @@ static int tps65917_ldo_registration(struct palmas_pmic *pmic, | |||
1044 | else | 1033 | else |
1045 | config.init_data = NULL; | 1034 | config.init_data = NULL; |
1046 | 1035 | ||
1047 | pmic->desc[id].supply_name = rinfo->sname; | 1036 | desc->supply_name = rinfo->sname; |
1048 | config.of_node = ddata->palmas_matches[id].of_node; | 1037 | config.of_node = ddata->palmas_matches[id].of_node; |
1049 | 1038 | ||
1050 | rdev = devm_regulator_register(pmic->dev, &pmic->desc[id], | 1039 | rdev = devm_regulator_register(pmic->dev, desc, &config); |
1051 | &config); | ||
1052 | if (IS_ERR(rdev)) { | 1040 | if (IS_ERR(rdev)) { |
1053 | dev_err(pmic->dev, | 1041 | dev_err(pmic->dev, |
1054 | "failed to register %s regulator\n", | 1042 | "failed to register %s regulator\n", |
@@ -1089,6 +1077,7 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1089 | struct regulator_dev *rdev; | 1077 | struct regulator_dev *rdev; |
1090 | struct palmas_reg_init *reg_init; | 1078 | struct palmas_reg_init *reg_init; |
1091 | struct palmas_regs_info *rinfo; | 1079 | struct palmas_regs_info *rinfo; |
1080 | struct regulator_desc *desc; | ||
1092 | 1081 | ||
1093 | for (id = ddata->smps_start; id <= ddata->smps_end; id++) { | 1082 | for (id = ddata->smps_start; id <= ddata->smps_end; id++) { |
1094 | bool ramp_delay_support = false; | 1083 | bool ramp_delay_support = false; |
@@ -1128,6 +1117,7 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1128 | continue; | 1117 | continue; |
1129 | } | 1118 | } |
1130 | rinfo = &ddata->palmas_regs_info[id]; | 1119 | rinfo = &ddata->palmas_regs_info[id]; |
1120 | desc = &pmic->desc[id]; | ||
1131 | 1121 | ||
1132 | if ((id == PALMAS_REG_SMPS6) || (id == PALMAS_REG_SMPS8)) | 1122 | if ((id == PALMAS_REG_SMPS6) || (id == PALMAS_REG_SMPS8)) |
1133 | ramp_delay_support = true; | 1123 | ramp_delay_support = true; |
@@ -1140,9 +1130,8 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1140 | "reading TSTEP reg failed: %d\n", ret); | 1130 | "reading TSTEP reg failed: %d\n", ret); |
1141 | return ret; | 1131 | return ret; |
1142 | } | 1132 | } |
1143 | pmic->desc[id].ramp_delay = | 1133 | desc->ramp_delay = palmas_smps_ramp_delay[reg & 0x3]; |
1144 | palmas_smps_ramp_delay[reg & 0x3]; | 1134 | pmic->ramp_delay[id] = desc->ramp_delay; |
1145 | pmic->ramp_delay[id] = pmic->desc[id].ramp_delay; | ||
1146 | } | 1135 | } |
1147 | 1136 | ||
1148 | /* Initialise sleep/init values from platform data */ | 1137 | /* Initialise sleep/init values from platform data */ |
@@ -1156,31 +1145,28 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1156 | } | 1145 | } |
1157 | 1146 | ||
1158 | /* Register the regulators */ | 1147 | /* Register the regulators */ |
1159 | pmic->desc[id].name = rinfo->name; | 1148 | desc->name = rinfo->name; |
1160 | pmic->desc[id].id = id; | 1149 | desc->id = id; |
1161 | 1150 | ||
1162 | switch (id) { | 1151 | switch (id) { |
1163 | case PALMAS_REG_SMPS10_OUT1: | 1152 | case PALMAS_REG_SMPS10_OUT1: |
1164 | case PALMAS_REG_SMPS10_OUT2: | 1153 | case PALMAS_REG_SMPS10_OUT2: |
1165 | pmic->desc[id].n_voltages = PALMAS_SMPS10_NUM_VOLTAGES; | 1154 | desc->n_voltages = PALMAS_SMPS10_NUM_VOLTAGES; |
1166 | pmic->desc[id].ops = &palmas_ops_smps10; | 1155 | desc->ops = &palmas_ops_smps10; |
1167 | pmic->desc[id].vsel_reg = | 1156 | desc->vsel_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1168 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | 1157 | PALMAS_SMPS10_CTRL); |
1169 | PALMAS_SMPS10_CTRL); | 1158 | desc->vsel_mask = SMPS10_VSEL; |
1170 | pmic->desc[id].vsel_mask = SMPS10_VSEL; | 1159 | desc->enable_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1171 | pmic->desc[id].enable_reg = | 1160 | PALMAS_SMPS10_CTRL); |
1172 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | ||
1173 | PALMAS_SMPS10_CTRL); | ||
1174 | if (id == PALMAS_REG_SMPS10_OUT1) | 1161 | if (id == PALMAS_REG_SMPS10_OUT1) |
1175 | pmic->desc[id].enable_mask = SMPS10_SWITCH_EN; | 1162 | desc->enable_mask = SMPS10_SWITCH_EN; |
1176 | else | 1163 | else |
1177 | pmic->desc[id].enable_mask = SMPS10_BOOST_EN; | 1164 | desc->enable_mask = SMPS10_BOOST_EN; |
1178 | pmic->desc[id].bypass_reg = | 1165 | desc->bypass_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1179 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | 1166 | PALMAS_SMPS10_CTRL); |
1180 | PALMAS_SMPS10_CTRL); | 1167 | desc->bypass_mask = SMPS10_BYPASS_EN; |
1181 | pmic->desc[id].bypass_mask = SMPS10_BYPASS_EN; | 1168 | desc->min_uV = 3750000; |
1182 | pmic->desc[id].min_uV = 3750000; | 1169 | desc->uV_step = 1250000; |
1183 | pmic->desc[id].uV_step = 1250000; | ||
1184 | break; | 1170 | break; |
1185 | default: | 1171 | default: |
1186 | /* | 1172 | /* |
@@ -1190,7 +1176,7 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1190 | * ranges. Read the current smps mode for later use. | 1176 | * ranges. Read the current smps mode for later use. |
1191 | */ | 1177 | */ |
1192 | addr = rinfo->vsel_addr; | 1178 | addr = rinfo->vsel_addr; |
1193 | pmic->desc[id].n_linear_ranges = 3; | 1179 | desc->n_linear_ranges = 3; |
1194 | 1180 | ||
1195 | ret = palmas_smps_read(pmic->palmas, addr, ®); | 1181 | ret = palmas_smps_read(pmic->palmas, addr, ®); |
1196 | if (ret) | 1182 | if (ret) |
@@ -1198,21 +1184,18 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1198 | if (reg & PALMAS_SMPS12_VOLTAGE_RANGE) | 1184 | if (reg & PALMAS_SMPS12_VOLTAGE_RANGE) |
1199 | pmic->range[id] = 1; | 1185 | pmic->range[id] = 1; |
1200 | if (pmic->range[id]) | 1186 | if (pmic->range[id]) |
1201 | pmic->desc[id].linear_ranges = smps_high_ranges; | 1187 | desc->linear_ranges = smps_high_ranges; |
1202 | else | 1188 | else |
1203 | pmic->desc[id].linear_ranges = smps_low_ranges; | 1189 | desc->linear_ranges = smps_low_ranges; |
1204 | 1190 | ||
1205 | if (reg_init && reg_init->roof_floor) | 1191 | if (reg_init && reg_init->roof_floor) |
1206 | pmic->desc[id].ops = | 1192 | desc->ops = &palmas_ops_ext_control_smps; |
1207 | &palmas_ops_ext_control_smps; | ||
1208 | else | 1193 | else |
1209 | pmic->desc[id].ops = &palmas_ops_smps; | 1194 | desc->ops = &palmas_ops_smps; |
1210 | pmic->desc[id].n_voltages = PALMAS_SMPS_NUM_VOLTAGES; | 1195 | desc->n_voltages = PALMAS_SMPS_NUM_VOLTAGES; |
1211 | pmic->desc[id].vsel_reg = | 1196 | desc->vsel_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1212 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | 1197 | rinfo->vsel_addr); |
1213 | rinfo->vsel_addr); | 1198 | desc->vsel_mask = PALMAS_SMPS12_VOLTAGE_VSEL_MASK; |
1214 | pmic->desc[id].vsel_mask = | ||
1215 | PALMAS_SMPS12_VOLTAGE_VSEL_MASK; | ||
1216 | 1199 | ||
1217 | /* Read the smps mode for later use. */ | 1200 | /* Read the smps mode for later use. */ |
1218 | addr = rinfo->ctrl_addr; | 1201 | addr = rinfo->ctrl_addr; |
@@ -1222,28 +1205,25 @@ static int palmas_smps_registration(struct palmas_pmic *pmic, | |||
1222 | pmic->current_reg_mode[id] = reg & | 1205 | pmic->current_reg_mode[id] = reg & |
1223 | PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; | 1206 | PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; |
1224 | 1207 | ||
1225 | pmic->desc[id].enable_reg = | 1208 | desc->enable_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1226 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | 1209 | rinfo->ctrl_addr); |
1227 | rinfo->ctrl_addr); | 1210 | desc->enable_mask = PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; |
1228 | pmic->desc[id].enable_mask = | ||
1229 | PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; | ||
1230 | /* set_mode overrides this value */ | 1211 | /* set_mode overrides this value */ |
1231 | pmic->desc[id].enable_val = SMPS_CTRL_MODE_ON; | 1212 | desc->enable_val = SMPS_CTRL_MODE_ON; |
1232 | } | 1213 | } |
1233 | 1214 | ||
1234 | pmic->desc[id].type = REGULATOR_VOLTAGE; | 1215 | desc->type = REGULATOR_VOLTAGE; |
1235 | pmic->desc[id].owner = THIS_MODULE; | 1216 | desc->owner = THIS_MODULE; |
1236 | 1217 | ||
1237 | if (pdata) | 1218 | if (pdata) |
1238 | config.init_data = pdata->reg_data[id]; | 1219 | config.init_data = pdata->reg_data[id]; |
1239 | else | 1220 | else |
1240 | config.init_data = NULL; | 1221 | config.init_data = NULL; |
1241 | 1222 | ||
1242 | pmic->desc[id].supply_name = rinfo->sname; | 1223 | desc->supply_name = rinfo->sname; |
1243 | config.of_node = ddata->palmas_matches[id].of_node; | 1224 | config.of_node = ddata->palmas_matches[id].of_node; |
1244 | 1225 | ||
1245 | rdev = devm_regulator_register(pmic->dev, &pmic->desc[id], | 1226 | rdev = devm_regulator_register(pmic->dev, desc, &config); |
1246 | &config); | ||
1247 | if (IS_ERR(rdev)) { | 1227 | if (IS_ERR(rdev)) { |
1248 | dev_err(pmic->dev, | 1228 | dev_err(pmic->dev, |
1249 | "failed to register %s regulator\n", | 1229 | "failed to register %s regulator\n", |
@@ -1269,13 +1249,15 @@ static int tps65917_smps_registration(struct palmas_pmic *pmic, | |||
1269 | struct regulator_dev *rdev; | 1249 | struct regulator_dev *rdev; |
1270 | struct palmas_reg_init *reg_init; | 1250 | struct palmas_reg_init *reg_init; |
1271 | struct palmas_regs_info *rinfo; | 1251 | struct palmas_regs_info *rinfo; |
1252 | struct regulator_desc *desc; | ||
1272 | 1253 | ||
1273 | for (id = ddata->smps_start; id <= ddata->smps_end; id++) { | 1254 | for (id = ddata->smps_start; id <= ddata->smps_end; id++) { |
1274 | /* | 1255 | /* |
1275 | * Miss out regulators which are not available due | 1256 | * Miss out regulators which are not available due |
1276 | * to slaving configurations. | 1257 | * to slaving configurations. |
1277 | */ | 1258 | */ |
1278 | pmic->desc[id].n_linear_ranges = 3; | 1259 | desc = &pmic->desc[id]; |
1260 | desc->n_linear_ranges = 3; | ||
1279 | if ((id == TPS65917_REG_SMPS2) && pmic->smps12) | 1261 | if ((id == TPS65917_REG_SMPS2) && pmic->smps12) |
1280 | continue; | 1262 | continue; |
1281 | 1263 | ||
@@ -1291,8 +1273,8 @@ static int tps65917_smps_registration(struct palmas_pmic *pmic, | |||
1291 | rinfo = &ddata->palmas_regs_info[id]; | 1273 | rinfo = &ddata->palmas_regs_info[id]; |
1292 | 1274 | ||
1293 | /* Register the regulators */ | 1275 | /* Register the regulators */ |
1294 | pmic->desc[id].name = rinfo->name; | 1276 | desc->name = rinfo->name; |
1295 | pmic->desc[id].id = id; | 1277 | desc->id = id; |
1296 | 1278 | ||
1297 | /* | 1279 | /* |
1298 | * Read and store the RANGE bit for later use | 1280 | * Read and store the RANGE bit for later use |
@@ -1309,24 +1291,19 @@ static int tps65917_smps_registration(struct palmas_pmic *pmic, | |||
1309 | pmic->range[id] = 1; | 1291 | pmic->range[id] = 1; |
1310 | 1292 | ||
1311 | if (pmic->range[id]) | 1293 | if (pmic->range[id]) |
1312 | pmic->desc[id].linear_ranges = smps_high_ranges; | 1294 | desc->linear_ranges = smps_high_ranges; |
1313 | else | 1295 | else |
1314 | pmic->desc[id].linear_ranges = smps_low_ranges; | 1296 | desc->linear_ranges = smps_low_ranges; |
1315 | |||
1316 | 1297 | ||
1317 | if (reg_init && reg_init->roof_floor) | 1298 | if (reg_init && reg_init->roof_floor) |
1318 | pmic->desc[id].ops = | 1299 | desc->ops = &tps65917_ops_ext_control_smps; |
1319 | &tps65917_ops_ext_control_smps; | ||
1320 | else | 1300 | else |
1321 | pmic->desc[id].ops = &tps65917_ops_smps; | 1301 | desc->ops = &tps65917_ops_smps; |
1322 | pmic->desc[id].n_voltages = PALMAS_SMPS_NUM_VOLTAGES; | 1302 | desc->n_voltages = PALMAS_SMPS_NUM_VOLTAGES; |
1323 | pmic->desc[id].vsel_reg = | 1303 | desc->vsel_reg = PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, |
1324 | PALMAS_BASE_TO_REG(PALMAS_SMPS_BASE, | 1304 | rinfo->vsel_addr); |
1325 | rinfo->vsel_addr); | 1305 | desc->vsel_mask = PALMAS_SMPS12_VOLTAGE_VSEL_MASK; |
1326 | pmic->desc[id].vsel_mask = | 1306 | desc->ramp_delay = 2500; |
1327 | PALMAS_SMPS12_VOLTAGE_VSEL_MASK; | ||
1328 | |||
1329 | pmic->desc[id].ramp_delay = 2500; | ||
1330 | 1307 | ||
1331 | /* Read the smps mode for later use. */ | 1308 | /* Read the smps mode for later use. */ |
1332 | addr = rinfo->ctrl_addr; | 1309 | addr = rinfo->ctrl_addr; |
@@ -1336,19 +1313,18 @@ static int tps65917_smps_registration(struct palmas_pmic *pmic, | |||
1336 | pmic->current_reg_mode[id] = reg & | 1313 | pmic->current_reg_mode[id] = reg & |
1337 | PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; | 1314 | PALMAS_SMPS12_CTRL_MODE_ACTIVE_MASK; |
1338 | 1315 | ||
1339 | pmic->desc[id].type = REGULATOR_VOLTAGE; | 1316 | desc->type = REGULATOR_VOLTAGE; |
1340 | pmic->desc[id].owner = THIS_MODULE; | 1317 | desc->owner = THIS_MODULE; |
1341 | 1318 | ||
1342 | if (pdata) | 1319 | if (pdata) |
1343 | config.init_data = pdata->reg_data[id]; | 1320 | config.init_data = pdata->reg_data[id]; |
1344 | else | 1321 | else |
1345 | config.init_data = NULL; | 1322 | config.init_data = NULL; |
1346 | 1323 | ||
1347 | pmic->desc[id].supply_name = rinfo->sname; | 1324 | desc->supply_name = rinfo->sname; |
1348 | config.of_node = ddata->palmas_matches[id].of_node; | 1325 | config.of_node = ddata->palmas_matches[id].of_node; |
1349 | 1326 | ||
1350 | rdev = devm_regulator_register(pmic->dev, &pmic->desc[id], | 1327 | rdev = devm_regulator_register(pmic->dev, desc, &config); |
1351 | &config); | ||
1352 | if (IS_ERR(rdev)) { | 1328 | if (IS_ERR(rdev)) { |
1353 | dev_err(pmic->dev, | 1329 | dev_err(pmic->dev, |
1354 | "failed to register %s regulator\n", | 1330 | "failed to register %s regulator\n", |