cvs commit: src/share/man/man4 Makefile src/sys/dev/cxgb cxgb_adapter.h cxgb_config.h cxgb_ioctl.h cxgb_lro.c cxgb_main.c cxgb_osdep.h cxgb_sge.c t3fw-3.2.bin.gz.uu src/sys/dev/cxgb/common cxgb_ael1002.c cxgb_common.h cxgb_firmware_exports.h cxgb

Peter Pentchev roam at ringlet.net
Fri Mar 16 10:39:19 UTC 2007


On Thu, Mar 15, 2007 at 10:35:49PM -0700, Kip Macy wrote:
> 
> 
> On 3/15/07, Peter Pentchev <roam at ringlet.net> wrote:
> >On Thu, 15 Mar 2007 at 03:06:32 +0000 (UTC), Kip Macy wrote:
> >>
> >> kmacy       2007-03-15 03:06:32 UTC
> >>
> >>   FreeBSD src repository
> >>
> >>   Modified files:        (Branch: RELENG_6)
> >>     share/man/man4       Makefile
> >>   Added files:           (Branch: RELENG_6)
> >>     sys/dev/cxgb         cxgb_adapter.h cxgb_config.h cxgb_ioctl.h
> >>                          cxgb_lro.c cxgb_main.c cxgb_osdep.h
> >>                          cxgb_sge.c t3fw-3.2.bin.gz.uu
> >>     sys/dev/cxgb/common  cxgb_ael1002.c cxgb_common.h
> >>                          cxgb_firmware_exports.h cxgb_mc5.c
> >>                          cxgb_mv88e1xxx.c cxgb_regs.h
> >>                          cxgb_sge_defs.h cxgb_t3_cpl.h
> >>                          cxgb_t3_hw.c cxgb_tcb.h cxgb_version.h
> >>                          cxgb_vsc8211.c cxgb_xgmac.c
> >>     sys/modules/cxgb     Makefile
> >>   Log:
> >>   MFC Chelsio T3 10 Gigabit Ethernet support
> >>
> >>   Don't hook into build just
> >
> >Is it possible that the GCC version in 6.x-STABLE is different from
> >that in -CURRENT?  On my laptop (i386, yesterday's -STABLE) LINT failed
> >to build with the following:
> >
> >/fs/6/usr.src/sys/dev/cxgb/cxgb_sge.c: In function `sge_timer_reclaim':
> >/fs/6/usr.src/sys/dev/cxgb/cxgb_sge.c:172: warning: inlining failed in 
> >call to 'refill_rspq': function body not available
> >/fs/6/usr.src/sys/dev/cxgb/cxgb_sge.c:699: warning: called from here
> >
> >It seems it simply needed refill_rspq() to be moved up, so that
> >the compiler could actually see the function body before first use;
> >or is this a bug in GCC?
> >
> >Anyway, here's a simple patch that fixed the LINT build for me.
> 
> I'm not saying it isn't a problem - but I can't reproduce it on my
> system. I see all sorts of inlining complaints from other modules but
> not cxgb. Are you sure you don't have a modified make.conf?

Actually, yes, I was using a slightly modified make.conf.  After playing
around for a while it turned out that the "problem" was a CONFIGARGS?=-g
line, which changed the gcc invocation to -O instead of the default -O2.

Again, after playing around with the gcc options a bit, it turns out
that -O2 includes -funit-at-a-time, making gcc parse the whole cxgb_sge.c
before the compilation, so that it can see the refill_rspq() function
body and it can inline it properly.

So... I'm not sure what the proper solution ought to be - either figure
out a way to add -funit-at-a-time to CFLAGS (which might not work all
that well with non-gcc compilers, I guess), or move the function body up
as per my original suggestion.

G'luck,
Peter

-- 
Peter Pentchev	roam at ringlet.net    roam at cnsys.bg    roam at FreeBSD.org
PGP key:	http://people.FreeBSD.org/~roam/roam.key.asc
Key fingerprint	FDBA FD79 C26F 3C51 C95E  DF9E ED18 B68D 1619 4553
I had to translate this sentence into English because I could not read the original Sanskrit.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 187 bytes
Desc: not available
Url : http://lists.freebsd.org/pipermail/cvs-src/attachments/20070316/9c79c348/attachment.pgp


More information about the cvs-src mailing list