1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * RZ/G2L A/D Converter driver 4 * 5 * Copyright (c) 2021 Renesas Electronics Europe GmbH 6 * 7 * Author: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com> 8 */ 9 10 #include <linux/bitfield.h> 11 #include <linux/cleanup.h> 12 #include <linux/completion.h> 13 #include <linux/delay.h> 14 #include <linux/iio/adc-helpers.h> 15 #include <linux/iio/iio.h> 16 #include <linux/interrupt.h> 17 #include <linux/io.h> 18 #include <linux/iopoll.h> 19 #include <linux/mod_devicetable.h> 20 #include <linux/module.h> 21 #include <linux/platform_device.h> 22 #include <linux/pm_runtime.h> 23 #include <linux/property.h> 24 #include <linux/reset.h> 25 26 #define DRIVER_NAME "rzg2l-adc" 27 28 #define RZG2L_ADM(n) ((n) * 0x4) 29 #define RZG2L_ADM0_ADCE BIT(0) 30 #define RZG2L_ADM0_ADBSY BIT(1) 31 #define RZG2L_ADM0_PWDWNB BIT(2) 32 #define RZG2L_ADM0_SRESB BIT(15) 33 #define RZG2L_ADM1_TRG BIT(0) 34 #define RZG2L_ADM1_MS BIT(2) 35 #define RZG2L_ADM1_BS BIT(4) 36 #define RZG2L_ADM1_EGA_MASK GENMASK(13, 12) 37 #define RZG2L_ADM3_ADIL_MASK GENMASK(31, 24) 38 #define RZG2L_ADM3_ADCMP_MASK GENMASK(23, 16) 39 40 #define RZG2L_ADINT 0x20 41 #define RZG2L_ADINT_CSEEN BIT(16) 42 #define RZG2L_ADINT_INTS BIT(31) 43 44 #define RZG2L_ADSTS 0x24 45 #define RZG2L_ADSTS_CSEST BIT(16) 46 47 #define RZG2L_ADIVC 0x28 48 #define RZG2L_ADIVC_DIVADC_MASK GENMASK(8, 0) 49 #define RZG2L_ADIVC_DIVADC_4 FIELD_PREP(RZG2L_ADIVC_DIVADC_MASK, 0x4) 50 51 #define RZG2L_ADFIL 0x2c 52 53 #define RZG2L_ADCR(n) (0x30 + ((n) * 0x4)) 54 #define RZG2L_ADCR_AD_MASK GENMASK(11, 0) 55 56 #define RZG2L_ADC_MAX_CHANNELS 9 57 #define RZG2L_ADC_TIMEOUT usecs_to_jiffies(1 * 4) 58 59 /** 60 * struct rzg2l_adc_hw_params - ADC hardware specific parameters 61 * @default_adsmp: default ADC sampling period (see ADM3 register); index 0 is 62 * used for voltage channels, index 1 is used for temperature channel 63 * @adsmp_mask: ADC sampling period mask (see ADM3 register) 64 * @adint_inten_mask: conversion end interrupt mask (see ADINT register) 65 * @default_adcmp: default ADC cmp (see ADM3 register) 66 * @num_channels: number of supported channels 67 * @adivc: specifies if ADVIC register is available 68 */ 69 struct rzg2l_adc_hw_params { 70 u16 default_adsmp[2]; 71 u16 adsmp_mask; 72 u16 adint_inten_mask; 73 u8 default_adcmp; 74 u8 num_channels; 75 bool adivc; 76 }; 77 78 struct rzg2l_adc_data { 79 const struct iio_chan_spec *channels; 80 u8 num_channels; 81 }; 82 83 struct rzg2l_adc { 84 void __iomem *base; 85 struct reset_control *presetn; 86 struct reset_control *adrstn; 87 const struct rzg2l_adc_data *data; 88 const struct rzg2l_adc_hw_params *hw_params; 89 struct completion completion; 90 struct mutex lock; 91 u16 last_val[RZG2L_ADC_MAX_CHANNELS]; 92 }; 93 94 /** 95 * struct rzg2l_adc_channel - ADC channel descriptor 96 * @name: ADC channel name 97 * @type: ADC channel type 98 */ 99 struct rzg2l_adc_channel { 100 const char * const name; 101 enum iio_chan_type type; 102 }; 103 104 static const struct rzg2l_adc_channel rzg2l_adc_channels[] = { 105 { "adc0", IIO_VOLTAGE }, 106 { "adc1", IIO_VOLTAGE }, 107 { "adc2", IIO_VOLTAGE }, 108 { "adc3", IIO_VOLTAGE }, 109 { "adc4", IIO_VOLTAGE }, 110 { "adc5", IIO_VOLTAGE }, 111 { "adc6", IIO_VOLTAGE }, 112 { "adc7", IIO_VOLTAGE }, 113 { "adc8", IIO_TEMP }, 114 }; 115 116 static unsigned int rzg2l_adc_readl(struct rzg2l_adc *adc, u32 reg) 117 { 118 return readl(adc->base + reg); 119 } 120 121 static void rzg2l_adc_writel(struct rzg2l_adc *adc, unsigned int reg, u32 val) 122 { 123 writel(val, adc->base + reg); 124 } 125 126 static void rzg2l_adc_pwr(struct rzg2l_adc *adc, bool on) 127 { 128 u32 reg; 129 130 reg = rzg2l_adc_readl(adc, RZG2L_ADM(0)); 131 if (on) 132 reg |= RZG2L_ADM0_PWDWNB; 133 else 134 reg &= ~RZG2L_ADM0_PWDWNB; 135 rzg2l_adc_writel(adc, RZG2L_ADM(0), reg); 136 udelay(2); 137 } 138 139 static void rzg2l_adc_start_stop(struct rzg2l_adc *adc, bool start) 140 { 141 int ret; 142 u32 reg; 143 144 reg = rzg2l_adc_readl(adc, RZG2L_ADM(0)); 145 if (start) 146 reg |= RZG2L_ADM0_ADCE; 147 else 148 reg &= ~RZG2L_ADM0_ADCE; 149 rzg2l_adc_writel(adc, RZG2L_ADM(0), reg); 150 151 if (start) 152 return; 153 154 ret = read_poll_timeout(rzg2l_adc_readl, reg, !(reg & (RZG2L_ADM0_ADBSY | RZG2L_ADM0_ADCE)), 155 200, 1000, true, adc, RZG2L_ADM(0)); 156 if (ret) 157 pr_err("%s stopping ADC timed out\n", __func__); 158 } 159 160 static void rzg2l_set_trigger(struct rzg2l_adc *adc) 161 { 162 u32 reg; 163 164 /* 165 * Setup ADM1 for SW trigger 166 * EGA[13:12] - Set 00 to indicate hardware trigger is invalid 167 * BS[4] - Enable 1-buffer mode 168 * MS[1] - Enable Select mode 169 * TRG[0] - Enable software trigger mode 170 */ 171 reg = rzg2l_adc_readl(adc, RZG2L_ADM(1)); 172 reg &= ~RZG2L_ADM1_EGA_MASK; 173 reg &= ~RZG2L_ADM1_BS; 174 reg &= ~RZG2L_ADM1_TRG; 175 reg |= RZG2L_ADM1_MS; 176 rzg2l_adc_writel(adc, RZG2L_ADM(1), reg); 177 } 178 179 static u8 rzg2l_adc_ch_to_adsmp_index(u8 ch) 180 { 181 if (rzg2l_adc_channels[ch].type == IIO_VOLTAGE) 182 return 0; 183 184 return 1; 185 } 186 187 static int rzg2l_adc_conversion_setup(struct rzg2l_adc *adc, u8 ch) 188 { 189 const struct rzg2l_adc_hw_params *hw_params = adc->hw_params; 190 u8 index = rzg2l_adc_ch_to_adsmp_index(ch); 191 u32 reg; 192 193 if (rzg2l_adc_readl(adc, RZG2L_ADM(0)) & RZG2L_ADM0_ADBSY) 194 return -EBUSY; 195 196 rzg2l_set_trigger(adc); 197 198 /* Select analog input channel subjected to conversion. */ 199 reg = rzg2l_adc_readl(adc, RZG2L_ADM(2)); 200 reg &= ~GENMASK(hw_params->num_channels - 1, 0); 201 reg |= BIT(ch); 202 rzg2l_adc_writel(adc, RZG2L_ADM(2), reg); 203 204 reg = rzg2l_adc_readl(adc, RZG2L_ADM(3)); 205 reg &= ~hw_params->adsmp_mask; 206 reg |= hw_params->default_adsmp[index]; 207 rzg2l_adc_writel(adc, RZG2L_ADM(3), reg); 208 209 /* 210 * Setup ADINT 211 * INTS[31] - Select pulse signal 212 * CSEEN[16] - Enable channel select error interrupt 213 * INTEN[7:0] - Select channel interrupt 214 */ 215 reg = rzg2l_adc_readl(adc, RZG2L_ADINT); 216 reg &= ~RZG2L_ADINT_INTS; 217 reg &= ~hw_params->adint_inten_mask; 218 reg |= (RZG2L_ADINT_CSEEN | BIT(ch)); 219 rzg2l_adc_writel(adc, RZG2L_ADINT, reg); 220 221 return 0; 222 } 223 224 static int rzg2l_adc_conversion(struct iio_dev *indio_dev, struct rzg2l_adc *adc, u8 ch) 225 { 226 const struct rzg2l_adc_hw_params *hw_params = adc->hw_params; 227 struct device *dev = indio_dev->dev.parent; 228 int ret; 229 230 ret = pm_runtime_resume_and_get(dev); 231 if (ret) 232 return ret; 233 234 ret = rzg2l_adc_conversion_setup(adc, ch); 235 if (ret) 236 goto rpm_put; 237 238 reinit_completion(&adc->completion); 239 240 rzg2l_adc_start_stop(adc, true); 241 242 if (!wait_for_completion_timeout(&adc->completion, RZG2L_ADC_TIMEOUT)) { 243 rzg2l_adc_writel(adc, RZG2L_ADINT, 244 rzg2l_adc_readl(adc, RZG2L_ADINT) & ~hw_params->adint_inten_mask); 245 ret = -ETIMEDOUT; 246 } 247 248 rzg2l_adc_start_stop(adc, false); 249 250 rpm_put: 251 pm_runtime_mark_last_busy(dev); 252 pm_runtime_put_autosuspend(dev); 253 return ret; 254 } 255 256 static int rzg2l_adc_read_raw(struct iio_dev *indio_dev, 257 struct iio_chan_spec const *chan, 258 int *val, int *val2, long mask) 259 { 260 struct rzg2l_adc *adc = iio_priv(indio_dev); 261 int ret; 262 263 switch (mask) { 264 case IIO_CHAN_INFO_RAW: { 265 if (chan->type != IIO_VOLTAGE && chan->type != IIO_TEMP) 266 return -EINVAL; 267 268 guard(mutex)(&adc->lock); 269 270 ret = rzg2l_adc_conversion(indio_dev, adc, chan->channel); 271 if (ret) 272 return ret; 273 274 *val = adc->last_val[chan->channel]; 275 276 return IIO_VAL_INT; 277 } 278 279 default: 280 return -EINVAL; 281 } 282 } 283 284 static int rzg2l_adc_read_label(struct iio_dev *iio_dev, 285 const struct iio_chan_spec *chan, 286 char *label) 287 { 288 return sysfs_emit(label, "%s\n", rzg2l_adc_channels[chan->channel].name); 289 } 290 291 static const struct iio_info rzg2l_adc_iio_info = { 292 .read_raw = rzg2l_adc_read_raw, 293 .read_label = rzg2l_adc_read_label, 294 }; 295 296 static irqreturn_t rzg2l_adc_isr(int irq, void *dev_id) 297 { 298 struct rzg2l_adc *adc = dev_id; 299 const struct rzg2l_adc_hw_params *hw_params = adc->hw_params; 300 unsigned long intst; 301 u32 reg; 302 int ch; 303 304 reg = rzg2l_adc_readl(adc, RZG2L_ADSTS); 305 306 /* A/D conversion channel select error interrupt */ 307 if (reg & RZG2L_ADSTS_CSEST) { 308 rzg2l_adc_writel(adc, RZG2L_ADSTS, reg); 309 return IRQ_HANDLED; 310 } 311 312 intst = reg & GENMASK(hw_params->num_channels - 1, 0); 313 if (!intst) 314 return IRQ_NONE; 315 316 for_each_set_bit(ch, &intst, hw_params->num_channels) 317 adc->last_val[ch] = rzg2l_adc_readl(adc, RZG2L_ADCR(ch)) & RZG2L_ADCR_AD_MASK; 318 319 /* clear the channel interrupt */ 320 rzg2l_adc_writel(adc, RZG2L_ADSTS, reg); 321 322 complete(&adc->completion); 323 324 return IRQ_HANDLED; 325 } 326 327 static const struct iio_chan_spec rzg2l_adc_chan_template = { 328 .indexed = 1, 329 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), 330 }; 331 332 static int rzg2l_adc_parse_properties(struct platform_device *pdev, struct rzg2l_adc *adc) 333 { 334 const struct rzg2l_adc_hw_params *hw_params = adc->hw_params; 335 struct iio_chan_spec *chan_array; 336 struct rzg2l_adc_data *data; 337 int num_channels; 338 u8 i; 339 340 data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL); 341 if (!data) 342 return -ENOMEM; 343 344 num_channels = devm_iio_adc_device_alloc_chaninfo_se(&pdev->dev, 345 &rzg2l_adc_chan_template, 346 hw_params->num_channels - 1, 347 &chan_array); 348 if (num_channels < 0) 349 return num_channels; 350 351 if (num_channels > hw_params->num_channels) 352 return dev_err_probe(&pdev->dev, -EINVAL, 353 "num of channel children out of range\n"); 354 355 for (i = 0; i < num_channels; i++) { 356 int channel = chan_array[i].channel; 357 358 chan_array[i].datasheet_name = rzg2l_adc_channels[channel].name; 359 chan_array[i].type = rzg2l_adc_channels[channel].type; 360 } 361 362 data->num_channels = num_channels; 363 data->channels = chan_array; 364 adc->data = data; 365 366 return 0; 367 } 368 369 static int rzg2l_adc_hw_init(struct device *dev, struct rzg2l_adc *adc) 370 { 371 const struct rzg2l_adc_hw_params *hw_params = adc->hw_params; 372 u32 reg; 373 int ret; 374 375 ret = pm_runtime_resume_and_get(dev); 376 if (ret) 377 return ret; 378 379 /* SW reset */ 380 reg = rzg2l_adc_readl(adc, RZG2L_ADM(0)); 381 reg |= RZG2L_ADM0_SRESB; 382 rzg2l_adc_writel(adc, RZG2L_ADM(0), reg); 383 384 ret = read_poll_timeout(rzg2l_adc_readl, reg, reg & RZG2L_ADM0_SRESB, 385 200, 1000, false, adc, RZG2L_ADM(0)); 386 if (ret) 387 goto exit_hw_init; 388 389 if (hw_params->adivc) { 390 /* Only division by 4 can be set */ 391 reg = rzg2l_adc_readl(adc, RZG2L_ADIVC); 392 reg &= ~RZG2L_ADIVC_DIVADC_MASK; 393 reg |= RZG2L_ADIVC_DIVADC_4; 394 rzg2l_adc_writel(adc, RZG2L_ADIVC, reg); 395 } 396 397 /* 398 * Setup AMD3 399 * ADIL[31:24] - Should be always set to 0 400 * ADCMP[23:16] - Should be always set to 0xe 401 * ADSMP[15:0] - Set default (0x578) sampling period 402 */ 403 reg = rzg2l_adc_readl(adc, RZG2L_ADM(3)); 404 reg &= ~RZG2L_ADM3_ADIL_MASK; 405 reg &= ~RZG2L_ADM3_ADCMP_MASK; 406 reg &= ~hw_params->adsmp_mask; 407 reg |= FIELD_PREP(RZG2L_ADM3_ADCMP_MASK, hw_params->default_adcmp) | 408 hw_params->default_adsmp[0]; 409 410 rzg2l_adc_writel(adc, RZG2L_ADM(3), reg); 411 412 exit_hw_init: 413 pm_runtime_mark_last_busy(dev); 414 pm_runtime_put_autosuspend(dev); 415 return ret; 416 } 417 418 static int rzg2l_adc_probe(struct platform_device *pdev) 419 { 420 struct device *dev = &pdev->dev; 421 struct iio_dev *indio_dev; 422 struct rzg2l_adc *adc; 423 int ret; 424 int irq; 425 426 indio_dev = devm_iio_device_alloc(dev, sizeof(*adc)); 427 if (!indio_dev) 428 return -ENOMEM; 429 430 platform_set_drvdata(pdev, indio_dev); 431 432 adc = iio_priv(indio_dev); 433 434 adc->hw_params = device_get_match_data(dev); 435 if (!adc->hw_params || adc->hw_params->num_channels > RZG2L_ADC_MAX_CHANNELS) 436 return -EINVAL; 437 438 ret = rzg2l_adc_parse_properties(pdev, adc); 439 if (ret) 440 return ret; 441 442 mutex_init(&adc->lock); 443 444 adc->base = devm_platform_ioremap_resource(pdev, 0); 445 if (IS_ERR(adc->base)) 446 return PTR_ERR(adc->base); 447 448 adc->adrstn = devm_reset_control_get_exclusive_deasserted(dev, "adrst-n"); 449 if (IS_ERR(adc->adrstn)) 450 return dev_err_probe(dev, PTR_ERR(adc->adrstn), 451 "failed to get/deassert adrst-n\n"); 452 453 adc->presetn = devm_reset_control_get_exclusive_deasserted(dev, "presetn"); 454 if (IS_ERR(adc->presetn)) 455 return dev_err_probe(dev, PTR_ERR(adc->presetn), 456 "failed to get/deassert presetn\n"); 457 458 pm_runtime_set_autosuspend_delay(dev, 300); 459 pm_runtime_use_autosuspend(dev); 460 ret = devm_pm_runtime_enable(dev); 461 if (ret) 462 return ret; 463 464 ret = rzg2l_adc_hw_init(dev, adc); 465 if (ret) 466 return dev_err_probe(&pdev->dev, ret, 467 "failed to initialize ADC HW\n"); 468 469 irq = platform_get_irq(pdev, 0); 470 if (irq < 0) 471 return irq; 472 473 ret = devm_request_irq(dev, irq, rzg2l_adc_isr, 474 0, dev_name(dev), adc); 475 if (ret < 0) 476 return ret; 477 478 init_completion(&adc->completion); 479 480 indio_dev->name = DRIVER_NAME; 481 indio_dev->info = &rzg2l_adc_iio_info; 482 indio_dev->modes = INDIO_DIRECT_MODE; 483 indio_dev->channels = adc->data->channels; 484 indio_dev->num_channels = adc->data->num_channels; 485 486 return devm_iio_device_register(dev, indio_dev); 487 } 488 489 static const struct rzg2l_adc_hw_params rzg2l_hw_params = { 490 .num_channels = 8, 491 .default_adcmp = 0xe, 492 .default_adsmp = { 0x578 }, 493 .adsmp_mask = GENMASK(15, 0), 494 .adint_inten_mask = GENMASK(7, 0), 495 .adivc = true 496 }; 497 498 static const struct rzg2l_adc_hw_params rzg3s_hw_params = { 499 .num_channels = 9, 500 .default_adcmp = 0x1d, 501 .default_adsmp = { 0x7f, 0xff }, 502 .adsmp_mask = GENMASK(7, 0), 503 .adint_inten_mask = GENMASK(11, 0), 504 }; 505 506 static const struct of_device_id rzg2l_adc_match[] = { 507 { .compatible = "renesas,r9a08g045-adc", .data = &rzg3s_hw_params }, 508 { .compatible = "renesas,rzg2l-adc", .data = &rzg2l_hw_params }, 509 { } 510 }; 511 MODULE_DEVICE_TABLE(of, rzg2l_adc_match); 512 513 static int rzg2l_adc_pm_runtime_suspend(struct device *dev) 514 { 515 struct iio_dev *indio_dev = dev_get_drvdata(dev); 516 struct rzg2l_adc *adc = iio_priv(indio_dev); 517 518 rzg2l_adc_pwr(adc, false); 519 520 return 0; 521 } 522 523 static int rzg2l_adc_pm_runtime_resume(struct device *dev) 524 { 525 struct iio_dev *indio_dev = dev_get_drvdata(dev); 526 struct rzg2l_adc *adc = iio_priv(indio_dev); 527 528 rzg2l_adc_pwr(adc, true); 529 530 return 0; 531 } 532 533 static int rzg2l_adc_suspend(struct device *dev) 534 { 535 struct iio_dev *indio_dev = dev_get_drvdata(dev); 536 struct rzg2l_adc *adc = iio_priv(indio_dev); 537 struct reset_control_bulk_data resets[] = { 538 { .rstc = adc->presetn }, 539 { .rstc = adc->adrstn }, 540 }; 541 int ret; 542 543 ret = pm_runtime_force_suspend(dev); 544 if (ret) 545 return ret; 546 547 ret = reset_control_bulk_assert(ARRAY_SIZE(resets), resets); 548 if (ret) 549 goto rpm_restore; 550 551 return 0; 552 553 rpm_restore: 554 pm_runtime_force_resume(dev); 555 return ret; 556 } 557 558 static int rzg2l_adc_resume(struct device *dev) 559 { 560 struct iio_dev *indio_dev = dev_get_drvdata(dev); 561 struct rzg2l_adc *adc = iio_priv(indio_dev); 562 struct reset_control_bulk_data resets[] = { 563 { .rstc = adc->adrstn }, 564 { .rstc = adc->presetn }, 565 }; 566 int ret; 567 568 ret = reset_control_bulk_deassert(ARRAY_SIZE(resets), resets); 569 if (ret) 570 return ret; 571 572 ret = pm_runtime_force_resume(dev); 573 if (ret) 574 goto resets_restore; 575 576 ret = rzg2l_adc_hw_init(dev, adc); 577 if (ret) 578 goto rpm_restore; 579 580 return 0; 581 582 rpm_restore: 583 pm_runtime_force_suspend(dev); 584 resets_restore: 585 reset_control_bulk_assert(ARRAY_SIZE(resets), resets); 586 return ret; 587 } 588 589 static const struct dev_pm_ops rzg2l_adc_pm_ops = { 590 RUNTIME_PM_OPS(rzg2l_adc_pm_runtime_suspend, rzg2l_adc_pm_runtime_resume, NULL) 591 SYSTEM_SLEEP_PM_OPS(rzg2l_adc_suspend, rzg2l_adc_resume) 592 }; 593 594 static struct platform_driver rzg2l_adc_driver = { 595 .probe = rzg2l_adc_probe, 596 .driver = { 597 .name = DRIVER_NAME, 598 .of_match_table = rzg2l_adc_match, 599 .pm = pm_ptr(&rzg2l_adc_pm_ops), 600 }, 601 }; 602 603 module_platform_driver(rzg2l_adc_driver); 604 605 MODULE_AUTHOR("Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>"); 606 MODULE_DESCRIPTION("Renesas RZ/G2L ADC driver"); 607 MODULE_LICENSE("GPL v2"); 608 MODULE_IMPORT_NS("IIO_DRIVER"); 609