summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@nbd.name>2016-05-13 16:31:58 +0200
committerFelix Fietkau <nbd@nbd.name>2016-05-13 16:32:36 +0200
commit0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c (patch)
treeed2026f974379a235152d530945878e90ad8987c /scripts
parent111285e742d075956a149dce5a817fad3de2c850 (diff)
downloadmaster-31e0f0ae-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.tar.gz
master-31e0f0ae-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.tar.bz2
master-31e0f0ae-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.zip
scripts/metadata.pl: add support for generating profile make code for the image builder
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/metadata.pl23
-rw-r--r--scripts/metadata.pm5
2 files changed, 22 insertions, 6 deletions
diff --git a/scripts/metadata.pl b/scripts/metadata.pl
index 260d06d712..c7582b42dc 100755
--- a/scripts/metadata.pl
+++ b/scripts/metadata.pl
@@ -282,12 +282,7 @@ EOF
foreach my $target (@target) {
my $profiles = $target->{profiles};
- $target->{sort} and @$profiles = sort {
- $a->{priority} <=> $b->{priority} or
- $a->{name} cmp $b->{name};
- } @$profiles;
-
- foreach my $profile (@$profiles) {
+ foreach my $profile (@{$target->{profiles}}) {
print <<EOF;
config TARGET_$target->{conf}_$profile->{id}
bool "$profile->{name}"
@@ -912,11 +907,26 @@ sub gen_version_filtered_list() {
}
}
+sub gen_profile_mk() {
+ my $file = shift @ARGV;
+ my $target = shift @ARGV;
+ my @targets = parse_target_metadata($file);
+ foreach my $cur (@targets) {
+ next unless $cur->{id} eq $target;
+ print "PROFILE_NAMES = ".join(" ", map { $_->{id} } @{$cur->{profiles}})."\n";
+ foreach my $profile (@{$cur->{profiles}}) {
+ print $profile->{id}.'_NAME:='.$profile->{name}."\n";
+ print $profile->{id}.'_PACKAGES:='.join(' ', @{$profile->{packages}})."\n";
+ }
+ }
+}
+
sub parse_command() {
GetOptions("ignore=s", \@ignore);
my $cmd = shift @ARGV;
for ($cmd) {
/^target_config$/ and return gen_target_config();
+ /^profile_mk$/ and return gen_profile_mk();
/^package_mk$/ and return gen_package_mk();
/^package_config$/ and return gen_package_config();
/^kconfig/ and return gen_kconfig_overrides();
@@ -929,6 +939,7 @@ sub parse_command() {
print <<EOF
Available Commands:
$0 target_config [file] Target metadata in Kconfig format
+ $0 profile_mk [file] [target] Profile metadata in makefile format
$0 package_mk [file] Package metadata in makefile format
$0 package_config [file] Package metadata in Kconfig format
$0 kconfig [file] [config] [patchver] Kernel config overrides
diff --git a/scripts/metadata.pm b/scripts/metadata.pm
index 5f28289037..e2a739533c 100644
--- a/scripts/metadata.pm
+++ b/scripts/metadata.pm
@@ -112,6 +112,11 @@ sub parse_target_metadata($) {
packages => []
}
];
+
+ $target->{sort} and @{$target->{profiles}} = sort {
+ $a->{priority} <=> $b->{priority} or
+ $a->{name} cmp $b->{name};
+ } @{$target->{profiles}};
}
return @target;
}