diff options
4 files changed, 161 insertions, 0 deletions
diff --git a/meta/conf/machine/include/microblaze/arch-microblaze.inc b/meta/conf/machine/include/microblaze/arch-microblaze.inc new file mode 100644 index 0000000000..eab7171cb2 --- /dev/null +++ b/meta/conf/machine/include/microblaze/arch-microblaze.inc | |||
@@ -0,0 +1,53 @@ | |||
1 | # MicroBlaze architecture tune feature configuration | ||
2 | |||
3 | # Architecture feature and override | ||
4 | TUNEVALID[microblaze] = "MicroBlaze" | ||
5 | MACHINEOVERRIDES =. "${@bb.utils.contains("TUNE_FEATURES", "microblaze", "microblaze:", "", d)}" | ||
6 | |||
7 | # Endian | ||
8 | TUNEVALID[bigendian] = "Use Microblaze Big Endian" | ||
9 | TUNECONFLICTS[bigendian] += "v10.0" | ||
10 | |||
11 | MBPKGARCH_ENDIAN = "${@bb.utils.contains("TUNE_FEATURES", "bigendian", "eb", "el", d)}" | ||
12 | |||
13 | TUNE_CCARGS += "${@bb.utils.contains("TUNE_FEATURES", "bigendian", "-mbig-endian", "-mlittle-endian", d)}" | ||
14 | |||
15 | # General features | ||
16 | TUNEVALID[barrel-shift] = "Enable Hardware Barrel Shifter" | ||
17 | TUNEVALID[pattern-compare] = "Enable Pattern Compare Instructions" | ||
18 | TUNEVALID[reorder] = "Enable Reorder Instructions" | ||
19 | TUNECONFLICTS[reorder] += "v8.00 v8.10 v8.20" | ||
20 | |||
21 | # Core configuration tune optimizations | ||
22 | TUNEVALID[frequency-optimized] = "Enabling tuning for frequency optimized core (AREA_OPTIMIZED_2)" | ||
23 | TUNECONFLICTS[frequency-optimized] += "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2 v9.3 v9.4 v9.5 v9.6" | ||
24 | |||
25 | # Feature compiler args | ||
26 | TUNE_CCARGS += "${@bb.utils.contains("TUNE_FEATURES", "barrel-shift", "-mxl-barrel-shift", "-mno-xl-barrel-shift", d)}" | ||
27 | TUNE_CCARGS += "${@bb.utils.contains("TUNE_FEATURES", "pattern-compare", "-mxl-pattern-compare", "-mno-xl-pattern-compare", d)}" | ||
28 | TUNE_CCARGS += "${@bb.utils.contains("TUNE_FEATURES", "frequency-optimized", "-mxl-frequency", "", d)}" | ||
29 | |||
30 | # Disable reorder for v8.30 if pattern-compare is not enabled | ||
31 | TUNE_CCARGS += "${@bb.utils.contains("TUNE_FEATURES", "reorder", \ | ||
32 | bb.utils.contains("TUNE_FEATURES", "v8.30", \ | ||
33 | bb.utils.contains("TUNE_FEATURES", "pattern-compare", \ | ||
34 | "-mxl-reorder", "-mno-xl-reorder", d), \ | ||
35 | "-mxl-reorder", d), "-mno-xl-reorder", d)}" | ||
36 | |||
37 | # Feature package architecture formatting | ||
38 | MBPKGARCH_TUNE = "" | ||
39 | MBPKGARCH_TUNE .= "${@bb.utils.contains("TUNE_FEATURES", "barrel-shift", "-bs", "", d)}" | ||
40 | MBPKGARCH_TUNE .= "${@bb.utils.contains("TUNE_FEATURES", "pattern-compare", "-cmp", "", d)}" | ||
41 | MBPKGARCH_TUNE .= "${@bb.utils.contains("TUNE_FEATURES", "reorder", "-re", "", d)}" | ||
42 | MBPKGARCH_TUNE .= "${@bb.utils.contains("TUNE_FEATURES", "frequency-optimized", "-fo", "", d)}" | ||
43 | |||
44 | # Additional features | ||
45 | require conf/machine/include/microblaze/feature-microblaze-versions.inc | ||
46 | require conf/machine/include/microblaze/feature-microblaze-math.inc | ||
47 | |||
48 | # Architecture name, either 'microblazeeb' or 'microblazeel' depending on endianess | ||
49 | TUNE_ARCH = "microblaze${@bb.utils.contains("TUNE_FEATURES", "bigendian", "eb", "el", d)}" | ||
50 | |||
51 | # Package Architecture formatting | ||
52 | TUNE_PKGARCH = "microblaze${MBPKGARCH_ENDIAN}${MBPKGARCH_VERSION}${MBPKGARCH_TUNE}${MBPKGARCH_MATH}" | ||
53 | |||
diff --git a/meta/conf/machine/include/microblaze/feature-microblaze-math.inc b/meta/conf/machine/include/microblaze/feature-microblaze-math.inc new file mode 100644 index 0000000000..a31516659c --- /dev/null +++ b/meta/conf/machine/include/microblaze/feature-microblaze-math.inc | |||
@@ -0,0 +1,33 @@ | |||
1 | # This include describes the math features (integer and floating point) that | ||
2 | # are available for the MicroBlaze ISA | ||
3 | |||
4 | TUNEVALID[multiply-low] = "Hardware multipler with 32 bit result" | ||
5 | TUNEVALID[multiply-high] = "Hardware multipler with 64 bit result" | ||
6 | TUNEVALID[divide-hard] = "Hardware divider" | ||
7 | TUNEVALID[fpu-soft] = "Software FPU" | ||
8 | TUNEVALID[fpu-hard] = "Hardware FPU in basic mode" | ||
9 | TUNEVALID[fpu-hard-extended] = "Hardware FPU in extended mode (conversion and square root instructions)" | ||
10 | |||
11 | TUNECONFLICTS[fpu-soft] = "fpu-hard fpu-hard-extended" | ||
12 | TUNECONFLICTS[fpu-hard] = "fpu-soft" | ||
13 | TUNECONFLICTS[fpu-hard-extended] = "fpu-soft" | ||
14 | |||
15 | # Compiler args | ||
16 | TUNE_CCARGS += "${@bb.utils.contains_any('TUNE_FEATURES', ['multiply-low', 'multiply-high'], '-mno-xl-soft-mul', '-mxl-soft-mul', d)}" | ||
17 | TUNE_CCARGS += "${@bb.utils.contains('TUNE_FEATURES', 'multiply-high', '-mxl-multiply-high', '', d)}" | ||
18 | |||
19 | TUNE_CCARGS += "${@bb.utils.contains('TUNE_FEATURES', 'divide-hard', '-mno-xl-soft-div', '-mxl-soft-div', d)}" | ||
20 | |||
21 | TUNE_CCARGS += "${@bb.utils.contains('TUNE_FEATURES', 'fpu-soft', '', '', d)}" | ||
22 | TUNE_CCARGS += "${@bb.utils.contains_any('TUNE_FEATURES', ['fpu-hard', 'fpu-hard-extended'], '-mhard-float', '', d)}" | ||
23 | TUNE_CCARGS += "${@bb.utils.contains('TUNE_FEATURES', 'fpu-hard-extended', '-mxl-float-convert -mxl-float-sqrt', '', d)}" | ||
24 | |||
25 | # Set target fpu (bitbake known target) to soft or hard (basic or extended) | ||
26 | TARGET_FPU = "${@bb.utils.contains_any('TUNE_FEATURES', 'fpu-hard fpu-hard-extended', 'fpu-hard', 'fpu-soft', d)}" | ||
27 | |||
28 | # Package Architecture formatting | ||
29 | MBPKGARCH_MATH = "" | ||
30 | MBPKGARCH_MATH .= "${@bb.utils.contains('TUNE_FEATURES', 'multiply-high', '-mh', bb.utils.contains('TUNE_FEATURES', 'multiply-low', '-ml', '', d), d)}" | ||
31 | MBPKGARCH_MATH .= "${@bb.utils.contains('TUNE_FEATURES', 'divide-hard', '-div', '', d)}" | ||
32 | MBPKGARCH_MATH .= "${@bb.utils.contains('TUNE_FEATURES', 'fpu-hard-extended', '-fe', bb.utils.contains('TUNE_FEATURES', 'fpu-hard', '-fb', '', d), d)}" | ||
33 | |||
diff --git a/meta/conf/machine/include/microblaze/feature-microblaze-versions.inc b/meta/conf/machine/include/microblaze/feature-microblaze-versions.inc new file mode 100644 index 0000000000..955674fff9 --- /dev/null +++ b/meta/conf/machine/include/microblaze/feature-microblaze-versions.inc | |||
@@ -0,0 +1,67 @@ | |||
1 | # MicroBlaze versions are defined as features, the features are setup to | ||
2 | # conflict with other versions as well as unavailable features for particular | ||
3 | # versions. | ||
4 | # | ||
5 | # Versions before v9.0 of MicroBlaze use a versioning scheme of "vX.YY.Z" | ||
6 | # (where Z = [abc]). For v8.* versions of MicroBlaze the revision (Z) changes | ||
7 | # did not affect ABI and are ignored by this tune configuration. Though this | ||
8 | # format is expected by GCC including the revision, but this is defaulted to | ||
9 | # ".a". | ||
10 | # | ||
11 | # Since v9.0 of MicroBlaze the revision (Z) part of versions was entirely | ||
12 | # dropped and the version scheme was changed to "vX.Y". | ||
13 | |||
14 | def microblaze_current_version(d, gcc = False): | ||
15 | import re | ||
16 | # find the current version, and convert it to major/minor integers | ||
17 | version = None | ||
18 | for t in (d.getVar("TUNE_FEATURES") or "").split(): | ||
19 | m = re.search("^v(\d+)\.(\d+)", t) | ||
20 | if m: | ||
21 | version = int(m.group(1)), int(m.group(2)) | ||
22 | break | ||
23 | |||
24 | # format the version string in generic or GCC specific formats | ||
25 | if version: | ||
26 | if version[0] <= 8: | ||
27 | return ("v%d.%02d" % version[0:2]) + (".a" if gcc else "") | ||
28 | else: | ||
29 | return "v%d.%d" % version[0:2] | ||
30 | return "" | ||
31 | |||
32 | # MicroBlaze versions | ||
33 | TUNEVALID[v8.00] = "MicroBlaze version 8.00" | ||
34 | TUNEVALID[v8.10] = "MicroBlaze version 8.10" | ||
35 | TUNEVALID[v8.20] = "MicroBlaze version 8.20" | ||
36 | TUNEVALID[v8.30] = "MicroBlaze version 8.30" | ||
37 | TUNEVALID[v8.40] = "MicroBlaze version 8.40" | ||
38 | TUNEVALID[v8.50] = "MicroBlaze version 8.50" | ||
39 | TUNEVALID[v9.0] = "MicroBlaze version 9.0" | ||
40 | TUNEVALID[v9.1] = "MicroBlaze version 9.1" | ||
41 | TUNEVALID[v9.2] = "MicroBlaze version 9.2" | ||
42 | TUNEVALID[v9.3] = "MicroBlaze version 9.3" | ||
43 | TUNEVALID[v9.4] = "MicroBlaze version 9.4" | ||
44 | TUNEVALID[v9.5] = "MicroBlaze version 9.5" | ||
45 | TUNEVALID[v9.6] = "MicroBlaze version 9.6" | ||
46 | TUNEVALID[v10.0] = "MicroBlaze version 10.0" | ||
47 | |||
48 | # Version conflict matrix | ||
49 | TUNECONFLICTS[v8.00] = "" | ||
50 | TUNECONFLICTS[v8.10] = "v8.00" | ||
51 | TUNECONFLICTS[v8.20] = "v8.00 v8.10" | ||
52 | TUNECONFLICTS[v8.30] = "v8.00 v8.10 v8.20" | ||
53 | TUNECONFLICTS[v8.40] = "v8.00 v8.10 v8.20 v8.30" | ||
54 | TUNECONFLICTS[v8.50] = "v8.00 v8.10 v8.20 v8.30 v8.40" | ||
55 | TUNECONFLICTS[v9.0] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50" | ||
56 | TUNECONFLICTS[v9.1] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0" | ||
57 | TUNECONFLICTS[v9.2] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1" | ||
58 | TUNECONFLICTS[v9.3] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2" | ||
59 | TUNECONFLICTS[v9.4] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2 v9.3" | ||
60 | TUNECONFLICTS[v9.5] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2 v9.3 v9.4" | ||
61 | TUNECONFLICTS[v9.6] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2 v9.3 v9.4 v9.5" | ||
62 | TUNECONFLICTS[v10.0] = "v8.00 v8.10 v8.20 v8.30 v8.40 v8.50 v9.0 v9.1 v9.2 v9.3 v9.4 v9.5 v9.6" | ||
63 | |||
64 | # Version flags | ||
65 | TUNE_CCARGS += "-mcpu=${@microblaze_current_version(d, True)}" | ||
66 | MBPKGARCH_VERSION = "-${@microblaze_current_version(d)}" | ||
67 | |||
diff --git a/meta/conf/machine/include/tune-microblaze.inc b/meta/conf/machine/include/tune-microblaze.inc new file mode 100644 index 0000000000..41f0afe668 --- /dev/null +++ b/meta/conf/machine/include/tune-microblaze.inc | |||
@@ -0,0 +1,8 @@ | |||
1 | DEFAULTTUNE ?= "microblaze" | ||
2 | |||
3 | require conf/machine/include/microblaze/arch-microblaze.inc | ||
4 | |||
5 | AVAILTUNES += "microblaze" | ||
6 | TUNE_FEATURES_tune-microblaze = "microblaze" | ||
7 | PACKAGE_EXTRA_ARCHS_tune-microblaze = "${TUNE_PKGARCH}" | ||
8 | |||