From owner-freebsd-current@FreeBSD.ORG Sun Dec 2 15:37:27 2012 Return-Path: Delivered-To: freebsd-current@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 4B484420; Sun, 2 Dec 2012 15:37:27 +0000 (UTC) (envelope-from dim@FreeBSD.org) Received: from tensor.andric.com (tensor.andric.com [87.251.56.140]) by mx1.freebsd.org (Postfix) with ESMTP id 004888FC13; Sun, 2 Dec 2012 15:37:26 +0000 (UTC) Received: from [IPv6:2001:7b8:3a7:0:d085:62e2:221f:26b1] (unknown [IPv6:2001:7b8:3a7:0:d085:62e2:221f:26b1]) (using TLSv1 with cipher DHE-RSA-CAMELLIA256-SHA (256/256 bits)) (No client certificate requested) by tensor.andric.com (Postfix) with ESMTPSA id 99F485C37; Sun, 2 Dec 2012 16:37:25 +0100 (CET) Message-ID: <50BB75B3.6070505@FreeBSD.org> Date: Sun, 02 Dec 2012 16:37:23 +0100 From: Dimitry Andric Organization: The FreeBSD Project User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20121128 Thunderbird/18.0 MIME-Version: 1.0 To: Andriy Gapon Subject: Re: A suspicious warning in sys/boot/zfs/zfsimpl.c References: <20120703102142.6554b10e.taku@tackymt.homeip.net> <50B9E47F.6070005@FreeBSD.org> In-Reply-To: <50B9E47F.6070005@FreeBSD.org> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: Garrett Cooper , Taku YAMAMOTO , freebsd-current@FreeBSD.org X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 02 Dec 2012 15:37:27 -0000 On 2012-12-01 12:05, Andriy Gapon wrote: > on 01/12/2012 12:59 Garrett Cooper said the following: >> On Mon, Jul 2, 2012 at 6:21 PM, Taku YAMAMOTO wrote: >>> When I built the world as of r237813, clang reported a warning which >>> caught my attention. >>> >>> ===> sys/boot/zfs (all) >>> clang -O2 -pipe -march=pentium4 -DBOOTPROG=\"zfsloader\" -I/usr/src/sys/boot/zfs/../common -I/usr/src/sys/boot/zfs/../.. -I. -I/usr/src/sys/boot/zfs/../../../lib/libstand -I/usr/src/sys/boot/zfs/../../cddl/boot/zfs -ffreestanding -mpreferred-stack-boundary=2 -mno-mmx -mno-3dnow -mno-sse -mno-sse2 -mno-sse3 -msoft-float -Wformat -Wall -DNDEBUG -std=gnu99 -Qunused-arguments -c /usr/src/sys/boot/zfs/zfs.c -o zfs.o >>> In file included from /usr/src/sys/boot/zfs/zfs.c:48: >>> /usr/src/sys/boot/zfs/zfsimpl.c:2033:19: warning: array index 264 is past the end of the array (which contains 192 elements) [-Warray-bounds] >>> memcpy(path, &dn.dn_bonus[sizeof(znode_phys_t)], >>> ^ ~~~~~~~~~~~~~~~~~~~~ >>> /usr/src/sys/boot/zfs/../../cddl/boot/zfs/zfsimpl.h:788:2: note: array 'dn_bonus' declared here >>> uint8_t dn_bonus[DN_MAX_BONUSLEN - sizeof (blkptr_t)]; >>> ^ >>> >>> I don't have a zfs-powered machine, so I'm not sure whether this >>> warning is false-positive or not. >> >> I'm seeing the same warnings trying to build HEAD r242903 with >> clang on amd64. Andriy CCed. > > I believe that there is no actual problem there. Indeed. The ZFS code seems to be using the dnode_phys_t::dn_bonus field as a sort of flexible struct member. These specific warnings can be ignored, or turned off.