In message: <064E7F22-AF3D-432C-B5E3-F71A34AB24AC_at_mac.com> Marcel Moolenaar <xcllnt_at_mac.com> writes: : : On Feb 18, 2009, at 11:05 AM, M. Warner Losh wrote: : > : In other words: by tweaking the alignment of 64-bit types in : > : n32, you prohibit GCC from using the 64-bit capabilities of : > : the processor and MIPS isn't so weird anymore. : > : > I think so, but there's a twist. : > : > On MIPS, one kernel supports multiple ABIs at the same time. I'm not : > entirely sure how the routing interface would cope with this sort of : > thing because the size of u_long changes. I need to do some more : > research to see what's going on there... : : Hmm... My first reaction is not to go there right away. It's : probably safer or go the amd64 route: keep ILP32 and LP64 : distinct. We have the infrastructure in place and we can : always optimize and blend once things are working. I don't think that's a viable option. MIPS doesn't have a 64-bit mode, but rather is always 64-bit. Or rather right now even in the port we have that supports n32 and n64 along side of o32, it is A or B or C. : > There are other ABIs on ARM that don't suffer from these problems. We : > should investigate using them. : : I agree. It's better for FreeBSD/arm in particular if it's : more like FreeBSD/i386. It may not be best for the ARM : port in absolute sense, but we only have a few developers : working on non-i386 hardware and a whole lot of developers : who don't care about non-i386... So far the number of places we've had to change in the kernel is minimal for the current ABI. The newer ABI is indeed targeted more at software that's been traditionally developed for x86 hardware. : > : At Juniper I changed the ARM compiler default by adding: : > : -mstructure-size-boundary=8 : > : : > : That made life a *lot* simpler and performance hasn't been : > : sacrificed. : > : > Except you've invented a new ABI by doing that... : : We have a products to make and a source base to work : with. Swimming upstream is best left to salmons :-) Yes. In a closed environment, you have that option. : > I think that the : > project should look at transitioning to a different ABI that works : > better. ARM has several to choose from... : : I tend to agree. : : : > It also turns out that in this case, a simple (void *) is safe and : > causes no issues because that time_t isn't accessed... It does give : > one time to pause and think about it. : : Fair enough. Misalignment in process space can easily be : made non-fatal, in which case it's mostly a performance : problem. That makes the problem space much more contained : and therefore easier to deal with... Other systems on mips are a mixed bag. Some allow user land fixup, while others abort the application... I think we need more real-world experience for which one is the best approach... WarnerReceived on Wed Feb 18 2009 - 21:11:44 UTC
This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:39:42 UTC