lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <202409010834.TxoQkZvt-lkp@intel.com>
Date: Sun, 1 Sep 2024 08:35:32 +0800
From: kernel test robot <lkp@...el.com>
To: Dimitri Fedrau <dima.fedrau@...il.com>
Cc: oe-kbuild-all@...ts.linux.dev, Sebastian Reichel <sre@...nel.org>,
	Srinivas Kandagatla <srinivas.kandagatla@...aro.org>,
	linux-pm@...r.kernel.org, linux-kernel@...r.kernel.org,
	Dimitri Fedrau <dima.fedrau@...il.com>
Subject: Re: [PATCH v2] power: supply: max1720x: add read support for nvmem

Hi Dimitri,

kernel test robot noticed the following build errors:

[auto build test ERROR on sre-power-supply/for-next]
[also build test ERROR on linus/master v6.11-rc5 next-20240830]
[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/Dimitri-Fedrau/power-supply-max1720x-add-read-support-for-nvmem/20240901-022223
base:   https://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply.git for-next
patch link:    https://lore.kernel.org/r/20240831182145.11589-1-dima.fedrau%40gmail.com
patch subject: [PATCH v2] power: supply: max1720x: add read support for nvmem
config: i386-buildonly-randconfig-001-20240901 (https://download.01.org/0day-ci/archive/20240901/202409010834.TxoQkZvt-lkp@intel.com/config)
compiler: gcc-12 (Debian 12.2.0-14) 12.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240901/202409010834.TxoQkZvt-lkp@intel.com/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@...el.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202409010834.TxoQkZvt-lkp@intel.com/

All error/warnings (new ones prefixed by >>):

>> drivers/power/supply/max1720x_battery.c:137:37: error: array type has incomplete element type 'struct nvmem_cell_info'
     137 | static const struct nvmem_cell_info max1720x_nvmem_cells[] = {
         |                                     ^~~~~~~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c: In function 'max1720x_probe_nvmem':
>> drivers/power/supply/max1720x_battery.c:404:16: error: variable 'nvmem_config' has initializer but incomplete type
     404 |         struct nvmem_config nvmem_config = {
         |                ^~~~~~~~~~~~
>> drivers/power/supply/max1720x_battery.c:405:18: error: 'struct nvmem_config' has no member named 'dev'
     405 |                 .dev = dev,
         |                  ^~~
>> drivers/power/supply/max1720x_battery.c:405:24: warning: excess elements in struct initializer
     405 |                 .dev = dev,
         |                        ^~~
   drivers/power/supply/max1720x_battery.c:405:24: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:406:18: error: 'struct nvmem_config' has no member named 'name'
     406 |                 .name = "max1720x_nvmem",
         |                  ^~~~
   drivers/power/supply/max1720x_battery.c:406:25: warning: excess elements in struct initializer
     406 |                 .name = "max1720x_nvmem",
         |                         ^~~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c:406:25: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:407:18: error: 'struct nvmem_config' has no member named 'cells'
     407 |                 .cells = max1720x_nvmem_cells,
         |                  ^~~~~
   drivers/power/supply/max1720x_battery.c:407:26: warning: excess elements in struct initializer
     407 |                 .cells = max1720x_nvmem_cells,
         |                          ^~~~~~~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c:407:26: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:408:18: error: 'struct nvmem_config' has no member named 'ncells'
     408 |                 .ncells = ARRAY_SIZE(max1720x_nvmem_cells),
         |                  ^~~~~~
   In file included from include/linux/bitfield.h:10,
                    from drivers/power/supply/max1720x_battery.c:10:
   include/linux/build_bug.h:16:51: error: bit-field '<anonymous>' width not an integer constant
      16 | #define BUILD_BUG_ON_ZERO(e) ((int)(sizeof(struct { int:(-!!(e)); })))
         |                                                   ^
   include/linux/compiler.h:243:33: note: in expansion of macro 'BUILD_BUG_ON_ZERO'
     243 | #define __must_be_array(a)      BUILD_BUG_ON_ZERO(__same_type((a), &(a)[0]))
         |                                 ^~~~~~~~~~~~~~~~~
   include/linux/array_size.h:11:59: note: in expansion of macro '__must_be_array'
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                                                           ^~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c:408:27: note: in expansion of macro 'ARRAY_SIZE'
     408 |                 .ncells = ARRAY_SIZE(max1720x_nvmem_cells),
         |                           ^~~~~~~~~~
   In file included from include/linux/string.h:6,
                    from arch/x86/include/asm/page_32.h:18,
                    from arch/x86/include/asm/page.h:14,
                    from arch/x86/include/asm/thread_info.h:12,
                    from include/linux/thread_info.h:60,
                    from include/linux/spinlock.h:60,
                    from include/linux/mmzone.h:8,
                    from include/linux/gfp.h:7,
                    from include/linux/slab.h:16,
                    from include/linux/resource_ext.h:11,
                    from include/linux/acpi.h:13,
                    from include/linux/i2c.h:13,
                    from drivers/power/supply/max1720x_battery.c:11:
   include/linux/array_size.h:11:25: warning: excess elements in struct initializer
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                         ^
   drivers/power/supply/max1720x_battery.c:408:27: note: in expansion of macro 'ARRAY_SIZE'
     408 |                 .ncells = ARRAY_SIZE(max1720x_nvmem_cells),
         |                           ^~~~~~~~~~
   include/linux/array_size.h:11:25: note: (near initialization for 'nvmem_config')
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                         ^
   drivers/power/supply/max1720x_battery.c:408:27: note: in expansion of macro 'ARRAY_SIZE'
     408 |                 .ncells = ARRAY_SIZE(max1720x_nvmem_cells),
         |                           ^~~~~~~~~~
>> drivers/power/supply/max1720x_battery.c:409:18: error: 'struct nvmem_config' has no member named 'read_only'
     409 |                 .read_only = true,
         |                  ^~~~~~~~~
   drivers/power/supply/max1720x_battery.c:409:30: warning: excess elements in struct initializer
     409 |                 .read_only = true,
         |                              ^~~~
   drivers/power/supply/max1720x_battery.c:409:30: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:410:18: error: 'struct nvmem_config' has no member named 'root_only'
     410 |                 .root_only = true,
         |                  ^~~~~~~~~
   drivers/power/supply/max1720x_battery.c:410:30: warning: excess elements in struct initializer
     410 |                 .root_only = true,
         |                              ^~~~
   drivers/power/supply/max1720x_battery.c:410:30: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:411:18: error: 'struct nvmem_config' has no member named 'reg_read'
     411 |                 .reg_read = max1720x_nvmem_reg_read,
         |                  ^~~~~~~~
   drivers/power/supply/max1720x_battery.c:411:29: warning: excess elements in struct initializer
     411 |                 .reg_read = max1720x_nvmem_reg_read,
         |                             ^~~~~~~~~~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c:411:29: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:412:18: error: 'struct nvmem_config' has no member named 'size'
     412 |                 .size = ARRAY_SIZE(max1720x_nvmem_cells) * 2,
         |                  ^~~~
   include/linux/build_bug.h:16:51: error: bit-field '<anonymous>' width not an integer constant
      16 | #define BUILD_BUG_ON_ZERO(e) ((int)(sizeof(struct { int:(-!!(e)); })))
         |                                                   ^
   include/linux/compiler.h:243:33: note: in expansion of macro 'BUILD_BUG_ON_ZERO'
     243 | #define __must_be_array(a)      BUILD_BUG_ON_ZERO(__same_type((a), &(a)[0]))
         |                                 ^~~~~~~~~~~~~~~~~
   include/linux/array_size.h:11:59: note: in expansion of macro '__must_be_array'
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                                                           ^~~~~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c:412:25: note: in expansion of macro 'ARRAY_SIZE'
     412 |                 .size = ARRAY_SIZE(max1720x_nvmem_cells) * 2,
         |                         ^~~~~~~~~~
   include/linux/array_size.h:11:25: warning: excess elements in struct initializer
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                         ^
   drivers/power/supply/max1720x_battery.c:412:25: note: in expansion of macro 'ARRAY_SIZE'
     412 |                 .size = ARRAY_SIZE(max1720x_nvmem_cells) * 2,
         |                         ^~~~~~~~~~
   include/linux/array_size.h:11:25: note: (near initialization for 'nvmem_config')
      11 | #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
         |                         ^
   drivers/power/supply/max1720x_battery.c:412:25: note: in expansion of macro 'ARRAY_SIZE'
     412 |                 .size = ARRAY_SIZE(max1720x_nvmem_cells) * 2,
         |                         ^~~~~~~~~~
>> drivers/power/supply/max1720x_battery.c:413:18: error: 'struct nvmem_config' has no member named 'word_size'
     413 |                 .word_size = 2,
         |                  ^~~~~~~~~
   drivers/power/supply/max1720x_battery.c:413:30: warning: excess elements in struct initializer
     413 |                 .word_size = 2,
         |                              ^
   drivers/power/supply/max1720x_battery.c:413:30: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:414:18: error: 'struct nvmem_config' has no member named 'stride'
     414 |                 .stride = 2,
         |                  ^~~~~~
   drivers/power/supply/max1720x_battery.c:414:27: warning: excess elements in struct initializer
     414 |                 .stride = 2,
         |                           ^
   drivers/power/supply/max1720x_battery.c:414:27: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:415:18: error: 'struct nvmem_config' has no member named 'priv'
     415 |                 .priv = info,
         |                  ^~~~
   drivers/power/supply/max1720x_battery.c:415:25: warning: excess elements in struct initializer
     415 |                 .priv = info,
         |                         ^~~~
   drivers/power/supply/max1720x_battery.c:415:25: note: (near initialization for 'nvmem_config')
>> drivers/power/supply/max1720x_battery.c:404:29: error: storage size of 'nvmem_config' isn't known
     404 |         struct nvmem_config nvmem_config = {
         |                             ^~~~~~~~~~~~
>> drivers/power/supply/max1720x_battery.c:453:17: error: implicit declaration of function 'devm_nvmem_register'; did you mean 'device_register'? [-Werror=implicit-function-declaration]
     453 |         nvmem = devm_nvmem_register(dev, &nvmem_config);
         |                 ^~~~~~~~~~~~~~~~~~~
         |                 device_register
>> drivers/power/supply/max1720x_battery.c:404:29: warning: unused variable 'nvmem_config' [-Wunused-variable]
     404 |         struct nvmem_config nvmem_config = {
         |                             ^~~~~~~~~~~~
   drivers/power/supply/max1720x_battery.c: At top level:
>> drivers/power/supply/max1720x_battery.c:137:37: warning: 'max1720x_nvmem_cells' defined but not used [-Wunused-variable]
     137 | static const struct nvmem_cell_info max1720x_nvmem_cells[] = {
         |                                     ^~~~~~~~~~~~~~~~~~~~
   cc1: some warnings being treated as errors


vim +137 drivers/power/supply/max1720x_battery.c

   136	
 > 137	static const struct nvmem_cell_info max1720x_nvmem_cells[] = {
   138		{ .name = "nXTable0",  .offset = 0,  .bytes = 2, },
   139		{ .name = "nXTable1",  .offset = 2,  .bytes = 2, },
   140		{ .name = "nXTable2",  .offset = 4,  .bytes = 2, },
   141		{ .name = "nXTable3",  .offset = 6,  .bytes = 2, },
   142		{ .name = "nXTable4",  .offset = 8,  .bytes = 2, },
   143		{ .name = "nXTable5",  .offset = 10, .bytes = 2, },
   144		{ .name = "nXTable6",  .offset = 12, .bytes = 2, },
   145		{ .name = "nXTable7",  .offset = 14, .bytes = 2, },
   146		{ .name = "nXTable8",  .offset = 16, .bytes = 2, },
   147		{ .name = "nXTable9",  .offset = 18, .bytes = 2, },
   148		{ .name = "nXTable10", .offset = 20, .bytes = 2, },
   149		{ .name = "nXTable11", .offset = 22, .bytes = 2, },
   150		{ .name = "nUser18C",  .offset = 24, .bytes = 2, },
   151		{ .name = "nUser18D",  .offset = 26, .bytes = 2, },
   152		{ .name = "nODSCTh",   .offset = 28, .bytes = 2, },
   153		{ .name = "nODSCCfg",  .offset = 30, .bytes = 2, },
   154	
   155		{ .name = "nOCVTable0",  .offset = 32, .bytes = 2, },
   156		{ .name = "nOCVTable1",  .offset = 34, .bytes = 2, },
   157		{ .name = "nOCVTable2",  .offset = 36, .bytes = 2, },
   158		{ .name = "nOCVTable3",  .offset = 38, .bytes = 2, },
   159		{ .name = "nOCVTable4",  .offset = 40, .bytes = 2, },
   160		{ .name = "nOCVTable5",  .offset = 42, .bytes = 2, },
   161		{ .name = "nOCVTable6",  .offset = 44, .bytes = 2, },
   162		{ .name = "nOCVTable7",  .offset = 46, .bytes = 2, },
   163		{ .name = "nOCVTable8",  .offset = 48, .bytes = 2, },
   164		{ .name = "nOCVTable9",  .offset = 50, .bytes = 2, },
   165		{ .name = "nOCVTable10", .offset = 52, .bytes = 2, },
   166		{ .name = "nOCVTable11", .offset = 54, .bytes = 2, },
   167		{ .name = "nIChgTerm",   .offset = 56, .bytes = 2, },
   168		{ .name = "nFilterCfg",  .offset = 58, .bytes = 2, },
   169		{ .name = "nVEmpty",     .offset = 60, .bytes = 2, },
   170		{ .name = "nLearnCfg",   .offset = 62, .bytes = 2, },
   171	
   172		{ .name = "nQRTable00",  .offset = 64, .bytes = 2, },
   173		{ .name = "nQRTable10",  .offset = 66, .bytes = 2, },
   174		{ .name = "nQRTable20",  .offset = 68, .bytes = 2, },
   175		{ .name = "nQRTable30",  .offset = 70, .bytes = 2, },
   176		{ .name = "nCycles",     .offset = 72, .bytes = 2, },
   177		{ .name = "nFullCapNom", .offset = 74, .bytes = 2, },
   178		{ .name = "nRComp0",     .offset = 76, .bytes = 2, },
   179		{ .name = "nTempCo",     .offset = 78, .bytes = 2, },
   180		{ .name = "nIAvgEmpty",  .offset = 80, .bytes = 2, },
   181		{ .name = "nFullCapRep", .offset = 82, .bytes = 2, },
   182		{ .name = "nVoltTemp",   .offset = 84, .bytes = 2, },
   183		{ .name = "nMaxMinCurr", .offset = 86, .bytes = 2, },
   184		{ .name = "nMaxMinVolt", .offset = 88, .bytes = 2, },
   185		{ .name = "nMaxMinTemp", .offset = 90, .bytes = 2, },
   186		{ .name = "nSOC",        .offset = 92, .bytes = 2, },
   187		{ .name = "nTimerH",     .offset = 94, .bytes = 2, },
   188	
   189		{ .name = "nConfig",    .offset = 96,  .bytes = 2, },
   190		{ .name = "nRippleCfg", .offset = 98,  .bytes = 2, },
   191		{ .name = "nMiscCfg",   .offset = 100, .bytes = 2, },
   192		{ .name = "nDesignCap", .offset = 102, .bytes = 2, },
   193		{ .name = "nHibCfg",    .offset = 104, .bytes = 2, },
   194		{ .name = "nPackCfg",   .offset = 106, .bytes = 2, },
   195		{ .name = "nRelaxCfg",  .offset = 108, .bytes = 2, },
   196		{ .name = "nConvgCfg",  .offset = 110, .bytes = 2, },
   197		{ .name = "nNVCfg0",    .offset = 112, .bytes = 2, },
   198		{ .name = "nNVCfg1",    .offset = 114, .bytes = 2, },
   199		{ .name = "nNVCfg2",    .offset = 116, .bytes = 2, },
   200		{ .name = "nSBSCfg",    .offset = 118, .bytes = 2, },
   201		{ .name = "nROMID0",    .offset = 120, .bytes = 2, },
   202		{ .name = "nROMID1",    .offset = 122, .bytes = 2, },
   203		{ .name = "nROMID2",    .offset = 124, .bytes = 2, },
   204		{ .name = "nROMID3",    .offset = 126, .bytes = 2, },
   205	
   206		{ .name = "nVAlrtTh",      .offset = 128, .bytes = 2, },
   207		{ .name = "nTAlrtTh",      .offset = 130, .bytes = 2, },
   208		{ .name = "nSAlrtTh",      .offset = 132, .bytes = 2, },
   209		{ .name = "nIAlrtTh",      .offset = 134, .bytes = 2, },
   210		{ .name = "nUser1C4",      .offset = 136, .bytes = 2, },
   211		{ .name = "nUser1C5",      .offset = 138, .bytes = 2, },
   212		{ .name = "nFullSOCThr",   .offset = 140, .bytes = 2, },
   213		{ .name = "nTTFCfg",       .offset = 142, .bytes = 2, },
   214		{ .name = "nCGain",        .offset = 144, .bytes = 2, },
   215		{ .name = "nTCurve",       .offset = 146, .bytes = 2, },
   216		{ .name = "nTGain",        .offset = 148, .bytes = 2, },
   217		{ .name = "nTOff",         .offset = 150, .bytes = 2, },
   218		{ .name = "nManfctrName0", .offset = 152, .bytes = 2, },
   219		{ .name = "nManfctrName1", .offset = 154, .bytes = 2, },
   220		{ .name = "nManfctrName2", .offset = 156, .bytes = 2, },
   221		{ .name = "nRSense",       .offset = 158, .bytes = 2, },
   222	
   223		{ .name = "nUser1D0",       .offset = 160, .bytes = 2, },
   224		{ .name = "nUser1D1",       .offset = 162, .bytes = 2, },
   225		{ .name = "nAgeFcCfg",      .offset = 164, .bytes = 2, },
   226		{ .name = "nDesignVoltage", .offset = 166, .bytes = 2, },
   227		{ .name = "nUser1D4",       .offset = 168, .bytes = 2, },
   228		{ .name = "nRFastVShdn",    .offset = 170, .bytes = 2, },
   229		{ .name = "nManfctrDate",   .offset = 172, .bytes = 2, },
   230		{ .name = "nFirstUsed",     .offset = 174, .bytes = 2, },
   231		{ .name = "nSerialNumber0", .offset = 176, .bytes = 2, },
   232		{ .name = "nSerialNumber1", .offset = 178, .bytes = 2, },
   233		{ .name = "nSerialNumber2", .offset = 180, .bytes = 2, },
   234		{ .name = "nDeviceName0",   .offset = 182, .bytes = 2, },
   235		{ .name = "nDeviceName1",   .offset = 184, .bytes = 2, },
   236		{ .name = "nDeviceName2",   .offset = 186, .bytes = 2, },
   237		{ .name = "nDeviceName3",   .offset = 188, .bytes = 2, },
   238		{ .name = "nDeviceName4",   .offset = 190, .bytes = 2, },
   239	};
   240	

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

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ