Hi Arnd,
On Sat, Apr 22, 2017 at 5:30 PM, Arnd Bergmann arnd@arndb.de wrote:
Based on what I found so far, gcc-4 can be pretty much ruled out from being the minimum version based on the number of failures I got. It's much better than 3.4 but much worse than 4.1 or 4.2 which seem fixable on MIPS and x86 at least, and may or may not work depending on configuration. So the best two possible (but conflicting) answers I have are
a) There are known users on gcc-4.1, and we never break things that work for users, so gcc-4.1 (or possibly 4.0 if a user shows up) would be the minimum version. b) gcc-4.1 and 4.2 have too many problems, so users are better off when we tell them to upgrade to something newer, and a minimum version of gcc-4.3 has fewer surprises. We should remove all workarounds for pre-gcc-4.3 compilers and just force a build error message.
If there's no real good reason (brokenness) to deprecate gcc-4.1, I would not do it.I guess most people using old compilers know what they're doing.
My main motivation for keep on using gcc-4.1 is that it gives many warnings that were disabled in later gcc versions. I do look at all new warnings, and send patches when they are real bugs, or are trivial to silence.
Lately the usefulness has been decreasing, as you've been too aggressively killing compiler warnings with recent gcc versions (which became better) ;-) Hence if I detected a new warning with a point or an rc release, it usually means the code was never in nex (ugh)t, or the maintainer ignored your patch.
I could easily switch to v4.9 from kernel.org crosstool, though, but then I would loose all those warnings.
BTW, below is the diff I use to avoid an ICE. After that, it builds and (test)boots fine on ARAnyM ;-)
diff --git a/fs/gfs2/glock.c b/fs/gfs2/glock.c index ec0848fcca02d896..eb75b324ac0ac53d 100644 --- a/fs/gfs2/glock.c +++ b/fs/gfs2/glock.c @@ -650,13 +650,16 @@ int gfs2_glock_get(struct gfs2_sbd *sdp, u64 number, struct gfs2_glock **glp) { struct super_block *s = sdp->sd_vfs; - struct lm_lockname name = { .ln_number = number, + // FIXME Avoid gcc 4.1.2 20061115 (prerelease) (Ubuntu 4.1.1-21) ICE + //struct lm_lockname name = { .ln_number = number, + struct lm_lockname name = { .ln_type = glops->go_type, .ln_sbd = sdp }; struct gfs2_glock *gl, *tmp = NULL; struct address_space *mapping; struct kmem_cache *cachep; int ret, tries = 0; + name.ln_number = number;
rcu_read_lock(); gl = rhashtable_lookup_fast(&gl_hash_table, &name, ht_parms); diff --git a/fs/gfs2/rgrp.c b/fs/gfs2/rgrp.c index 86ccc01593937d93..8783b72df5fa3d0c 100644 --- a/fs/gfs2/rgrp.c +++ b/fs/gfs2/rgrp.c @@ -1767,7 +1767,11 @@ static void try_rgrp_unlink(struct gfs2_rgrpd *rgd, u64 *last_unlinked, u64 skip struct gfs2_inode *ip; int error; int found = 0; - struct gfs2_rbm rbm = { .rgd = rgd, .bii = 0, .offset = 0 }; + // FIXME Avoid gcc 4.1.2 20061115 (prerelease) (Ubuntu 4.1.1-21) ICE + // struct gfs2_rbm rbm = { .rgd = rgd, .bii = 0, .offset = 0 }; + struct gfs2_rbm rbm = { .bii = 0, .offset = 0 }; + rbm.rgd = rgd; +
while (1) { down_write(&sdp->sd_log_flush_lock);
Gr{oetje,eeting}s,
Geert
-- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org
In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds