[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