From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754027AbbBSOST (ORCPT ); Thu, 19 Feb 2015 09:18:19 -0500 Received: from mail-wi0-f181.google.com ([209.85.212.181]:48634 "EHLO mail-wi0-f181.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752732AbbBSOSS (ORCPT ); Thu, 19 Feb 2015 09:18:18 -0500 Message-ID: <54E5F0A4.9080300@suse.cz> Date: Thu, 19 Feb 2015 15:18:12 +0100 From: Jiri Slaby User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-Version: 1.0 To: johan.hedberg@gmail.com CC: linux-bluetooth@vger.kernel.org, linux-kernel@vger.kernel.org, Marcel Holtmann , Gustavo Padovan Subject: Re: [PATCH 1/1] Bluetooth: make hci_test_bit's addr const References: <1424354164-11728-1-git-send-email-jslaby@suse.cz> In-Reply-To: <1424354164-11728-1-git-send-email-jslaby@suse.cz> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/19/2015, 02:56 PM, Jiri Slaby wrote: > gcc5 warns about passing a const array to hci_test_bit which takes a > non-const pointer: > net/bluetooth/hci_sock.c: In function ‘hci_sock_sendmsg’: > net/bluetooth/hci_sock.c:955:8: warning: passing argument 2 of ‘hci_test_bit’ discards ‘const’ qualifier from pointer target type [-Wdiscarded-array-qualifiers] > &hci_sec_filter.ocf_mask[ogf])) && > ^ > net/bluetooth/hci_sock.c:49:19: note: expected ‘void *’ but argument is of type ‘const __u32 (*)[4] {aka const unsigned int (*)[4]}’ > static inline int hci_test_bit(int nr, void *addr) > ^ > > So make 'addr' 'const void *'. > > Signed-off-by: Jiri Slaby > Cc: Marcel Holtmann > Cc: Gustavo Padovan > Cc: Johan Hedberg > --- > net/bluetooth/hci_sock.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/net/bluetooth/hci_sock.c b/net/bluetooth/hci_sock.c > index 1d65c5be7c82..34a095ff8679 100644 > --- a/net/bluetooth/hci_sock.c > +++ b/net/bluetooth/hci_sock.c > @@ -46,7 +46,7 @@ struct hci_pinfo { > unsigned short channel; > }; > > -static inline int hci_test_bit(int nr, void *addr) > +static inline int hci_test_bit(int nr, const void *addr) > { > return *((__u32 *) addr + (nr >> 5)) & ((__u32) 1 << (nr & 31)); quite interestingly, the compiler doesn't complain against the cast... Will send a v2. -- js suse labs