diff options
Diffstat (limited to 'target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn')
-rw-r--r-- | target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/entries | 62 | ||||
-rw-r--r-- | target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/text-base/10-ath9k-eeprom.svn-base | 69 |
2 files changed, 131 insertions, 0 deletions
diff --git a/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/entries b/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/entries new file mode 100644 index 0000000..099f4a3 --- /dev/null +++ b/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/entries @@ -0,0 +1,62 @@ +10 + +dir +36060 +svn://svn.openwrt.org/openwrt/trunk/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware +svn://svn.openwrt.org/openwrt + + + +2013-02-21T19:20:34.086008Z +35733 +juhosg + + + + + + + + + + + + + + +3c298f89-4303-0410-b956-a3cf2f4a3e73 + +10-ath9k-eeprom +file + + + + +2013-03-17T12:12:30.000000Z +586541ca7730996128ecfe76e3b2805e +2013-02-21T19:20:34.086008Z +35733 +juhosg + + + + + + + + + + + + + + + + + + + + + +1220 + diff --git a/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/text-base/10-ath9k-eeprom.svn-base b/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/text-base/10-ath9k-eeprom.svn-base new file mode 100644 index 0000000..a6f9c91 --- /dev/null +++ b/target/linux/mpc85xx/base-files/etc/hotplug.d/firmware/.svn/text-base/10-ath9k-eeprom.svn-base @@ -0,0 +1,69 @@ +#!/bin/sh + +FW_FILE="/lib/firmware/$FIRMWARE" + +ath9k_eeprom_die() { + echo "ath9k eeprom: " "$*" >&2 + exit 1 +} + +ath9k_eeprom_extract() { + local part=$1 + local offset=$2 + local count=$3 + local mtd + + . /lib/functions.sh + + mtd=$(find_mtd_chardev $part) + [ -n "$mtd" ] || \ + ath9k_eeprom_die "no mtd device found for partition $part" + + dd if=$mtd bs=$offset skip=1 count=1 2>/dev/null | dd of=$FW_FILE bs=$count count=1 2>/dev/null || \ + ath9k_eeprom_die "failed to extract from $mtd" +} + +tpl_set_wireless_mac() +{ + local offset=$1 + local mac + + . /lib/functions.sh + + mac=$(mtd_get_mac_binary u-boot 326656) + mac=$(macaddr_add $mac $offset) + + macaddr_2bin $mac | dd bs=1 count=6 seek=2 conv=notrunc of=$FW_FILE 2>/dev/null +} + +[ -e $FW_FILE ] && exit 0 + +. /lib/mpc85xx.sh + +board=$(mpc85xx_board_name) + +case "$FIRMWARE" in +"pci_wmac0.eeprom") + case $board in + tl-wdr4900-v1) + ath9k_eeprom_extract "caldata" 4096 2048 + tpl_set_wireless_mac 0 + ;; + *) + ath9k_eeprom_die "board $board is not supported yet" + ;; + esac + ;; + +"pci_wmac1.eeprom") + case $board in + tl-wdr4900-v1) + ath9k_eeprom_extract "caldata" 20480 2048 + tpl_set_wireless_mac -1 + ;; + *) + ath9k_eeprom_die "board $board is not supported yet" + ;; + esac + ;; +esac |