Re: [PATCH 3/3] leds: leds-lp5569: Add support for Texas Instruments LP5569

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Christian,

kernel test robot noticed the following build errors:

[auto build test ERROR on lee-leds/for-leds-next]
[also build test ERROR on robh/for-next linus/master v6.9 next-20240516]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch#_base_tree_information]

url:    https://github.com/intel-lab-lkp/linux/commits/Christian-Marangi/dt-bindings-leds-lp55xx-Add-new-ti-lp5569-compatible/20240515-223434
base:   https://git.kernel.org/pub/scm/linux/kernel/git/lee/leds.git for-leds-next
patch link:    https://lore.kernel.org/r/20240515143129.31557-3-ansuelsmth%40gmail.com
patch subject: [PATCH 3/3] leds: leds-lp5569: Add support for Texas Instruments LP5569
config: alpha-allyesconfig (https://download.01.org/0day-ci/archive/20240517/202405170244.MEWiW9it-lkp@xxxxxxxxx/config)
compiler: alpha-linux-gcc (GCC) 13.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240517/202405170244.MEWiW9it-lkp@xxxxxxxxx/reproduce)

If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@xxxxxxxxx>
| Closes: https://lore.kernel.org/oe-kbuild-all/202405170244.MEWiW9it-lkp@xxxxxxxxx/

All errors (new ones prefixed by >>):

   drivers/leds/leds-lp5569.c: In function 'lp5569_post_init_device':
>> drivers/leds/leds-lp5569.c:169:16: error: implicit declaration of function 'FIELD_PREP' [-Werror=implicit-function-declaration]
     169 |         val |= FIELD_PREP(LP5569_CP_MODE_MASK, chip->pdata->charge_pump_mode);
         |                ^~~~~~~~~~
   drivers/leds/leds-lp5569.c: In function 'lp5569_load_engine':
>> drivers/leds/leds-lp5569.c:41:41: error: implicit declaration of function 'FIELD_PREP_CONST' [-Werror=implicit-function-declaration]
      41 | #define   LP5569_MODE_LOAD_ENG          FIELD_PREP_CONST(LP5569_MODE_ENG_MASK, 0x1)
         |                                         ^~~~~~~~~~~~~~~~
   drivers/leds/leds-lp5569.c:195:15: note: in expansion of macro 'LP5569_MODE_LOAD_ENG'
     195 |         val = LP5569_MODE_LOAD_ENG << LP5569_MODE_ENGn_SHIFT(idx);
         |               ^~~~~~~~~~~~~~~~~~~~
   drivers/leds/leds-lp5569.c: In function 'lp5569_init_program_engine':
>> drivers/leds/leds-lp5569.c:321:18: error: implicit declaration of function 'FIELD_GET' [-Werror=implicit-function-declaration]
     321 |         status = FIELD_GET(LP5569_ENG_STATUS_MASK, status);
         |                  ^~~~~~~~~
   drivers/leds/leds-lp5569.c: In function 'show_master_fader_leds':
>> drivers/leds/leds-lp5569.c:904:27: error: implicit declaration of function 'FIELD_MAX'; did you mean 'IPL_MAX'? [-Werror=implicit-function-declaration]
     904 |                 if (val > FIELD_MAX(LP5569_FADER_MAPPING_MASK)) {
         |                           ^~~~~~~~~
         |                           IPL_MAX
   cc1: some warnings being treated as errors


vim +/FIELD_PREP +169 drivers/leds/leds-lp5569.c

    29	
    30	#define LP5569_REG_EXEC_CTRL		0x01
    31	/*
    32	 * Program Memory Operations
    33	 * Same Mask for each engine for both mode and exec
    34	 * ENG1	GENMASK(3, 2)
    35	 * ENG2	GENMASK(5, 4)
    36	 * ENG3	GENMASK(7, 6)
    37	 */
    38	#define LP5569_MODE_ENG_MASK		GENMASK(1, 0)
    39	#define   LP5569_MODE_ENG_SHIFT		2
    40	#define   LP5569_MODE_DISABLE_ENG	FIELD_PREP_CONST(LP5569_MODE_ENG_MASK, 0x0)
  > 41	#define   LP5569_MODE_LOAD_ENG		FIELD_PREP_CONST(LP5569_MODE_ENG_MASK, 0x1)
    42	#define   LP5569_MODE_RUN_ENG		FIELD_PREP_CONST(LP5569_MODE_ENG_MASK, 0x2)
    43	#define   LP5569_MODE_HALT_ENG		FIELD_PREP_CONST(LP5569_MODE_ENG_MASK, 0x3)
    44	
    45	#define   LP5569_MODE_ENGn_SHIFT(n)	(LP5569_MODE_ENG_SHIFT + (2 * (3 - (n))))
    46	#define   LP5569_MODE_ENGn_MASK(n)	(LP5569_MODE_ENG_MASK << LP5569_MODE_ENGn_SHIFT(n))
    47	#define   LP5569_MODE_ENGn_GET(n, mode)	\
    48		(((mode) >> LP5569_MODE_ENGn_SHIFT(n)) & LP5569_MODE_ENG_MASK)
    49	
    50	#define LP5569_REG_OP_MODE		0x02
    51	#define   LP5569_EXEC_ENG_MASK		GENMASK(1, 0)
    52	#define   LP5569_EXEC_ENG_SHIFT		2
    53	#define   LP5569_EXEC_HOLD_ENG		FIELD_PREP_CONST(LP5569_EXEC_ENG_MASK, 0x0)
    54	#define   LP5569_EXEC_STEP_ENG		FIELD_PREP_CONST(LP5569_EXEC_ENG_MASK, 0x1)
    55	#define   LP5569_EXEC_RUN_ENG		FIELD_PREP_CONST(LP5569_EXEC_ENG_MASK, 0x2)
    56	#define   LP5569_EXEC_ONCE_ENG		FIELD_PREP_CONST(LP5569_EXEC_ENG_MASK, 0x3)
    57	
    58	#define   LP5569_EXEC_ENGn_SHIFT(n)	(LP5569_EXEC_ENG_SHIFT + (2 * (3 - (n))))
    59	#define   LP5569_EXEC_ENGn_MASK(n)	(LP5569_EXEC_ENG_MASK << LP5569_EXEC_ENGn_SHIFT(n))
    60	
    61	#define LP5569_REG_ENABLE_LEDS_MSB	0x04
    62	#define LP5569_REG_ENABLE_LEDS_LSB	0x05
    63	#define LP5569_REG_LED_CTRL_BASE	0x07
    64	#define   LP5569_FADER_MAPPING_MASK	GENMASK(7, 5)
    65	#define LP5569_REG_LED_PWM_BASE		0x16
    66	#define LP5569_REG_LED_CURRENT_BASE	0x22
    67	#define LP5569_REG_MISC			0x2F
    68	#define   LP5569_AUTO_INC		BIT(6)
    69	#define   LP5569_PWR_SAVE		BIT(5)
    70	#define   LP5569_CP_MODE_MASK		GENMASK(4, 3)
    71	#define   LP5569_PWM_PWR_SAVE		BIT(2)
    72	#define   LP5569_INTERNAL_CLK		BIT(0)
    73	#define LP5569_REG_MISC2		0x33
    74	#define   LP5569_LED_SHORT_TEST		BIT(4)
    75	#define   LP5569_LED_OPEN_TEST		BIT(3)
    76	#define LP5569_REG_STATUS		0x3C
    77	#define   LP5569_MASK_BUSY		BIT(7)
    78	#define   LP5569_STARTUP_BUSY		BIT(6)
    79	#define   LP5569_ENGINE_BUSY		BIT(5)
    80	#define   LP5569_ENGINE1_INT		BIT(2)
    81	#define   LP5569_ENGINE2_INT		BIT(1)
    82	#define   LP5569_ENGINE3_INT		BIT(0)
    83	#define   LP5569_ENG_STATUS_MASK	(LP5569_ENGINE1_INT | LP5569_ENGINE2_INT | \
    84						 LP5569_ENGINE3_INT)
    85	#define LP5569_REG_IO_CONTROL		0x3D
    86	#define   LP5569_CLK_OUTPUT		BIT(3)
    87	#define LP5569_REG_RESET		0x3F
    88	#define   LP5569_RESET			0xFF
    89	#define LP5569_REG_MASTER_FADER_BASE	0x46
    90	#define LP5569_REG_CH1_PROG_START	0x4B
    91	#define LP5569_REG_CH2_PROG_START	0x4C
    92	#define LP5569_REG_CH3_PROG_START	0x4D
    93	#define LP5569_REG_PROG_PAGE_SEL	0x4F
    94	#define LP5569_REG_PROG_MEM		0x50
    95	#define LP5569_REG_LED_FAULT1		0x81
    96	#define   LP5569_LED_FAULT8		BIT(0)
    97	#define LP5569_REG_LED_FAULT2		0x82
    98	#define   LP5569_LED_FAULT7		BIT(7)
    99	#define   LP5569_LED_FAULT6		BIT(6)
   100	#define   LP5569_LED_FAULT5		BIT(5)
   101	#define   LP5569_LED_FAULT4		BIT(4)
   102	#define   LP5569_LED_FAULT3		BIT(3)
   103	#define   LP5569_LED_FAULT2		BIT(2)
   104	#define   LP5569_LED_FAULT1		BIT(1)
   105	#define   LP5569_LED_FAULT0		BIT(0)
   106	
   107	#define LP5569_MAX_LEDS			9
   108	
   109	#define LP5569_PROGRAM_PAGES		16
   110	#define LP5569_PROGRAM_LENGTH		32	/* bytes */
   111	/* Memory is used like this:
   112	 * 0x00 engine 1 program
   113	 * 0x10 engine 2 program
   114	 * 0x20 engine 3 program
   115	 * 0x30 engine 1 muxing info
   116	 * 0x40 engine 2 muxing info
   117	 * 0x50 engine 3 muxing info
   118	 */
   119	#define LP5569_ENG1_PROG_ADDR		0x0
   120	#define LP5569_ENG2_PROG_ADDR		0x10
   121	#define LP5569_ENG3_PROG_ADDR		0x20
   122	#define LP5569_ENG1_MUX_ADDR		0x30
   123	#define LP5569_ENG2_MUX_ADDR		0x40
   124	#define LP5569_ENG3_MUX_ADDR		0x50
   125	
   126	/* Memory Page Selection */
   127	#define LP5569_PAGE_ENG_OFFSET		0
   128	#define LP5569_PAGE_ENG(n)		(((n) - 1) + LP5569_PAGE_ENG_OFFSET)
   129	#define LP5569_PAGE_MUX_OFFSET		3
   130	#define LP5569_PAGE_MUX(n)		(((n) - 1) + LP5569_PAGE_MUX_OFFSET)
   131	
   132	#define LEDn_STATUS_FAULT(n, status)	((status) >> (n) & BIT(0))
   133	#define LED_ACTIVE(mux, led)		(!!((mux) & (0x0001 << (led))))
   134	
   135	#define LP5569_DEFAULT_CONFIG \
   136		(LP5569_AUTO_INC | LP5569_PWR_SAVE | LP5569_PWM_PWR_SAVE)
   137	
   138	enum lp5569_chip_id {
   139		LP5569,
   140	};
   141	
   142	static int lp5569_init_program_engine(struct lp55xx_chip *chip);
   143	
   144	static inline void lp5569_wait_opmode_done(void)
   145	{
   146		usleep_range(1000, 2000);
   147	}
   148	
   149	static void lp5569_set_led_current(struct lp55xx_led *led, u8 led_current)
   150	{
   151		led->led_current = led_current;
   152		lp55xx_write(led->chip, LP5569_REG_LED_CURRENT_BASE + led->chan_nr,
   153			     led_current);
   154	}
   155	
   156	static int lp5569_post_init_device(struct lp55xx_chip *chip)
   157	{
   158		int ret;
   159		int val;
   160	
   161		ret = lp55xx_write(chip, LP5569_REG_ENABLE, LP5569_ENABLE);
   162		if (ret)
   163			return ret;
   164	
   165		/* Chip startup time is 500 us, 1 - 2 ms gives some margin */
   166		usleep_range(1000, 2000);
   167	
   168		val = LP5569_DEFAULT_CONFIG;
 > 169		val |= FIELD_PREP(LP5569_CP_MODE_MASK, chip->pdata->charge_pump_mode);
   170	
   171		if (chip->pdata->clock_mode == LP55XX_CLOCK_INT)
   172			val |= LP5569_INTERNAL_CLK;
   173	
   174		ret = lp55xx_write(chip, LP5569_REG_MISC, val);
   175		if (ret)
   176			return ret;
   177	
   178		if (chip->pdata->clock_mode == LP55XX_CLOCK_INT) {
   179			ret = lp55xx_update_bits(chip, LP5569_REG_IO_CONTROL,
   180						 LP5569_CLK_OUTPUT,
   181						 LP5569_CLK_OUTPUT);
   182			if (ret)
   183				return ret;
   184		}
   185	
   186		return lp5569_init_program_engine(chip);
   187	}
   188	
   189	static void lp5569_load_engine(struct lp55xx_chip *chip)
   190	{
   191		enum lp55xx_engine_index idx = chip->engine_idx;
   192		u8 mask, val;
   193	
   194		mask = LP5569_MODE_ENGn_MASK(idx);
   195		val = LP5569_MODE_LOAD_ENG << LP5569_MODE_ENGn_SHIFT(idx);
   196	
   197		lp55xx_update_bits(chip, LP5569_REG_OP_MODE, mask, val);
   198	
   199		lp5569_wait_opmode_done();
   200	}
   201	
   202	static void lp5569_load_engine_and_select_page(struct lp55xx_chip *chip)
   203	{
   204		enum lp55xx_engine_index idx = chip->engine_idx;
   205	
   206		lp5569_load_engine(chip);
   207	
   208		lp55xx_write(chip, LP5569_REG_PROG_PAGE_SEL, LP5569_PAGE_ENG(idx));
   209	}
   210	
   211	static void lp5569_stop_all_engines(struct lp55xx_chip *chip)
   212	{
   213		lp55xx_write(chip, LP5569_REG_OP_MODE, 0);
   214		lp5569_wait_opmode_done();
   215	}
   216	
   217	static void lp5569_stop_engine(struct lp55xx_chip *chip)
   218	{
   219		enum lp55xx_engine_index idx = chip->engine_idx;
   220	
   221		lp55xx_update_bits(chip, LP5569_REG_OP_MODE, LP5569_MODE_ENGn_MASK(idx), 0);
   222	
   223		lp5569_wait_opmode_done();
   224	}
   225	
   226	static void lp5569_turn_off_channels(struct lp55xx_chip *chip)
   227	{
   228		int i;
   229	
   230		for (i = 0; i < LP5569_MAX_LEDS; i++)
   231			lp55xx_write(chip, LP5569_REG_LED_PWM_BASE + i, 0);
   232	}
   233	
   234	static void lp5569_run_engine(struct lp55xx_chip *chip, bool start)
   235	{
   236		int i, ret;
   237		u8 mode;
   238		u8 exec;
   239	
   240		/* stop engine */
   241		if (!start) {
   242			lp5569_stop_engine(chip);
   243			lp5569_turn_off_channels(chip);
   244			return;
   245		}
   246	
   247		/*
   248		 * To run the engine,
   249		 * operation mode and enable register should updated at the same time
   250		 */
   251	
   252		ret = lp55xx_read(chip, LP5569_REG_OP_MODE, &mode);
   253		if (ret)
   254			return;
   255	
   256		ret = lp55xx_read(chip, LP5569_REG_EXEC_CTRL, &exec);
   257		if (ret)
   258			return;
   259	
   260		/* change operation mode to RUN only when each engine is loading */
   261		for (i = LP55XX_ENGINE_1; i <= LP55XX_ENGINE_3; i++) {
   262			if (LP5569_MODE_ENGn_GET(i, mode) != LP5569_MODE_LOAD_ENG)
   263				continue;
   264	
   265			mode &= ~LP5569_MODE_ENGn_MASK(i);
   266			mode |= LP5569_MODE_RUN_ENG << LP5569_MODE_ENGn_SHIFT(i);
   267			exec &= ~LP5569_EXEC_ENGn_MASK(i);
   268			exec |= LP5569_EXEC_RUN_ENG << LP5569_EXEC_ENGn_SHIFT(i);
   269		}
   270	
   271		lp55xx_write(chip, LP5569_REG_OP_MODE, mode);
   272		lp5569_wait_opmode_done();
   273	
   274		lp55xx_write(chip, LP5569_REG_EXEC_CTRL, exec);
   275	}
   276	
   277	static int lp5569_init_program_engine(struct lp55xx_chip *chip)
   278	{
   279		int i;
   280		int j;
   281		int ret;
   282		u8 status;
   283		/* one pattern per engine setting LED MUX start and stop addresses */
   284		static const u8 pattern[][LP5569_PROGRAM_LENGTH] =  {
   285			{ 0x9c, LP5569_ENG1_MUX_ADDR, 0x9c, 0xb0, 0x9d, 0x80, 0xd8, 0x00, 0},
   286			{ 0x9c, LP5569_ENG2_MUX_ADDR, 0x9c, 0xc0, 0x9d, 0x80, 0xd8, 0x00, 0},
   287			{ 0x9c, LP5569_ENG3_MUX_ADDR, 0x9c, 0xd0, 0x9d, 0x80, 0xd8, 0x00, 0},
   288		};
   289	
   290		/* hardcode 32 bytes of memory for each engine from program memory */
   291		ret = lp55xx_write(chip, LP5569_REG_CH1_PROG_START, LP5569_ENG1_PROG_ADDR);
   292		if (ret)
   293			return ret;
   294	
   295		ret = lp55xx_write(chip, LP5569_REG_CH2_PROG_START, LP5569_ENG2_PROG_ADDR);
   296		if (ret)
   297			return ret;
   298	
   299		ret = lp55xx_write(chip, LP5569_REG_CH3_PROG_START, LP5569_ENG3_PROG_ADDR);
   300		if (ret)
   301			return ret;
   302	
   303		/* write LED MUX address space for each engine */
   304		for (i = LP55XX_ENGINE_1; i <= LP55XX_ENGINE_3; i++) {
   305			chip->engine_idx = i;
   306			lp5569_load_engine_and_select_page(chip);
   307	
   308			for (j = 0; j < LP5569_PROGRAM_LENGTH; j++) {
   309				ret = lp55xx_write(chip, LP5569_REG_PROG_MEM + j,
   310						   pattern[i - 1][j]);
   311				if (ret)
   312					goto out;
   313			}
   314		}
   315	
   316		lp5569_run_engine(chip, true);
   317	
   318		/* Let the programs run for couple of ms and check the engine status */
   319		usleep_range(3000, 6000);
   320		lp55xx_read(chip, LP5569_REG_STATUS, &status);
 > 321		status = FIELD_GET(LP5569_ENG_STATUS_MASK, status);
   322	
   323		if (status != LP5569_ENG_STATUS_MASK) {
   324			dev_err(&chip->cl->dev,
   325				"could not configure LED engine, status = 0x%.2x\n",
   326				status);
   327			ret = -1;
   328		}
   329	
   330	out:
   331		lp5569_stop_all_engines(chip);
   332		return ret;
   333	}
   334	

-- 
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki




[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux