Lines Matching +full:data +full:- +full:ready +full:- +full:hiz
1 // SPDX-License-Identifier: GPL-2.0
23 #include <media/v4l2-ctrls.h>
24 #include <media/v4l2-device.h>
30 #define mxm_dbg(ctx, fmt, arg...) dev_dbg(&ctx->client->dev, fmt, ## arg)
31 #define mxm_err(ctx, fmt, arg...) dev_err(&ctx->client->dev, fmt, ## arg)
264 struct v4l2_subdev sd; /* Sub-device */
273 struct v4l2_ctrl *hsls; /* High-side/Low-side polarity */
288 bool am_hiz; /* AM Hi-Z filter */
321 ret = regmap_read(ctx->regmap, idx, ®val); in max2175_read()
334 ret = regmap_write(ctx->regmap, idx, val); in max2175_write()
355 int ret = regmap_update_bits(ctx->regmap, idx, GENMASK(msb, lsb), in max2175_write_bits()
375 return regmap_read_poll_timeout(ctx->regmap, idx, val, in max2175_poll_timeout()
386 mxm_err(ctx, "csm not ready\n"); in max2175_poll_csm_ready()
455 ctx->decim_ratio = 36; in max2175_load_fmeu_1p2()
470 ctx->decim_ratio = 1; in max2175_load_dab_1p2()
495 max2175_write_bits(ctx, 12, 3, 0, ctx->rom_bbf_bw_am); in max2175_set_bbfilter()
496 mxm_dbg(ctx, "set_bbfilter AM: rom %d\n", ctx->rom_bbf_bw_am); in max2175_set_bbfilter()
498 max2175_write_bits(ctx, 12, 3, 0, ctx->rom_bbf_bw_dab); in max2175_set_bbfilter()
499 mxm_dbg(ctx, "set_bbfilter DAB: rom %d\n", ctx->rom_bbf_bw_dab); in max2175_set_bbfilter()
501 max2175_write_bits(ctx, 12, 3, 0, ctx->rom_bbf_bw_fm); in max2175_set_bbfilter()
502 mxm_dbg(ctx, "set_bbfilter FM: rom %d\n", ctx->rom_bbf_bw_fm); in max2175_set_bbfilter()
593 int_desired = lo_freq / ctx->xtal_freq; in max2175_set_lo_freq()
594 frac_desired = div64_ul((u64)(lo_freq % ctx->xtal_freq) << 20, in max2175_set_lo_freq()
595 ctx->xtal_freq); in max2175_set_lo_freq()
625 return div_s64(dividend - divisor / 2, divisor); in max2175_round_closest()
630 s32 clock_rate = ctx->xtal_freq / ctx->decim_ratio; in max2175_set_nco_freq()
638 nco_val_desired = 2LL * (clock_rate - abs_nco_freq); in max2175_set_nco_freq()
640 nco_val_desired = -nco_val_desired; in max2175_set_nco_freq()
682 adj_freq = freq - low_if_freq; in max2175_set_rf_freq_non_am_bands()
688 return max2175_set_nco_freq(ctx, -low_if_freq); in max2175_set_rf_freq_non_am_bands()
717 mxm_dbg(ctx, "tune_rf_freq: old %u new %llu\n", ctx->freq, freq); in max2175_tune_rf_freq()
718 ctx->freq = freq; in max2175_tune_rf_freq()
745 if (!ctx->master) in max2175_set_eu_rx_mode()
760 if (!ctx->master) in max2175_set_na_rx_mode()
763 ctx->decim_ratio = 27; in max2175_set_na_rx_mode()
773 mxm_dbg(ctx, "set_rx_mode: %u am_hiz %u\n", rx_mode, ctx->am_hiz); in max2175_set_rx_mode()
774 if (ctx->xtal_freq == MAX2175_EU_XTAL_FREQ) in max2175_set_rx_mode()
779 if (ctx->am_hiz) { in max2175_set_rx_mode()
780 mxm_dbg(ctx, "setting AM HiZ related config\n"); in max2175_set_rx_mode()
791 max2175_set_hsls(ctx, ctx->hsls->cur.val); in max2175_set_rx_mode()
794 max2175_i2s_enable(ctx, ctx->i2s_en->cur.val); in max2175_set_rx_mode()
796 ctx->mode_resolved = true; in max2175_set_rx_mode()
807 for (i = 0; i <= ctx->rx_mode->maximum; i++) { in max2175_rx_mode_from_freq()
808 if (ctx->rx_modes[i].band == band) { in max2175_rx_mode_from_freq()
816 return -EINVAL; in max2175_rx_mode_from_freq()
824 return (ctx->rx_modes[mode].band == band); in max2175_freq_rx_mode_valid()
840 /* Execute on-chip power-up/calibration */ in max2175_init_power_manager()
857 /* ADC Re-calibration */ in max2175_recalibrate_adc()
874 u8 data = 0; in max2175_read_rom() local
880 max2175_read(ctx, 58, &data); in max2175_read_rom()
884 mxm_dbg(ctx, "read_rom: row %d data 0x%02x\n", row, data); in max2175_read_rom()
886 return data; in max2175_read_rom()
891 u8 data = 0; in max2175_load_from_rom() local
893 data = max2175_read_rom(ctx, 0); in max2175_load_from_rom()
894 ctx->rom_bbf_bw_am = data & 0x0f; in max2175_load_from_rom()
895 max2175_write_bits(ctx, 81, 3, 0, data >> 4); in max2175_load_from_rom()
897 data = max2175_read_rom(ctx, 1); in max2175_load_from_rom()
898 ctx->rom_bbf_bw_fm = data & 0x0f; in max2175_load_from_rom()
899 ctx->rom_bbf_bw_dab = data >> 4; in max2175_load_from_rom()
901 data = max2175_read_rom(ctx, 2); in max2175_load_from_rom()
902 max2175_write_bits(ctx, 82, 4, 0, data & 0x1f); in max2175_load_from_rom()
903 max2175_write_bits(ctx, 82, 7, 5, data >> 5); in max2175_load_from_rom()
905 data = max2175_read_rom(ctx, 3); in max2175_load_from_rom()
906 if (ctx->am_hiz) { in max2175_load_from_rom()
907 data &= 0x0f; in max2175_load_from_rom()
908 data |= (max2175_read_rom(ctx, 7) & 0x40) >> 2; in max2175_load_from_rom()
909 if (!data) in max2175_load_from_rom()
910 data |= 2; in max2175_load_from_rom()
912 data = (data & 0xf0) >> 4; in max2175_load_from_rom()
913 data |= (max2175_read_rom(ctx, 7) & 0x80) >> 3; in max2175_load_from_rom()
914 if (!data) in max2175_load_from_rom()
915 data |= 30; in max2175_load_from_rom()
917 max2175_write_bits(ctx, 80, 5, 0, data + 31); in max2175_load_from_rom()
919 data = max2175_read_rom(ctx, 6); in max2175_load_from_rom()
920 max2175_write_bits(ctx, 81, 7, 6, data >> 6); in max2175_load_from_rom()
931 ctx->decim_ratio = 36; in max2175_load_full_fm_eu_1p0()
942 ctx->decim_ratio = 27; in max2175_load_full_fm_na_1p0()
950 if (ctx->xtal_freq == MAX2175_EU_XTAL_FREQ) in max2175_core_init()
956 if (!ctx->master) in max2175_core_init()
985 if (ctx->xtal_freq == MAX2175_EU_XTAL_FREQ) { in max2175_core_init()
1008 mxm_dbg(ctx, "s_ctrl_rx_mode: %u curr freq %u\n", rx_mode, ctx->freq); in max2175_s_ctrl_rx_mode()
1011 if (max2175_freq_rx_mode_valid(ctx, rx_mode, ctx->freq)) in max2175_s_ctrl_rx_mode()
1012 max2175_tune_rf_freq(ctx, ctx->freq, ctx->hsls->cur.val); in max2175_s_ctrl_rx_mode()
1015 max2175_tune_rf_freq(ctx, ctx->rx_modes[rx_mode].freq, in max2175_s_ctrl_rx_mode()
1016 ctx->hsls->cur.val); in max2175_s_ctrl_rx_mode()
1021 struct max2175 *ctx = max2175_from_ctrl_hdl(ctrl->handler); in max2175_s_ctrl()
1023 mxm_dbg(ctx, "s_ctrl: id 0x%x, val %u\n", ctrl->id, ctrl->val); in max2175_s_ctrl()
1024 switch (ctrl->id) { in max2175_s_ctrl()
1026 max2175_i2s_enable(ctx, ctrl->val); in max2175_s_ctrl()
1029 max2175_set_hsls(ctx, ctrl->val); in max2175_s_ctrl()
1032 max2175_s_ctrl_rx_mode(ctx, ctrl->val); in max2175_s_ctrl()
1057 struct max2175 *ctx = max2175_from_ctrl_hdl(ctrl->handler); in max2175_g_volatile_ctrl()
1059 switch (ctrl->id) { in max2175_g_volatile_ctrl()
1061 ctrl->val = max2175_get_lna_gain(ctx); in max2175_g_volatile_ctrl()
1064 ctrl->val = max2175_read_bits(ctx, 49, 4, 0); in max2175_g_volatile_ctrl()
1067 ctrl->val = (max2175_read_bits(ctx, 60, 7, 6) == 3); in max2175_g_volatile_ctrl()
1088 ctx->rx_mode->cur.val = rx_mode; in max2175_set_freq_and_mode()
1091 return max2175_tune_rf_freq(ctx, freq, ctx->hsls->cur.val); in max2175_set_freq_and_mode()
1102 vf->frequency, ctx->freq, ctx->mode_resolved); in max2175_s_frequency()
1104 if (vf->tuner != 0) in max2175_s_frequency()
1105 return -EINVAL; in max2175_s_frequency()
1107 freq = clamp(vf->frequency, ctx->bands_rf->rangelow, in max2175_s_frequency()
1108 ctx->bands_rf->rangehigh); in max2175_s_frequency()
1111 if (ctx->mode_resolved && in max2175_s_frequency()
1112 max2175_freq_rx_mode_valid(ctx, ctx->rx_mode->cur.val, freq)) in max2175_s_frequency()
1113 ret = max2175_tune_rf_freq(ctx, freq, ctx->hsls->cur.val); in max2175_s_frequency()
1119 ret, ctx->freq, ctx->mode_resolved, ctx->rx_mode->cur.val); in max2175_s_frequency()
1129 if (vf->tuner != 0) in max2175_g_frequency()
1130 return -EINVAL; in max2175_g_frequency()
1133 vf->type = V4L2_TUNER_RF; in max2175_g_frequency()
1134 vf->frequency = ctx->freq; in max2175_g_frequency()
1144 if (band->tuner != 0 || band->index != 0) in max2175_enum_freq_bands()
1145 return -EINVAL; in max2175_enum_freq_bands()
1147 *band = *ctx->bands_rf; in max2175_enum_freq_bands()
1156 if (vt->index > 0) in max2175_g_tuner()
1157 return -EINVAL; in max2175_g_tuner()
1159 strscpy(vt->name, "RF", sizeof(vt->name)); in max2175_g_tuner()
1160 vt->type = V4L2_TUNER_RF; in max2175_g_tuner()
1161 vt->capability = V4L2_TUNER_CAP_1HZ | V4L2_TUNER_CAP_FREQ_BANDS; in max2175_g_tuner()
1162 vt->rangelow = ctx->bands_rf->rangelow; in max2175_g_tuner()
1163 vt->rangehigh = ctx->bands_rf->rangehigh; in max2175_g_tuner()
1171 if (vt->index > 0) in max2175_s_tuner()
1172 return -EINVAL; in max2175_s_tuner()
1196 * Refer to Documentation/userspace-api/media/drivers/max2175.rst for more details.
1212 * Refer to Documentation/userspace-api/media/drivers/max2175.rst for more details.
1228 * Refer to Documentation/userspace-api/media/drivers/max2175.rst for more details.
1245 .max = ARRAY_SIZE(max2175_ctrl_eu_rx_modes) - 1,
1255 .max = ARRAY_SIZE(max2175_ctrl_na_rx_modes) - 1,
1266 *bits = load / 10 - 1; in max2175_refout_load_to_bits()
1268 return -EINVAL; in max2175_refout_load_to_bits()
1287 np = of_parse_phandle(client->dev.of_node, "maxim,master", 0); in max2175_probe()
1293 fwnode = of_fwnode_handle(client->dev.of_node); in max2175_probe()
1294 if (fwnode_property_present(fwnode, "maxim,am-hiz-filter")) in max2175_probe()
1297 if (!fwnode_property_read_u32(fwnode, "maxim,refout-load", in max2175_probe()
1302 dev_err(&client->dev, "invalid refout_load %u\n", in max2175_probe()
1304 return -EINVAL; in max2175_probe()
1308 clk = devm_clk_get(&client->dev, NULL); in max2175_probe()
1311 dev_err(&client->dev, "cannot get clock %d\n", ret); in max2175_probe()
1318 dev_err(&client->dev, "regmap init failed %d\n", ret); in max2175_probe()
1319 return -ENODEV; in max2175_probe()
1323 ctx = devm_kzalloc(&client->dev, sizeof(*ctx), GFP_KERNEL); in max2175_probe()
1325 return -ENOMEM; in max2175_probe()
1327 sd = &ctx->sd; in max2175_probe()
1328 ctx->master = master; in max2175_probe()
1329 ctx->am_hiz = am_hiz; in max2175_probe()
1330 ctx->mode_resolved = false; in max2175_probe()
1331 ctx->regmap = regmap; in max2175_probe()
1332 ctx->xtal_freq = clk_get_rate(clk); in max2175_probe()
1333 dev_info(&client->dev, "xtal freq %luHz\n", ctx->xtal_freq); in max2175_probe()
1336 ctx->client = client; in max2175_probe()
1338 sd->flags |= V4L2_SUBDEV_FL_HAS_DEVNODE; in max2175_probe()
1341 hdl = &ctx->ctrl_hdl; in max2175_probe()
1346 ctx->lna_gain = v4l2_ctrl_new_std(hdl, &max2175_ctrl_ops, in max2175_probe()
1349 ctx->lna_gain->flags |= (V4L2_CTRL_FLAG_VOLATILE | in max2175_probe()
1351 ctx->if_gain = v4l2_ctrl_new_std(hdl, &max2175_ctrl_ops, in max2175_probe()
1354 ctx->if_gain->flags |= (V4L2_CTRL_FLAG_VOLATILE | in max2175_probe()
1356 ctx->pll_lock = v4l2_ctrl_new_std(hdl, &max2175_ctrl_ops, in max2175_probe()
1359 ctx->pll_lock->flags |= (V4L2_CTRL_FLAG_VOLATILE | in max2175_probe()
1361 ctx->i2s_en = v4l2_ctrl_new_custom(hdl, &max2175_i2s_en, NULL); in max2175_probe()
1362 ctx->hsls = v4l2_ctrl_new_custom(hdl, &max2175_hsls, NULL); in max2175_probe()
1364 if (ctx->xtal_freq == MAX2175_EU_XTAL_FREQ) { in max2175_probe()
1365 ctx->rx_mode = v4l2_ctrl_new_custom(hdl, in max2175_probe()
1367 ctx->rx_modes = eu_rx_modes; in max2175_probe()
1368 ctx->bands_rf = &eu_bands_rf; in max2175_probe()
1370 ctx->rx_mode = v4l2_ctrl_new_custom(hdl, in max2175_probe()
1372 ctx->rx_modes = na_rx_modes; in max2175_probe()
1373 ctx->bands_rf = &na_bands_rf; in max2175_probe()
1375 ctx->sd.ctrl_handler = &ctx->ctrl_hdl; in max2175_probe()
1378 ctx->freq = ctx->bands_rf->rangelow; in max2175_probe()
1383 dev_err(&client->dev, "register subdev failed\n"); in max2175_probe()
1401 v4l2_ctrl_handler_free(&ctx->ctrl_hdl); in max2175_probe()
1411 v4l2_ctrl_handler_free(&ctx->ctrl_hdl); in max2175_remove()