Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp4027804rwb; Mon, 21 Nov 2022 02:49:52 -0800 (PST) X-Google-Smtp-Source: AA0mqf494jYpYeZpMZq2ydQVwLcTNlTj1mlyFADNzSr7MgOrpChbLKnU10YcraQPJiJNeIugdeNx X-Received: by 2002:a17:907:d042:b0:78c:c893:1965 with SMTP id vb2-20020a170907d04200b0078cc8931965mr14281379ejc.247.1669027792322; Mon, 21 Nov 2022 02:49:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669027792; cv=none; d=google.com; s=arc-20160816; b=HttPXZ4/1WJwZIkqkfKxq0Wz32wF4sOMj0aXnYGYmnn1zPn3lQcxZ4dCaceI+Pr7LB EKAKVTIx1AZQ3ODEwIRs0QV6KMpgvbQnBQh3ACuWivWd3FnPgRzsWReN3xolEYQnZ1KV wQZVmdePxhfE2HakanKSby1slP+TuBTXtNnmQbg3hHCxynOhcq5hNHarU/fYqVY2mBOL J+Ts6MZzAZ0fgseDYnDJ7XbieikrK0GryUJlmzkiY6Wo2I0mVVNYL0AH4Blb1nb6X37G Yi7F6ZNualinkLUU9V+2TzZmOxBNXVO7/qoNSUljuDU7ehdMPR2pHjJQv1JPvVRjVQMA aXvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:in-reply-to :subject:cc:to:from:message-id:date:dkim-signature:dkim-signature; bh=po11InVlA78FEY3WlPUwwll4GVuOWXuBABURTMivemg=; b=0Ut76Dq5O/f/WmPv/lFc19GancLZRcMc5SOsgb/ceaIlvGObIaF4AtDhAms77m7CfQ mxhzeiqykDVksOc9Dva96yqZuOuNn05FEUN8HPwL5+AvlrJq2prNoa7IGyIxr9TCWmQ2 8dIHPylAcnaJGgGMUbZkv+5PiVVqEWqLuiq9eZxoQegvMoZL/H5LeKCiBTHzKJq2X6WM tY0BxEwKwCG6n4F9Y9DXPSwNofnLAMu/iHx1m5j4vEEeI6/MJT2itoryK71N6ex78bvf koPgcppRFIcy1bDwpxxdB5/mfJ6BH2yQixbSo4kG0KVn4OVOb5anxkOev2J0gpV/aI+c T6bw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=DCiMa5bU; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v14-20020a170906338e00b00770534b5a71si8026151eja.858.2022.11.21.02.49.28; Mon, 21 Nov 2022 02:49:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=DCiMa5bU; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229967AbiKUKf1 (ORCPT + 91 others); Mon, 21 Nov 2022 05:35:27 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41418 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230092AbiKUKfL (ORCPT ); Mon, 21 Nov 2022 05:35:11 -0500 Received: from smtp-out1.suse.de (smtp-out1.suse.de [IPv6:2001:67c:2178:6::1c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DEAC8B08D6 for ; Mon, 21 Nov 2022 02:35:05 -0800 (PST) Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id 554F221AA1; Mon, 21 Nov 2022 10:35:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1669026904; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=po11InVlA78FEY3WlPUwwll4GVuOWXuBABURTMivemg=; b=DCiMa5bUOpAohqg34JiBbUR40BOly2yuZc0jTYZ0NbLlDXmeU0JvXnpl6PA7e9Yta2N42a LqS8DTzGSlKzNtQY3s2w+DuS6gf93UKOxjOyNH+Yk2T4c57j3QL6HtSD4biPW1SSQEIOds 4jM+4MG7OyUhgaFHwaC0Kfn5RE7zgL4= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1669026904; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=po11InVlA78FEY3WlPUwwll4GVuOWXuBABURTMivemg=; b=iZpdmIHERrm/XkNSiYgwgETqNWc2F5uoNL3+vo+fz2VPS0znkxEWoIMwNI6EXj2rxwUNE3 zZCXJ5b82JFXezAA== Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 2B6531376E; Mon, 21 Nov 2022 10:35:04 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id JDjZCVhUe2NOEwAAMHmgww (envelope-from ); Mon, 21 Nov 2022 10:35:04 +0000 Date: Mon, 21 Nov 2022 11:35:03 +0100 Message-ID: <87h6yswq7c.wl-tiwai@suse.de> From: Takashi Iwai To: Baisong Zhong Cc: , , , , , Subject: Re: [PATCH -next] ALSA: pcm: fix undefined behavior in bit shift for SNDRV_PCM_RATE_KNOT In-Reply-To: <20221121023329.2423665-1-zhongbaisong@huawei.com> References: <20221121023329.2423665-1-zhongbaisong@huawei.com> User-Agent: Wanderlust/2.15.9 (Almost Unreal) Emacs/27.2 Mule/6.0 MIME-Version: 1.0 (generated by SEMI-EPG 1.14.7 - "Harue") Content-Type: text/plain; charset=US-ASCII X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 21 Nov 2022 03:33:29 +0100, Baisong Zhong wrote: > > Shifting signed 32-bit value by 31 bits is undefined, so changing > significant bit to unsigned. The UBSAN warning calltrace like below: > > UBSAN: shift-out-of-bounds in sound/core/pcm_native.c:2676:21 > left shift of 1 by 31 places cannot be represented in type 'int' > ... > Call Trace: > > dump_stack_lvl+0x8d/0xcf > ubsan_epilogue+0xa/0x44 > __ubsan_handle_shift_out_of_bounds+0x1e7/0x208 > snd_pcm_open_substream+0x9f0/0xa90 > snd_pcm_oss_open.part.26+0x313/0x670 > snd_pcm_oss_open+0x30/0x40 > soundcore_open+0x18b/0x2e0 > chrdev_open+0xe2/0x270 > do_dentry_open+0x2f7/0x620 > path_openat+0xd66/0xe70 > do_filp_open+0xe3/0x170 > do_sys_openat2+0x357/0x4a0 > do_sys_open+0x87/0xd0 > do_syscall_64+0x34/0x80 > > Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") > Signed-off-by: Baisong Zhong > --- > include/sound/pcm.h | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/include/sound/pcm.h b/include/sound/pcm.h > index 7b1a022910e8..ec28c2ec89de 100644 > --- a/include/sound/pcm.h > +++ b/include/sound/pcm.h > @@ -123,7 +123,7 @@ struct snd_pcm_ops { > #define SNDRV_PCM_RATE_384000 (1<<14) /* 384000Hz */ > > #define SNDRV_PCM_RATE_CONTINUOUS (1<<30) /* continuous range */ > -#define SNDRV_PCM_RATE_KNOT (1<<31) /* supports more non-continuos rates */ > +#define SNDRV_PCM_RATE_KNOT (1U<<31) /* supports more non-continuos rates */ Could you rather update all SNDRV_PCM_RATE_* to 1U? Otherwise it'll look inconsistent. thanks, Takashi