[pve-devel] r5207 - pve-kernel-2.6.35/trunk
svn-commits at proxmox.com
svn-commits at proxmox.com
Mon Oct 4 16:06:43 CEST 2010
Author: dietmar
Date: 2010-10-04 14:06:43 +0000 (Mon, 04 Oct 2010)
New Revision: 5207
Added:
pve-kernel-2.6.35/trunk/assemble-firmware.pl
pve-kernel-2.6.35/trunk/changelog.Debian
Log:
Added: pve-kernel-2.6.35/trunk/assemble-firmware.pl
===================================================================
--- pve-kernel-2.6.35/trunk/assemble-firmware.pl (rev 0)
+++ pve-kernel-2.6.35/trunk/assemble-firmware.pl 2010-10-04 14:06:43 UTC (rev 5207)
@@ -0,0 +1,194 @@
+#!/usr/bin/perl -w
+
+use strict;
+use File::Basename;
+use File::Path;
+
+my $fwsrc0 = "linux-2.6.35/firmware";
+my $fwsrc1 = "linux-firmware.git";
+my $fwsrc2 = "linux-firmware-from-kernel.git";
+my $fwsrc3 = "firmware-misc";
+
+my $fwlist = shift;
+die "no firmware list specified" if !$fwlist || ! -f $fwlist;
+
+my $target = shift;
+die "no target directory" if !$target || ! -d $target;
+
+my $force_skip = {
+
+ # not needed, the HBA has burned-in firmware
+ 'ql8100_fw.bin' => 1,
+};
+
+my $skip = {};
+# debian squeeze also misses those files
+foreach my $fw (qw(
+libertas/gspi8385.bin libertas/gspi8385_hlp.bin
+cbfw.bin ctfw.bin
+tehuti/firmware.bin
+cyzfirm.bin
+isi4616.bin
+isi4608.bin
+isi616em.bin
+isi608.bin
+isi608em.bin
+c320tunx.cod
+cp204unx.cod
+c218tunx.cod
+isight.fw
+BT3CPCC.bin
+bfubase.frm
+solos-db-FPGA.bin
+solos-Firmware.bin
+solos-FPGA.bin
+pca200e_ecd.bin2
+prism2_ru.fw
+tms380tr.bin
+FW10
+FW13
+comedi/jr3pci.idm
+
+sd8686.bin
+sd8686_helper.bin
+usb8388.bin
+libertas_cs_helper.fw
+lbtf_usb.bin
+
+wl1271-fw.bin
+wl1251-fw.bin
+symbol_sp24t_sec_fw
+symbol_sp24t_prim_fw
+prism_ap_fw.bin
+prism_sta_fw.bin
+ar9170.fw
+iwmc3200wifi-lmac-sdio.bin
+iwmc3200wifi-calib-sdio.bin
+iwmc3200wifi-umac-sdio.bin
+zd1201.fw
+zd1201-ap.fw
+isl3887usb
+isl3886usb
+isl3886pci
+3826.arm
+
+rtl8168d-1.fw
+rtl8168d-2.fw
+
+i2400m-fw-sdio-1.3.sbcf
+
+nx3fwmn.bin
+nx3fwct.bin
+nxromimg.bin
+
+myri10ge_rss_eth_z8e.dat
+myri10ge_rss_ethp_z8e.dat
+myri10ge_eth_z8e.dat
+myri10ge_ethp_z8e.dat
+
+i1480-phy-0.0.bin
+i1480-usb-0.0.bin
+i1480-pre-phy-0.0.bin
+
+)) {
+ $skip->{$fw} = 1;
+}
+
+sub copy_fw {
+ my ($src, $dstfw) = @_;
+
+ my $dest = "$target/$dstfw";
+
+ return if -f $dest;
+
+ mkpath dirname($dest);
+ system ("cp '$src' '$dest'") == 0 || die "copy $src to $dest failed";
+}
+
+my $fwdone = {};
+
+open(TMP, $fwlist);
+while(defined(my $line = <TMP>)) {
+ chomp $line;
+ my ($fw, $mod) = split(/\s+/, $line, 2);
+
+ next if $mod =~ m|^kernel/sound|;
+ next if $mod =~ m|^kernel/drivers/isdn|;
+
+ # skip ZyDas usb wireless, use package zd1211-firmware instead
+ next if $fw =~ m|^zd1211/|;
+
+ # skip atmel at76c50x wireless networking chips.
+ # use package atmel-firmware instead
+ next if $fw =~ m|^atmel_at76c50|;
+
+ # skip Bluetooth dongles based on the Broadcom BCM203x
+ # use package bluez-firmware instead
+ next if $fw =~ m|^BCM2033|;
+
+ next if $force_skip->{$fw};
+
+ next if $fwdone->{$fw};
+ $fwdone->{$fw} = 1;
+
+ my $fwdest = $fw;
+ if ($fw eq 'libertas/gspi8686.bin') {
+ $fw = 'libertas/gspi8686_v9.bin';
+ }
+ if ($fw eq 'libertas/gspi8686_hlp.bin') {
+ $fw = 'libertas/gspi8686_v9_helper.bin';
+ }
+
+ if (-f "$fwsrc0/$fw") {
+ copy_fw("$fwsrc0/$fw", $fwdest);
+ next;
+ }
+ if (-f "$fwsrc1/$fw") {
+ copy_fw("$fwsrc1/$fw", $fwdest);
+ next;
+ }
+ if (-f "$fwsrc2/$fw") {
+ copy_fw("$fwsrc2/$fw", $fwdest);
+ next;
+ }
+ if (-f "$fwsrc3/$fw") {
+ copy_fw("$fwsrc3/$fw", $fwdest);
+ next;
+ }
+
+ if ($fw =~ m|/|) {
+ next if $skip->{$fw};
+ die "unable to find firmware: $fw $mod\n";
+ }
+
+ my $name = basename($fw);
+
+ my $sr = `find '$fwsrc1' -name '$name'`;
+ chomp $sr;
+ if ($sr) {
+ #print "found $fw in $sr\n";
+ copy_fw($sr, $fwdest);
+ next;
+ }
+ $sr = `find '$fwsrc2' -name '$name'`;
+ chomp $sr;
+ if ($sr) {
+ #print "found $fw in $sr\n";
+ copy_fw($sr, $fwdest);
+ next;
+ }
+ $sr = `find '$fwsrc3' -name '$name'`;
+ chomp $sr;
+ if ($sr) {
+ #print "found $fw in $sr\n";
+ copy_fw($sr, $fwdest);
+ next;
+ }
+
+ next if $skip->{$fw};
+
+ die "unable to find firmware: $fw $mod\n";
+}
+close(TMP);
+
+exit(0);
Property changes on: pve-kernel-2.6.35/trunk/assemble-firmware.pl
___________________________________________________________________
Added: svn:executable
+ *
Added: pve-kernel-2.6.35/trunk/changelog.Debian
===================================================================
--- pve-kernel-2.6.35/trunk/changelog.Debian (rev 0)
+++ pve-kernel-2.6.35/trunk/changelog.Debian 2010-10-04 14:06:43 UTC (rev 5207)
@@ -0,0 +1,6 @@
+pve-kernel-2.6.35 (2.6.35-1) stable; urgency=low
+
+ * initial release
+
+ -- Proxmox Support Team <support at proxmox.com> Mon, 04 Oct 2010 15:40:01 +0200
+
More information about the pve-devel
mailing list