From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
To: buildroot@busybox.net
Subject: [Buildroot] [PATCH v2] pkg-cmake.mk: Set CMAKE_SYSTEM_PROCESSOR.
Date: Tue, 18 Nov 2014 10:05:37 +0100 [thread overview]
Message-ID: <20141118100537.3ebb37ea@free-electrons.com> (raw)
In-Reply-To: <3699446.aCFlAc4tJo@vkpc9>
Hello,
On Mon, 17 Nov 2014 21:00:16 +0100, Volker Krause wrote:
> > I believe armv6l and armv7l is only valid on little-endian ARM systems,
> > not big endian ones.
>
> you are right, and armv5 is missing the endianess suffix. Fixed in the next
> version.
Ok, thanks.
> > Are we sure that $(BR2_ARCH) is valid for all other cases?
>
> It is correct for x86 (32 and 64 bit), as discussed previously. Besides that I
> only have access to armv6 and armv7a devices for testing.
>
> I looked at the kernel code, but unfortunately it's not exactly
> straightforward to determine what the machine name will be in which case. So,
> no, I can't provide a complete $(BR2_ARCH) -> uname -m mapping for all
> platforms.
>
> That's of course sub-optimal, but IMHO not necessarily a blocker. This value
> is kinda unreliable from a CMake POV anyway (as it's provided by the system,
> especially when also considering non-Linux), and is therefore only useful for
> a very basic distinction between a fixed set of known architectures, if no
> better check is available, by means of some fuzzy comparison (see e.g. the x86
> vs. i686 discussion earlier). You'd not use this for details like endianess or
> pointer sizes for example, there's more robust ways to check for that (e.g.
> CMAKE_SIZEOF_VOID_P). But an "is MIPS?" check would work no matter if the
> exact value might be "mips", "mipsel", "mips64" or "mips64l".
>
> I therefore think that $(BR2_ARCH) is a sufficient approximation for all
> platforms where we do not know the exact mapping to uname -m.
>
> Impact on existing packages is also worth looking at. There is very few
> actually making use of CMAKE_SYSTEM_PROCESSOR to begin with. I think it's safe
> to assume the case that a package breaks if the variable is set but worked
> with an empty one before is reasonably unlikely. So the ones making use of
> this are currently doing their own mapping and set CMAKE_SYSTEM_PROCESSOR via
> the command line (which is where the first version of the mapping for this
> patch came from). Those should not see a difference at all, they'd still be
> overriding it manually.
>
> And anyone targeting a platform with a currently possibly wrong mapping with a
> new/updated package would need to sort that out in any case, while at least
> some platforms would work out of the box already with this patch.
>
> So, IMHO still a step into the right direction, even if we cannot complete the
> $(BR2_ARCH) -> uname -m mapping entirely.
Yes, I agree. I know that being sure that all $(BR2_ARCH) values are
valid is difficult, and we probably should simply rely on autobuilders
+ user testing to find out whether it causes some problems.
Thanks!
Thomas
--
Thomas Petazzoni, CTO, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
prev parent reply other threads:[~2014-11-18 9:05 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-11-16 11:55 [Buildroot] [PATCH v2] pkg-cmake.mk: Set CMAKE_SYSTEM_PROCESSOR Volker Krause
2014-11-16 14:20 ` Samuel Martin
2014-11-16 22:23 ` Thomas Petazzoni
2014-11-17 20:00 ` Volker Krause
2014-11-18 9:05 ` Thomas Petazzoni [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20141118100537.3ebb37ea@free-electrons.com \
--to=thomas.petazzoni@free-electrons.com \
--cc=buildroot@busybox.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.