From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 10586 invoked by alias); 17 Jul 2002 08:26:03 -0000 Mailing-List: contact gcc-prs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Archive: List-Post: List-Help: Sender: gcc-prs-owner@gcc.gnu.org Received: (qmail 10562 invoked by uid 71); 17 Jul 2002 08:26:02 -0000 Resent-Date: 17 Jul 2002 08:26:02 -0000 Resent-Message-ID: <20020717082602.10561.qmail@sources.redhat.com> Resent-From: gcc-gnats@gcc.gnu.org (GNATS Filer) Resent-To: nobody@gcc.gnu.org Resent-Cc: gcc-prs@gcc.gnu.org, gcc-bugs@gcc.gnu.org Resent-Reply-To: gcc-gnats@gcc.gnu.org, glushko@yahoo.com Received: (qmail 4434 invoked by uid 61); 17 Jul 2002 08:16:27 -0000 Message-Id: <20020717081627.4433.qmail@sources.redhat.com> Date: Wed, 17 Jul 2002 01:26:00 -0000 From: glushko@yahoo.com Reply-To: glushko@yahoo.com To: gcc-gnats@gcc.gnu.org X-Send-Pr-Version: gnatsweb-2.9.3 (1.1.1.1.2.31) Subject: c/7334: SIGBUS in assignment and in memcpy() X-SW-Source: 2002-07/txt/msg00502.txt.bz2 List-Id: >Number: 7334 >Category: c >Synopsis: SIGBUS in assignment and in memcpy() >Confidential: no >Severity: serious >Priority: medium >Responsible: unassigned >State: open >Class: sw-bug >Submitter-Id: net >Arrival-Date: Wed Jul 17 01:26:01 PDT 2002 >Closed-Date: >Last-Modified: >Originator: Igor Glushko >Release: 2.95.2 and 3.0.2 >Organization: >Environment: SunOS samson 5.6 Generic_105181-23 sun4d sparc SUNW,SPARCserver-1000 >Description: Assigning a not-aligned field of a packed structure produces SIGBUS and a core dump. In more complex program than the one attached the same result got using memcpy() instead of assignment. >How-To-Repeat: compile the attached file >Fix: use byte-by-byte assignmet copying in a while loop without any optimization >Release-Note: >Audit-Trail: >Unformatted: ----gnatsweb-attachment---- Content-Type: text/plain; name="sigbus_in_assignment.c" Content-Disposition: inline; filename="sigbus_in_assignment.c" #include #include static void* byte_memcpy(void* to, const void* from, size_t n) { register char* t=(char*)to; register const char* fb=(const char*)from; register const char* fe=(const char*)from+n; while(fb