Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 4 Sep 2003 18:04:48 +0200
From:      Alexander Leidinger <Alexander@Leidinger.net>
To:        current@freebsd.org
Subject:   Question about genassym, locore.s and 0-sized arrays (showstopper for an icc compiled kernel)
Message-ID:  <20030904180448.021a1b6b.Alexander@Leidinger.net>

next in thread | raw e-mail | index | archive | help
Hi,

I'm in the process of building our kernel with Intels C Compiler (icc).
So far we are able to build a working UP and SMP kernel (not completely
automated). Most of it works just fine (NFS-client is known to not
work).

At the moment I discussing an issue with Intel regarding 0-sized arrays.
gcc seems to be violating the standard and produces code with an array
size of "0", whereas icc produces code where an 0-sized array has the
size "1". This results in different nm output of genassym.o:

gcc generated:
---snip---
00000000 C BC32SELsign
00000050 C BC32SELw0
00000000 C BC32SELw1
00000000 C BC32SELw2
00000000 C BC32SELw3
---snip---

icc generated:
---snip---
00000001 C BC32SELsign
00000050 C BC32SELw0
00000001 C BC32SELw1
00000001 C BC32SELw2
00000001 C BC32SELw3
---snip---

Thus the output of genassym.sh with a icc generated genassym.o is wrong:
---snip---
#define	BC32SEL	-0x1000100010050
#define	BI_ENDCOMMON	-0x100010001000c
#define	BI_ESYMTAB	-0x1000100010044
#define	BI_KERNELNAME	-0x1000100010004
#define	BI_KERNEND	-0x1000100010048
#define	BI_NFS_DISKLESS	-0x1000100010008
#define	BI_SIZE	-0x1000100010030
---snip---

With a gcc generated genassym.o it looks like:
---snip---
#define	BC32SEL	0x50
#define	BI_ENDCOMMON	0xc
#define	BI_ESYMTAB	0x44
#define	BI_KERNELNAME	0x4
#define	BI_KERNEND	0x48
#define	BI_NFS_DISKLESS	0x8
#define	BI_SIZE	0x30
---snip---

At least the generated defines are used in locore.s, but is this the
only consumer of this "feature"? What I need to know is:
 - Do we really depend on 0-sized arrays in the code or is it just a
   genassym.sh issue?
 - If we depend on it: how hard would it be to rewrite it to not depend
   on 0-sized arrays (and does someone volunteer to rewrite it)? It
   would be nice if someone could point me to the source if it isn't
   an easy task, my contact @Intel is willing to convince the
   developers to change icc, but he has to "present a persuasive argument
   to development to pursue a solution".
 - If it is a genassym.sh issue: would someone with enough glue please
   provide me with a patch for genassym.sh which either uses a switch
   to understand the icc generated file or is able to detect it on it's
   own (I'm able to provide the output of nm and/or the object file)?
   Or at least describes what needs to be done, so I can try do do it
   myself after refreshing my awk knowledge?

Bye,
Alexander.

-- 
Failure is not an option. It comes bundled with your Microsoft product.

http://www.Leidinger.net                       Alexander @ Leidinger.net
  GPG fingerprint = C518 BC70 E67F 143F BE91  3365 79E2 9C60 B006 3FE7



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030904180448.021a1b6b.Alexander>