[bharr...@fs2 ~/dev/git/pub/scsi-misc] 1115$ git bisect good f25c80a4b2bf93c99820f470573626557db35202 is the first bad commit commit f25c80a4b2bf93c99820f470573626557db35202 Author: Julia Lawall <ju...@diku.dk> Date: Tue Jul 20 12:25:17 2010 +0000
arch/um/drivers: remove duplicate structure field initialization There are two initializations of ndo_set_mac_address, one to a local function that is not used otherwise and one to a function that is defined elsewhere. The semantic match that finds this problem is as follows: (http://coccinelle.lip6.fr/) // <smpl> @r@ identifier I, s, fld; position p0,p; expression E; @@ struct I s =...@p0 { ... ....@p = E, ...}; @s@ identifier I, s, r.fld; position r.p0,p; expression E; @@ struct I s =...@p0 { ... ....@p = E, ...}; @script:python@ p0 << r.p0; fld << r.fld; ps << s.p; pr << r.p; @@ if int(ps[0].line)<int(pr[0].line) or int(ps[0].column)<int(pr[0].column): cocci.print_main(fld,p0) // </smpl> akpm: - Use the standard eth_mac_addr() in uml_net_set_mac() - Remove unneeded and racy local set_ether_mac() - Remove duplicated (and incorrect) uml_netdev_ops.ndo_set_mac_address initializer. Fixes 8bb95b39a16ed55226810596f92216c53329d2fe ("uml: convert network device to netdevice ops"). [a...@linux-foundation.org: rework as above] Signed-off-by: Julia Lawall <ju...@diku.dk> Cc: Stephen Hemminger <shemmin...@vyatta.com> Cc: "David S. Miller" <da...@davemloft.net> Signed-off-by: Andrew Morton <a...@linux-foundation.org> Signed-off-by: David S. Miller <da...@davemloft.net> :040000 040000 b3ff18738a5de659b97ff6ad7ba3c23eb2736263 241657298557b14317378fbb08ad664cf6f59ad3 M arch When this patch is applied my UML's networking works less then 50% of the times. Then 30% of the times I see ethX where 1 < X < enf. Only 20% of boots will come up with the regular eth0. At 50% of the times when the nic fails to show up I get: * Bringing up interface eth0: RTNETLINK answers: Cannot assign requested address Failed to bring up eth0. When I get the funny ethX I get: * Bringing up interface eth0: Device eth0 does not seem to be present, delaying initialization. [FAILED] The patch Reverts cleanly on top of 2.6.36-rc5 and after Revert works perfectly as before. If indeed this is a cleanup. It can be included (fixed) again in next Kernel. I can try any patches until this is fixed. <RANT A HEAD CAN BE IGNORED> It has become extremely hard to bisect a simple problem in latest Kernels! Most mainline merges during a merge window are based on an rc1 of the previous Kernel. In the last 5 Kernels there was a 90% chance of a BAD bug in systems I use, at rc1. If a bug is found that needs bisecting. The other bugs creep up during bisect and mask out the possibility to bisect. For instance I found the bug I see was already present in 2.6.36-rc2 and that a good point was 2.6.35. Bisecting two bad(s) quickly took me to some 2.6.35-rc1 Kernel that did not boot at all. So I was clever I decided to merge in 2.6.35 at each bisect point. Then reset and continue. But for some reason the bisect got mixed up and complained about an impossible merge common bases. So out of desperation I did a very very^ stupid thing. []$ git rebase -i v2.6.35 v2.6.36-rc1 After endless merge conflicts, at about 3700/7100 I realised that I know what is the patch that makes my UML refuse to boot. I have actually bisect a problem with it's absence 2 Kernels ago. So I was again at my bisecting manually cherry-picking the offending patch. Making sure to reset it before every git bisect XXX step. But clearly I got lucky. In short I wish at some 2.6.XX-rc[45] of every Kernel cycle. Maintainers would rebase their next's tree of [XX+1] to a some what more stable rc. Sure re-run all the tests. They still have time for the new tree in next to be tested and verified before the next merge window. (Hell one of my bisect points took me as back as 2.6.34) Please remind me why maintainers should not rebase their trees once committed, to the point that they don't rebase even for buggy patches that are already in next, and apply fix patches, all within the same merge window. The same is also done with merge conflicts with the rc-cycle of their own code, instead of rebasing. So in short this is a call for, possibly, cleaner History in main Kernel. Please remind me why re-writing history is a bad thing. </RANT A HEAD CAN BE IGNORED> Thanks Boaz ------------------------------------------------------------------------------ Start uncovering the many advantages of virtual appliances and start using them to simplify application deployment and accelerate your shift to cloud computing. http://p.sf.net/sfu/novell-sfdev2dev _______________________________________________ User-mode-linux-devel mailing list User-mode-linux-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel