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=unavailable autolearn_force=no version=3.4.4 Path: eternal-september.org!reader01.eternal-september.org!reader02.eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail From: Simon Wright Newsgroups: comp.lang.ada Subject: Re: Allocators design flaw Date: Sat, 14 Oct 2017 09:02:47 +0100 Organization: A noiseless patient Spider Message-ID: References: Mime-Version: 1.0 Content-Type: text/plain Injection-Info: reader02.eternal-september.org; posting-host="e53c3a1e14119dea7f561d1d98279ae1"; logging-data="1955"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18z1eTPjtMUgQVB7RRaNMvoilPgSsBZndk=" User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/25.3 (darwin) Cancel-Lock: sha1:mLRoaTCTR0Vn8TW6BOAXwHB4bYI= sha1:G2NhLRC0vLxRp65d3sch+3ZVCKk= Xref: news.eternal-september.org comp.lang.ada:48447 Date: 2017-10-14T09:02:47+01:00 List-Id: Victor Porton writes: > It is impossible to properly implement an allocator through a C function > (such as raptor_alloc_memory() from Raptor C library) which allocates a > struct and returns the pointer to the allocated struct. > > It is because RM13.11(21.5/3) "The Alignment parameter is a nonzero integral > multiple of D'Alignment..." > > (If it were "The Alignment parameter is equal to D'Alignment", then we would > be able just to check (in Allocate procedure implementation) that > > pragma Assert(Dummy_Record'Alignment mod Alignment = 0); > -- where Dummy_Record is an arbitrary C-convention record > -- (as all C records have the same alignment reqs) See the arguments in the AI: http://www.ada-auth.org/cgi-bin/cvsweb.cgi/ai05s/ai05-0193-1.txt?rev=1.8&raw=N > So Alignment parameter may be arbitrarily big and the C function alignment > may not conform to it. No bigger than 'Max_Alignment_For_Allocation. > Let us think how to work around (in Ada 202x) of this design flaw. If the C struct needs alignment greater than that of the elements of which it is composed (see the AI for example) it would have it.