Linux Audio

Check our new training course

Loading...
Note: File does not exist in v5.9.
   1// SPDX-License-Identifier: GPL-2.0-only
   2/*
   3 * Copyright (c) 2017-2022 Linaro Ltd
   4 * Copyright (c) 2010-2012, The Linux Foundation. All rights reserved.
   5 */
   6#include <linux/bits.h>
   7#include <linux/bitfield.h>
   8#include <linux/led-class-multicolor.h>
   9#include <linux/module.h>
  10#include <linux/of.h>
  11#include <linux/of_device.h>
  12#include <linux/platform_device.h>
  13#include <linux/pwm.h>
  14#include <linux/regmap.h>
  15#include <linux/slab.h>
  16
  17#define LPG_SUBTYPE_REG		0x05
  18#define  LPG_SUBTYPE_LPG	0x2
  19#define  LPG_SUBTYPE_PWM	0xb
  20#define  LPG_SUBTYPE_LPG_LITE	0x11
  21#define LPG_PATTERN_CONFIG_REG	0x40
  22#define LPG_SIZE_CLK_REG	0x41
  23#define  PWM_CLK_SELECT_MASK	GENMASK(1, 0)
  24#define LPG_PREDIV_CLK_REG	0x42
  25#define  PWM_FREQ_PRE_DIV_MASK	GENMASK(6, 5)
  26#define  PWM_FREQ_EXP_MASK	GENMASK(2, 0)
  27#define PWM_TYPE_CONFIG_REG	0x43
  28#define PWM_VALUE_REG		0x44
  29#define PWM_ENABLE_CONTROL_REG	0x46
  30#define PWM_SYNC_REG		0x47
  31#define LPG_RAMP_DURATION_REG	0x50
  32#define LPG_HI_PAUSE_REG	0x52
  33#define LPG_LO_PAUSE_REG	0x54
  34#define LPG_HI_IDX_REG		0x56
  35#define LPG_LO_IDX_REG		0x57
  36#define PWM_SEC_ACCESS_REG	0xd0
  37#define PWM_DTEST_REG(x)	(0xe2 + (x) - 1)
  38
  39#define TRI_LED_SRC_SEL		0x45
  40#define TRI_LED_EN_CTL		0x46
  41#define TRI_LED_ATC_CTL		0x47
  42
  43#define LPG_LUT_REG(x)		(0x40 + (x) * 2)
  44#define RAMP_CONTROL_REG	0xc8
  45
  46#define LPG_RESOLUTION		512
  47#define LPG_MAX_M		7
  48
  49struct lpg_channel;
  50struct lpg_data;
  51
  52/**
  53 * struct lpg - LPG device context
  54 * @dev:	pointer to LPG device
  55 * @map:	regmap for register access
  56 * @lock:	used to synchronize LED and pwm callback requests
  57 * @pwm:	PWM-chip object, if operating in PWM mode
  58 * @data:	reference to version specific data
  59 * @lut_base:	base address of the LUT block (optional)
  60 * @lut_size:	number of entries in the LUT block
  61 * @lut_bitmap:	allocation bitmap for LUT entries
  62 * @triled_base: base address of the TRILED block (optional)
  63 * @triled_src:	power-source for the TRILED
  64 * @triled_has_atc_ctl:	true if there is TRI_LED_ATC_CTL register
  65 * @triled_has_src_sel:	true if there is TRI_LED_SRC_SEL register
  66 * @channels:	list of PWM channels
  67 * @num_channels: number of @channels
  68 */
  69struct lpg {
  70	struct device *dev;
  71	struct regmap *map;
  72
  73	struct mutex lock;
  74
  75	struct pwm_chip pwm;
  76
  77	const struct lpg_data *data;
  78
  79	u32 lut_base;
  80	u32 lut_size;
  81	unsigned long *lut_bitmap;
  82
  83	u32 triled_base;
  84	u32 triled_src;
  85	bool triled_has_atc_ctl;
  86	bool triled_has_src_sel;
  87
  88	struct lpg_channel *channels;
  89	unsigned int num_channels;
  90};
  91
  92/**
  93 * struct lpg_channel - per channel data
  94 * @lpg:	reference to parent lpg
  95 * @base:	base address of the PWM channel
  96 * @triled_mask: mask in TRILED to enable this channel
  97 * @lut_mask:	mask in LUT to start pattern generator for this channel
  98 * @subtype:	PMIC hardware block subtype
  99 * @in_use:	channel is exposed to LED framework
 100 * @color:	color of the LED attached to this channel
 101 * @dtest_line:	DTEST line for output, or 0 if disabled
 102 * @dtest_value: DTEST line configuration
 103 * @pwm_value:	duty (in microseconds) of the generated pulses, overridden by LUT
 104 * @enabled:	output enabled?
 105 * @period:	period (in nanoseconds) of the generated pulses
 106 * @clk_sel:	reference clock frequency selector
 107 * @pre_div_sel: divider selector of the reference clock
 108 * @pre_div_exp: exponential divider of the reference clock
 109 * @ramp_enabled: duty cycle is driven by iterating over lookup table
 110 * @ramp_ping_pong: reverse through pattern, rather than wrapping to start
 111 * @ramp_oneshot: perform only a single pass over the pattern
 112 * @ramp_reverse: iterate over pattern backwards
 113 * @ramp_tick_ms: length (in milliseconds) of one step in the pattern
 114 * @ramp_lo_pause_ms: pause (in milliseconds) before iterating over pattern
 115 * @ramp_hi_pause_ms: pause (in milliseconds) after iterating over pattern
 116 * @pattern_lo_idx: start index of associated pattern
 117 * @pattern_hi_idx: last index of associated pattern
 118 */
 119struct lpg_channel {
 120	struct lpg *lpg;
 121
 122	u32 base;
 123	unsigned int triled_mask;
 124	unsigned int lut_mask;
 125	unsigned int subtype;
 126
 127	bool in_use;
 128
 129	int color;
 130
 131	u32 dtest_line;
 132	u32 dtest_value;
 133
 134	u16 pwm_value;
 135	bool enabled;
 136
 137	u64 period;
 138	unsigned int clk_sel;
 139	unsigned int pre_div_sel;
 140	unsigned int pre_div_exp;
 141
 142	bool ramp_enabled;
 143	bool ramp_ping_pong;
 144	bool ramp_oneshot;
 145	bool ramp_reverse;
 146	unsigned short ramp_tick_ms;
 147	unsigned long ramp_lo_pause_ms;
 148	unsigned long ramp_hi_pause_ms;
 149
 150	unsigned int pattern_lo_idx;
 151	unsigned int pattern_hi_idx;
 152};
 153
 154/**
 155 * struct lpg_led - logical LED object
 156 * @lpg:		lpg context reference
 157 * @cdev:		LED class device
 158 * @mcdev:		Multicolor LED class device
 159 * @num_channels:	number of @channels
 160 * @channels:		list of channels associated with the LED
 161 */
 162struct lpg_led {
 163	struct lpg *lpg;
 164
 165	struct led_classdev cdev;
 166	struct led_classdev_mc mcdev;
 167
 168	unsigned int num_channels;
 169	struct lpg_channel *channels[];
 170};
 171
 172/**
 173 * struct lpg_channel_data - per channel initialization data
 174 * @base:		base address for PWM channel registers
 175 * @triled_mask:	bitmask for controlling this channel in TRILED
 176 */
 177struct lpg_channel_data {
 178	unsigned int base;
 179	u8 triled_mask;
 180};
 181
 182/**
 183 * struct lpg_data - initialization data
 184 * @lut_base:		base address of LUT block
 185 * @lut_size:		number of entries in LUT
 186 * @triled_base:	base address of TRILED
 187 * @triled_has_atc_ctl:	true if there is TRI_LED_ATC_CTL register
 188 * @triled_has_src_sel:	true if there is TRI_LED_SRC_SEL register
 189 * @num_channels:	number of channels in LPG
 190 * @channels:		list of channel initialization data
 191 */
 192struct lpg_data {
 193	unsigned int lut_base;
 194	unsigned int lut_size;
 195	unsigned int triled_base;
 196	bool triled_has_atc_ctl;
 197	bool triled_has_src_sel;
 198	int num_channels;
 199	const struct lpg_channel_data *channels;
 200};
 201
 202static int triled_set(struct lpg *lpg, unsigned int mask, unsigned int enable)
 203{
 204	/* Skip if we don't have a triled block */
 205	if (!lpg->triled_base)
 206		return 0;
 207
 208	return regmap_update_bits(lpg->map, lpg->triled_base + TRI_LED_EN_CTL,
 209				  mask, enable);
 210}
 211
 212static int lpg_lut_store(struct lpg *lpg, struct led_pattern *pattern,
 213			 size_t len, unsigned int *lo_idx, unsigned int *hi_idx)
 214{
 215	unsigned int idx;
 216	u16 val;
 217	int i;
 218
 219	idx = bitmap_find_next_zero_area(lpg->lut_bitmap, lpg->lut_size,
 220					 0, len, 0);
 221	if (idx >= lpg->lut_size)
 222		return -ENOMEM;
 223
 224	for (i = 0; i < len; i++) {
 225		val = pattern[i].brightness;
 226
 227		regmap_bulk_write(lpg->map, lpg->lut_base + LPG_LUT_REG(idx + i),
 228				  &val, sizeof(val));
 229	}
 230
 231	bitmap_set(lpg->lut_bitmap, idx, len);
 232
 233	*lo_idx = idx;
 234	*hi_idx = idx + len - 1;
 235
 236	return 0;
 237}
 238
 239static void lpg_lut_free(struct lpg *lpg, unsigned int lo_idx, unsigned int hi_idx)
 240{
 241	int len;
 242
 243	len = hi_idx - lo_idx + 1;
 244	if (len == 1)
 245		return;
 246
 247	bitmap_clear(lpg->lut_bitmap, lo_idx, len);
 248}
 249
 250static int lpg_lut_sync(struct lpg *lpg, unsigned int mask)
 251{
 252	return regmap_write(lpg->map, lpg->lut_base + RAMP_CONTROL_REG, mask);
 253}
 254
 255static const unsigned int lpg_clk_rates[] = {0, 1024, 32768, 19200000};
 256static const unsigned int lpg_pre_divs[] = {1, 3, 5, 6};
 257
 258static int lpg_calc_freq(struct lpg_channel *chan, uint64_t period)
 259{
 260	unsigned int clk_sel, best_clk = 0;
 261	unsigned int div, best_div = 0;
 262	unsigned int m, best_m = 0;
 263	unsigned int error;
 264	unsigned int best_err = UINT_MAX;
 265	u64 best_period = 0;
 266	u64 max_period;
 267
 268	/*
 269	 * The PWM period is determined by:
 270	 *
 271	 *          resolution * pre_div * 2^M
 272	 * period = --------------------------
 273	 *                   refclk
 274	 *
 275	 * With resolution fixed at 2^9 bits, pre_div = {1, 3, 5, 6} and
 276	 * M = [0..7].
 277	 *
 278	 * This allows for periods between 27uS and 384s, as the PWM framework
 279	 * wants a period of equal or lower length than requested, reject
 280	 * anything below 27uS.
 281	 */
 282	if (period <= (u64)NSEC_PER_SEC * LPG_RESOLUTION / 19200000)
 283		return -EINVAL;
 284
 285	/* Limit period to largest possible value, to avoid overflows */
 286	max_period = (u64)NSEC_PER_SEC * LPG_RESOLUTION * 6 * (1 << LPG_MAX_M) / 1024;
 287	if (period > max_period)
 288		period = max_period;
 289
 290	/*
 291	 * Search for the pre_div, refclk and M by solving the rewritten formula
 292	 * for each refclk and pre_div value:
 293	 *
 294	 *                     period * refclk
 295	 * M = log2 -------------------------------------
 296	 *           NSEC_PER_SEC * pre_div * resolution
 297	 */
 298	for (clk_sel = 1; clk_sel < ARRAY_SIZE(lpg_clk_rates); clk_sel++) {
 299		u64 numerator = period * lpg_clk_rates[clk_sel];
 300
 301		for (div = 0; div < ARRAY_SIZE(lpg_pre_divs); div++) {
 302			u64 denominator = (u64)NSEC_PER_SEC * lpg_pre_divs[div] * LPG_RESOLUTION;
 303			u64 actual;
 304			u64 ratio;
 305
 306			if (numerator < denominator)
 307				continue;
 308
 309			ratio = div64_u64(numerator, denominator);
 310			m = ilog2(ratio);
 311			if (m > LPG_MAX_M)
 312				m = LPG_MAX_M;
 313
 314			actual = DIV_ROUND_UP_ULL(denominator * (1 << m), lpg_clk_rates[clk_sel]);
 315
 316			error = period - actual;
 317			if (error < best_err) {
 318				best_err = error;
 319
 320				best_div = div;
 321				best_m = m;
 322				best_clk = clk_sel;
 323				best_period = actual;
 324			}
 325		}
 326	}
 327
 328	chan->clk_sel = best_clk;
 329	chan->pre_div_sel = best_div;
 330	chan->pre_div_exp = best_m;
 331	chan->period = best_period;
 332
 333	return 0;
 334}
 335
 336static void lpg_calc_duty(struct lpg_channel *chan, uint64_t duty)
 337{
 338	unsigned int max = LPG_RESOLUTION - 1;
 339	unsigned int val;
 340
 341	val = div64_u64(duty * lpg_clk_rates[chan->clk_sel],
 342			(u64)NSEC_PER_SEC * lpg_pre_divs[chan->pre_div_sel] * (1 << chan->pre_div_exp));
 343
 344	chan->pwm_value = min(val, max);
 345}
 346
 347static void lpg_apply_freq(struct lpg_channel *chan)
 348{
 349	unsigned long val;
 350	struct lpg *lpg = chan->lpg;
 351
 352	if (!chan->enabled)
 353		return;
 354
 355	val = chan->clk_sel;
 356
 357	/* Specify 9bit resolution, based on the subtype of the channel */
 358	switch (chan->subtype) {
 359	case LPG_SUBTYPE_LPG:
 360		val |= GENMASK(5, 4);
 361		break;
 362	case LPG_SUBTYPE_PWM:
 363		val |= BIT(2);
 364		break;
 365	case LPG_SUBTYPE_LPG_LITE:
 366	default:
 367		val |= BIT(4);
 368		break;
 369	}
 370
 371	regmap_write(lpg->map, chan->base + LPG_SIZE_CLK_REG, val);
 372
 373	val = FIELD_PREP(PWM_FREQ_PRE_DIV_MASK, chan->pre_div_sel) |
 374	      FIELD_PREP(PWM_FREQ_EXP_MASK, chan->pre_div_exp);
 375	regmap_write(lpg->map, chan->base + LPG_PREDIV_CLK_REG, val);
 376}
 377
 378#define LPG_ENABLE_GLITCH_REMOVAL	BIT(5)
 379
 380static void lpg_enable_glitch(struct lpg_channel *chan)
 381{
 382	struct lpg *lpg = chan->lpg;
 383
 384	regmap_update_bits(lpg->map, chan->base + PWM_TYPE_CONFIG_REG,
 385			   LPG_ENABLE_GLITCH_REMOVAL, 0);
 386}
 387
 388static void lpg_disable_glitch(struct lpg_channel *chan)
 389{
 390	struct lpg *lpg = chan->lpg;
 391
 392	regmap_update_bits(lpg->map, chan->base + PWM_TYPE_CONFIG_REG,
 393			   LPG_ENABLE_GLITCH_REMOVAL,
 394			   LPG_ENABLE_GLITCH_REMOVAL);
 395}
 396
 397static void lpg_apply_pwm_value(struct lpg_channel *chan)
 398{
 399	struct lpg *lpg = chan->lpg;
 400	u16 val = chan->pwm_value;
 401
 402	if (!chan->enabled)
 403		return;
 404
 405	regmap_bulk_write(lpg->map, chan->base + PWM_VALUE_REG, &val, sizeof(val));
 406}
 407
 408#define LPG_PATTERN_CONFIG_LO_TO_HI	BIT(4)
 409#define LPG_PATTERN_CONFIG_REPEAT	BIT(3)
 410#define LPG_PATTERN_CONFIG_TOGGLE	BIT(2)
 411#define LPG_PATTERN_CONFIG_PAUSE_HI	BIT(1)
 412#define LPG_PATTERN_CONFIG_PAUSE_LO	BIT(0)
 413
 414static void lpg_apply_lut_control(struct lpg_channel *chan)
 415{
 416	struct lpg *lpg = chan->lpg;
 417	unsigned int hi_pause;
 418	unsigned int lo_pause;
 419	unsigned int conf = 0;
 420	unsigned int lo_idx = chan->pattern_lo_idx;
 421	unsigned int hi_idx = chan->pattern_hi_idx;
 422	u16 step = chan->ramp_tick_ms;
 423
 424	if (!chan->ramp_enabled || chan->pattern_lo_idx == chan->pattern_hi_idx)
 425		return;
 426
 427	hi_pause = DIV_ROUND_UP(chan->ramp_hi_pause_ms, step);
 428	lo_pause = DIV_ROUND_UP(chan->ramp_lo_pause_ms, step);
 429
 430	if (!chan->ramp_reverse)
 431		conf |= LPG_PATTERN_CONFIG_LO_TO_HI;
 432	if (!chan->ramp_oneshot)
 433		conf |= LPG_PATTERN_CONFIG_REPEAT;
 434	if (chan->ramp_ping_pong)
 435		conf |= LPG_PATTERN_CONFIG_TOGGLE;
 436	if (chan->ramp_hi_pause_ms)
 437		conf |= LPG_PATTERN_CONFIG_PAUSE_HI;
 438	if (chan->ramp_lo_pause_ms)
 439		conf |= LPG_PATTERN_CONFIG_PAUSE_LO;
 440
 441	regmap_write(lpg->map, chan->base + LPG_PATTERN_CONFIG_REG, conf);
 442	regmap_write(lpg->map, chan->base + LPG_HI_IDX_REG, hi_idx);
 443	regmap_write(lpg->map, chan->base + LPG_LO_IDX_REG, lo_idx);
 444
 445	regmap_bulk_write(lpg->map, chan->base + LPG_RAMP_DURATION_REG, &step, sizeof(step));
 446	regmap_write(lpg->map, chan->base + LPG_HI_PAUSE_REG, hi_pause);
 447	regmap_write(lpg->map, chan->base + LPG_LO_PAUSE_REG, lo_pause);
 448}
 449
 450#define LPG_ENABLE_CONTROL_OUTPUT		BIT(7)
 451#define LPG_ENABLE_CONTROL_BUFFER_TRISTATE	BIT(5)
 452#define LPG_ENABLE_CONTROL_SRC_PWM		BIT(2)
 453#define LPG_ENABLE_CONTROL_RAMP_GEN		BIT(1)
 454
 455static void lpg_apply_control(struct lpg_channel *chan)
 456{
 457	unsigned int ctrl;
 458	struct lpg *lpg = chan->lpg;
 459
 460	ctrl = LPG_ENABLE_CONTROL_BUFFER_TRISTATE;
 461
 462	if (chan->enabled)
 463		ctrl |= LPG_ENABLE_CONTROL_OUTPUT;
 464
 465	if (chan->pattern_lo_idx != chan->pattern_hi_idx)
 466		ctrl |= LPG_ENABLE_CONTROL_RAMP_GEN;
 467	else
 468		ctrl |= LPG_ENABLE_CONTROL_SRC_PWM;
 469
 470	regmap_write(lpg->map, chan->base + PWM_ENABLE_CONTROL_REG, ctrl);
 471
 472	/*
 473	 * Due to LPG hardware bug, in the PWM mode, having enabled PWM,
 474	 * We have to write PWM values one more time.
 475	 */
 476	if (chan->enabled)
 477		lpg_apply_pwm_value(chan);
 478}
 479
 480#define LPG_SYNC_PWM	BIT(0)
 481
 482static void lpg_apply_sync(struct lpg_channel *chan)
 483{
 484	struct lpg *lpg = chan->lpg;
 485
 486	regmap_write(lpg->map, chan->base + PWM_SYNC_REG, LPG_SYNC_PWM);
 487}
 488
 489static int lpg_parse_dtest(struct lpg *lpg)
 490{
 491	struct lpg_channel *chan;
 492	struct device_node *np = lpg->dev->of_node;
 493	int count;
 494	int ret;
 495	int i;
 496
 497	count = of_property_count_u32_elems(np, "qcom,dtest");
 498	if (count == -EINVAL) {
 499		return 0;
 500	} else if (count < 0) {
 501		ret = count;
 502		goto err_malformed;
 503	} else if (count != lpg->data->num_channels * 2) {
 504		dev_err(lpg->dev, "qcom,dtest needs to be %d items\n",
 505			lpg->data->num_channels * 2);
 506		return -EINVAL;
 507	}
 508
 509	for (i = 0; i < lpg->data->num_channels; i++) {
 510		chan = &lpg->channels[i];
 511
 512		ret = of_property_read_u32_index(np, "qcom,dtest", i * 2,
 513						 &chan->dtest_line);
 514		if (ret)
 515			goto err_malformed;
 516
 517		ret = of_property_read_u32_index(np, "qcom,dtest", i * 2 + 1,
 518						 &chan->dtest_value);
 519		if (ret)
 520			goto err_malformed;
 521	}
 522
 523	return 0;
 524
 525err_malformed:
 526	dev_err(lpg->dev, "malformed qcom,dtest\n");
 527	return ret;
 528}
 529
 530static void lpg_apply_dtest(struct lpg_channel *chan)
 531{
 532	struct lpg *lpg = chan->lpg;
 533
 534	if (!chan->dtest_line)
 535		return;
 536
 537	regmap_write(lpg->map, chan->base + PWM_SEC_ACCESS_REG, 0xa5);
 538	regmap_write(lpg->map, chan->base + PWM_DTEST_REG(chan->dtest_line),
 539		     chan->dtest_value);
 540}
 541
 542static void lpg_apply(struct lpg_channel *chan)
 543{
 544	lpg_disable_glitch(chan);
 545	lpg_apply_freq(chan);
 546	lpg_apply_pwm_value(chan);
 547	lpg_apply_control(chan);
 548	lpg_apply_sync(chan);
 549	lpg_apply_lut_control(chan);
 550	lpg_enable_glitch(chan);
 551}
 552
 553static void lpg_brightness_set(struct lpg_led *led, struct led_classdev *cdev,
 554			       struct mc_subled *subleds)
 555{
 556	enum led_brightness brightness;
 557	struct lpg_channel *chan;
 558	unsigned int triled_enabled = 0;
 559	unsigned int triled_mask = 0;
 560	unsigned int lut_mask = 0;
 561	unsigned int duty;
 562	struct lpg *lpg = led->lpg;
 563	int i;
 564
 565	for (i = 0; i < led->num_channels; i++) {
 566		chan = led->channels[i];
 567		brightness = subleds[i].brightness;
 568
 569		if (brightness == LED_OFF) {
 570			chan->enabled = false;
 571			chan->ramp_enabled = false;
 572		} else if (chan->pattern_lo_idx != chan->pattern_hi_idx) {
 573			lpg_calc_freq(chan, NSEC_PER_MSEC);
 574
 575			chan->enabled = true;
 576			chan->ramp_enabled = true;
 577
 578			lut_mask |= chan->lut_mask;
 579			triled_enabled |= chan->triled_mask;
 580		} else {
 581			lpg_calc_freq(chan, NSEC_PER_MSEC);
 582
 583			duty = div_u64(brightness * chan->period, cdev->max_brightness);
 584			lpg_calc_duty(chan, duty);
 585			chan->enabled = true;
 586			chan->ramp_enabled = false;
 587
 588			triled_enabled |= chan->triled_mask;
 589		}
 590
 591		triled_mask |= chan->triled_mask;
 592
 593		lpg_apply(chan);
 594	}
 595
 596	/* Toggle triled lines */
 597	if (triled_mask)
 598		triled_set(lpg, triled_mask, triled_enabled);
 599
 600	/* Trigger start of ramp generator(s) */
 601	if (lut_mask)
 602		lpg_lut_sync(lpg, lut_mask);
 603}
 604
 605static int lpg_brightness_single_set(struct led_classdev *cdev,
 606				     enum led_brightness value)
 607{
 608	struct lpg_led *led = container_of(cdev, struct lpg_led, cdev);
 609	struct mc_subled info;
 610
 611	mutex_lock(&led->lpg->lock);
 612
 613	info.brightness = value;
 614	lpg_brightness_set(led, cdev, &info);
 615
 616	mutex_unlock(&led->lpg->lock);
 617
 618	return 0;
 619}
 620
 621static int lpg_brightness_mc_set(struct led_classdev *cdev,
 622				 enum led_brightness value)
 623{
 624	struct led_classdev_mc *mc = lcdev_to_mccdev(cdev);
 625	struct lpg_led *led = container_of(mc, struct lpg_led, mcdev);
 626
 627	mutex_lock(&led->lpg->lock);
 628
 629	led_mc_calc_color_components(mc, value);
 630	lpg_brightness_set(led, cdev, mc->subled_info);
 631
 632	mutex_unlock(&led->lpg->lock);
 633
 634	return 0;
 635}
 636
 637static int lpg_blink_set(struct lpg_led *led,
 638			 unsigned long *delay_on, unsigned long *delay_off)
 639{
 640	struct lpg_channel *chan;
 641	unsigned int period;
 642	unsigned int triled_mask = 0;
 643	struct lpg *lpg = led->lpg;
 644	u64 duty;
 645	int i;
 646
 647	if (!*delay_on && !*delay_off) {
 648		*delay_on = 500;
 649		*delay_off = 500;
 650	}
 651
 652	duty = *delay_on * NSEC_PER_MSEC;
 653	period = (*delay_on + *delay_off) * NSEC_PER_MSEC;
 654
 655	for (i = 0; i < led->num_channels; i++) {
 656		chan = led->channels[i];
 657
 658		lpg_calc_freq(chan, period);
 659		lpg_calc_duty(chan, duty);
 660
 661		chan->enabled = true;
 662		chan->ramp_enabled = false;
 663
 664		triled_mask |= chan->triled_mask;
 665
 666		lpg_apply(chan);
 667	}
 668
 669	/* Enable triled lines */
 670	triled_set(lpg, triled_mask, triled_mask);
 671
 672	chan = led->channels[0];
 673	duty = div_u64(chan->pwm_value * chan->period, LPG_RESOLUTION);
 674	*delay_on = div_u64(duty, NSEC_PER_MSEC);
 675	*delay_off = div_u64(chan->period - duty, NSEC_PER_MSEC);
 676
 677	return 0;
 678}
 679
 680static int lpg_blink_single_set(struct led_classdev *cdev,
 681				unsigned long *delay_on, unsigned long *delay_off)
 682{
 683	struct lpg_led *led = container_of(cdev, struct lpg_led, cdev);
 684	int ret;
 685
 686	mutex_lock(&led->lpg->lock);
 687
 688	ret = lpg_blink_set(led, delay_on, delay_off);
 689
 690	mutex_unlock(&led->lpg->lock);
 691
 692	return ret;
 693}
 694
 695static int lpg_blink_mc_set(struct led_classdev *cdev,
 696			    unsigned long *delay_on, unsigned long *delay_off)
 697{
 698	struct led_classdev_mc *mc = lcdev_to_mccdev(cdev);
 699	struct lpg_led *led = container_of(mc, struct lpg_led, mcdev);
 700	int ret;
 701
 702	mutex_lock(&led->lpg->lock);
 703
 704	ret = lpg_blink_set(led, delay_on, delay_off);
 705
 706	mutex_unlock(&led->lpg->lock);
 707
 708	return ret;
 709}
 710
 711static int lpg_pattern_set(struct lpg_led *led, struct led_pattern *led_pattern,
 712			   u32 len, int repeat)
 713{
 714	struct lpg_channel *chan;
 715	struct lpg *lpg = led->lpg;
 716	struct led_pattern *pattern;
 717	unsigned int brightness_a;
 718	unsigned int brightness_b;
 719	unsigned int actual_len;
 720	unsigned int hi_pause;
 721	unsigned int lo_pause;
 722	unsigned int delta_t;
 723	unsigned int lo_idx;
 724	unsigned int hi_idx;
 725	unsigned int i;
 726	bool ping_pong = true;
 727	int ret = -EINVAL;
 728
 729	/* Hardware only support oneshot or indefinite loops */
 730	if (repeat != -1 && repeat != 1)
 731		return -EINVAL;
 732
 733	/*
 734	 * The standardized leds-trigger-pattern format defines that the
 735	 * brightness of the LED follows a linear transition from one entry
 736	 * in the pattern to the next, over the given delta_t time. It
 737	 * describes that the way to perform instant transitions a zero-length
 738	 * entry should be added following a pattern entry.
 739	 *
 740	 * The LPG hardware is only able to perform the latter (no linear
 741	 * transitions), so require each entry in the pattern to be followed by
 742	 * a zero-length transition.
 743	 */
 744	if (len % 2)
 745		return -EINVAL;
 746
 747	pattern = kcalloc(len / 2, sizeof(*pattern), GFP_KERNEL);
 748	if (!pattern)
 749		return -ENOMEM;
 750
 751	for (i = 0; i < len; i += 2) {
 752		if (led_pattern[i].brightness != led_pattern[i + 1].brightness)
 753			goto out_free_pattern;
 754		if (led_pattern[i + 1].delta_t != 0)
 755			goto out_free_pattern;
 756
 757		pattern[i / 2].brightness = led_pattern[i].brightness;
 758		pattern[i / 2].delta_t = led_pattern[i].delta_t;
 759	}
 760
 761	len /= 2;
 762
 763	/*
 764	 * Specifying a pattern of length 1 causes the hardware to iterate
 765	 * through the entire LUT, so prohibit this.
 766	 */
 767	if (len < 2)
 768		goto out_free_pattern;
 769
 770	/*
 771	 * The LPG plays patterns with at a fixed pace, a "low pause" can be
 772	 * used to stretch the first delay of the pattern and a "high pause"
 773	 * the last one.
 774	 *
 775	 * In order to save space the pattern can be played in "ping pong"
 776	 * mode, in which the pattern is first played forward, then "high
 777	 * pause" is applied, then the pattern is played backwards and finally
 778	 * the "low pause" is applied.
 779	 *
 780	 * The middle elements of the pattern are used to determine delta_t and
 781	 * the "low pause" and "high pause" multipliers are derrived from this.
 782	 *
 783	 * The first element in the pattern is used to determine "low pause".
 784	 *
 785	 * If the specified pattern is a palindrome the ping pong mode is
 786	 * enabled. In this scenario the delta_t of the middle entry (i.e. the
 787	 * last in the programmed pattern) determines the "high pause".
 788	 */
 789
 790	/* Detect palindromes and use "ping pong" to reduce LUT usage */
 791	for (i = 0; i < len / 2; i++) {
 792		brightness_a = pattern[i].brightness;
 793		brightness_b = pattern[len - i - 1].brightness;
 794
 795		if (brightness_a != brightness_b) {
 796			ping_pong = false;
 797			break;
 798		}
 799	}
 800
 801	/* The pattern length to be written to the LUT */
 802	if (ping_pong)
 803		actual_len = (len + 1) / 2;
 804	else
 805		actual_len = len;
 806
 807	/*
 808	 * Validate that all delta_t in the pattern are the same, with the
 809	 * exception of the middle element in case of ping_pong.
 810	 */
 811	delta_t = pattern[1].delta_t;
 812	for (i = 2; i < len; i++) {
 813		if (pattern[i].delta_t != delta_t) {
 814			/*
 815			 * Allow last entry in the full or shortened pattern to
 816			 * specify hi pause. Reject other variations.
 817			 */
 818			if (i != actual_len - 1)
 819				goto out_free_pattern;
 820		}
 821	}
 822
 823	/* LPG_RAMP_DURATION_REG is a 9bit */
 824	if (delta_t >= BIT(9))
 825		goto out_free_pattern;
 826
 827	/* Find "low pause" and "high pause" in the pattern */
 828	lo_pause = pattern[0].delta_t;
 829	hi_pause = pattern[actual_len - 1].delta_t;
 830
 831	mutex_lock(&lpg->lock);
 832	ret = lpg_lut_store(lpg, pattern, actual_len, &lo_idx, &hi_idx);
 833	if (ret < 0)
 834		goto out_unlock;
 835
 836	for (i = 0; i < led->num_channels; i++) {
 837		chan = led->channels[i];
 838
 839		chan->ramp_tick_ms = delta_t;
 840		chan->ramp_ping_pong = ping_pong;
 841		chan->ramp_oneshot = repeat != -1;
 842
 843		chan->ramp_lo_pause_ms = lo_pause;
 844		chan->ramp_hi_pause_ms = hi_pause;
 845
 846		chan->pattern_lo_idx = lo_idx;
 847		chan->pattern_hi_idx = hi_idx;
 848	}
 849
 850out_unlock:
 851	mutex_unlock(&lpg->lock);
 852out_free_pattern:
 853	kfree(pattern);
 854
 855	return ret;
 856}
 857
 858static int lpg_pattern_single_set(struct led_classdev *cdev,
 859				  struct led_pattern *pattern, u32 len,
 860				  int repeat)
 861{
 862	struct lpg_led *led = container_of(cdev, struct lpg_led, cdev);
 863	int ret;
 864
 865	ret = lpg_pattern_set(led, pattern, len, repeat);
 866	if (ret < 0)
 867		return ret;
 868
 869	lpg_brightness_single_set(cdev, LED_FULL);
 870
 871	return 0;
 872}
 873
 874static int lpg_pattern_mc_set(struct led_classdev *cdev,
 875			      struct led_pattern *pattern, u32 len,
 876			      int repeat)
 877{
 878	struct led_classdev_mc *mc = lcdev_to_mccdev(cdev);
 879	struct lpg_led *led = container_of(mc, struct lpg_led, mcdev);
 880	int ret;
 881
 882	ret = lpg_pattern_set(led, pattern, len, repeat);
 883	if (ret < 0)
 884		return ret;
 885
 886	led_mc_calc_color_components(mc, LED_FULL);
 887	lpg_brightness_set(led, cdev, mc->subled_info);
 888
 889	return 0;
 890}
 891
 892static int lpg_pattern_clear(struct lpg_led *led)
 893{
 894	struct lpg_channel *chan;
 895	struct lpg *lpg = led->lpg;
 896	int i;
 897
 898	mutex_lock(&lpg->lock);
 899
 900	chan = led->channels[0];
 901	lpg_lut_free(lpg, chan->pattern_lo_idx, chan->pattern_hi_idx);
 902
 903	for (i = 0; i < led->num_channels; i++) {
 904		chan = led->channels[i];
 905		chan->pattern_lo_idx = 0;
 906		chan->pattern_hi_idx = 0;
 907	}
 908
 909	mutex_unlock(&lpg->lock);
 910
 911	return 0;
 912}
 913
 914static int lpg_pattern_single_clear(struct led_classdev *cdev)
 915{
 916	struct lpg_led *led = container_of(cdev, struct lpg_led, cdev);
 917
 918	return lpg_pattern_clear(led);
 919}
 920
 921static int lpg_pattern_mc_clear(struct led_classdev *cdev)
 922{
 923	struct led_classdev_mc *mc = lcdev_to_mccdev(cdev);
 924	struct lpg_led *led = container_of(mc, struct lpg_led, mcdev);
 925
 926	return lpg_pattern_clear(led);
 927}
 928
 929static int lpg_pwm_request(struct pwm_chip *chip, struct pwm_device *pwm)
 930{
 931	struct lpg *lpg = container_of(chip, struct lpg, pwm);
 932	struct lpg_channel *chan = &lpg->channels[pwm->hwpwm];
 933
 934	return chan->in_use ? -EBUSY : 0;
 935}
 936
 937/*
 938 * Limitations:
 939 * - Updating both duty and period is not done atomically, so the output signal
 940 *   will momentarily be a mix of the settings.
 941 * - Changed parameters takes effect immediately.
 942 * - A disabled channel outputs a logical 0.
 943 */
 944static int lpg_pwm_apply(struct pwm_chip *chip, struct pwm_device *pwm,
 945			 const struct pwm_state *state)
 946{
 947	struct lpg *lpg = container_of(chip, struct lpg, pwm);
 948	struct lpg_channel *chan = &lpg->channels[pwm->hwpwm];
 949	int ret = 0;
 950
 951	if (state->polarity != PWM_POLARITY_NORMAL)
 952		return -EINVAL;
 953
 954	mutex_lock(&lpg->lock);
 955
 956	if (state->enabled) {
 957		ret = lpg_calc_freq(chan, state->period);
 958		if (ret < 0)
 959			goto out_unlock;
 960
 961		lpg_calc_duty(chan, state->duty_cycle);
 962	}
 963	chan->enabled = state->enabled;
 964
 965	lpg_apply(chan);
 966
 967	triled_set(lpg, chan->triled_mask, chan->enabled ? chan->triled_mask : 0);
 968
 969out_unlock:
 970	mutex_unlock(&lpg->lock);
 971
 972	return ret;
 973}
 974
 975static int lpg_pwm_get_state(struct pwm_chip *chip, struct pwm_device *pwm,
 976			     struct pwm_state *state)
 977{
 978	struct lpg *lpg = container_of(chip, struct lpg, pwm);
 979	struct lpg_channel *chan = &lpg->channels[pwm->hwpwm];
 980	unsigned int pre_div;
 981	unsigned int refclk;
 982	unsigned int val;
 983	unsigned int m;
 984	u16 pwm_value;
 985	int ret;
 986
 987	ret = regmap_read(lpg->map, chan->base + LPG_SIZE_CLK_REG, &val);
 988	if (ret)
 989		return ret;
 990
 991	refclk = lpg_clk_rates[val & PWM_CLK_SELECT_MASK];
 992	if (refclk) {
 993		ret = regmap_read(lpg->map, chan->base + LPG_PREDIV_CLK_REG, &val);
 994		if (ret)
 995			return ret;
 996
 997		pre_div = lpg_pre_divs[FIELD_GET(PWM_FREQ_PRE_DIV_MASK, val)];
 998		m = FIELD_GET(PWM_FREQ_EXP_MASK, val);
 999
1000		ret = regmap_bulk_read(lpg->map, chan->base + PWM_VALUE_REG, &pwm_value, sizeof(pwm_value));
1001		if (ret)
1002			return ret;
1003
1004		state->period = DIV_ROUND_UP_ULL((u64)NSEC_PER_SEC * LPG_RESOLUTION * pre_div * (1 << m), refclk);
1005		state->duty_cycle = DIV_ROUND_UP_ULL((u64)NSEC_PER_SEC * pwm_value * pre_div * (1 << m), refclk);
1006	} else {
1007		state->period = 0;
1008		state->duty_cycle = 0;
1009	}
1010
1011	ret = regmap_read(lpg->map, chan->base + PWM_ENABLE_CONTROL_REG, &val);
1012	if (ret)
1013		return ret;
1014
1015	state->enabled = FIELD_GET(LPG_ENABLE_CONTROL_OUTPUT, val);
1016	state->polarity = PWM_POLARITY_NORMAL;
1017
1018	if (state->duty_cycle > state->period)
1019		state->duty_cycle = state->period;
1020
1021	return 0;
1022}
1023
1024static const struct pwm_ops lpg_pwm_ops = {
1025	.request = lpg_pwm_request,
1026	.apply = lpg_pwm_apply,
1027	.get_state = lpg_pwm_get_state,
1028	.owner = THIS_MODULE,
1029};
1030
1031static int lpg_add_pwm(struct lpg *lpg)
1032{
1033	int ret;
1034
1035	lpg->pwm.base = -1;
1036	lpg->pwm.dev = lpg->dev;
1037	lpg->pwm.npwm = lpg->num_channels;
1038	lpg->pwm.ops = &lpg_pwm_ops;
1039
1040	ret = pwmchip_add(&lpg->pwm);
1041	if (ret)
1042		dev_err(lpg->dev, "failed to add PWM chip: ret %d\n", ret);
1043
1044	return ret;
1045}
1046
1047static int lpg_parse_channel(struct lpg *lpg, struct device_node *np,
1048			     struct lpg_channel **channel)
1049{
1050	struct lpg_channel *chan;
1051	u32 color = LED_COLOR_ID_GREEN;
1052	u32 reg;
1053	int ret;
1054
1055	ret = of_property_read_u32(np, "reg", &reg);
1056	if (ret || !reg || reg > lpg->num_channels) {
1057		dev_err(lpg->dev, "invalid \"reg\" of %pOFn\n", np);
1058		return -EINVAL;
1059	}
1060
1061	chan = &lpg->channels[reg - 1];
1062	chan->in_use = true;
1063
1064	ret = of_property_read_u32(np, "color", &color);
1065	if (ret < 0 && ret != -EINVAL) {
1066		dev_err(lpg->dev, "failed to parse \"color\" of %pOF\n", np);
1067		return ret;
1068	}
1069
1070	chan->color = color;
1071
1072	*channel = chan;
1073
1074	return 0;
1075}
1076
1077static int lpg_add_led(struct lpg *lpg, struct device_node *np)
1078{
1079	struct led_init_data init_data = {};
1080	struct led_classdev *cdev;
1081	struct device_node *child;
1082	struct mc_subled *info;
1083	struct lpg_led *led;
1084	const char *state;
1085	int num_channels;
1086	u32 color = 0;
1087	int ret;
1088	int i;
1089
1090	ret = of_property_read_u32(np, "color", &color);
1091	if (ret < 0 && ret != -EINVAL) {
1092		dev_err(lpg->dev, "failed to parse \"color\" of %pOF\n", np);
1093		return ret;
1094	}
1095
1096	if (color == LED_COLOR_ID_RGB)
1097		num_channels = of_get_available_child_count(np);
1098	else
1099		num_channels = 1;
1100
1101	led = devm_kzalloc(lpg->dev, struct_size(led, channels, num_channels), GFP_KERNEL);
1102	if (!led)
1103		return -ENOMEM;
1104
1105	led->lpg = lpg;
1106	led->num_channels = num_channels;
1107
1108	if (color == LED_COLOR_ID_RGB) {
1109		info = devm_kcalloc(lpg->dev, num_channels, sizeof(*info), GFP_KERNEL);
1110		if (!info)
1111			return -ENOMEM;
1112		i = 0;
1113		for_each_available_child_of_node(np, child) {
1114			ret = lpg_parse_channel(lpg, child, &led->channels[i]);
1115			if (ret < 0)
1116				return ret;
1117
1118			info[i].color_index = led->channels[i]->color;
1119			info[i].intensity = 0;
1120			i++;
1121		}
1122
1123		led->mcdev.subled_info = info;
1124		led->mcdev.num_colors = num_channels;
1125
1126		cdev = &led->mcdev.led_cdev;
1127		cdev->brightness_set_blocking = lpg_brightness_mc_set;
1128		cdev->blink_set = lpg_blink_mc_set;
1129
1130		/* Register pattern accessors only if we have a LUT block */
1131		if (lpg->lut_base) {
1132			cdev->pattern_set = lpg_pattern_mc_set;
1133			cdev->pattern_clear = lpg_pattern_mc_clear;
1134		}
1135	} else {
1136		ret = lpg_parse_channel(lpg, np, &led->channels[0]);
1137		if (ret < 0)
1138			return ret;
1139
1140		cdev = &led->cdev;
1141		cdev->brightness_set_blocking = lpg_brightness_single_set;
1142		cdev->blink_set = lpg_blink_single_set;
1143
1144		/* Register pattern accessors only if we have a LUT block */
1145		if (lpg->lut_base) {
1146			cdev->pattern_set = lpg_pattern_single_set;
1147			cdev->pattern_clear = lpg_pattern_single_clear;
1148		}
1149	}
1150
1151	cdev->default_trigger = of_get_property(np, "linux,default-trigger", NULL);
1152	cdev->max_brightness = LPG_RESOLUTION - 1;
1153
1154	if (!of_property_read_string(np, "default-state", &state) &&
1155	    !strcmp(state, "on"))
1156		cdev->brightness = cdev->max_brightness;
1157	else
1158		cdev->brightness = LED_OFF;
1159
1160	cdev->brightness_set_blocking(cdev, cdev->brightness);
1161
1162	init_data.fwnode = of_fwnode_handle(np);
1163
1164	if (color == LED_COLOR_ID_RGB)
1165		ret = devm_led_classdev_multicolor_register_ext(lpg->dev, &led->mcdev, &init_data);
1166	else
1167		ret = devm_led_classdev_register_ext(lpg->dev, &led->cdev, &init_data);
1168	if (ret)
1169		dev_err(lpg->dev, "unable to register %s\n", cdev->name);
1170
1171	return ret;
1172}
1173
1174static int lpg_init_channels(struct lpg *lpg)
1175{
1176	const struct lpg_data *data = lpg->data;
1177	struct lpg_channel *chan;
1178	int i;
1179
1180	lpg->num_channels = data->num_channels;
1181	lpg->channels = devm_kcalloc(lpg->dev, data->num_channels,
1182				     sizeof(struct lpg_channel), GFP_KERNEL);
1183	if (!lpg->channels)
1184		return -ENOMEM;
1185
1186	for (i = 0; i < data->num_channels; i++) {
1187		chan = &lpg->channels[i];
1188
1189		chan->lpg = lpg;
1190		chan->base = data->channels[i].base;
1191		chan->triled_mask = data->channels[i].triled_mask;
1192		chan->lut_mask = BIT(i);
1193
1194		regmap_read(lpg->map, chan->base + LPG_SUBTYPE_REG, &chan->subtype);
1195	}
1196
1197	return 0;
1198}
1199
1200static int lpg_init_triled(struct lpg *lpg)
1201{
1202	struct device_node *np = lpg->dev->of_node;
1203	int ret;
1204
1205	/* Skip initialization if we don't have a triled block */
1206	if (!lpg->data->triled_base)
1207		return 0;
1208
1209	lpg->triled_base = lpg->data->triled_base;
1210	lpg->triled_has_atc_ctl = lpg->data->triled_has_atc_ctl;
1211	lpg->triled_has_src_sel = lpg->data->triled_has_src_sel;
1212
1213	if (lpg->triled_has_src_sel) {
1214		ret = of_property_read_u32(np, "qcom,power-source", &lpg->triled_src);
1215		if (ret || lpg->triled_src == 2 || lpg->triled_src > 3) {
1216			dev_err(lpg->dev, "invalid power source\n");
1217			return -EINVAL;
1218		}
1219	}
1220
1221	/* Disable automatic trickle charge LED */
1222	if (lpg->triled_has_atc_ctl)
1223		regmap_write(lpg->map, lpg->triled_base + TRI_LED_ATC_CTL, 0);
1224
1225	/* Configure power source */
1226	if (lpg->triled_has_src_sel)
1227		regmap_write(lpg->map, lpg->triled_base + TRI_LED_SRC_SEL, lpg->triled_src);
1228
1229	/* Default all outputs to off */
1230	regmap_write(lpg->map, lpg->triled_base + TRI_LED_EN_CTL, 0);
1231
1232	return 0;
1233}
1234
1235static int lpg_init_lut(struct lpg *lpg)
1236{
1237	const struct lpg_data *data = lpg->data;
1238
1239	if (!data->lut_base)
1240		return 0;
1241
1242	lpg->lut_base = data->lut_base;
1243	lpg->lut_size = data->lut_size;
1244
1245	lpg->lut_bitmap = devm_bitmap_zalloc(lpg->dev, lpg->lut_size, GFP_KERNEL);
1246	if (!lpg->lut_bitmap)
1247		return -ENOMEM;
1248
1249	return 0;
1250}
1251
1252static int lpg_probe(struct platform_device *pdev)
1253{
1254	struct device_node *np;
1255	struct lpg *lpg;
1256	int ret;
1257	int i;
1258
1259	lpg = devm_kzalloc(&pdev->dev, sizeof(*lpg), GFP_KERNEL);
1260	if (!lpg)
1261		return -ENOMEM;
1262
1263	lpg->data = of_device_get_match_data(&pdev->dev);
1264	if (!lpg->data)
1265		return -EINVAL;
1266
1267	platform_set_drvdata(pdev, lpg);
1268
1269	lpg->dev = &pdev->dev;
1270	mutex_init(&lpg->lock);
1271
1272	lpg->map = dev_get_regmap(pdev->dev.parent, NULL);
1273	if (!lpg->map)
1274		return dev_err_probe(&pdev->dev, -ENXIO, "parent regmap unavailable\n");
1275
1276	ret = lpg_init_channels(lpg);
1277	if (ret < 0)
1278		return ret;
1279
1280	ret = lpg_parse_dtest(lpg);
1281	if (ret < 0)
1282		return ret;
1283
1284	ret = lpg_init_triled(lpg);
1285	if (ret < 0)
1286		return ret;
1287
1288	ret = lpg_init_lut(lpg);
1289	if (ret < 0)
1290		return ret;
1291
1292	for_each_available_child_of_node(pdev->dev.of_node, np) {
1293		ret = lpg_add_led(lpg, np);
1294		if (ret)
1295			return ret;
1296	}
1297
1298	for (i = 0; i < lpg->num_channels; i++)
1299		lpg_apply_dtest(&lpg->channels[i]);
1300
1301	return lpg_add_pwm(lpg);
1302}
1303
1304static int lpg_remove(struct platform_device *pdev)
1305{
1306	struct lpg *lpg = platform_get_drvdata(pdev);
1307
1308	pwmchip_remove(&lpg->pwm);
1309
1310	return 0;
1311}
1312
1313static const struct lpg_data pm8916_pwm_data = {
1314	.num_channels = 1,
1315	.channels = (const struct lpg_channel_data[]) {
1316		{ .base = 0xbc00 },
1317	},
1318};
1319
1320static const struct lpg_data pm8941_lpg_data = {
1321	.lut_base = 0xb000,
1322	.lut_size = 64,
1323
1324	.triled_base = 0xd000,
1325	.triled_has_atc_ctl = true,
1326	.triled_has_src_sel = true,
1327
1328	.num_channels = 8,
1329	.channels = (const struct lpg_channel_data[]) {
1330		{ .base = 0xb100 },
1331		{ .base = 0xb200 },
1332		{ .base = 0xb300 },
1333		{ .base = 0xb400 },
1334		{ .base = 0xb500, .triled_mask = BIT(5) },
1335		{ .base = 0xb600, .triled_mask = BIT(6) },
1336		{ .base = 0xb700, .triled_mask = BIT(7) },
1337		{ .base = 0xb800 },
1338	},
1339};
1340
1341static const struct lpg_data pm8994_lpg_data = {
1342	.lut_base = 0xb000,
1343	.lut_size = 64,
1344
1345	.num_channels = 6,
1346	.channels = (const struct lpg_channel_data[]) {
1347		{ .base = 0xb100 },
1348		{ .base = 0xb200 },
1349		{ .base = 0xb300 },
1350		{ .base = 0xb400 },
1351		{ .base = 0xb500 },
1352		{ .base = 0xb600 },
1353	},
1354};
1355
1356static const struct lpg_data pmi8994_lpg_data = {
1357	.lut_base = 0xb000,
1358	.lut_size = 24,
1359
1360	.triled_base = 0xd000,
1361	.triled_has_atc_ctl = true,
1362	.triled_has_src_sel = true,
1363
1364	.num_channels = 4,
1365	.channels = (const struct lpg_channel_data[]) {
1366		{ .base = 0xb100, .triled_mask = BIT(5) },
1367		{ .base = 0xb200, .triled_mask = BIT(6) },
1368		{ .base = 0xb300, .triled_mask = BIT(7) },
1369		{ .base = 0xb400 },
1370	},
1371};
1372
1373static const struct lpg_data pmi8998_lpg_data = {
1374	.lut_base = 0xb000,
1375	.lut_size = 49,
1376
1377	.triled_base = 0xd000,
1378
1379	.num_channels = 6,
1380	.channels = (const struct lpg_channel_data[]) {
1381		{ .base = 0xb100 },
1382		{ .base = 0xb200 },
1383		{ .base = 0xb300, .triled_mask = BIT(5) },
1384		{ .base = 0xb400, .triled_mask = BIT(6) },
1385		{ .base = 0xb500, .triled_mask = BIT(7) },
1386		{ .base = 0xb600 },
1387	},
1388};
1389
1390static const struct lpg_data pm8150b_lpg_data = {
1391	.lut_base = 0xb000,
1392	.lut_size = 24,
1393
1394	.triled_base = 0xd000,
1395
1396	.num_channels = 2,
1397	.channels = (const struct lpg_channel_data[]) {
1398		{ .base = 0xb100, .triled_mask = BIT(7) },
1399		{ .base = 0xb200, .triled_mask = BIT(6) },
1400	},
1401};
1402
1403static const struct lpg_data pm8150l_lpg_data = {
1404	.lut_base = 0xb000,
1405	.lut_size = 48,
1406
1407	.triled_base = 0xd000,
1408
1409	.num_channels = 5,
1410	.channels = (const struct lpg_channel_data[]) {
1411		{ .base = 0xb100, .triled_mask = BIT(7) },
1412		{ .base = 0xb200, .triled_mask = BIT(6) },
1413		{ .base = 0xb300, .triled_mask = BIT(5) },
1414		{ .base = 0xbc00 },
1415		{ .base = 0xbd00 },
1416
1417	},
1418};
1419
1420static const struct lpg_data pm8350c_pwm_data = {
1421	.triled_base = 0xef00,
1422
1423	.num_channels = 4,
1424	.channels = (const struct lpg_channel_data[]) {
1425		{ .base = 0xe800, .triled_mask = BIT(7) },
1426		{ .base = 0xe900, .triled_mask = BIT(6) },
1427		{ .base = 0xea00, .triled_mask = BIT(5) },
1428		{ .base = 0xeb00 },
1429	},
1430};
1431
1432static const struct of_device_id lpg_of_table[] = {
1433	{ .compatible = "qcom,pm8150b-lpg", .data = &pm8150b_lpg_data },
1434	{ .compatible = "qcom,pm8150l-lpg", .data = &pm8150l_lpg_data },
1435	{ .compatible = "qcom,pm8350c-pwm", .data = &pm8350c_pwm_data },
1436	{ .compatible = "qcom,pm8916-pwm", .data = &pm8916_pwm_data },
1437	{ .compatible = "qcom,pm8941-lpg", .data = &pm8941_lpg_data },
1438	{ .compatible = "qcom,pm8994-lpg", .data = &pm8994_lpg_data },
1439	{ .compatible = "qcom,pmi8994-lpg", .data = &pmi8994_lpg_data },
1440	{ .compatible = "qcom,pmi8998-lpg", .data = &pmi8998_lpg_data },
1441	{ .compatible = "qcom,pmc8180c-lpg", .data = &pm8150l_lpg_data },
1442	{}
1443};
1444MODULE_DEVICE_TABLE(of, lpg_of_table);
1445
1446static struct platform_driver lpg_driver = {
1447	.probe = lpg_probe,
1448	.remove = lpg_remove,
1449	.driver = {
1450		.name = "qcom-spmi-lpg",
1451		.of_match_table = lpg_of_table,
1452	},
1453};
1454module_platform_driver(lpg_driver);
1455
1456MODULE_DESCRIPTION("Qualcomm LPG LED driver");
1457MODULE_LICENSE("GPL v2");