my $ret;
while ($_ = shift @_) {
- /arm_v(\w+)/ and $ret .= "\tselect arm_v$1\n";
- /broken/ and $ret .= "\tdepends on BROKEN\n";
- /audio/ and $ret .= "\tselect AUDIO_SUPPORT\n";
- /display/ and $ret .= "\tselect DISPLAY_SUPPORT\n";
- /dt/ and $ret .= "\tselect USES_DEVICETREE\n";
- /gpio/ and $ret .= "\tselect GPIO_SUPPORT\n";
- /pci/ and $ret .= "\tselect PCI_SUPPORT\n";
- /pcie/ and $ret .= "\tselect PCIE_SUPPORT\n";
- /usb/ and $ret .= "\tselect USB_SUPPORT\n";
- /usbgadget/ and $ret .= "\tselect USB_GADGET_SUPPORT\n";
- /pcmcia/ and $ret .= "\tselect PCMCIA_SUPPORT\n";
- /rtc/ and $ret .= "\tselect RTC_SUPPORT\n";
- /squashfs/ and $ret .= "\tselect USES_SQUASHFS\n";
- /jffs2$/ and $ret .= "\tselect USES_JFFS2\n";
- /jffs2_nand/ and $ret .= "\tselect USES_JFFS2_NAND\n";
- /ext4/ and $ret .= "\tselect USES_EXT4\n";
- /targz/ and $ret .= "\tselect USES_TARGZ\n";
- /cpiogz/ and $ret .= "\tselect USES_CPIOGZ\n";
- /minor/ and $ret .= "\tselect USES_MINOR\n";
- /ubifs/ and $ret .= "\tselect USES_UBIFS\n";
- /fpu/ and $ret .= "\tselect HAS_FPU\n";
- /spe_fpu/ and $ret .= "\tselect HAS_SPE_FPU\n";
- /ramdisk/ and $ret .= "\tselect USES_INITRAMFS\n";
- /powerpc64/ and $ret .= "\tselect powerpc64\n";
- /nommu/ and $ret .= "\tselect NOMMU\n";
- /mips16/ and $ret .= "\tselect HAS_MIPS16\n";
- /rfkill/ and $ret .= "\tselect RFKILL_SUPPORT\n";
- /low_mem/ and $ret .= "\tselect LOW_MEMORY_FOOTPRINT\n";
- /small_flash/ and $ret .= "\tselect SMALL_FLASH\n";
- /nand/ and $ret .= "\tselect NAND_SUPPORT\n";
- /virtio/ and $ret .= "\tselect VIRTIO_SUPPORT\n";
+ /^arm_v(\w+)$/ and $ret .= "\tselect arm_v$1\n";
+ /^broken$/ and $ret .= "\tdepends on BROKEN\n";
+ /^audio$/ and $ret .= "\tselect AUDIO_SUPPORT\n";
+ /^display$/ and $ret .= "\tselect DISPLAY_SUPPORT\n";
+ /^dt$/ and $ret .= "\tselect USES_DEVICETREE\n";
+ /^gpio$/ and $ret .= "\tselect GPIO_SUPPORT\n";
+ /^pci$/ and $ret .= "\tselect PCI_SUPPORT\n";
+ /^pcie$/ and $ret .= "\tselect PCIE_SUPPORT\n";
+ /^usb$/ and $ret .= "\tselect USB_SUPPORT\n";
+ /^usbgadget$/ and $ret .= "\tselect USB_GADGET_SUPPORT\n";
+ /^pcmcia$/ and $ret .= "\tselect PCMCIA_SUPPORT\n";
+ /^rtc$/ and $ret .= "\tselect RTC_SUPPORT\n";
+ /^squashfs$/ and $ret .= "\tselect USES_SQUASHFS\n";
+ /^jffs2$/ and $ret .= "\tselect USES_JFFS2\n";
+ /^jffs2_nand$/ and $ret .= "\tselect USES_JFFS2_NAND\n";
+ /^ext4$/ and $ret .= "\tselect USES_EXT4\n";
+ /^targz$/ and $ret .= "\tselect USES_TARGZ\n";
+ /^cpiogz$/ and $ret .= "\tselect USES_CPIOGZ\n";
+ /^minor$/ and $ret .= "\tselect USES_MINOR\n";
+ /^ubifs$/ and $ret .= "\tselect USES_UBIFS\n";
+ /^fpu$/ and $ret .= "\tselect HAS_FPU\n";
+ /^spe_fpu$/ and $ret .= "\tselect HAS_SPE_FPU\n";
+ /^ramdisk$/ and $ret .= "\tselect USES_INITRAMFS\n";
+ /^powerpc64$/ and $ret .= "\tselect powerpc64\n";
+ /^nommu$/ and $ret .= "\tselect NOMMU\n";
+ /^mips16$/ and $ret .= "\tselect HAS_MIPS16\n";
+ /^rfkill$/ and $ret .= "\tselect RFKILL_SUPPORT\n";
+ /^low_mem$/ and $ret .= "\tselect LOW_MEMORY_FOOTPRINT\n";
+ /^small_flash$/ and $ret .= "\tselect SMALL_FLASH\n";
+ /^nand$/ and $ret .= "\tselect NAND_SUPPORT\n";
+ /^virtio$/ and $ret .= "\tselect VIRTIO_SUPPORT\n";
+ /^rootfs-part$/ and $ret .= "\tselect USES_ROOTFS_PART\n";
+ /^boot-part$/ and $ret .= "\tselect USES_BOOT_PART\n";
+ /^testing-kernel$/ and $ret .= "\tselect HAS_TESTING_KERNEL\n";
}
return $ret;
}
}
my $v = kver($target->{version});
+ my $tv = kver($target->{testing_version});
+ $tv or $tv = $v;
if (@{$target->{subtargets}} == 0) {
$confstr = <<EOF;
config TARGET_$target->{conf}
bool "$target->{name}"
- select LINUX_$v
+ select LINUX_$v if !TESTING_KERNEL
+ select LINUX_$tv if TESTING_KERNEL
EOF
}
else {
print <<EOF;
choice
prompt "Target System"
- default TARGET_ar71xx
+ default TARGET_ath79
reset if !DEVEL
EOF
choice
prompt "Target Profile"
+ default TARGET_MULTI_PROFILE if BUILDBOT
EOF
foreach my $target (@target) {
my $profile = $target->{profiles}->[0];
$profile or next;
print <<EOF;
- default TARGET_$target->{conf}_$profile->{id} if TARGET_$target->{conf}
+ default TARGET_$target->{conf}_$profile->{id} if TARGET_$target->{conf} && !BUILDBOT
EOF
}
config TARGET_ALL_PROFILES
bool "Enable all profiles by default"
+ default BUILDBOT
config TARGET_PER_DEVICE_ROOTFS
bool "Use a per-device root filesystem that adds profile packages"
+ default BUILDBOT
help
When disabled, all device packages from all selected devices
will be included in all images by default. (Marked as <*>) You will
EOF
foreach my $target (@target) {
- my $profiles = $target->{profiles};
- foreach my $profile (@{$target->{profiles}}) {
+ my @profiles = sort {
+ my $x = $a->{name};
+ my $y = $b->{name};
+ "\L$x" cmp "\L$y";
+ } @{$target->{profiles}};
+ foreach my $profile (@profiles) {
next unless $profile->{id} =~ /^DEVICE_/;
print <<EOF;
menuconfig TARGET_DEVICE_$target->{conf}_$profile->{id}
bool "$profile->{name}"
depends on TARGET_$target->{conf}
- default y if TARGET_ALL_PROFILES
+ default $profile->{default}
EOF
my @pkglist = merge_package_lists($target->{packages}, $profile->{packages});
foreach my $pkg (@pkglist) {
my %kver;
foreach my $target (@target) {
- my $v = kver($target->{version});
- next if $kver{$v};
- $kver{$v} = 1;
- print <<EOF;
+ foreach my $tv ($target->{version}, $target->{testing_version}) {
+ next unless $tv;
+ my $v = kver($tv);
+ next if $kver{$v};
+ $kver{$v} = 1;
+ print <<EOF;
config LINUX_$v
bool
EOF
+ }
}
foreach my $def (sort keys %defaults) {
print <<EOF;
print "PROFILE_NAMES = ".join(" ", map { $_->{id} } @{$cur->{profiles}})."\n";
foreach my $profile (@{$cur->{profiles}}) {
print $profile->{id}.'_NAME:='.$profile->{name}."\n";
+ print $profile->{id}.'_HAS_IMAGE_METADATA:='.$profile->{has_image_metadata}."\n";
+ if (defined($profile->{supported_devices}) and @{$profile->{supported_devices}} > 0) {
+ print $profile->{id}.'_SUPPORTED_DEVICES:='.join(' ', @{$profile->{supported_devices}})."\n";
+ }
print $profile->{id}.'_PACKAGES:='.join(' ', @{$profile->{packages}})."\n";
}
}