use lib "$FindBin::Bin";
use strict;
use metadata;
+use Getopt::Long;
my %board;
-sub confstr($) {
- my $conf = shift;
- $conf =~ tr#/\.\-/#___#;
- return $conf;
-}
-
sub version_to_num($) {
my $str = shift;
my $num = 0;
return @items;
}
-sub parse_target_metadata() {
- my $file = shift @ARGV;
- my ($target, @target, $profile);
- my %target;
-
- open FILE, "<$file" or do {
- warn "Can't open file '$file': $!\n";
- return;
- };
- while (<FILE>) {
- chomp;
- /^Target:\s*(.+)\s*$/ and do {
- my $name = $1;
- $target = {
- id => $name,
- board => $name,
- boardconf => confstr($name),
- conf => confstr($name),
- profiles => [],
- features => [],
- depends => [],
- subtargets => []
- };
- push @target, $target;
- $target{$name} = $target;
- if ($name =~ /([^\/]+)\/([^\/]+)/) {
- push @{$target{$1}->{subtargets}}, $2;
- $target->{board} = $1;
- $target->{boardconf} = confstr($1);
- $target->{subtarget} = 1;
- $target->{parent} = $target{$1};
- }
- };
- /^Target-Name:\s*(.+)\s*$/ and $target->{name} = $1;
- /^Target-Path:\s*(.+)\s*$/ and $target->{path} = $1;
- /^Target-Arch:\s*(.+)\s*$/ and $target->{arch} = $1;
- /^Target-Arch-Packages:\s*(.+)\s*$/ and $target->{arch_packages} = $1;
- /^Target-Features:\s*(.+)\s*$/ and $target->{features} = [ split(/\s+/, $1) ];
- /^Target-Depends:\s*(.+)\s*$/ and $target->{depends} = [ split(/\s+/, $1) ];
- /^Target-Description:/ and $target->{desc} = get_multiline(*FILE);
- /^Target-Optimization:\s*(.+)\s*$/ and $target->{cflags} = $1;
- /^CPU-Type:\s*(.+)\s*$/ and $target->{cputype} = $1;
- /^Linux-Version:\s*(.+)\s*$/ and $target->{version} = $1;
- /^Linux-Release:\s*(.+)\s*$/ and $target->{release} = $1;
- /^Linux-Kernel-Arch:\s*(.+)\s*$/ and $target->{karch} = $1;
- /^Default-Subtarget:\s*(.+)\s*$/ and $target->{def_subtarget} = $1;
- /^Default-Packages:\s*(.+)\s*$/ and $target->{packages} = [ split(/\s+/, $1) ];
- /^Target-Profile:\s*(.+)\s*$/ and do {
- $profile = {
- id => $1,
- name => $1,
- packages => []
- };
- push @{$target->{profiles}}, $profile;
- };
- /^Target-Profile-Name:\s*(.+)\s*$/ and $profile->{name} = $1;
- /^Target-Profile-Packages:\s*(.*)\s*$/ and $profile->{packages} = [ split(/\s+/, $1) ];
- /^Target-Profile-Description:\s*(.*)\s*/ and $profile->{desc} = get_multiline(*FILE);
- /^Target-Profile-Config:/ and $profile->{config} = get_multiline(*FILE, "\t");
- /^Target-Profile-Kconfig:/ and $profile->{kconfig} = 1;
- }
- close FILE;
- foreach my $target (@target) {
- if (@{$target->{subtargets}} > 0) {
- $target->{profiles} = [];
- next;
- }
- @{$target->{profiles}} > 0 or $target->{profiles} = [
- {
- id => 'Default',
- name => 'Default',
- packages => []
- }
- ];
- }
- return @target;
-}
-
sub gen_kconfig_overrides() {
my %config;
my %kconfig;
grep { /broken/ } @{$target->{features}} and $confstr .= "\tdepends on BROKEN\n";
} else {
$confstr .= $features;
+ if ($target->{arch} =~ /\w/) {
+ $confstr .= "\tselect $target->{arch}\n";
+ }
}
- if ($target->{arch} =~ /\w/) {
- $confstr .= "\tselect $target->{arch}\n";
- }
foreach my $dep (@{$target->{depends}}) {
my $mode = "depends on";
my $flags;
}
sub gen_target_config() {
- my @target = parse_target_metadata();
+ my $file = shift @ARGV;
+ my @target = parse_target_metadata($file);
my %defaults;
my @target_sort = sort {
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) {
print <<EOF;
$target->{subtarget} or print "\t\tdefault \"".$target->{board}."\" if TARGET_".$target->{conf}."\n";
}
print <<EOF;
+config TARGET_SUBTARGET
+ string
+ default "generic" if !HAS_SUBTARGETS
+
+EOF
+
+ foreach my $target (@target) {
+ foreach my $subtarget (@{$target->{subtargets}}) {
+ print "\t\tdefault \"$subtarget\" if TARGET_".$target->{conf}."_$subtarget\n";
+ }
+ }
+ print <<EOF;
+config TARGET_PROFILE
+ string
+EOF
+ foreach my $target (@target) {
+ my $profiles = $target->{profiles};
+ foreach my $profile (@$profiles) {
+ print "\tdefault \"$profile->{id}\" if TARGET_$target->{conf}_$profile->{id}\n";
+ }
+ }
+
+ print <<EOF;
+
config TARGET_ARCH_PACKAGES
string
$depend = $2;
}
next if $package{$depend} and $package{$depend}->{buildonly};
- if ($vdep = $package{$depend}->{vdepends}) {
- $depend = join("||", map { "PACKAGE_".$_ } @$vdep);
- } else {
- $flags =~ /\+/ and do {
- # Menuconfig will not treat 'select FOO' as a real dependency
- # thus if FOO depends on other config options, these dependencies
- # will not be checked. To fix this, we simply emit all of FOO's
- # depends here as well.
- $package{$depend} and push @t_depends, [ $package{$depend}->{depends}, $condition ];
-
- $m = "select";
- next if $only_dep;
- };
- $flags =~ /@/ or $depend = "PACKAGE_$depend";
- if ($condition) {
- if ($m =~ /select/) {
- next if $depend eq $condition;
- $depend = "$depend if $condition";
- } else {
- $depend = "!($condition) || $depend" unless $dep->{$condition} eq 'select';
+ if ($flags =~ /\+/) {
+ if ($vdep = $package{$depend}->{vdepends}) {
+ my @vdeps = @$vdep;
+ $depend = shift @vdeps;
+ if (@vdeps > 1) {
+ $condition = '!('.join("||", map { "PACKAGE_".$_ } @vdeps).')';
+ } elsif (@vdeps > 0) {
+ $condition = '!PACKAGE_'.$vdeps[0];
}
}
+
+ # Menuconfig will not treat 'select FOO' as a real dependency
+ # thus if FOO depends on other config options, these dependencies
+ # will not be checked. To fix this, we simply emit all of FOO's
+ # depends here as well.
+ $package{$depend} and push @t_depends, [ $package{$depend}->{depends}, $condition ];
+
+ $m = "select";
+ next if $only_dep;
+ } else {
+ if ($vdep = $package{$depend}->{vdepends}) {
+ $depend = join("||", map { "PACKAGE_".$_ } @$vdep);
+ }
+ }
+ $flags =~ /@/ or $depend = "PACKAGE_$depend";
+ if ($condition) {
+ if ($m =~ /select/) {
+ next if $depend eq $condition;
+ $depend = "$depend if $condition";
+ } else {
+ $depend = "!($condition) || $depend" unless $dep->{$condition} eq 'select';
+ }
}
$dep->{$depend} =~ /select/ or $dep->{$depend} = $m;
}
print "\t\t".($pkg->{tristate} ? 'tristate' : 'bool')." $title\n";
print "\t\tdefault y if DEFAULT_".$pkg->{name}."\n";
unless ($pkg->{hidden}) {
- $pkg->{default} ||= "m if ALL";
+ my @def = ("ALL");
+ if (!exists($pkg->{repository})) {
+ push @def, "ALL_NONSHARED";
+ }
+ if ($pkg->{name} =~ /^kmod-/) {
+ push @def, "ALL_KMODS";
+ }
+ $pkg->{default} ||= "m if " . join("||", @def);
}
if ($pkg->{default}) {
foreach my $default (split /\s*,\s*/, $pkg->{default}) {
}
}
-sub gen_package_feeds() {
+sub gen_package_subdirs() {
parse_package_metadata($ARGV[0]) or exit 1;
foreach my $name (sort {uc($a) cmp uc($b)} keys %package) {
my $pkg = $package{$name};
- if ($pkg->{name} && $pkg->{feed}) {
- print "Package/$name/feed = $pkg->{feed}\n";
+ if ($pkg->{name} && $pkg->{repository}) {
+ print "Package/$name/subdir = $pkg->{repository}\n";
}
}
}
}
sub parse_command() {
+ GetOptions("ignore=s", \@ignore);
my $cmd = shift @ARGV;
for ($cmd) {
/^target_config$/ and return gen_target_config();
/^package_config$/ and return gen_package_config();
/^kconfig/ and return gen_kconfig_overrides();
/^package_source$/ and return gen_package_source();
- /^package_feeds$/ and return gen_package_feeds();
+ /^package_subdirs$/ and return gen_package_subdirs();
/^package_license$/ and return gen_package_license(0);
/^package_licensefull$/ and return gen_package_license(1);
/^version_filter$/ and return gen_version_filtered_list();
$0 package_config [file] Package metadata in Kconfig format
$0 kconfig [file] [config] [patchver] Kernel config overrides
$0 package_source [file] Package source file information
- $0 package_feeds [file] Package feed information in makefile format
+ $0 package_subdirs [file] Package subdir information in makefile format
$0 package_license [file] Package license information
$0 package_licensefull [file] Package license information (full list)
$0 version_filter [patchver] [list...] Filter list of version tagged strings
+Options:
+ --ignore <name> Ignore the source package <name>
EOF
}