diff options
| author | Tom Rini <tom_rini@mentor.com> | 2011-07-12 09:29:34 -0700 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-07-21 10:59:18 +0100 |
| commit | 997b1fc7f722ee20212107f8243fd71fef4fcf7e (patch) | |
| tree | d93cac7247a83fd8c1d97afa823a67b4f8ff9165 /meta | |
| parent | fe7db148c2f0286c1e4106d718c650f86cbb5030 (diff) | |
| download | poky-997b1fc7f722ee20212107f8243fd71fef4fcf7e.tar.gz | |
siteinfo.bbclass: Port over oe.dev logic for site files
In oe.dev we have a sets to pick out hostos/hostarch/etc site
files out of and include things like a common-linux site file.
This should also help out with adding multilib-specific site files
(ie x32). In oe.dev we have an iterator but at Richard's request
we continue to return a list of files in siteinfo_get_files().
(From OE-Core rev: cb3d7cd1c0f2bbcd448abbb832074ca965e0af5e)
Signed-off-by: Tom Rini <tom_rini@mentor.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
| -rw-r--r-- | meta/classes/siteinfo.bbclass | 203 | ||||
| -rw-r--r-- | meta/site/common-linux | 0 |
2 files changed, 98 insertions, 105 deletions
diff --git a/meta/classes/siteinfo.bbclass b/meta/classes/siteinfo.bbclass index 78b7008e85..ff9fd0db95 100644 --- a/meta/classes/siteinfo.bbclass +++ b/meta/classes/siteinfo.bbclass | |||
| @@ -15,121 +15,114 @@ | |||
| 15 | # It is an error for the target not to exist. | 15 | # It is an error for the target not to exist. |
| 16 | # If 'what' doesn't exist then an empty value is returned | 16 | # If 'what' doesn't exist then an empty value is returned |
| 17 | # | 17 | # |
| 18 | def get_siteinfo_list(d): | 18 | def siteinfo_data(d): |
| 19 | target = bb.data.getVar('HOST_ARCH', d, 1) + "-" + bb.data.getVar('HOST_OS', d, 1) | 19 | archinfo = { |
| 20 | "allarch": "endian-little bit-32", # bogus, but better than special-casing the checks below for allarch | ||
| 21 | "arm": "endian-little bit-32 arm-common", | ||
| 22 | "armeb": "endian-big bit-32 arm-common", | ||
| 23 | "avr32": "endian-big bit-32 avr32-common", | ||
| 24 | "bfin": "endian-little bit-32 bfin-common", | ||
| 25 | "i386": "endian-little bit-32 ix86-common", | ||
| 26 | "i486": "endian-little bit-32 ix86-common", | ||
| 27 | "i586": "endian-little bit-32 ix86-common", | ||
| 28 | "i686": "endian-little bit-32 ix86-common", | ||
| 29 | "ia64": "endian-little bit-64", | ||
| 30 | "microblaze": "endian-big bit-32 microblaze-common", | ||
| 31 | "microblazeel": "endian-little bit-32 microblaze-common", | ||
| 32 | "mips": "endian-big bit-32 mips-common", | ||
| 33 | "mips64": "endian-big bit-64 mips64-common", | ||
| 34 | "mips64el": "endian-little bit-64 mips64-common", | ||
| 35 | "mipsel": "endian-little bit-32 mips-common", | ||
| 36 | "powerpc": "endian-big bit-32 powerpc-common", | ||
| 37 | "nios2": "endian-little bit-32 nios2-common", | ||
| 38 | "powerpc64": "endian-big bit-64 powerpc-common powerpc64-linux", | ||
| 39 | "ppc": "endian-big bit-32 powerpc-common", | ||
| 40 | "ppc64": "endian-big bit-64 powerpc-common powerpc64-linux", | ||
| 41 | "sh3": "endian-little bit-32 sh-common", | ||
| 42 | "sh4": "endian-little bit-32 sh-common", | ||
| 43 | "sparc": "endian-big bit-32", | ||
| 44 | "viac3": "endian-little bit-32 ix86-common", | ||
| 45 | "x86_64": "endian-little bit-64", | ||
| 46 | } | ||
| 47 | osinfo = { | ||
| 48 | "darwin": "common-darwin", | ||
| 49 | "darwin9": "common-darwin", | ||
| 50 | "linux": "common-linux common-glibc", | ||
| 51 | "linux-gnueabi": "common-linux common-glibc", | ||
| 52 | "linux-gnuspe": "common-linux common-glibc", | ||
| 53 | "linux-uclibc": "common-linux common-uclibc", | ||
| 54 | "linux-uclibceabi": "common-linux common-uclibc", | ||
| 55 | "linux-uclibcspe": "common-linux common-uclibc", | ||
| 56 | "uclinux-uclibc": "common-uclibc", | ||
| 57 | "cygwin": "common-cygwin", | ||
| 58 | "mingw32": "common-mingw", | ||
| 59 | } | ||
| 60 | targetinfo = { | ||
| 61 | "arm-linux-gnueabi": "arm-linux", | ||
| 62 | "arm-linux-uclibceabi": "arm-linux-uclibc", | ||
| 63 | "armeb-linux-gnueabi": "armeb-linux", | ||
| 64 | "armeb-linux-uclibceabi": "armeb-linux-uclibc", | ||
| 65 | "powerpc-linux-gnuspe": "powerpc-linux", | ||
| 66 | "powerpc-linux-uclibcspe": "powerpc-linux-uclibc", | ||
| 67 | } | ||
| 20 | 68 | ||
| 21 | targetinfo = {\ | 69 | hostarch = d.getVar("HOST_ARCH", True) |
| 22 | "allarch-linux": "",\ | 70 | hostos = d.getVar("HOST_OS", True) |
| 23 | "armeb-linux": "endian-big bit-32 common-glibc arm-common",\ | 71 | target = "%s-%s" % (hostarch, hostos) |
| 24 | "armeb-linux-gnueabi": "endian-big bit-32 common-glibc arm-common armeb-linux",\ | ||
| 25 | "armeb-linux-uclibc": "endian-big bit-32 common-uclibc arm-common",\ | ||
| 26 | "armeb-linux-uclibceabi": "endian-big bit-32 common-uclibc arm-common armeb-linux-uclibc",\ | ||
| 27 | "arm-darwin": "endian-little bit-32 common-darwin",\ | ||
| 28 | "arm-darwin8": "endian-little bit-32 common-darwin",\ | ||
| 29 | "arm-linux": "endian-little bit-32 common-glibc arm-common",\ | ||
| 30 | "arm-linux-gnueabi": "endian-little bit-32 common-glibc arm-common arm-linux",\ | ||
| 31 | "arm-linux-uclibc": "endian-little bit-32 common-uclibc arm-common",\ | ||
| 32 | "arm-linux-uclibceabi": "endian-little bit-32 common-uclibc arm-common arm-linux-uclibc",\ | ||
| 33 | "avr32-linux": "endian-big bit-32 common-glibc avr32-common",\ | ||
| 34 | "avr32-linux-uclibc": "endian-big bit-32 common-uclibc avr32-common",\ | ||
| 35 | "bfin-uclinux-uclibc": "endian-little bit-32 common-uclibc bfin-common",\ | ||
| 36 | "i386-linux": "endian-little bit-32 common-glibc ix86-common",\ | ||
| 37 | "i486-linux": "endian-little bit-32 common-glibc ix86-common",\ | ||
| 38 | "i586-linux": "endian-little bit-32 common-glibc ix86-common",\ | ||
| 39 | "i686-linux": "endian-little bit-32 common-glibc ix86-common",\ | ||
| 40 | "i386-linux-uclibc": "endian-little bit-32 common-uclibc ix86-common",\ | ||
| 41 | "i486-linux-uclibc": "endian-little bit-32 common-uclibc ix86-common",\ | ||
| 42 | "i586-linux-uclibc": "endian-little bit-32 common-uclibc ix86-common",\ | ||
| 43 | "i686-linux-uclibc": "endian-little bit-32 common-uclibc ix86-common",\ | ||
| 44 | "microblaze-linux-gnu": "endian-big bit-32 common-glibc microblaze-common",\ | ||
| 45 | "microblazeel-linux-gnu": "endian-little bit-32 common-glibc microblaze-common",\ | ||
| 46 | "mipsel-linux": "endian-little bit-32 common-glibc mips-common",\ | ||
| 47 | "mipsel-linux-uclibc": "endian-little bit-32 common-uclibc mips-common",\ | ||
| 48 | "mips-linux": "endian-big bit-32 common-glibc mips-common",\ | ||
| 49 | "mips-linux-uclibc": "endian-big bit-32 common-uclibc mips-common",\ | ||
| 50 | "powerpc-darwin": "endian-big bit-32 common-darwin",\ | ||
| 51 | "ppc-linux": "endian-big bit-32 common-glibc powerpc-common",\ | ||
| 52 | "powerpc-linux": "endian-big bit-32 common-glibc powerpc-common",\ | ||
| 53 | "powerpc-linux-gnuspe": "endian-big bit-32 common-glibc powerpc-common",\ | ||
| 54 | "powerpc-linux-uclibc": "endian-big bit-32 common-uclibc powerpc-common",\ | ||
| 55 | "sh3-linux": "endian-little bit-32 common-glibc sh-common",\ | ||
| 56 | "sh4-linux": "endian-little bit-32 common-glibc sh-common",\ | ||
| 57 | "sh4-linux-uclibc": "endian-little bit-32 common-uclibc sh-common",\ | ||
| 58 | "sparc-linux": "endian-big bit-32 common-glibc",\ | ||
| 59 | "x86_64-linux": "endian-little bit-64 common-glibc",\ | ||
| 60 | "x86_64-linux-uclibc": "endian-little bit-64 common-uclibc"} | ||
| 61 | if target in targetinfo: | ||
| 62 | info = targetinfo[target].split() | ||
| 63 | info.append(target) | ||
| 64 | info.append("common") | ||
| 65 | return info | ||
| 66 | else: | ||
| 67 | bb.error("Information not available for target '%s'" % target) | ||
| 68 | 72 | ||
| 73 | sitedata = [] | ||
| 74 | if hostarch in archinfo: | ||
| 75 | sitedata.extend(archinfo[hostarch].split()) | ||
| 76 | if hostos in osinfo: | ||
| 77 | sitedata.extend(osinfo[hostos].split()) | ||
| 78 | if target in targetinfo: | ||
| 79 | sitedata.extend(targetinfo[target].split()) | ||
| 80 | sitedata.append(target) | ||
| 81 | sitedata.append("common") | ||
| 69 | 82 | ||
| 70 | # | 83 | bb.debug(1, "SITE files %s" % sitedata); |
| 71 | # Define which site files to use. We check for several site files and | 84 | return sitedata |
| 72 | # use each one that is found, based on the list returned by get_siteinfo_list() | ||
| 73 | # | ||
| 74 | # Search for the files in the following directories: | ||
| 75 | # 1) ${BBPATH}/site (in reverse) - app specific, then site wide | ||
| 76 | # 2) ${FILE_DIRNAME}/site-${PV} - app version specific | ||
| 77 | # | ||
| 78 | def siteinfo_get_files(d): | ||
| 79 | sitefiles = "" | ||
| 80 | 85 | ||
| 81 | # Determine which site files to look for | 86 | python () { |
| 82 | sites = get_siteinfo_list(d) | 87 | sitedata = set(siteinfo_data(d)) |
| 88 | if "endian-little" in sitedata: | ||
| 89 | d.setVar("SITEINFO_ENDIANESS", "le") | ||
| 90 | elif "endian-big" in sitedata: | ||
| 91 | d.setVar("SITEINFO_ENDIANESS", "be") | ||
| 92 | else: | ||
| 93 | bb.error("Unable to determine endianness for architecture '%s'" % | ||
| 94 | d.getVar("HOST_ARCH", True)) | ||
| 95 | bb.fatal("Please add your architecture to siteinfo.bbclass") | ||
| 83 | 96 | ||
| 84 | # Check along bbpath for site files and append in reverse order so | 97 | if "bit-32" in sitedata: |
| 85 | # the application specific sites files are last and system site | 98 | d.setVar("SITEINFO_BITS", "32") |
| 86 | # files first. | 99 | elif "bit-64" in sitedata: |
| 87 | path_bb = bb.data.getVar('BBPATH', d, 1) | 100 | d.setVar("SITEINFO_BITS", "64") |
| 88 | for p in (path_bb or "").split(':'): | 101 | else: |
| 89 | tmp = "" | 102 | bb.error("Unable to determine bit size for architecture '%s'" % |
| 90 | for i in sites: | 103 | d.getVar("HOST_ARCH", True)) |
| 91 | fname = os.path.join(p, 'site', i) | 104 | bb.fatal("Please add your architecture to siteinfo.bbclass") |
| 92 | if os.path.exists(fname): | 105 | } |
| 93 | tmp += fname + " " | ||
| 94 | sitefiles = tmp + sitefiles; | ||
| 95 | 106 | ||
| 96 | # Now check for the applications version specific site files | 107 | def siteinfo_get_files(d): |
| 97 | path_pkgv = os.path.join(bb.data.getVar('FILE_DIRNAME', d, 1), "site-" + bb.data.getVar('PV', d, 1)) | 108 | sitedata = siteinfo_data(d) |
| 98 | for i in sites: | 109 | sitefiles = "" |
| 99 | fname = os.path.join(path_pkgv, i) | 110 | for path in d.getVar("BBPATH", True).split(":"): |
| 100 | if os.path.exists(fname): | 111 | for element in sitedata: |
| 101 | sitefiles += fname + " " | 112 | filename = os.path.join(path, "site", element) |
| 102 | 113 | if os.path.exists(filename): | |
| 103 | # Now check for siteconfig cache files | 114 | sitefiles += filename + " " |
| 104 | path_siteconfig = bb.data.getVar('SITECONFIG_SYSROOTCACHE', d, 1) | ||
| 105 | if os.path.isdir(path_siteconfig): | ||
| 106 | for i in os.listdir(path_siteconfig): | ||
| 107 | fname = os.path.join(path_siteconfig, i) | ||
| 108 | sitefiles += fname + " " | ||
| 109 | |||
| 110 | bb.debug(1, "SITE files " + sitefiles); | ||
| 111 | return sitefiles | ||
| 112 | 115 | ||
| 113 | def siteinfo_get_endianess(d): | 116 | # Now check for siteconfig cache files |
| 114 | info = get_siteinfo_list(d) | 117 | path_siteconfig = bb.data.getVar('SITECONFIG_SYSROOTCACHE', d, 1) |
| 115 | if 'endian-little' in info: | 118 | if os.path.isdir(path_siteconfig): |
| 116 | return "le" | 119 | for i in os.listdir(path_siteconfig): |
| 117 | elif 'endian-big' in info: | 120 | filename = os.path.join(path_siteconfig, i) |
| 118 | return "be" | 121 | sitefiles += filename + " " |
| 119 | bb.error("Site info could not determine endianess for target") | ||
| 120 | 122 | ||
| 121 | def siteinfo_get_bits(d): | 123 | return sitefiles |
| 122 | info = get_siteinfo_list(d) | ||
| 123 | if 'bit-32' in info: | ||
| 124 | return "32" | ||
| 125 | elif 'bit-64' in info: | ||
| 126 | return "64" | ||
| 127 | bb.error("Site info could not determine bit size for target") | ||
| 128 | 124 | ||
| 129 | # | 125 | # |
| 130 | # Make some information available via variables | 126 | # Make some information available via variables |
| 131 | # | 127 | # |
| 132 | SITEINFO_ENDIANESS = "${@siteinfo_get_endianess(d)}" | ||
| 133 | SITEINFO_BITS = "${@siteinfo_get_bits(d)}" | ||
| 134 | SITECONFIG_SYSROOTCACHE = "${STAGING_DATADIR}/${TARGET_SYS}_config_site.d" | 128 | SITECONFIG_SYSROOTCACHE = "${STAGING_DATADIR}/${TARGET_SYS}_config_site.d" |
| 135 | |||
diff --git a/meta/site/common-linux b/meta/site/common-linux new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/meta/site/common-linux | |||
