From: Jiri Slaby <jirislaby@kernel.org>
To: Damien Le Moal <damien.lemoal@opensource.wdc.com>,
Arnd Bergmann <arnd@kernel.org>
Cc: linux-kernel@vger.kernel.org, Arnd Bergmann <arnd@arndb.de>,
Luis Machado <luis.machado@arm.com>,
linux-ide@vger.kernel.org, stable@vger.kernel.org,
Randy Dunlap <rdunlap@infradead.org>
Subject: Re: [PATCH] [v2] ata: ahci: fix enum constants for gcc-13
Date: Wed, 7 Dec 2022 07:41:25 +0100 [thread overview]
Message-ID: <3beac08e-ffba-8c3b-a5b1-1a34e125b3a7@kernel.org> (raw)
In-Reply-To: <95785bc5-ac4b-9c44-74ea-6b3afb11cf14@opensource.wdc.com>
Arnd,
I just noticed this on stable@. Do you have more of the gcc-13-enum
patches? I sent some (this one incl.), but didn't have time for v2 of
some of them. So should I respin the rest or have you fixed them all yet?
> [PATCH] ath11k (gcc13): synchronize
ath11k_mac_he_gi_to_nl80211_he_gi()'s return type - "Jiri Slaby (SUSE)"
<jirislaby@kernel.org> - 2022-10-31 1243.eml:Message-Id:
<20221031114341.10377-1-jirislaby@kernel.org>
> [PATCH] block_blk-iocost (gcc13): cast enum members to int in prints
- "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1245.eml:Message-Id: <20221031114520.10518-1-jirislaby@kernel.org>
> [PATCH] bonding (gcc13): synchronize bond_{a,t}lb_xmit() types -
"Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1244.eml:Message-Id: <20221031114409.10417-1-jirislaby@kernel.org>
> [PATCH] drm_amd_display (gcc13): fix enum mismatch - "Jiri Slaby
(SUSE)" <jirislaby@kernel.org> - 2022-10-31 1242.eml:Message-Id:
<20221031114247.10309-1-jirislaby@kernel.org>
> [PATCH] drm_nouveau_kms_nv50- (gcc13): fix nv50_wndw_new_ prototype -
"Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1242.eml:Message-Id: <20221031114229.10289-1-jirislaby@kernel.org>
> [PATCH] init: Kconfig (gcc13): disable -Warray-bounds on gcc-13 too -
"Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1242.eml:Message-Id: <20221031114212.10266-1-jirislaby@kernel.org>
> [PATCH] i40e (gcc13): synchronize allocate_free functions return type
& values - "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1244.eml:Message-Id: <20221031114456.10482-1-jirislaby@kernel.org>
> [PATCH] qed (gcc13): use u16 for fid to be big enough - "Jiri Slaby
(SUSE)" <jirislaby@kernel.org> - 2022-10-31 1243.eml:Message-Id:
<20221031114354.10398-1-jirislaby@kernel.org>
> [PATCH] RDMA_srp (gcc13): force int types for max_send_sge and
can_queue - "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1245.eml:Message-Id: <20221031114506.10501-1-jirislaby@kernel.org>
> [PATCH] sfc (gcc13): synchronize ef100_enqueue_skb()'s return type -
"Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1244.eml:Message-Id: <20221031114440.10461-1-jirislaby@kernel.org>
> [PATCH] thunderbolt (gcc13): synchronize tb_port_is_clx_enabled()'s
2nd param - "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1243.eml:Message-Id: <20221031114323.10356-1-jirislaby@kernel.org>
> [PATCH] wireguard (gcc13): cast enum limits members to int in prints
- "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1244.eml:Message-Id: <20221031114424.10438-1-jirislaby@kernel.org>
> [PATCH 1_2] ata: ahci (gcc13): use BIT() for bit definitions in enum
- "Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1243.eml:Message-Id: <20221031114310.10337-1-jirislaby@kernel.org>
> [PATCH 2_2] ata: ahci (gcc13): use U suffix for enum definitions -
"Jiri Slaby (SUSE)" <jirislaby@kernel.org> - 2022-10-31
1243.eml:Message-Id: <20221031114310.10337-2-jirislaby@kernel.org>
thanks,
On 06. 12. 22, 7:46, Damien Le Moal wrote:
> On 12/3/22 19:54, Arnd Bergmann wrote:
>> From: Arnd Bergmann <arnd@arndb.de>
>>
>> gcc-13 slightly changes the type of constant expressions that are defined
>> in an enum, which triggers a compile time sanity check in libata:
>>
>> linux/drivers/ata/libahci.c: In function 'ahci_led_store':
>> linux/include/linux/compiler_types.h:357:45: error: call to '__compiletime_assert_302' declared with attribute error: BUILD_BUG_ON failed: sizeof(_s) > sizeof(long)
>> 357 | _compiletime_assert(condition, msg, __compiletime_assert_, __COUNTER__)
>>
>> The new behavior is that sizeof() returns the same value for the
>> constant as it does for the enum type, which is generally more sensible
>> and consistent.
>>
>> The problem in libata is that it contains a single enum definition for
>> lots of unrelated constants, some of which are large positive (unsigned)
>> integers like 0xffffffff, while others like (1<<31) are interpreted as
>> negative integers, and this forces the enum type to become 64 bit wide
>> even though most constants would still fit into a signed 32-bit 'int'.
>>
>> Fix this by changing the entire enum definition to use BIT(x) in place
>> of (1<<x), which results in all values being seen as 'unsigned' and
>> fitting into an unsigned 32-bit type.
>>
>> Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=107917
>> Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=107405
>> Reported-by: Luis Machado <luis.machado@arm.com>
>> Cc: linux-ide@vger.kernel.org
>> Cc: Damien Le Moal <damien.lemoal@opensource.wdc.com>
>> Cc: stable@vger.kernel.org
>> Cc: Randy Dunlap <rdunlap@infradead.org>
>> Signed-off-by: Arnd Bergmann <arnd@arndb.de>
>
> Applied to for-6.2. Thanks !
>
--
js
suse labs
next prev parent reply other threads:[~2022-12-07 6:41 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-12-03 10:54 [PATCH] [v2] ata: ahci: fix enum constants for gcc-13 Arnd Bergmann
2022-12-05 13:33 ` Damien Le Moal
2022-12-05 13:38 ` Luis Machado
2022-12-05 16:34 ` Luis Machado
2022-12-06 6:46 ` Damien Le Moal
2022-12-07 6:41 ` Jiri Slaby [this message]
2022-12-07 7:32 ` Arnd Bergmann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3beac08e-ffba-8c3b-a5b1-1a34e125b3a7@kernel.org \
--to=jirislaby@kernel.org \
--cc=arnd@arndb.de \
--cc=arnd@kernel.org \
--cc=damien.lemoal@opensource.wdc.com \
--cc=linux-ide@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=luis.machado@arm.com \
--cc=rdunlap@infradead.org \
--cc=stable@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox