From fa8cd6785344d3c9a9af3f64cfaf50f7bcdd3834 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Sat, 16 Apr 2011 18:31:05 +0000 Subject: [PATCH] kernel: reorganize 2.6.39 patches SVN-Revision: 26691 --- .../067-block2mtd_2.6.38_fix.patch | 35 --- ...09-overlayfs.patch => 100-overlayfs.patch} | 0 ...rsion.patch => 200-fix_localversion.patch} | 0 ...ion.patch => 201-extra_optimization.patch} | 0 ...patch => 210-darwin_scripts_include.patch} | 0 ...include.patch => 211-stddef_include.patch} | 0 ...exports.patch => 220-module_exports.patch} | 0 ...s.patch => 230-openwrt_lzma_options.patch} | 0 ...ends.patch => 250-netfilter_depends.patch} | 0 ..._kconfig.patch => 251-sound_kconfig.patch} | 0 ...epends.patch => 252-mv_cesa_depends.patch} | 0 ..._on.patch => 253-ssb_b43_default_on.patch} | 0 ...tch => 254-textsearch_kconfig_hacks.patch} | 2 +- ...patch => 255-lib80211_kconfig_hacks.patch} | 0 ...h => 256-crypto_add_kconfig_prompts.patch} | 0 ...ch => 257-wireless_ext_kconfig_hack.patch} | 0 ...w.patch => 300-mips_expose_boot_raw.patch} | 0 ...atch => 301-mips_image_cmdline_hack.patch} | 0 ...s_use_generic_thread_info_allocator.patch} | 0 ...x-kexec.patch => 303-mips_fix_kexec.patch} | 0 ...e_fpu.patch => 304-mips_disable_fpu.patch} | 0 ...eloc.patch => 305-mips_module_reloc.patch} | 0 ... 306-mips_mem_functions_performance.patch} | 0 ..._fix.patch => 307-mips_oprofile_fix.patch} | 0 ... 310-arm_module_unresolved_weak_sym.patch} | 0 ...on.patch => 320-ppc4xx_optimization.patch} | 0 ...tch => 321-powerpc_crtsavres_prereq.patch} | 0 ...tfs_split.patch => 400-rootfs_split.patch} | 290 ----------------- ...tch => 401-partial_eraseblock_write.patch} | 0 ...h => 410-mtd_info_move_forward_decl.patch} | 0 ...ot_space.patch => 420-redboot_space.patch} | 0 ...ig.patch => 421-redboot_boardconfig.patch} | 0 ...> 430-mtd_myloader_partition_parser.patch} | 0 ...td_init.patch => 440-block2mtd_init.patch} | 2 +- .../441-block2mtd_refresh.patch | 291 ++++++++++++++++++ ..._probe.patch => 442-block2mtd_probe.patch} | 4 +- ...tch => 450-mtd_plat_nand_chip_fixup.patch} | 0 ...d_fix_nand_correct_data_return_code.patch} | 0 ...cfi_show_amd_extended_table_version.patch} | 0 ...mtd_m25p80_add_pm25lv_flash_support.patch} | 0 ...2-mtd_m25p80_add_MX25L1606E_support.patch} | 0 ..._support.patch => 500-yaffs_support.patch} | 0 ...4.patch => 501-yaffs_cvs_2009_04_24.patch} | 0 ...0.patch => 502-yaffs_git_2010_10_20.patch} | 0 ..._bug.patch => 503-yaffs_symlink_bug.patch} | 0 ...ex_fix.patch => 504-yaffs_mutex_fix.patch} | 0 ...ch => 510-jffs2_make_lzma_available.patch} | 0 ...loat_lzma.patch => 511-debloat_lzma.patch} | 0 ...detect.patch => 512-jffs2_eofdetect.patch} | 0 ...=> 520-squashfs_update_xz_comp_opts.patch} | 0 ....patch => 600-netfilter_layer7_2.22.patch} | 2 +- ...ch => 601-netfilter_layer7_pktmatch.patch} | 0 ...patch => 602-netfilter_layer7_match.patch} | 0 ... => 603-netfilter_layer7_2.6.36_fix.patch} | 4 +- ... => 604-netfilter_cisco_794x_iphone.patch} | 0 ...er_rtsp.patch => 605-netfilter_rtsp.patch} | 0 ...-sched_esfq.patch => 620-sched_esfq.patch} | 0 ...ark.patch => 621-sched_act_connmark.patch} | 0 ...ype.patch => 630-packet_socket_type.patch} | 0 ....patch => 640-bridge_no_eap_forward.patch} | 0 ...tch => 641-bridge_always_accept_eap.patch} | 0 ...te.patch => 642-bridge_port_isolate.patch} | 0 ...r_pad.patch => 650-pppoe_header_pad.patch} | 0 ...r.patch => 651-wireless_mesh_header.patch} | 0 ...{650-swconfig.patch => 700-swconfig.patch} | 0 ...xtension.patch => 701-phy_extension.patch} | 0 ...h => 702-phy_add_aneg_done_function.patch} | 0 ...hy_adm6996.patch => 720-phy_adm6996.patch} | 4 +- ...hy_packets.patch => 721-phy_packets.patch} | 0 ..._mvswitch.patch => 722-phy_mvswitch.patch} | 0 ...-phy_ip175c.patch => 723-phy_ip175c.patch} | 0 ...-phy_ar8216.patch => 724-phy_ar8216.patch} | 0 ...hy_rtl8306.patch => 725-phy_rtl8306.patch} | 0 ...hy_rtl8366.patch => 726-phy_rtl8366.patch} | 0 ...txpower.patch => 750-hostap_txpower.patch} | 0 ...ch => 810-pci_disable_common_quirks.patch} | 0 ...> 811-pci_disable_usb_common_quirks.patch} | 0 ...820-usb_add_usb_find_device_by_name.patch} | 0 ...tch => 821-usb_serial_endpoint_size.patch} | 0 ...ig_morse.patch => 830-ledtrig_morse.patch} | 0 ..._netdev.patch => 831-ledtrig_netdev.patch} | 0 ...-usbdev.patch => 832-ledtrig_usbdev.patch} | 0 ...o_buttons.patch => 833-gpio_buttons.patch} | 0 ...-gpio_ioctl.patch => 834-gpio_ioctl.patch} | 0 .../{420-gpiodev.patch => 835-gpiodev.patch} | 0 .../{700-rtc7301.patch => 840-rtc7301.patch} | 0 ...-headers.patch => 850-glamo_headers.patch} | 0 ...tch => 860-01_hotpluggable_spi_gpio.patch} | 0 ...861-04_spi_gpio_implement_spi_delay.patch} | 0 ...driver.patch => 862-gpio_spi_driver.patch} | 0 .../{922-gpiommc.patch => 863-gpiommc.patch} | 0 ...tch => 864-gpiommc_configfs_locking.patch} | 0 ...swap.patch => 870-hifn795x_byteswap.patch} | 0 ...b_maxsize.patch => 900-slab_maxsize.patch} | 0 ..._uevent.patch => 910-kobject_uevent.patch} | 0 ...=> 911-kobject_add_broadcast_uevent.patch} | 0 ...patch => 920-unable_to_open_console.patch} | 0 ...it.patch => 921-use_preinit_as_init.patch} | 0 ...patch => 940-ocf_kbuild_integration.patch} | 0 ..._20100325.patch => 941-ocf_20100325.patch} | 0 ...-vm_exports.patch => 950-vm_exports.patch} | 0 ...x.patch => 960-decompress_unlzo_fix.patch} | 0 102 files changed, 300 insertions(+), 334 deletions(-) delete mode 100644 target/linux/generic/patches-2.6.39/067-block2mtd_2.6.38_fix.patch rename target/linux/generic/patches-2.6.39/{209-overlayfs.patch => 100-overlayfs.patch} (100%) rename target/linux/generic/patches-2.6.39/{001-fix_localversion.patch => 200-fix_localversion.patch} (100%) rename target/linux/generic/patches-2.6.39/{012-extra_optimization.patch => 201-extra_optimization.patch} (100%) rename target/linux/generic/patches-2.6.39/{902-darwin_scripts_include.patch => 210-darwin_scripts_include.patch} (100%) rename target/linux/generic/patches-2.6.39/{903-stddef_include.patch => 211-stddef_include.patch} (100%) rename target/linux/generic/patches-2.6.39/{028-module_exports.patch => 220-module_exports.patch} (100%) rename target/linux/generic/patches-2.6.39/{998-openwrt_lzma_options.patch => 230-openwrt_lzma_options.patch} (100%) rename target/linux/generic/patches-2.6.39/{180-netfilter_depends.patch => 250-netfilter_depends.patch} (100%) rename target/linux/generic/patches-2.6.39/{220-sound_kconfig.patch => 251-sound_kconfig.patch} (100%) rename target/linux/generic/patches-2.6.39/{972-mv_cesa_depends.patch => 252-mv_cesa_depends.patch} (100%) rename target/linux/generic/patches-2.6.39/{974-ssb_b43_default_on.patch => 253-ssb_b43_default_on.patch} (100%) rename target/linux/generic/patches-2.6.39/{977-textsearch_kconfig_hacks.patch => 254-textsearch_kconfig_hacks.patch} (89%) rename target/linux/generic/patches-2.6.39/{978-lib80211_kconfig_hacks.patch => 255-lib80211_kconfig_hacks.patch} (100%) rename target/linux/generic/patches-2.6.39/{979-crypto_add_kconfig_prompts.patch => 256-crypto_add_kconfig_prompts.patch} (100%) rename target/linux/generic/patches-2.6.39/{981-wireless_ext_kconfig_hack.patch => 257-wireless_ext_kconfig_hack.patch} (100%) rename target/linux/generic/patches-2.6.39/{011-mips_expose_boot_raw.patch => 300-mips_expose_boot_raw.patch} (100%) rename target/linux/generic/patches-2.6.39/{021-mips_image_cmdline_hack.patch => 301-mips_image_cmdline_hack.patch} (100%) rename target/linux/generic/patches-2.6.39/{022-mips_use_generic_thread_info_allocator.patch => 302-mips_use_generic_thread_info_allocator.patch} (100%) rename target/linux/generic/patches-2.6.39/{023-mips-fix-kexec.patch => 303-mips_fix_kexec.patch} (100%) rename target/linux/generic/patches-2.6.39/{025-mips_disable_fpu.patch => 304-mips_disable_fpu.patch} (100%) rename target/linux/generic/patches-2.6.39/{027-mips_module_reloc.patch => 305-mips_module_reloc.patch} (100%) rename target/linux/generic/patches-2.6.39/{202-mips_mem_functions_performance.patch => 306-mips_mem_functions_performance.patch} (100%) rename target/linux/generic/patches-2.6.39/{208-mips_oprofile_fix.patch => 307-mips_oprofile_fix.patch} (100%) rename target/linux/generic/patches-2.6.39/{029-arm_module_unresolved_weak_sym.patch => 310-arm_module_unresolved_weak_sym.patch} (100%) rename target/linux/generic/patches-2.6.39/{991-ppc4xx_optimization.patch => 320-ppc4xx_optimization.patch} (100%) rename target/linux/generic/patches-2.6.39/{950-powerpc_crtsavres_prereq.patch => 321-powerpc_crtsavres_prereq.patch} (100%) rename target/linux/generic/patches-2.6.39/{065-rootfs_split.patch => 400-rootfs_split.patch} (57%) rename target/linux/generic/patches-2.6.39/{222-partial_eraseblock_write.patch => 401-partial_eraseblock_write.patch} (100%) rename target/linux/generic/patches-2.6.39/{082-mtd_info_move_forward_decl.patch => 410-mtd_info_move_forward_decl.patch} (100%) rename target/linux/generic/patches-2.6.39/{070-redboot_space.patch => 420-redboot_space.patch} (100%) rename target/linux/generic/patches-2.6.39/{071-redboot_boardconfig.patch => 421-redboot_boardconfig.patch} (100%) rename target/linux/generic/patches-2.6.39/{081-mtd_myloader_partition_parser.patch => 430-mtd_myloader_partition_parser.patch} (100%) rename target/linux/generic/patches-2.6.39/{060-block2mtd_init.patch => 440-block2mtd_init.patch} (99%) create mode 100644 target/linux/generic/patches-2.6.39/441-block2mtd_refresh.patch rename target/linux/generic/patches-2.6.39/{066-block2mtd_probe.patch => 442-block2mtd_probe.patch} (72%) rename target/linux/generic/patches-2.6.39/{080-mtd_plat_nand_chip_fixup.patch => 450-mtd_plat_nand_chip_fixup.patch} (100%) rename target/linux/generic/patches-2.6.39/{083-mtd_fix_nand_correct_data_return_code.patch => 451-mtd_fix_nand_correct_data_return_code.patch} (100%) rename target/linux/generic/patches-2.6.39/{014-cfi_show_amd_extended_table_version.patch => 460-cfi_show_amd_extended_table_version.patch} (100%) rename target/linux/generic/patches-2.6.39/{084-mtd_m25p80_add_pm25lv_flash_support.patch => 470-mtd_m25p80_add_pm25lv_flash_support.patch} (100%) rename target/linux/generic/patches-2.6.39/{091-mtd-m25p80-add-MX25L1606E-support.patch => 472-mtd_m25p80_add_MX25L1606E_support.patch} (100%) rename target/linux/generic/patches-2.6.39/{510-yaffs_support.patch => 500-yaffs_support.patch} (100%) rename target/linux/generic/patches-2.6.39/{511-yaffs-cvs-2009-04-24.patch => 501-yaffs_cvs_2009_04_24.patch} (100%) rename target/linux/generic/patches-2.6.39/{511-yaffs-git-2010-10-20.patch => 502-yaffs_git_2010_10_20.patch} (100%) rename target/linux/generic/patches-2.6.39/{512-yaffs_symlink_bug.patch => 503-yaffs_symlink_bug.patch} (100%) rename target/linux/generic/patches-2.6.39/{513-yaffs_mutex_fix.patch => 504-yaffs_mutex_fix.patch} (100%) rename target/linux/generic/patches-2.6.39/{008-jffs2_make_lzma_available.patch => 510-jffs2_make_lzma_available.patch} (100%) rename target/linux/generic/patches-2.6.39/{010-debloat_lzma.patch => 511-debloat_lzma.patch} (100%) rename target/linux/generic/patches-2.6.39/{204-jffs2_eofdetect.patch => 512-jffs2_eofdetect.patch} (100%) rename target/linux/generic/patches-2.6.39/{550-squashfs_update_xz_comp_opts.patch => 520-squashfs_update_xz_comp_opts.patch} (100%) rename target/linux/generic/patches-2.6.39/{100-netfilter_layer7_2.22.patch => 600-netfilter_layer7_2.22.patch} (99%) rename target/linux/generic/patches-2.6.39/{101-netfilter_layer7_pktmatch.patch => 601-netfilter_layer7_pktmatch.patch} (100%) rename target/linux/generic/patches-2.6.39/{102-netfilter_layer7_match.patch => 602-netfilter_layer7_match.patch} (100%) rename target/linux/generic/patches-2.6.39/{103-netfilter_layer7_2.6.36_fix.patch => 603-netfilter_layer7_2.6.36_fix.patch} (94%) rename target/linux/generic/patches-2.6.39/{160-netfilter_cisco_794x_iphone.patch => 604-netfilter_cisco_794x_iphone.patch} (100%) rename target/linux/generic/patches-2.6.39/{190-netfilter_rtsp.patch => 605-netfilter_rtsp.patch} (100%) rename target/linux/generic/patches-2.6.39/{200-sched_esfq.patch => 620-sched_esfq.patch} (100%) rename target/linux/generic/patches-2.6.39/{290-sched_act_connmark.patch => 621-sched_act_connmark.patch} (100%) rename target/linux/generic/patches-2.6.39/{240-packet_socket_type.patch => 630-packet_socket_type.patch} (100%) rename target/linux/generic/patches-2.6.39/{270-bridge_no_eap_forward.patch => 640-bridge_no_eap_forward.patch} (100%) rename target/linux/generic/patches-2.6.39/{271-bridge_always_accept_eap.patch => 641-bridge_always_accept_eap.patch} (100%) rename target/linux/generic/patches-2.6.39/{300-bridge_port_isolate.patch => 642-bridge_port_isolate.patch} (100%) rename target/linux/generic/patches-2.6.39/{250-pppoe_header_pad.patch => 650-pppoe_header_pad.patch} (100%) rename target/linux/generic/patches-2.6.39/{940-wireless_mesh_header.patch => 651-wireless_mesh_header.patch} (100%) rename target/linux/generic/patches-2.6.39/{650-swconfig.patch => 700-swconfig.patch} (100%) rename target/linux/generic/patches-2.6.39/{600-phy_extension.patch => 701-phy_extension.patch} (100%) rename target/linux/generic/patches-2.6.39/{601-phy-add-aneg-done-function.patch => 702-phy_add_aneg_done_function.patch} (100%) rename target/linux/generic/patches-2.6.39/{620-phy_adm6996.patch => 720-phy_adm6996.patch} (88%) rename target/linux/generic/patches-2.6.39/{630-phy_packets.patch => 721-phy_packets.patch} (100%) rename target/linux/generic/patches-2.6.39/{660-phy_mvswitch.patch => 722-phy_mvswitch.patch} (100%) rename target/linux/generic/patches-2.6.39/{670-phy_ip175c.patch => 723-phy_ip175c.patch} (100%) rename target/linux/generic/patches-2.6.39/{680-phy_ar8216.patch => 724-phy_ar8216.patch} (100%) rename target/linux/generic/patches-2.6.39/{690-phy_rtl8306.patch => 725-phy_rtl8306.patch} (100%) rename target/linux/generic/patches-2.6.39/{691-phy_rtl8366.patch => 726-phy_rtl8366.patch} (100%) rename target/linux/generic/patches-2.6.39/{903-hostap_txpower.patch => 750-hostap_txpower.patch} (100%) rename target/linux/generic/patches-2.6.39/{030-pci_disable_common_quirks.patch => 810-pci_disable_common_quirks.patch} (100%) rename target/linux/generic/patches-2.6.39/{031-pci_disable_usb_common_quirks.patch => 811-pci_disable_usb_common_quirks.patch} (100%) rename target/linux/generic/patches-2.6.39/{310-usb-add-usb_find_device_by_name.patch => 820-usb_add_usb_find_device_by_name.patch} (100%) rename target/linux/generic/patches-2.6.39/{801-usb_serial_endpoint_size.patch => 821-usb_serial_endpoint_size.patch} (100%) rename target/linux/generic/patches-2.6.39/{400-ledtrig_morse.patch => 830-ledtrig_morse.patch} (100%) rename target/linux/generic/patches-2.6.39/{402-ledtrig_netdev.patch => 831-ledtrig_netdev.patch} (100%) rename target/linux/generic/patches-2.6.39/{403-ledtrig-usbdev.patch => 832-ledtrig_usbdev.patch} (100%) rename target/linux/generic/patches-2.6.39/{410-gpio_buttons.patch => 833-gpio_buttons.patch} (100%) rename target/linux/generic/patches-2.6.39/{411-gpio_ioctl.patch => 834-gpio_ioctl.patch} (100%) rename target/linux/generic/patches-2.6.39/{420-gpiodev.patch => 835-gpiodev.patch} (100%) rename target/linux/generic/patches-2.6.39/{700-rtc7301.patch => 840-rtc7301.patch} (100%) rename target/linux/generic/patches-2.6.39/{750-glamo-headers.patch => 850-glamo_headers.patch} (100%) rename target/linux/generic/patches-2.6.39/{920-01-hotpluggable-spi-gpio.patch => 860-01_hotpluggable_spi_gpio.patch} (100%) rename target/linux/generic/patches-2.6.39/{920-04-spi-gpio-implement-spi-delay.patch => 861-04_spi_gpio_implement_spi_delay.patch} (100%) rename target/linux/generic/patches-2.6.39/{921-gpio_spi_driver.patch => 862-gpio_spi_driver.patch} (100%) rename target/linux/generic/patches-2.6.39/{922-gpiommc.patch => 863-gpiommc.patch} (100%) rename target/linux/generic/patches-2.6.39/{923-gpiommc-configfs-locking.patch => 864-gpiommc_configfs_locking.patch} (100%) rename target/linux/generic/patches-2.6.39/{975-hifn795x-byteswap.patch => 870-hifn795x_byteswap.patch} (100%) rename target/linux/generic/patches-2.6.39/{203-slab_maxsize.patch => 900-slab_maxsize.patch} (100%) rename target/linux/generic/patches-2.6.39/{219-kobject_uevent.patch => 910-kobject_uevent.patch} (100%) rename target/linux/generic/patches-2.6.39/{223-kobject-add-broadcast_uevent.patch => 911-kobject_add_broadcast_uevent.patch} (100%) rename target/linux/generic/patches-2.6.39/{840-unable_to_open_console.patch => 920-unable_to_open_console.patch} (100%) rename target/linux/generic/patches-2.6.39/{999-use_preinit_as_init.patch => 921-use_preinit_as_init.patch} (100%) rename target/linux/generic/patches-2.6.39/{970-ocf_kbuild_integration.patch => 940-ocf_kbuild_integration.patch} (100%) rename target/linux/generic/patches-2.6.39/{971-ocf_20100325.patch => 941-ocf_20100325.patch} (100%) rename target/linux/generic/patches-2.6.39/{980-vm_exports.patch => 950-vm_exports.patch} (100%) rename target/linux/generic/patches-2.6.39/{009-decompress_unlzo_fix.patch => 960-decompress_unlzo_fix.patch} (100%) diff --git a/target/linux/generic/patches-2.6.39/067-block2mtd_2.6.38_fix.patch b/target/linux/generic/patches-2.6.39/067-block2mtd_2.6.38_fix.patch deleted file mode 100644 index 1a052b3f43..0000000000 --- a/target/linux/generic/patches-2.6.39/067-block2mtd_2.6.38_fix.patch +++ /dev/null @@ -1,35 +0,0 @@ ---- a/drivers/mtd/devices/block2mtd.c -+++ b/drivers/mtd/devices/block2mtd.c -@@ -264,12 +264,13 @@ static int _open_bdev(struct block2mtd_d - bdev = blkdev_get_by_path(dev->devname, mode, dev); - #ifndef MODULE - if (IS_ERR(bdev)) { -+ dev_t devt; - - /* We might not have rootfs mounted at this point. Try - to resolve the device name by other means. */ - - wait_for_device_probe(); -- dev_t devt = name_to_dev_t(dev->devname); -+ devt = name_to_dev_t(dev->devname); - if (devt) - bdev = blkdev_get_by_dev(devt, mode, dev); - } -@@ -330,7 +331,7 @@ static int block2mtd_refresh(struct mtd_ - _close_bdev(dev); - - /* open the whole disk, issue a partition rescan, then */ -- bdev = blkdev_get_by_dev(devt, FMODE_WRITE | FMODE_READ); -+ bdev = blkdev_get_by_dev(devt, FMODE_WRITE | FMODE_READ, mtd); - if (!bdev || !bdev->bd_disk) - err = -EINVAL; - #ifndef CONFIG_MTD_BLOCK2MTD_MODULE -@@ -395,7 +396,7 @@ static struct block2mtd_dev *add_device( - dev->mtd.refresh_device = block2mtd_refresh; - - part = kzalloc(sizeof(struct mtd_partition), GFP_KERNEL); -- part->name = dev->mtd.name; -+ part->name = name; - part->offset = 0; - part->size = dev->mtd.size; - if (add_mtd_partitions(&dev->mtd, part, 1)) { diff --git a/target/linux/generic/patches-2.6.39/209-overlayfs.patch b/target/linux/generic/patches-2.6.39/100-overlayfs.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/209-overlayfs.patch rename to target/linux/generic/patches-2.6.39/100-overlayfs.patch diff --git a/target/linux/generic/patches-2.6.39/001-fix_localversion.patch b/target/linux/generic/patches-2.6.39/200-fix_localversion.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/001-fix_localversion.patch rename to target/linux/generic/patches-2.6.39/200-fix_localversion.patch diff --git a/target/linux/generic/patches-2.6.39/012-extra_optimization.patch b/target/linux/generic/patches-2.6.39/201-extra_optimization.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/012-extra_optimization.patch rename to target/linux/generic/patches-2.6.39/201-extra_optimization.patch diff --git a/target/linux/generic/patches-2.6.39/902-darwin_scripts_include.patch b/target/linux/generic/patches-2.6.39/210-darwin_scripts_include.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/902-darwin_scripts_include.patch rename to target/linux/generic/patches-2.6.39/210-darwin_scripts_include.patch diff --git a/target/linux/generic/patches-2.6.39/903-stddef_include.patch b/target/linux/generic/patches-2.6.39/211-stddef_include.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/903-stddef_include.patch rename to target/linux/generic/patches-2.6.39/211-stddef_include.patch diff --git a/target/linux/generic/patches-2.6.39/028-module_exports.patch b/target/linux/generic/patches-2.6.39/220-module_exports.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/028-module_exports.patch rename to target/linux/generic/patches-2.6.39/220-module_exports.patch diff --git a/target/linux/generic/patches-2.6.39/998-openwrt_lzma_options.patch b/target/linux/generic/patches-2.6.39/230-openwrt_lzma_options.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/998-openwrt_lzma_options.patch rename to target/linux/generic/patches-2.6.39/230-openwrt_lzma_options.patch diff --git a/target/linux/generic/patches-2.6.39/180-netfilter_depends.patch b/target/linux/generic/patches-2.6.39/250-netfilter_depends.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/180-netfilter_depends.patch rename to target/linux/generic/patches-2.6.39/250-netfilter_depends.patch diff --git a/target/linux/generic/patches-2.6.39/220-sound_kconfig.patch b/target/linux/generic/patches-2.6.39/251-sound_kconfig.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/220-sound_kconfig.patch rename to target/linux/generic/patches-2.6.39/251-sound_kconfig.patch diff --git a/target/linux/generic/patches-2.6.39/972-mv_cesa_depends.patch b/target/linux/generic/patches-2.6.39/252-mv_cesa_depends.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/972-mv_cesa_depends.patch rename to target/linux/generic/patches-2.6.39/252-mv_cesa_depends.patch diff --git a/target/linux/generic/patches-2.6.39/974-ssb_b43_default_on.patch b/target/linux/generic/patches-2.6.39/253-ssb_b43_default_on.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/974-ssb_b43_default_on.patch rename to target/linux/generic/patches-2.6.39/253-ssb_b43_default_on.patch diff --git a/target/linux/generic/patches-2.6.39/977-textsearch_kconfig_hacks.patch b/target/linux/generic/patches-2.6.39/254-textsearch_kconfig_hacks.patch similarity index 89% rename from target/linux/generic/patches-2.6.39/977-textsearch_kconfig_hacks.patch rename to target/linux/generic/patches-2.6.39/254-textsearch_kconfig_hacks.patch index e4d1909ea3..2bb01f77ee 100644 --- a/target/linux/generic/patches-2.6.39/977-textsearch_kconfig_hacks.patch +++ b/target/linux/generic/patches-2.6.39/254-textsearch_kconfig_hacks.patch @@ -1,6 +1,6 @@ --- a/lib/Kconfig +++ b/lib/Kconfig -@@ -206,16 +206,16 @@ config BCH_CONST_T +@@ -200,16 +200,16 @@ config BCH_CONST_T # Textsearch support is select'ed if needed # config TEXTSEARCH diff --git a/target/linux/generic/patches-2.6.39/978-lib80211_kconfig_hacks.patch b/target/linux/generic/patches-2.6.39/255-lib80211_kconfig_hacks.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/978-lib80211_kconfig_hacks.patch rename to target/linux/generic/patches-2.6.39/255-lib80211_kconfig_hacks.patch diff --git a/target/linux/generic/patches-2.6.39/979-crypto_add_kconfig_prompts.patch b/target/linux/generic/patches-2.6.39/256-crypto_add_kconfig_prompts.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/979-crypto_add_kconfig_prompts.patch rename to target/linux/generic/patches-2.6.39/256-crypto_add_kconfig_prompts.patch diff --git a/target/linux/generic/patches-2.6.39/981-wireless_ext_kconfig_hack.patch b/target/linux/generic/patches-2.6.39/257-wireless_ext_kconfig_hack.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/981-wireless_ext_kconfig_hack.patch rename to target/linux/generic/patches-2.6.39/257-wireless_ext_kconfig_hack.patch diff --git a/target/linux/generic/patches-2.6.39/011-mips_expose_boot_raw.patch b/target/linux/generic/patches-2.6.39/300-mips_expose_boot_raw.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/011-mips_expose_boot_raw.patch rename to target/linux/generic/patches-2.6.39/300-mips_expose_boot_raw.patch diff --git a/target/linux/generic/patches-2.6.39/021-mips_image_cmdline_hack.patch b/target/linux/generic/patches-2.6.39/301-mips_image_cmdline_hack.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/021-mips_image_cmdline_hack.patch rename to target/linux/generic/patches-2.6.39/301-mips_image_cmdline_hack.patch diff --git a/target/linux/generic/patches-2.6.39/022-mips_use_generic_thread_info_allocator.patch b/target/linux/generic/patches-2.6.39/302-mips_use_generic_thread_info_allocator.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/022-mips_use_generic_thread_info_allocator.patch rename to target/linux/generic/patches-2.6.39/302-mips_use_generic_thread_info_allocator.patch diff --git a/target/linux/generic/patches-2.6.39/023-mips-fix-kexec.patch b/target/linux/generic/patches-2.6.39/303-mips_fix_kexec.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/023-mips-fix-kexec.patch rename to target/linux/generic/patches-2.6.39/303-mips_fix_kexec.patch diff --git a/target/linux/generic/patches-2.6.39/025-mips_disable_fpu.patch b/target/linux/generic/patches-2.6.39/304-mips_disable_fpu.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/025-mips_disable_fpu.patch rename to target/linux/generic/patches-2.6.39/304-mips_disable_fpu.patch diff --git a/target/linux/generic/patches-2.6.39/027-mips_module_reloc.patch b/target/linux/generic/patches-2.6.39/305-mips_module_reloc.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/027-mips_module_reloc.patch rename to target/linux/generic/patches-2.6.39/305-mips_module_reloc.patch diff --git a/target/linux/generic/patches-2.6.39/202-mips_mem_functions_performance.patch b/target/linux/generic/patches-2.6.39/306-mips_mem_functions_performance.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/202-mips_mem_functions_performance.patch rename to target/linux/generic/patches-2.6.39/306-mips_mem_functions_performance.patch diff --git a/target/linux/generic/patches-2.6.39/208-mips_oprofile_fix.patch b/target/linux/generic/patches-2.6.39/307-mips_oprofile_fix.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/208-mips_oprofile_fix.patch rename to target/linux/generic/patches-2.6.39/307-mips_oprofile_fix.patch diff --git a/target/linux/generic/patches-2.6.39/029-arm_module_unresolved_weak_sym.patch b/target/linux/generic/patches-2.6.39/310-arm_module_unresolved_weak_sym.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/029-arm_module_unresolved_weak_sym.patch rename to target/linux/generic/patches-2.6.39/310-arm_module_unresolved_weak_sym.patch diff --git a/target/linux/generic/patches-2.6.39/991-ppc4xx_optimization.patch b/target/linux/generic/patches-2.6.39/320-ppc4xx_optimization.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/991-ppc4xx_optimization.patch rename to target/linux/generic/patches-2.6.39/320-ppc4xx_optimization.patch diff --git a/target/linux/generic/patches-2.6.39/950-powerpc_crtsavres_prereq.patch b/target/linux/generic/patches-2.6.39/321-powerpc_crtsavres_prereq.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/950-powerpc_crtsavres_prereq.patch rename to target/linux/generic/patches-2.6.39/321-powerpc_crtsavres_prereq.patch diff --git a/target/linux/generic/patches-2.6.39/065-rootfs_split.patch b/target/linux/generic/patches-2.6.39/400-rootfs_split.patch similarity index 57% rename from target/linux/generic/patches-2.6.39/065-rootfs_split.patch rename to target/linux/generic/patches-2.6.39/400-rootfs_split.patch index 081a1b4f01..45072bab22 100644 --- a/target/linux/generic/patches-2.6.39/065-rootfs_split.patch +++ b/target/linux/generic/patches-2.6.39/400-rootfs_split.patch @@ -256,296 +256,6 @@ static DEFINE_SPINLOCK(part_parser_lock); static LIST_HEAD(part_parsers); ---- a/drivers/mtd/devices/block2mtd.c -+++ b/drivers/mtd/devices/block2mtd.c -@@ -30,6 +30,8 @@ struct block2mtd_dev { - struct block_device *blkdev; - struct mtd_info mtd; - struct mutex write_mutex; -+ rwlock_t bdev_mutex; -+ char devname[0]; - }; - - -@@ -82,6 +84,12 @@ static int block2mtd_erase(struct mtd_in - size_t len = instr->len; - int err; - -+ read_lock(&dev->bdev_mutex); -+ if (!dev->blkdev) { -+ err = -EINVAL; -+ goto done; -+ } -+ - instr->state = MTD_ERASING; - mutex_lock(&dev->write_mutex); - err = _block2mtd_erase(dev, from, len); -@@ -93,6 +101,10 @@ static int block2mtd_erase(struct mtd_in - instr->state = MTD_ERASE_DONE; - - mtd_erase_callback(instr); -+ -+done: -+ read_unlock(&dev->bdev_mutex); -+ - return err; - } - -@@ -104,10 +116,14 @@ static int block2mtd_read(struct mtd_inf - struct page *page; - int index = from >> PAGE_SHIFT; - int offset = from & (PAGE_SIZE-1); -- int cpylen; -+ int cpylen, err = 0; -+ -+ read_lock(&dev->bdev_mutex); -+ if (!dev->blkdev || (from > mtd->size)) { -+ err = -EINVAL; -+ goto done; -+ } - -- if (from > mtd->size) -- return -EINVAL; - if (from + len > mtd->size) - len = mtd->size - from; - -@@ -122,10 +138,14 @@ static int block2mtd_read(struct mtd_inf - len = len - cpylen; - - page = page_read(dev->blkdev->bd_inode->i_mapping, index); -- if (!page) -- return -ENOMEM; -- if (IS_ERR(page)) -- return PTR_ERR(page); -+ if (!page) { -+ err = -ENOMEM; -+ goto done; -+ } -+ if (IS_ERR(page)) { -+ err = PTR_ERR(page); -+ goto done; -+ } - - memcpy(buf, page_address(page) + offset, cpylen); - page_cache_release(page); -@@ -136,7 +156,10 @@ static int block2mtd_read(struct mtd_inf - offset = 0; - index++; - } -- return 0; -+ -+done: -+ read_unlock(&dev->bdev_mutex); -+ return err; - } - - -@@ -188,12 +211,22 @@ static int block2mtd_write(struct mtd_in - size_t *retlen, const u_char *buf) - { - struct block2mtd_dev *dev = mtd->priv; -- int err; -+ int err = 0; -+ -+ read_lock(&dev->bdev_mutex); -+ if (!dev->blkdev) { -+ err = -EINVAL; -+ goto done; -+ } - - if (!len) -- return 0; -- if (to >= mtd->size) -- return -ENOSPC; -+ goto done; -+ -+ if (to >= mtd->size) { -+ err = -ENOSPC; -+ goto done; -+ } -+ - if (to + len > mtd->size) - len = mtd->size - to; - -@@ -202,6 +235,9 @@ static int block2mtd_write(struct mtd_in - mutex_unlock(&dev->write_mutex); - if (err > 0) - err = 0; -+ -+done: -+ read_unlock(&dev->bdev_mutex); - return err; - } - -@@ -210,33 +246,109 @@ static int block2mtd_write(struct mtd_in - static void block2mtd_sync(struct mtd_info *mtd) - { - struct block2mtd_dev *dev = mtd->priv; -+ read_lock(&dev->bdev_mutex); -+ if (dev->blkdev) - sync_blockdev(dev->blkdev); -+ read_unlock(&dev->bdev_mutex); -+ - return; - } - - -+static int _open_bdev(struct block2mtd_dev *dev) -+{ -+ const fmode_t mode = FMODE_READ | FMODE_WRITE | FMODE_EXCL; -+ struct block_device *bdev; -+ -+ /* Get a handle on the device */ -+ bdev = blkdev_get_by_path(dev->devname, mode, dev); -+#ifndef MODULE -+ if (IS_ERR(bdev)) { -+ -+ /* We might not have rootfs mounted at this point. Try -+ to resolve the device name by other means. */ -+ -+ dev_t devt = name_to_dev_t(dev->devname); -+ if (devt) -+ bdev = blkdev_get_by_dev(devt, mode, dev); -+ } -+#endif -+ -+ if (IS_ERR(bdev)) { -+ ERROR("error: cannot open device %s", dev->devname); -+ return 1; -+ } -+ dev->blkdev = bdev; -+ -+ if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) { -+ ERROR("attempting to use an MTD device as a block device"); -+ return 1; -+ } -+ -+ return 0; -+} -+ -+static void _close_bdev(struct block2mtd_dev *dev) -+{ -+ struct block_device *bdev; -+ -+ if (!dev->blkdev) -+ return; -+ -+ bdev = dev->blkdev; -+ invalidate_mapping_pages(dev->blkdev->bd_inode->i_mapping, 0, -1); -+ blkdev_put(dev->blkdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); -+ dev->blkdev = NULL; -+} -+ - static void block2mtd_free_device(struct block2mtd_dev *dev) - { - if (!dev) - return; - - kfree(dev->mtd.name); -- -- if (dev->blkdev) { -- invalidate_mapping_pages(dev->blkdev->bd_inode->i_mapping, -- 0, -1); -- blkdev_put(dev->blkdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); -- } -- -+ _close_bdev(dev); - kfree(dev); - } - - --/* FIXME: ensure that mtd->size % erase_size == 0 */ --static struct block2mtd_dev *add_device(char *devname, int erase_size, const char *mtdname) -+static int block2mtd_refresh(struct mtd_info *mtd) - { -- const fmode_t mode = FMODE_READ | FMODE_WRITE | FMODE_EXCL; -+ struct block2mtd_dev *dev = mtd->priv; - struct block_device *bdev; -+ dev_t devt; -+ int err = 0; -+ -+ /* no other mtd function can run at this point */ -+ write_lock(&dev->bdev_mutex); -+ -+ /* get the device number for the whole disk */ -+ devt = MKDEV(MAJOR(dev->blkdev->bd_dev), 0); -+ -+ /* close the old block device */ -+ _close_bdev(dev); -+ -+ /* open the whole disk, issue a partition rescan, then */ -+ bdev = blkdev_get_by_dev(devt, FMODE_WRITE | FMODE_READ); -+ if (!bdev || !bdev->bd_disk) -+ err = -EINVAL; -+#ifndef CONFIG_MTD_BLOCK2MTD_MODULE -+ else -+ err = rescan_partitions(bdev->bd_disk, bdev); -+#endif -+ if (bdev) -+ blkdev_put(bdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); -+ -+ /* try to open the partition block device again */ -+ _open_bdev(dev); -+ write_unlock(&dev->bdev_mutex); -+ -+ return err; -+} -+ -+/* FIXME: ensure that mtd->size % erase_size == 0 */ -+static struct block2mtd_dev *add_device(char *devname, int erase_size, char *mtdname) -+{ - struct block2mtd_dev *dev; - struct mtd_partition *part; - char *name; -@@ -244,36 +356,17 @@ static struct block2mtd_dev *add_device( - if (!devname) - return NULL; - -- dev = kzalloc(sizeof(struct block2mtd_dev), GFP_KERNEL); -+ dev = kzalloc(sizeof(struct block2mtd_dev) + strlen(devname) + 1, GFP_KERNEL); - if (!dev) - return NULL; - -- /* Get a handle on the device */ -- bdev = blkdev_get_by_path(devname, mode, dev); --#ifndef MODULE -- if (IS_ERR(bdev)) { -- -- /* We might not have rootfs mounted at this point. Try -- to resolve the device name by other means. */ -+ strcpy(dev->devname, devname); - -- dev_t devt = name_to_dev_t(devname); -- if (devt) -- bdev = blkdev_get_by_dev(devt, mode, dev); -- } --#endif -- -- if (IS_ERR(bdev)) { -- ERROR("error: cannot open device %s", devname); -+ if (_open_bdev(dev)) - goto devinit_err; -- } -- dev->blkdev = bdev; -- -- if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) { -- ERROR("attempting to use an MTD device as a block device"); -- goto devinit_err; -- } - - mutex_init(&dev->write_mutex); -+ rwlock_init(&dev->bdev_mutex); - - /* Setup the MTD structure */ - /* make the name contain the block device in */ -@@ -298,6 +391,7 @@ static struct block2mtd_dev *add_device( - dev->mtd.read = block2mtd_read; - dev->mtd.priv = dev; - dev->mtd.owner = THIS_MODULE; -+ dev->mtd.refresh_device = block2mtd_refresh; - - part = kzalloc(sizeof(struct mtd_partition), GFP_KERNEL); - part->name = dev->mtd.name; --- a/drivers/mtd/mtdchar.c +++ b/drivers/mtd/mtdchar.c @@ -841,6 +841,13 @@ static int mtd_ioctl(struct file *file, diff --git a/target/linux/generic/patches-2.6.39/222-partial_eraseblock_write.patch b/target/linux/generic/patches-2.6.39/401-partial_eraseblock_write.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/222-partial_eraseblock_write.patch rename to target/linux/generic/patches-2.6.39/401-partial_eraseblock_write.patch diff --git a/target/linux/generic/patches-2.6.39/082-mtd_info_move_forward_decl.patch b/target/linux/generic/patches-2.6.39/410-mtd_info_move_forward_decl.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/082-mtd_info_move_forward_decl.patch rename to target/linux/generic/patches-2.6.39/410-mtd_info_move_forward_decl.patch diff --git a/target/linux/generic/patches-2.6.39/070-redboot_space.patch b/target/linux/generic/patches-2.6.39/420-redboot_space.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/070-redboot_space.patch rename to target/linux/generic/patches-2.6.39/420-redboot_space.patch diff --git a/target/linux/generic/patches-2.6.39/071-redboot_boardconfig.patch b/target/linux/generic/patches-2.6.39/421-redboot_boardconfig.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/071-redboot_boardconfig.patch rename to target/linux/generic/patches-2.6.39/421-redboot_boardconfig.patch diff --git a/target/linux/generic/patches-2.6.39/081-mtd_myloader_partition_parser.patch b/target/linux/generic/patches-2.6.39/430-mtd_myloader_partition_parser.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/081-mtd_myloader_partition_parser.patch rename to target/linux/generic/patches-2.6.39/430-mtd_myloader_partition_parser.patch diff --git a/target/linux/generic/patches-2.6.39/060-block2mtd_init.patch b/target/linux/generic/patches-2.6.39/440-block2mtd_init.patch similarity index 99% rename from target/linux/generic/patches-2.6.39/060-block2mtd_init.patch rename to target/linux/generic/patches-2.6.39/440-block2mtd_init.patch index b0a95a1bd7..04dd40893d 100644 --- a/target/linux/generic/patches-2.6.39/060-block2mtd_init.patch +++ b/target/linux/generic/patches-2.6.39/440-block2mtd_init.patch @@ -47,7 +47,7 @@ - if (add_mtd_device(&dev->mtd)) { + part = kzalloc(sizeof(struct mtd_partition), GFP_KERNEL); -+ part->name = dev->mtd.name; ++ part->name = name; + part->offset = 0; + part->size = dev->mtd.size; + if (add_mtd_partitions(&dev->mtd, part, 1)) { diff --git a/target/linux/generic/patches-2.6.39/441-block2mtd_refresh.patch b/target/linux/generic/patches-2.6.39/441-block2mtd_refresh.patch new file mode 100644 index 0000000000..24ee22f5f6 --- /dev/null +++ b/target/linux/generic/patches-2.6.39/441-block2mtd_refresh.patch @@ -0,0 +1,291 @@ +--- a/drivers/mtd/devices/block2mtd.c ++++ b/drivers/mtd/devices/block2mtd.c +@@ -30,6 +30,8 @@ struct block2mtd_dev { + struct block_device *blkdev; + struct mtd_info mtd; + struct mutex write_mutex; ++ rwlock_t bdev_mutex; ++ char devname[0]; + }; + + +@@ -82,6 +84,12 @@ static int block2mtd_erase(struct mtd_in + size_t len = instr->len; + int err; + ++ read_lock(&dev->bdev_mutex); ++ if (!dev->blkdev) { ++ err = -EINVAL; ++ goto done; ++ } ++ + instr->state = MTD_ERASING; + mutex_lock(&dev->write_mutex); + err = _block2mtd_erase(dev, from, len); +@@ -93,6 +101,10 @@ static int block2mtd_erase(struct mtd_in + instr->state = MTD_ERASE_DONE; + + mtd_erase_callback(instr); ++ ++done: ++ read_unlock(&dev->bdev_mutex); ++ + return err; + } + +@@ -104,10 +116,14 @@ static int block2mtd_read(struct mtd_inf + struct page *page; + int index = from >> PAGE_SHIFT; + int offset = from & (PAGE_SIZE-1); +- int cpylen; ++ int cpylen, err = 0; ++ ++ read_lock(&dev->bdev_mutex); ++ if (!dev->blkdev || (from > mtd->size)) { ++ err = -EINVAL; ++ goto done; ++ } + +- if (from > mtd->size) +- return -EINVAL; + if (from + len > mtd->size) + len = mtd->size - from; + +@@ -122,10 +138,14 @@ static int block2mtd_read(struct mtd_inf + len = len - cpylen; + + page = page_read(dev->blkdev->bd_inode->i_mapping, index); +- if (!page) +- return -ENOMEM; +- if (IS_ERR(page)) +- return PTR_ERR(page); ++ if (!page) { ++ err = -ENOMEM; ++ goto done; ++ } ++ if (IS_ERR(page)) { ++ err = PTR_ERR(page); ++ goto done; ++ } + + memcpy(buf, page_address(page) + offset, cpylen); + page_cache_release(page); +@@ -136,7 +156,10 @@ static int block2mtd_read(struct mtd_inf + offset = 0; + index++; + } +- return 0; ++ ++done: ++ read_unlock(&dev->bdev_mutex); ++ return err; + } + + +@@ -188,12 +211,22 @@ static int block2mtd_write(struct mtd_in + size_t *retlen, const u_char *buf) + { + struct block2mtd_dev *dev = mtd->priv; +- int err; ++ int err = 0; ++ ++ read_lock(&dev->bdev_mutex); ++ if (!dev->blkdev) { ++ err = -EINVAL; ++ goto done; ++ } + + if (!len) +- return 0; +- if (to >= mtd->size) +- return -ENOSPC; ++ goto done; ++ ++ if (to >= mtd->size) { ++ err = -ENOSPC; ++ goto done; ++ } ++ + if (to + len > mtd->size) + len = mtd->size - to; + +@@ -202,6 +235,9 @@ static int block2mtd_write(struct mtd_in + mutex_unlock(&dev->write_mutex); + if (err > 0) + err = 0; ++ ++done: ++ read_unlock(&dev->bdev_mutex); + return err; + } + +@@ -210,33 +246,110 @@ static int block2mtd_write(struct mtd_in + static void block2mtd_sync(struct mtd_info *mtd) + { + struct block2mtd_dev *dev = mtd->priv; ++ read_lock(&dev->bdev_mutex); ++ if (dev->blkdev) + sync_blockdev(dev->blkdev); ++ read_unlock(&dev->bdev_mutex); ++ + return; + } + + ++static int _open_bdev(struct block2mtd_dev *dev) ++{ ++ const fmode_t mode = FMODE_READ | FMODE_WRITE | FMODE_EXCL; ++ struct block_device *bdev; ++ ++ /* Get a handle on the device */ ++ bdev = blkdev_get_by_path(dev->devname, mode, dev); ++#ifndef MODULE ++ if (IS_ERR(bdev)) { ++ dev_t devt; ++ ++ /* We might not have rootfs mounted at this point. Try ++ to resolve the device name by other means. */ ++ ++ devt = name_to_dev_t(dev->devname); ++ if (devt) ++ bdev = blkdev_get_by_dev(devt, mode, dev); ++ } ++#endif ++ ++ if (IS_ERR(bdev)) { ++ ERROR("error: cannot open device %s", dev->devname); ++ return 1; ++ } ++ dev->blkdev = bdev; ++ ++ if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) { ++ ERROR("attempting to use an MTD device as a block device"); ++ return 1; ++ } ++ ++ return 0; ++} ++ ++static void _close_bdev(struct block2mtd_dev *dev) ++{ ++ struct block_device *bdev; ++ ++ if (!dev->blkdev) ++ return; ++ ++ bdev = dev->blkdev; ++ invalidate_mapping_pages(dev->blkdev->bd_inode->i_mapping, 0, -1); ++ blkdev_put(dev->blkdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); ++ dev->blkdev = NULL; ++} ++ + static void block2mtd_free_device(struct block2mtd_dev *dev) + { + if (!dev) + return; + + kfree(dev->mtd.name); +- +- if (dev->blkdev) { +- invalidate_mapping_pages(dev->blkdev->bd_inode->i_mapping, +- 0, -1); +- blkdev_put(dev->blkdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); +- } +- ++ _close_bdev(dev); + kfree(dev); + } + + +-/* FIXME: ensure that mtd->size % erase_size == 0 */ +-static struct block2mtd_dev *add_device(char *devname, int erase_size, const char *mtdname) ++static int block2mtd_refresh(struct mtd_info *mtd) + { +- const fmode_t mode = FMODE_READ | FMODE_WRITE | FMODE_EXCL; ++ struct block2mtd_dev *dev = mtd->priv; + struct block_device *bdev; ++ dev_t devt; ++ int err = 0; ++ ++ /* no other mtd function can run at this point */ ++ write_lock(&dev->bdev_mutex); ++ ++ /* get the device number for the whole disk */ ++ devt = MKDEV(MAJOR(dev->blkdev->bd_dev), 0); ++ ++ /* close the old block device */ ++ _close_bdev(dev); ++ ++ /* open the whole disk, issue a partition rescan, then */ ++ bdev = blkdev_get_by_dev(devt, FMODE_WRITE | FMODE_READ, mtd); ++ if (!bdev || !bdev->bd_disk) ++ err = -EINVAL; ++#ifndef CONFIG_MTD_BLOCK2MTD_MODULE ++ else ++ err = rescan_partitions(bdev->bd_disk, bdev); ++#endif ++ if (bdev) ++ blkdev_put(bdev, FMODE_READ|FMODE_WRITE|FMODE_EXCL); ++ ++ /* try to open the partition block device again */ ++ _open_bdev(dev); ++ write_unlock(&dev->bdev_mutex); ++ ++ return err; ++} ++ ++/* FIXME: ensure that mtd->size % erase_size == 0 */ ++static struct block2mtd_dev *add_device(char *devname, int erase_size, char *mtdname) ++{ + struct block2mtd_dev *dev; + struct mtd_partition *part; + char *name; +@@ -244,36 +357,17 @@ static struct block2mtd_dev *add_device( + if (!devname) + return NULL; + +- dev = kzalloc(sizeof(struct block2mtd_dev), GFP_KERNEL); ++ dev = kzalloc(sizeof(struct block2mtd_dev) + strlen(devname) + 1, GFP_KERNEL); + if (!dev) + return NULL; + +- /* Get a handle on the device */ +- bdev = blkdev_get_by_path(devname, mode, dev); +-#ifndef MODULE +- if (IS_ERR(bdev)) { +- +- /* We might not have rootfs mounted at this point. Try +- to resolve the device name by other means. */ ++ strcpy(dev->devname, devname); + +- dev_t devt = name_to_dev_t(devname); +- if (devt) +- bdev = blkdev_get_by_dev(devt, mode, dev); +- } +-#endif +- +- if (IS_ERR(bdev)) { +- ERROR("error: cannot open device %s", devname); ++ if (_open_bdev(dev)) + goto devinit_err; +- } +- dev->blkdev = bdev; +- +- if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) { +- ERROR("attempting to use an MTD device as a block device"); +- goto devinit_err; +- } + + mutex_init(&dev->write_mutex); ++ rwlock_init(&dev->bdev_mutex); + + /* Setup the MTD structure */ + /* make the name contain the block device in */ +@@ -298,6 +392,7 @@ static struct block2mtd_dev *add_device( + dev->mtd.read = block2mtd_read; + dev->mtd.priv = dev; + dev->mtd.owner = THIS_MODULE; ++ dev->mtd.refresh_device = block2mtd_refresh; + + part = kzalloc(sizeof(struct mtd_partition), GFP_KERNEL); + part->name = name; diff --git a/target/linux/generic/patches-2.6.39/066-block2mtd_probe.patch b/target/linux/generic/patches-2.6.39/442-block2mtd_probe.patch similarity index 72% rename from target/linux/generic/patches-2.6.39/066-block2mtd_probe.patch rename to target/linux/generic/patches-2.6.39/442-block2mtd_probe.patch index 1afd2ff20a..780dd28fd2 100644 --- a/target/linux/generic/patches-2.6.39/066-block2mtd_probe.patch +++ b/target/linux/generic/patches-2.6.39/442-block2mtd_probe.patch @@ -1,10 +1,10 @@ --- a/drivers/mtd/devices/block2mtd.c +++ b/drivers/mtd/devices/block2mtd.c -@@ -268,6 +268,7 @@ static int _open_bdev(struct block2mtd_d +@@ -269,6 +269,7 @@ static int _open_bdev(struct block2mtd_d /* We might not have rootfs mounted at this point. Try to resolve the device name by other means. */ + wait_for_device_probe(); - dev_t devt = name_to_dev_t(dev->devname); + devt = name_to_dev_t(dev->devname); if (devt) bdev = blkdev_get_by_dev(devt, mode, dev); diff --git a/target/linux/generic/patches-2.6.39/080-mtd_plat_nand_chip_fixup.patch b/target/linux/generic/patches-2.6.39/450-mtd_plat_nand_chip_fixup.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/080-mtd_plat_nand_chip_fixup.patch rename to target/linux/generic/patches-2.6.39/450-mtd_plat_nand_chip_fixup.patch diff --git a/target/linux/generic/patches-2.6.39/083-mtd_fix_nand_correct_data_return_code.patch b/target/linux/generic/patches-2.6.39/451-mtd_fix_nand_correct_data_return_code.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/083-mtd_fix_nand_correct_data_return_code.patch rename to target/linux/generic/patches-2.6.39/451-mtd_fix_nand_correct_data_return_code.patch diff --git a/target/linux/generic/patches-2.6.39/014-cfi_show_amd_extended_table_version.patch b/target/linux/generic/patches-2.6.39/460-cfi_show_amd_extended_table_version.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/014-cfi_show_amd_extended_table_version.patch rename to target/linux/generic/patches-2.6.39/460-cfi_show_amd_extended_table_version.patch diff --git a/target/linux/generic/patches-2.6.39/084-mtd_m25p80_add_pm25lv_flash_support.patch b/target/linux/generic/patches-2.6.39/470-mtd_m25p80_add_pm25lv_flash_support.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/084-mtd_m25p80_add_pm25lv_flash_support.patch rename to target/linux/generic/patches-2.6.39/470-mtd_m25p80_add_pm25lv_flash_support.patch diff --git a/target/linux/generic/patches-2.6.39/091-mtd-m25p80-add-MX25L1606E-support.patch b/target/linux/generic/patches-2.6.39/472-mtd_m25p80_add_MX25L1606E_support.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/091-mtd-m25p80-add-MX25L1606E-support.patch rename to target/linux/generic/patches-2.6.39/472-mtd_m25p80_add_MX25L1606E_support.patch diff --git a/target/linux/generic/patches-2.6.39/510-yaffs_support.patch b/target/linux/generic/patches-2.6.39/500-yaffs_support.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/510-yaffs_support.patch rename to target/linux/generic/patches-2.6.39/500-yaffs_support.patch diff --git a/target/linux/generic/patches-2.6.39/511-yaffs-cvs-2009-04-24.patch b/target/linux/generic/patches-2.6.39/501-yaffs_cvs_2009_04_24.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/511-yaffs-cvs-2009-04-24.patch rename to target/linux/generic/patches-2.6.39/501-yaffs_cvs_2009_04_24.patch diff --git a/target/linux/generic/patches-2.6.39/511-yaffs-git-2010-10-20.patch b/target/linux/generic/patches-2.6.39/502-yaffs_git_2010_10_20.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/511-yaffs-git-2010-10-20.patch rename to target/linux/generic/patches-2.6.39/502-yaffs_git_2010_10_20.patch diff --git a/target/linux/generic/patches-2.6.39/512-yaffs_symlink_bug.patch b/target/linux/generic/patches-2.6.39/503-yaffs_symlink_bug.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/512-yaffs_symlink_bug.patch rename to target/linux/generic/patches-2.6.39/503-yaffs_symlink_bug.patch diff --git a/target/linux/generic/patches-2.6.39/513-yaffs_mutex_fix.patch b/target/linux/generic/patches-2.6.39/504-yaffs_mutex_fix.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/513-yaffs_mutex_fix.patch rename to target/linux/generic/patches-2.6.39/504-yaffs_mutex_fix.patch diff --git a/target/linux/generic/patches-2.6.39/008-jffs2_make_lzma_available.patch b/target/linux/generic/patches-2.6.39/510-jffs2_make_lzma_available.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/008-jffs2_make_lzma_available.patch rename to target/linux/generic/patches-2.6.39/510-jffs2_make_lzma_available.patch diff --git a/target/linux/generic/patches-2.6.39/010-debloat_lzma.patch b/target/linux/generic/patches-2.6.39/511-debloat_lzma.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/010-debloat_lzma.patch rename to target/linux/generic/patches-2.6.39/511-debloat_lzma.patch diff --git a/target/linux/generic/patches-2.6.39/204-jffs2_eofdetect.patch b/target/linux/generic/patches-2.6.39/512-jffs2_eofdetect.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/204-jffs2_eofdetect.patch rename to target/linux/generic/patches-2.6.39/512-jffs2_eofdetect.patch diff --git a/target/linux/generic/patches-2.6.39/550-squashfs_update_xz_comp_opts.patch b/target/linux/generic/patches-2.6.39/520-squashfs_update_xz_comp_opts.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/550-squashfs_update_xz_comp_opts.patch rename to target/linux/generic/patches-2.6.39/520-squashfs_update_xz_comp_opts.patch diff --git a/target/linux/generic/patches-2.6.39/100-netfilter_layer7_2.22.patch b/target/linux/generic/patches-2.6.39/600-netfilter_layer7_2.22.patch similarity index 99% rename from target/linux/generic/patches-2.6.39/100-netfilter_layer7_2.22.patch rename to target/linux/generic/patches-2.6.39/600-netfilter_layer7_2.22.patch index 2bebf646cb..710afc8c99 100644 --- a/target/linux/generic/patches-2.6.39/100-netfilter_layer7_2.22.patch +++ b/target/linux/generic/patches-2.6.39/600-netfilter_layer7_2.22.patch @@ -1,6 +1,6 @@ --- a/net/netfilter/Kconfig +++ b/net/netfilter/Kconfig -@@ -1020,6 +1020,27 @@ config NETFILTER_XT_MATCH_STATE +@@ -1018,6 +1018,27 @@ config NETFILTER_XT_MATCH_STATE To compile it as a module, choose M here. If unsure, say N. diff --git a/target/linux/generic/patches-2.6.39/101-netfilter_layer7_pktmatch.patch b/target/linux/generic/patches-2.6.39/601-netfilter_layer7_pktmatch.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/101-netfilter_layer7_pktmatch.patch rename to target/linux/generic/patches-2.6.39/601-netfilter_layer7_pktmatch.patch diff --git a/target/linux/generic/patches-2.6.39/102-netfilter_layer7_match.patch b/target/linux/generic/patches-2.6.39/602-netfilter_layer7_match.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/102-netfilter_layer7_match.patch rename to target/linux/generic/patches-2.6.39/602-netfilter_layer7_match.patch diff --git a/target/linux/generic/patches-2.6.39/103-netfilter_layer7_2.6.36_fix.patch b/target/linux/generic/patches-2.6.39/603-netfilter_layer7_2.6.36_fix.patch similarity index 94% rename from target/linux/generic/patches-2.6.39/103-netfilter_layer7_2.6.36_fix.patch rename to target/linux/generic/patches-2.6.39/603-netfilter_layer7_2.6.36_fix.patch index 58e5c30a3f..9f4c310d7e 100644 --- a/target/linux/generic/patches-2.6.39/103-netfilter_layer7_2.6.36_fix.patch +++ b/target/linux/generic/patches-2.6.39/603-netfilter_layer7_2.6.36_fix.patch @@ -1,6 +1,6 @@ --- a/net/netfilter/Kconfig +++ b/net/netfilter/Kconfig -@@ -834,6 +834,27 @@ config NETFILTER_XT_MATCH_IPVS +@@ -832,6 +832,27 @@ config NETFILTER_XT_MATCH_IPVS If unsure, say N. @@ -28,7 +28,7 @@ config NETFILTER_XT_MATCH_LENGTH tristate '"length" match support' depends on NETFILTER_ADVANCED -@@ -1020,26 +1041,11 @@ config NETFILTER_XT_MATCH_STATE +@@ -1018,26 +1039,11 @@ config NETFILTER_XT_MATCH_STATE To compile it as a module, choose M here. If unsure, say N. diff --git a/target/linux/generic/patches-2.6.39/160-netfilter_cisco_794x_iphone.patch b/target/linux/generic/patches-2.6.39/604-netfilter_cisco_794x_iphone.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/160-netfilter_cisco_794x_iphone.patch rename to target/linux/generic/patches-2.6.39/604-netfilter_cisco_794x_iphone.patch diff --git a/target/linux/generic/patches-2.6.39/190-netfilter_rtsp.patch b/target/linux/generic/patches-2.6.39/605-netfilter_rtsp.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/190-netfilter_rtsp.patch rename to target/linux/generic/patches-2.6.39/605-netfilter_rtsp.patch diff --git a/target/linux/generic/patches-2.6.39/200-sched_esfq.patch b/target/linux/generic/patches-2.6.39/620-sched_esfq.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/200-sched_esfq.patch rename to target/linux/generic/patches-2.6.39/620-sched_esfq.patch diff --git a/target/linux/generic/patches-2.6.39/290-sched_act_connmark.patch b/target/linux/generic/patches-2.6.39/621-sched_act_connmark.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/290-sched_act_connmark.patch rename to target/linux/generic/patches-2.6.39/621-sched_act_connmark.patch diff --git a/target/linux/generic/patches-2.6.39/240-packet_socket_type.patch b/target/linux/generic/patches-2.6.39/630-packet_socket_type.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/240-packet_socket_type.patch rename to target/linux/generic/patches-2.6.39/630-packet_socket_type.patch diff --git a/target/linux/generic/patches-2.6.39/270-bridge_no_eap_forward.patch b/target/linux/generic/patches-2.6.39/640-bridge_no_eap_forward.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/270-bridge_no_eap_forward.patch rename to target/linux/generic/patches-2.6.39/640-bridge_no_eap_forward.patch diff --git a/target/linux/generic/patches-2.6.39/271-bridge_always_accept_eap.patch b/target/linux/generic/patches-2.6.39/641-bridge_always_accept_eap.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/271-bridge_always_accept_eap.patch rename to target/linux/generic/patches-2.6.39/641-bridge_always_accept_eap.patch diff --git a/target/linux/generic/patches-2.6.39/300-bridge_port_isolate.patch b/target/linux/generic/patches-2.6.39/642-bridge_port_isolate.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/300-bridge_port_isolate.patch rename to target/linux/generic/patches-2.6.39/642-bridge_port_isolate.patch diff --git a/target/linux/generic/patches-2.6.39/250-pppoe_header_pad.patch b/target/linux/generic/patches-2.6.39/650-pppoe_header_pad.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/250-pppoe_header_pad.patch rename to target/linux/generic/patches-2.6.39/650-pppoe_header_pad.patch diff --git a/target/linux/generic/patches-2.6.39/940-wireless_mesh_header.patch b/target/linux/generic/patches-2.6.39/651-wireless_mesh_header.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/940-wireless_mesh_header.patch rename to target/linux/generic/patches-2.6.39/651-wireless_mesh_header.patch diff --git a/target/linux/generic/patches-2.6.39/650-swconfig.patch b/target/linux/generic/patches-2.6.39/700-swconfig.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/650-swconfig.patch rename to target/linux/generic/patches-2.6.39/700-swconfig.patch diff --git a/target/linux/generic/patches-2.6.39/600-phy_extension.patch b/target/linux/generic/patches-2.6.39/701-phy_extension.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/600-phy_extension.patch rename to target/linux/generic/patches-2.6.39/701-phy_extension.patch diff --git a/target/linux/generic/patches-2.6.39/601-phy-add-aneg-done-function.patch b/target/linux/generic/patches-2.6.39/702-phy_add_aneg_done_function.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/601-phy-add-aneg-done-function.patch rename to target/linux/generic/patches-2.6.39/702-phy_add_aneg_done_function.patch diff --git a/target/linux/generic/patches-2.6.39/620-phy_adm6996.patch b/target/linux/generic/patches-2.6.39/720-phy_adm6996.patch similarity index 88% rename from target/linux/generic/patches-2.6.39/620-phy_adm6996.patch rename to target/linux/generic/patches-2.6.39/720-phy_adm6996.patch index 614cfdfe1d..5b2218edf4 100644 --- a/target/linux/generic/patches-2.6.39/620-phy_adm6996.patch +++ b/target/linux/generic/patches-2.6.39/720-phy_adm6996.patch @@ -1,6 +1,6 @@ --- a/drivers/net/phy/Kconfig +++ b/drivers/net/phy/Kconfig -@@ -91,6 +91,11 @@ config MICREL_PHY +@@ -97,6 +97,11 @@ config MICREL_PHY ---help--- Supports the KSZ9021, VSC8201, KS8001 PHYs. @@ -14,7 +14,7 @@ depends on PHYLIB=y --- a/drivers/net/phy/Makefile +++ b/drivers/net/phy/Makefile -@@ -13,6 +13,7 @@ obj-$(CONFIG_VITESSE_PHY) += vitesse.o +@@ -14,6 +14,7 @@ obj-$(CONFIG_VITESSE_PHY) += vitesse.o obj-$(CONFIG_BROADCOM_PHY) += broadcom.o obj-$(CONFIG_BCM63XX_PHY) += bcm63xx.o obj-$(CONFIG_ICPLUS_PHY) += icplus.o diff --git a/target/linux/generic/patches-2.6.39/630-phy_packets.patch b/target/linux/generic/patches-2.6.39/721-phy_packets.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/630-phy_packets.patch rename to target/linux/generic/patches-2.6.39/721-phy_packets.patch diff --git a/target/linux/generic/patches-2.6.39/660-phy_mvswitch.patch b/target/linux/generic/patches-2.6.39/722-phy_mvswitch.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/660-phy_mvswitch.patch rename to target/linux/generic/patches-2.6.39/722-phy_mvswitch.patch diff --git a/target/linux/generic/patches-2.6.39/670-phy_ip175c.patch b/target/linux/generic/patches-2.6.39/723-phy_ip175c.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/670-phy_ip175c.patch rename to target/linux/generic/patches-2.6.39/723-phy_ip175c.patch diff --git a/target/linux/generic/patches-2.6.39/680-phy_ar8216.patch b/target/linux/generic/patches-2.6.39/724-phy_ar8216.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/680-phy_ar8216.patch rename to target/linux/generic/patches-2.6.39/724-phy_ar8216.patch diff --git a/target/linux/generic/patches-2.6.39/690-phy_rtl8306.patch b/target/linux/generic/patches-2.6.39/725-phy_rtl8306.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/690-phy_rtl8306.patch rename to target/linux/generic/patches-2.6.39/725-phy_rtl8306.patch diff --git a/target/linux/generic/patches-2.6.39/691-phy_rtl8366.patch b/target/linux/generic/patches-2.6.39/726-phy_rtl8366.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/691-phy_rtl8366.patch rename to target/linux/generic/patches-2.6.39/726-phy_rtl8366.patch diff --git a/target/linux/generic/patches-2.6.39/903-hostap_txpower.patch b/target/linux/generic/patches-2.6.39/750-hostap_txpower.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/903-hostap_txpower.patch rename to target/linux/generic/patches-2.6.39/750-hostap_txpower.patch diff --git a/target/linux/generic/patches-2.6.39/030-pci_disable_common_quirks.patch b/target/linux/generic/patches-2.6.39/810-pci_disable_common_quirks.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/030-pci_disable_common_quirks.patch rename to target/linux/generic/patches-2.6.39/810-pci_disable_common_quirks.patch diff --git a/target/linux/generic/patches-2.6.39/031-pci_disable_usb_common_quirks.patch b/target/linux/generic/patches-2.6.39/811-pci_disable_usb_common_quirks.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/031-pci_disable_usb_common_quirks.patch rename to target/linux/generic/patches-2.6.39/811-pci_disable_usb_common_quirks.patch diff --git a/target/linux/generic/patches-2.6.39/310-usb-add-usb_find_device_by_name.patch b/target/linux/generic/patches-2.6.39/820-usb_add_usb_find_device_by_name.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/310-usb-add-usb_find_device_by_name.patch rename to target/linux/generic/patches-2.6.39/820-usb_add_usb_find_device_by_name.patch diff --git a/target/linux/generic/patches-2.6.39/801-usb_serial_endpoint_size.patch b/target/linux/generic/patches-2.6.39/821-usb_serial_endpoint_size.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/801-usb_serial_endpoint_size.patch rename to target/linux/generic/patches-2.6.39/821-usb_serial_endpoint_size.patch diff --git a/target/linux/generic/patches-2.6.39/400-ledtrig_morse.patch b/target/linux/generic/patches-2.6.39/830-ledtrig_morse.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/400-ledtrig_morse.patch rename to target/linux/generic/patches-2.6.39/830-ledtrig_morse.patch diff --git a/target/linux/generic/patches-2.6.39/402-ledtrig_netdev.patch b/target/linux/generic/patches-2.6.39/831-ledtrig_netdev.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/402-ledtrig_netdev.patch rename to target/linux/generic/patches-2.6.39/831-ledtrig_netdev.patch diff --git a/target/linux/generic/patches-2.6.39/403-ledtrig-usbdev.patch b/target/linux/generic/patches-2.6.39/832-ledtrig_usbdev.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/403-ledtrig-usbdev.patch rename to target/linux/generic/patches-2.6.39/832-ledtrig_usbdev.patch diff --git a/target/linux/generic/patches-2.6.39/410-gpio_buttons.patch b/target/linux/generic/patches-2.6.39/833-gpio_buttons.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/410-gpio_buttons.patch rename to target/linux/generic/patches-2.6.39/833-gpio_buttons.patch diff --git a/target/linux/generic/patches-2.6.39/411-gpio_ioctl.patch b/target/linux/generic/patches-2.6.39/834-gpio_ioctl.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/411-gpio_ioctl.patch rename to target/linux/generic/patches-2.6.39/834-gpio_ioctl.patch diff --git a/target/linux/generic/patches-2.6.39/420-gpiodev.patch b/target/linux/generic/patches-2.6.39/835-gpiodev.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/420-gpiodev.patch rename to target/linux/generic/patches-2.6.39/835-gpiodev.patch diff --git a/target/linux/generic/patches-2.6.39/700-rtc7301.patch b/target/linux/generic/patches-2.6.39/840-rtc7301.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/700-rtc7301.patch rename to target/linux/generic/patches-2.6.39/840-rtc7301.patch diff --git a/target/linux/generic/patches-2.6.39/750-glamo-headers.patch b/target/linux/generic/patches-2.6.39/850-glamo_headers.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/750-glamo-headers.patch rename to target/linux/generic/patches-2.6.39/850-glamo_headers.patch diff --git a/target/linux/generic/patches-2.6.39/920-01-hotpluggable-spi-gpio.patch b/target/linux/generic/patches-2.6.39/860-01_hotpluggable_spi_gpio.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/920-01-hotpluggable-spi-gpio.patch rename to target/linux/generic/patches-2.6.39/860-01_hotpluggable_spi_gpio.patch diff --git a/target/linux/generic/patches-2.6.39/920-04-spi-gpio-implement-spi-delay.patch b/target/linux/generic/patches-2.6.39/861-04_spi_gpio_implement_spi_delay.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/920-04-spi-gpio-implement-spi-delay.patch rename to target/linux/generic/patches-2.6.39/861-04_spi_gpio_implement_spi_delay.patch diff --git a/target/linux/generic/patches-2.6.39/921-gpio_spi_driver.patch b/target/linux/generic/patches-2.6.39/862-gpio_spi_driver.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/921-gpio_spi_driver.patch rename to target/linux/generic/patches-2.6.39/862-gpio_spi_driver.patch diff --git a/target/linux/generic/patches-2.6.39/922-gpiommc.patch b/target/linux/generic/patches-2.6.39/863-gpiommc.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/922-gpiommc.patch rename to target/linux/generic/patches-2.6.39/863-gpiommc.patch diff --git a/target/linux/generic/patches-2.6.39/923-gpiommc-configfs-locking.patch b/target/linux/generic/patches-2.6.39/864-gpiommc_configfs_locking.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/923-gpiommc-configfs-locking.patch rename to target/linux/generic/patches-2.6.39/864-gpiommc_configfs_locking.patch diff --git a/target/linux/generic/patches-2.6.39/975-hifn795x-byteswap.patch b/target/linux/generic/patches-2.6.39/870-hifn795x_byteswap.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/975-hifn795x-byteswap.patch rename to target/linux/generic/patches-2.6.39/870-hifn795x_byteswap.patch diff --git a/target/linux/generic/patches-2.6.39/203-slab_maxsize.patch b/target/linux/generic/patches-2.6.39/900-slab_maxsize.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/203-slab_maxsize.patch rename to target/linux/generic/patches-2.6.39/900-slab_maxsize.patch diff --git a/target/linux/generic/patches-2.6.39/219-kobject_uevent.patch b/target/linux/generic/patches-2.6.39/910-kobject_uevent.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/219-kobject_uevent.patch rename to target/linux/generic/patches-2.6.39/910-kobject_uevent.patch diff --git a/target/linux/generic/patches-2.6.39/223-kobject-add-broadcast_uevent.patch b/target/linux/generic/patches-2.6.39/911-kobject_add_broadcast_uevent.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/223-kobject-add-broadcast_uevent.patch rename to target/linux/generic/patches-2.6.39/911-kobject_add_broadcast_uevent.patch diff --git a/target/linux/generic/patches-2.6.39/840-unable_to_open_console.patch b/target/linux/generic/patches-2.6.39/920-unable_to_open_console.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/840-unable_to_open_console.patch rename to target/linux/generic/patches-2.6.39/920-unable_to_open_console.patch diff --git a/target/linux/generic/patches-2.6.39/999-use_preinit_as_init.patch b/target/linux/generic/patches-2.6.39/921-use_preinit_as_init.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/999-use_preinit_as_init.patch rename to target/linux/generic/patches-2.6.39/921-use_preinit_as_init.patch diff --git a/target/linux/generic/patches-2.6.39/970-ocf_kbuild_integration.patch b/target/linux/generic/patches-2.6.39/940-ocf_kbuild_integration.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/970-ocf_kbuild_integration.patch rename to target/linux/generic/patches-2.6.39/940-ocf_kbuild_integration.patch diff --git a/target/linux/generic/patches-2.6.39/971-ocf_20100325.patch b/target/linux/generic/patches-2.6.39/941-ocf_20100325.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/971-ocf_20100325.patch rename to target/linux/generic/patches-2.6.39/941-ocf_20100325.patch diff --git a/target/linux/generic/patches-2.6.39/980-vm_exports.patch b/target/linux/generic/patches-2.6.39/950-vm_exports.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/980-vm_exports.patch rename to target/linux/generic/patches-2.6.39/950-vm_exports.patch diff --git a/target/linux/generic/patches-2.6.39/009-decompress_unlzo_fix.patch b/target/linux/generic/patches-2.6.39/960-decompress_unlzo_fix.patch similarity index 100% rename from target/linux/generic/patches-2.6.39/009-decompress_unlzo_fix.patch rename to target/linux/generic/patches-2.6.39/960-decompress_unlzo_fix.patch -- 2.30.2