Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3740707ybl; Mon, 12 Aug 2019 05:43:07 -0700 (PDT) X-Google-Smtp-Source: APXvYqzNxB3uYX4SvOm6DwVRaADtUEsMVkmihXbdAcPeZxcJ3e3Z2ZrbVJtF5FGmXBlZQ6xXrwRa X-Received: by 2002:a63:24a:: with SMTP id 71mr29510740pgc.273.1565613787572; Mon, 12 Aug 2019 05:43:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565613787; cv=none; d=google.com; s=arc-20160816; b=OFRXyl99tdxF1K/BwcujfoR+3j/UruY8sU8zUdNITlE8oUNRvBgl4cWYEszh3JZBbB xOoBLfkIdDPu6mwq2J1+kNwgBRAbg/7k8gedeD+purQ++DDaj+kdSPh2CfZk9Z3RJjF2 ATfNIZeItVXwE5L433gPcpiHwm4w8+nKS7D790hJ61hdXg5dv3js39QivWMlU1MW+als xZHcOx86t2yxDU7J75oyt5yFEyRjRIC5gBwJD324gQWNXDyCRKYxsyFt3rao8YTQxhz0 3ZmrHBc8roX+u5lhRpB6g7Fyy7wQht/+UieSQKsvuBvq3j6iugTCjDocKONZU11EA2wp GDjA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:subject:ironport-sdr; bh=qGa11T4885NwQdBxwajKHMY8qlonZurdDCFiPYpxCMk=; b=ptx0CrpvjehIIYbKxVPpHXoNytZ31QUOxqcu3uNpOEoHm4CTq/c3NPHfMhmUWZq0P3 G4jBiOuB4alw+vNFjVd1m9vRUH4lrBqO5xfneO0IXE8Jult7JDmpx5k9Pp4vS5vYZWbw vtZ//dV/Yov/+yAZOwPWPQsYNJEgYuTv0rjAQgiF7UOhdPmse7lcX8rvRkuFhhM1TmBi 3yk2cUFoufCRr9LxhalnxBUXOXhqiM+UBUcIQeX3wPYzzBJNDcFlKb8tvPSPa4p/VWts 3GLENXHG/LFoK9GeVqymaeK/idCCX0U4PFJOLJ67R3BQ9W/dy3WK1s6Zk39/O/L7XC1Q hMyA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w9si55565642plp.118.2019.08.12.05.42.51; Mon, 12 Aug 2019 05:43:07 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726685AbfHLMlu (ORCPT + 99 others); Mon, 12 Aug 2019 08:41:50 -0400 Received: from hel-mailgw-01.vaisala.com ([193.143.230.17]:64791 "EHLO hel-mailgw-01.vaisala.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726458AbfHLMlr (ORCPT ); Mon, 12 Aug 2019 08:41:47 -0400 IronPort-SDR: 826mzmceumwPFScYSCPm+eF20YPkNW/ySU1RHPZC1SQDSh5FQz8EImeqFU/3OwHZIwSA4bO1W9 XqOs6N2oXU7d3Ppp8VKiChB9Bqivo7hmDqTdopFYXzfBqabro+Od6mcTEwx8dnED5AVKHzLgmf 6OeQLEO/xyRO82NNiMYxWf2mrPC0oyYUVbZei55w8o4AoZuaIRFiKTmdfb6xqQ7DBmMicwFXK4 idX0OCsk4T7VIypFoZBzTYwwplx688aaeuRaZHRaP2kvr19GXC39XAC4TarO5Iv8TFHjUZhIn/ I2s= X-IronPort-AV: E=Sophos;i="5.64,377,1559509200"; d="scan'208";a="228268207" Subject: Re: drivers/power/reset/nvmem-reboot-mode.c:27:42: error: passing argument 2 of 'nvmem_cell_write' from incompatible pointer type Cc: kbuild-all@01.org, linux-kernel@vger.kernel.org, Sebastian Reichel References: <201908110745.3Zksfatm%lkp@intel.com> From: Nandor Han Message-ID: <03e59e9b-8647-c9b2-b60a-99817af5313d@vaisala.com> Date: Mon, 12 Aug 2019 15:41:42 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <201908110745.3Zksfatm%lkp@intel.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-OriginalArrivalTime: 12 Aug 2019 12:41:42.0313 (UTC) FILETIME=[4B100990:01D5510B] To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/11/19 2:43 AM, kbuild test robot wrote: > Hi Han, > > FYI, the error/warning still remains. > > tree: https://kernel.googlesource.com/pub/scm/linux/kernel/git/torvalds/linux.git master > head: dcbb4a153971ff8646af0c963f5698bf21bfbfdc > commit: 7a78a7f7695bf9ef9cef3c06fbc5fa4573fd0eef power: reset: nvmem-reboot-mode: use NVMEM as reboot mode write interface > date: 7 weeks ago > config: x86_64-randconfig-d003-201932 (attached as .config) > compiler: gcc-7 (Debian 7.4.0-10) 7.4.0 > reproduce: > git checkout 7a78a7f7695bf9ef9cef3c06fbc5fa4573fd0eef > # save the attached .config to linux build tree > make ARCH=x86_64 > > If you fix the issue, kindly add following tag > Reported-by: kbuild test robot > > All errors (new ones prefixed by >>): > > drivers/power/reset/nvmem-reboot-mode.c: In function 'nvmem_reboot_mode_write': >>> drivers/power/reset/nvmem-reboot-mode.c:27:42: error: passing argument 2 of 'nvmem_cell_write' from incompatible pointer type [-Werror=incompatible-pointer-types] > ret = nvmem_cell_write(nvmem_rbm->cell, &magic, sizeof(magic)); > ^ > In file included from drivers/power/reset/nvmem-reboot-mode.c:10:0: > include/linux/nvmem-consumer.h:120:19: note: expected 'const char *' but argument is of type 'unsigned int *' > static inline int nvmem_cell_write(struct nvmem_cell *cell, > ^~~~~~~~~~~~~~~~ > cc1: some warnings being treated as errors > > vim +/nvmem_cell_write +27 drivers/power/reset/nvmem-reboot-mode.c > > 18 > 19 static int nvmem_reboot_mode_write(struct reboot_mode_driver *reboot, > 20 unsigned int magic) > 21 { > 22 int ret; > 23 struct nvmem_reboot_mode *nvmem_rbm; > 24 > 25 nvmem_rbm = container_of(reboot, struct nvmem_reboot_mode, reboot); > 26 > > 27 ret = nvmem_cell_write(nvmem_rbm->cell, &magic, sizeof(magic)); > 28 if (ret < 0) > 29 dev_err(reboot->dev, "update reboot mode bits failed\n"); > 30 > 31 return ret; > 32 } > 33 > > --- > 0-DAY kernel test infrastructure Open Source Technology Center > https://lists.01.org/pipermail/kbuild-all Intel Corporation > Hi, Seems that `nvmem-consumer.h` declares a different signature for `nvmem_cell_write` method depending on `CONFIG_NVMEM` configuration: #if IS_ENABLED(CONFIG_NVMEM) ... int nvmem_cell_write(struct nvmem_cell *cell, void *buf, size_t len); ... #else ... static inline int nvmem_cell_write(struct nvmem_cell *cell, const char *buf, size_t len) { return -EOPNOTSUPP; } ... #endif /* CONFIG_NVMEM * What's the best approach here? Nandor