From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=ham autolearn_force=no version=3.4.4 X-Google-Thread: 103376,5b9a38a75a50e726 X-Google-Attributes: gid103376,domainid0,public,usenet X-Google-Language: ENGLISH,ASCII-7-bit Path: g2news1.google.com!news4.google.com!feeder.news-service.com!border1.nntp.ams.giganews.com!nntp.giganews.com!feeder2.news.saunalahti.fi!newsfeed2.funet.fi!newsfeeds.funet.fi!news.cc.tut.fi!not-for-mail From: Tero Koskinen Newsgroups: comp.lang.ada Subject: Re: Feature or Bug? 2#1111# shifted by 4 is 224 Date: Mon, 2 Jun 2008 19:11:45 +0300 Message-ID: <20080602191145.1b75b1ee.tero.koskinen@iki.fi> References: NNTP-Posting-Host: ip154.otanner14.opintanner.fi Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Trace: news.cc.tut.fi 1212423105 13298 195.148.53.154 (2 Jun 2008 16:11:45 GMT) X-Complaints-To: abuse@tut.fi NNTP-Posting-Date: Mon, 2 Jun 2008 16:11:45 +0000 (UTC) X-Newsreader: Sylpheed 2.4.5 (GTK+ 2.12.7; i386-unknown-openbsd4.3) Xref: g2news1.google.com comp.lang.ada:528 Date: 2008-06-02T19:11:45+03:00 List-Id: On Mon, 02 Jun 2008 17:17:19 +0200 Dennis Hoppe wrote: > Hi, > > we probably found a bug in Ada or we cannot realize, that this is indeed > a feature ;) [snip] > > In Example B, we limit the parameter N to Positive, because we do not > want "negative" shifts. The result of Shift_Left(2#1111#, 4) is 224 > (2#11100000#) ! > > -- Example B > type Modular_Type is mod 2**4; > function Shift_Left (Item : in Modular_Type; > N : in Positive) return Modular_Type is > begin > return Item * 2**N; > end Shift_Left; > > Why does this happen? It is a bug in GCC on i386 platform. I can repeat it with GNAT GPL 2007 and GCC 4.3.0 (OpenBSD/i386). With GCC 4.3.0 optimization flags (-O2 vs. -O0) seem to affect to the result. On Solaris (5.10 Generic_127111-05 sun4u sparc SUNW,Sun-Fire-V240) with GCC 4.2.1 the example returns 0 always. Here is more complete test case: with Ada.Text_IO; use Ada.Text_IO; procedure Shift is type Modular_Type is mod 2**4; function Shift_Left (Item : in Modular_Type; N : in Positive) return Modular_Type is begin return Item * (2**N); end Shift_Left; X : Modular_Type; begin X := Shift_Left(2#1111#, 4); Put_Line (X'Img); end Shift; -- Tero Koskinen - http://iki.fi/tero.koskinen/