kernel: remove linux 3.3 patches and config
authorFelix Fietkau <nbd@openwrt.org>
Sat, 24 Jan 2015 20:02:02 +0000 (20:02 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Sat, 24 Jan 2015 20:02:02 +0000 (20:02 +0000)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
SVN-Revision: 44109

179 files changed:
target/linux/generic/config-3.3 [deleted file]
target/linux/generic/patches-3.3/001-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch [deleted file]
target/linux/generic/patches-3.3/002-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch [deleted file]
target/linux/generic/patches-3.3/003-MIPS-Refactor-clear_page-and-copy_page-functions.patch [deleted file]
target/linux/generic/patches-3.3/006-arm_kernel_xz_support.patch [deleted file]
target/linux/generic/patches-3.3/007-hso-Earlier-catch-of-error-condition.patch [deleted file]
target/linux/generic/patches-3.3/008-hso-Fix-stack-corruption-on-some-architectures.patch [deleted file]
target/linux/generic/patches-3.3/020-ssb_update.patch [deleted file]
target/linux/generic/patches-3.3/025-bcma_backport.patch [deleted file]
target/linux/generic/patches-3.3/040-Controlled-Delay-AQM.patch [deleted file]
target/linux/generic/patches-3.3/041-codel-use-Newton-method-instead-of-sqrt-and-divides.patch [deleted file]
target/linux/generic/patches-3.3/042-fq_codel-Fair-Queue-Codel-AQM.patch [deleted file]
target/linux/generic/patches-3.3/043-net-codel-Add-missing-include-linux-prefetch.h.patch [deleted file]
target/linux/generic/patches-3.3/044-net-codel-fix-build-errors.patch [deleted file]
target/linux/generic/patches-3.3/045-codel-use-u16-field-instead-of-31bits-for-rec_inv_sq.patch [deleted file]
target/linux/generic/patches-3.3/046-fq_codel-qdisc-backlog.patch [deleted file]
target/linux/generic/patches-3.3/047-spi_message_queue.patch [deleted file]
target/linux/generic/patches-3.3/048-spi-Dont-call-prepare-unprepare-transfer-if-not-popu.patch [deleted file]
target/linux/generic/patches-3.3/049-codel-refine-one-condition-to-avoid-a-nul-rec_inv_sqrt.patch [deleted file]
target/linux/generic/patches-3.3/050-rng_git_backport.patch [deleted file]
target/linux/generic/patches-3.3/051-rng_git_backport-remove_irqf_sample_random.patch [deleted file]
target/linux/generic/patches-3.3/060-hso_devices.patch [deleted file]
target/linux/generic/patches-3.3/060-tcp-ecn-dont-delay-ACKS-after-CE.patch [deleted file]
target/linux/generic/patches-3.3/061-fq_codel-dont-reinit-flow-state.patch [deleted file]
target/linux/generic/patches-3.3/065-8139cp-fixes.patch [deleted file]
target/linux/generic/patches-3.3/070-gpio-add-flags-to-export-GPIOs-when-requesting.patch [deleted file]
target/linux/generic/patches-3.3/080-prot-release-cb.patch [deleted file]
target/linux/generic/patches-3.3/081-USB-OHCI-Add-a-generic-platform-device-driver.patch [deleted file]
target/linux/generic/patches-3.3/082-USB-EHCI-Add-a-generic-platform-device-driver.patch [deleted file]
target/linux/generic/patches-3.3/083-USB-EHCI-platform-remove-update.patch [deleted file]
target/linux/generic/patches-3.3/084-x86_fix_perf_uclibc_build.patch [deleted file]
target/linux/generic/patches-3.3/090-CVE-2013-1763.patch [deleted file]
target/linux/generic/patches-3.3/100-overlayfs_v12.patch [deleted file]
target/linux/generic/patches-3.3/102-ehci_hcd_ignore_oc.patch [deleted file]
target/linux/generic/patches-3.3/110-fix_mtd_include.patch [deleted file]
target/linux/generic/patches-3.3/130-pppoatm-queue-depth.patch [deleted file]
target/linux/generic/patches-3.3/131-atm-fixes.patch [deleted file]
target/linux/generic/patches-3.3/132-solos-dma.patch [deleted file]
target/linux/generic/patches-3.3/140-ixp4xx_hss_module_h_include.patch [deleted file]
target/linux/generic/patches-3.3/200-fix_localversion.patch [deleted file]
target/linux/generic/patches-3.3/201-extra_optimization.patch [deleted file]
target/linux/generic/patches-3.3/202-reduce_module_size.patch [deleted file]
target/linux/generic/patches-3.3/210-darwin_scripts_include.patch [deleted file]
target/linux/generic/patches-3.3/211-stddef_include.patch [deleted file]
target/linux/generic/patches-3.3/212-x86_reloc_portability.patch [deleted file]
target/linux/generic/patches-3.3/220-module_exports.patch [deleted file]
target/linux/generic/patches-3.3/230-openwrt_lzma_options.patch [deleted file]
target/linux/generic/patches-3.3/250-netfilter_depends.patch [deleted file]
target/linux/generic/patches-3.3/251-sound_kconfig.patch [deleted file]
target/linux/generic/patches-3.3/252-mv_cesa_depends.patch [deleted file]
target/linux/generic/patches-3.3/253-ssb_b43_default_on.patch [deleted file]
target/linux/generic/patches-3.3/254-textsearch_kconfig_hacks.patch [deleted file]
target/linux/generic/patches-3.3/255-lib80211_kconfig_hacks.patch [deleted file]
target/linux/generic/patches-3.3/256-crypto_add_kconfig_prompts.patch [deleted file]
target/linux/generic/patches-3.3/257-wireless_ext_kconfig_hack.patch [deleted file]
target/linux/generic/patches-3.3/258-netfilter_netlink_kconfig_hack.patch [deleted file]
target/linux/generic/patches-3.3/259-compressor_kconfig_hack.patch [deleted file]
target/linux/generic/patches-3.3/260-move_bcm963xx_tag.patch [deleted file]
target/linux/generic/patches-3.3/270-regmap_dynamic.patch [deleted file]
target/linux/generic/patches-3.3/300-mips_expose_boot_raw.patch [deleted file]
target/linux/generic/patches-3.3/301-mips_image_cmdline_hack.patch [deleted file]
target/linux/generic/patches-3.3/302-mips_use_generic_thread_info_allocator.patch [deleted file]
target/linux/generic/patches-3.3/303-mips_fix_kexec.patch [deleted file]
target/linux/generic/patches-3.3/304-mips_disable_fpu.patch [deleted file]
target/linux/generic/patches-3.3/305-mips_module_reloc.patch [deleted file]
target/linux/generic/patches-3.3/306-mips_mem_functions_performance.patch [deleted file]
target/linux/generic/patches-3.3/307-mips_oprofile_fix.patch [deleted file]
target/linux/generic/patches-3.3/308-mips-show-correct-cpu-name-for-24KEc.patch [deleted file]
target/linux/generic/patches-3.3/309-mips_fuse_workaround.patch [deleted file]
target/linux/generic/patches-3.3/310-arm_module_unresolved_weak_sym.patch [deleted file]
target/linux/generic/patches-3.3/320-ppc4xx_optimization.patch [deleted file]
target/linux/generic/patches-3.3/321-powerpc_crtsavres_prereq.patch [deleted file]
target/linux/generic/patches-3.3/322-ppc4xx-crypto-compile-fix.patch [deleted file]
target/linux/generic/patches-3.3/330-mips-add-crash-and-kdump-support.patch [deleted file]
target/linux/generic/patches-3.3/331-mips-kexec-enhanche-the-support.patch [deleted file]
target/linux/generic/patches-3.3/332-mips-kexec-init-the-arguments-for-the-new-kernel-image.patch [deleted file]
target/linux/generic/patches-3.3/333-mips-kexec-get-kernel-parameters-from-kexec-tools.patch [deleted file]
target/linux/generic/patches-3.3/334-mips-fix-compiling-failure-of-relocate_kernel.patch [deleted file]
target/linux/generic/patches-3.3/335-mips-kexec-cleanup-kexec-tools-parameter-handling.patch [deleted file]
target/linux/generic/patches-3.3/340-module_alloc_size_check.patch [deleted file]
target/linux/generic/patches-3.3/400-rootfs_split.patch [deleted file]
target/linux/generic/patches-3.3/401-partial_eraseblock_write.patch [deleted file]
target/linux/generic/patches-3.3/410-mtd_info_move_forward_decl.patch [deleted file]
target/linux/generic/patches-3.3/420-redboot_space.patch [deleted file]
target/linux/generic/patches-3.3/430-mtd_myloader_partition_parser.patch [deleted file]
target/linux/generic/patches-3.3/440-block2mtd_init.patch [deleted file]
target/linux/generic/patches-3.3/441-block2mtd_refresh.patch [deleted file]
target/linux/generic/patches-3.3/442-block2mtd_probe.patch [deleted file]
target/linux/generic/patches-3.3/443-block2mtd-avoid-recursive-call-of-mtd_writev.patch [deleted file]
target/linux/generic/patches-3.3/450-mtd_plat_nand_chip_fixup.patch [deleted file]
target/linux/generic/patches-3.3/451-mtd_fix_nand_correct_data_return_code.patch [deleted file]
target/linux/generic/patches-3.3/460-cfi_cmdset_0002_no_erase_suspend.patch [deleted file]
target/linux/generic/patches-3.3/470-mtd_m25p80_add_pm25lv_flash_support.patch [deleted file]
target/linux/generic/patches-3.3/473-mtd_m25p80_add_w25q128.patch [deleted file]
target/linux/generic/patches-3.3/475-mtd_cfi_cmdset_0002-add-buffer-write-cmd-timeout.patch [deleted file]
target/linux/generic/patches-3.3/476-mtd-m25p80-allow-to-disable-small-sector-erase.patch [deleted file]
target/linux/generic/patches-3.3/477-mtd-m25p80-add-support-for-the-EON-EN25Q64-chip.patch [deleted file]
target/linux/generic/patches-3.3/478-mtd-partial_eraseblock_unlock.patch [deleted file]
target/linux/generic/patches-3.3/520-squashfs_update_xz_comp_opts.patch [deleted file]
target/linux/generic/patches-3.3/530-jffs2_make_lzma_available.patch [deleted file]
target/linux/generic/patches-3.3/531-debloat_lzma.patch [deleted file]
target/linux/generic/patches-3.3/532-jffs2_eofdetect.patch [deleted file]
target/linux/generic/patches-3.3/540-crypto-xz-decompression-support.patch [deleted file]
target/linux/generic/patches-3.3/541-ubifs-xz-decompression-support.patch [deleted file]
target/linux/generic/patches-3.3/550-ubifs-symlink-xattr-support.patch [deleted file]
target/linux/generic/patches-3.3/600-netfilter_layer7_2.22.patch [deleted file]
target/linux/generic/patches-3.3/601-netfilter_layer7_pktmatch.patch [deleted file]
target/linux/generic/patches-3.3/602-netfilter_layer7_match.patch [deleted file]
target/linux/generic/patches-3.3/603-netfilter_layer7_2.6.36_fix.patch [deleted file]
target/linux/generic/patches-3.3/604-netfilter_conntrack_flush.patch [deleted file]
target/linux/generic/patches-3.3/610-netfilter_match_bypass_default_checks.patch [deleted file]
target/linux/generic/patches-3.3/611-netfilter_match_bypass_default_table.patch [deleted file]
target/linux/generic/patches-3.3/612-netfilter_match_reduce_memory_access.patch [deleted file]
target/linux/generic/patches-3.3/613-netfilter_optional_tcp_window_check.patch [deleted file]
target/linux/generic/patches-3.3/615-netfilter_add_xt_id_match.patch [deleted file]
target/linux/generic/patches-3.3/620-sched_esfq.patch [deleted file]
target/linux/generic/patches-3.3/621-sched_act_connmark.patch [deleted file]
target/linux/generic/patches-3.3/630-packet_socket_type.patch [deleted file]
target/linux/generic/patches-3.3/640-bridge_no_eap_forward.patch [deleted file]
target/linux/generic/patches-3.3/641-bridge_always_accept_eap.patch [deleted file]
target/linux/generic/patches-3.3/642-bridge_port_isolate.patch [deleted file]
target/linux/generic/patches-3.3/643-bridge_remove_ipv6_dependency.patch [deleted file]
target/linux/generic/patches-3.3/644-bridge_optimize_netfilter_hooks.patch [deleted file]
target/linux/generic/patches-3.3/650-pppoe_header_pad.patch [deleted file]
target/linux/generic/patches-3.3/651-wireless_mesh_header.patch [deleted file]
target/linux/generic/patches-3.3/652-atm_header_changes.patch [deleted file]
target/linux/generic/patches-3.3/653-disable_netlink_trim.patch [deleted file]
target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch [deleted file]
target/linux/generic/patches-3.3/655-increase_skb_pad.patch [deleted file]
target/linux/generic/patches-3.3/700-swconfig.patch [deleted file]
target/linux/generic/patches-3.3/701-phy_extension.patch [deleted file]
target/linux/generic/patches-3.3/702-phy_add_aneg_done_function.patch [deleted file]
target/linux/generic/patches-3.3/703-phy-add-detach-callback-to-struct-phy_driver.patch [deleted file]
target/linux/generic/patches-3.3/710-phy-add-mdio_register_board_info.patch [deleted file]
target/linux/generic/patches-3.3/720-phy_adm6996.patch [deleted file]
target/linux/generic/patches-3.3/721-phy_packets.patch [deleted file]
target/linux/generic/patches-3.3/722-phy_mvswitch.patch [deleted file]
target/linux/generic/patches-3.3/723-phy_ip175c.patch [deleted file]
target/linux/generic/patches-3.3/724-phy_ar8216.patch [deleted file]
target/linux/generic/patches-3.3/725-phy_rtl8306.patch [deleted file]
target/linux/generic/patches-3.3/726-phy_rtl8366.patch [deleted file]
target/linux/generic/patches-3.3/727-phy-rtl8367.patch [deleted file]
target/linux/generic/patches-3.3/728-phy-micrel.patch [deleted file]
target/linux/generic/patches-3.3/729-phy-rtl8367b.patch [deleted file]
target/linux/generic/patches-3.3/729-phy-tantos.patch [deleted file]
target/linux/generic/patches-3.3/750-hostap_txpower.patch [deleted file]
target/linux/generic/patches-3.3/800-usb-ohci-multiple-platform-driver-fix.patch [deleted file]
target/linux/generic/patches-3.3/801-usb-ehci-multiple-platform-driver-fix.patch [deleted file]
target/linux/generic/patches-3.3/810-pci_disable_common_quirks.patch [deleted file]
target/linux/generic/patches-3.3/811-pci_disable_usb_common_quirks.patch [deleted file]
target/linux/generic/patches-3.3/820-usb_add_usb_find_device_by_name.patch [deleted file]
target/linux/generic/patches-3.3/830-ledtrig_morse.patch [deleted file]
target/linux/generic/patches-3.3/831-ledtrig_netdev.patch [deleted file]
target/linux/generic/patches-3.3/832-ledtrig_usbdev.patch [deleted file]
target/linux/generic/patches-3.3/840-rtc7301.patch [deleted file]
target/linux/generic/patches-3.3/841-rtc_pt7c4338.patch [deleted file]
target/linux/generic/patches-3.3/861-04_spi_gpio_implement_spi_delay.patch [deleted file]
target/linux/generic/patches-3.3/862-gpio_spi_driver.patch [deleted file]
target/linux/generic/patches-3.3/863-gpiommc.patch [deleted file]
target/linux/generic/patches-3.3/864-gpiommc_configfs_locking.patch [deleted file]
target/linux/generic/patches-3.3/870-hifn795x_byteswap.patch [deleted file]
target/linux/generic/patches-3.3/880-gateworks_system_controller.patch [deleted file]
target/linux/generic/patches-3.3/900-slab_maxsize.patch [deleted file]
target/linux/generic/patches-3.3/910-kobject_uevent.patch [deleted file]
target/linux/generic/patches-3.3/911-kobject_add_broadcast_uevent.patch [deleted file]
target/linux/generic/patches-3.3/921-use_preinit_as_init.patch [deleted file]
target/linux/generic/patches-3.3/922-always-create-console-node-in-initramfs.patch [deleted file]
target/linux/generic/patches-3.3/930-crashlog.patch [deleted file]
target/linux/generic/patches-3.3/940-ocf_kbuild_integration.patch [deleted file]
target/linux/generic/patches-3.3/941-ocf_20120127.patch [deleted file]
target/linux/generic/patches-3.3/960-decompress_unlzo_fix.patch [deleted file]
target/linux/generic/patches-3.3/970-remove-unsane-filenames-from-deps_initramfs-list.patch [deleted file]
target/linux/generic/patches-3.3/980-arm_openwrt_machtypes.patch [deleted file]
target/linux/generic/patches-3.3/992-mpcore_wdt_fix_watchdog_counter_loading.patch [deleted file]
target/linux/generic/patches-3.3/993-mpcore_wdt_fix_wdioc_setoptions_handling.patch [deleted file]
target/linux/generic/patches-3.3/994-mpcore_wdt_fix_timer_mode_setup.patch [deleted file]
target/linux/generic/patches-3.3/a01-swconfig_leds-define-leds_set_brightness.patch [deleted file]
target/linux/generic/patches-3.3/a02-swconfig-revert-portid-snd_portid-usage.patch [deleted file]
target/linux/generic/patches-3.3/a03-swconfig-revert-UAPI-disintegration.patch [deleted file]

diff --git a/target/linux/generic/config-3.3 b/target/linux/generic/config-3.3
deleted file mode 100644 (file)
index 4de7995..0000000
+++ /dev/null
@@ -1,3527 +0,0 @@
-CONFIG_32BIT=y
-# CONFIG_6PACK is not set
-# CONFIG_8139CP is not set
-# CONFIG_8139TOO is not set
-# CONFIG_9P_FS is not set
-# CONFIG_AB3100_CORE is not set
-# CONFIG_AB8500_CORE is not set
-# CONFIG_ABX500_CORE is not set
-# CONFIG_ACCESSIBILITY is not set
-# CONFIG_ACENIC is not set
-# CONFIG_ACERHDF is not set
-# CONFIG_ACORN_PARTITION is not set
-# CONFIG_ACPI_APEI is not set
-# CONFIG_ACPI_CUSTOM_METHOD is not set
-# CONFIG_ACPI_HED is not set
-# CONFIG_ACPI_POWER_METER is not set
-# CONFIG_ACPI_QUICKSTART is not set
-# CONFIG_AD525X_DPOT is not set
-# CONFIG_ADAPTEC_STARFIRE is not set
-# CONFIG_ADFS_FS is not set
-# CONFIG_ADIS16255 is not set
-# CONFIG_ADM6996_PHY is not set
-# CONFIG_ADM8211 is not set
-CONFIG_AEABI=y
-# CONFIG_AFFS_FS is not set
-# CONFIG_AFS_FS is not set
-# CONFIG_AF_RXRPC is not set
-# CONFIG_AGP is not set
-CONFIG_AIO=y
-# CONFIG_AIRO is not set
-# CONFIG_AIRO_CS is not set
-# CONFIG_ALCHEMY_GPIO_INDIRECT is not set
-# CONFIG_ALIM7101_WDT is not set
-# CONFIG_ALTERA_STAPL is not set
-# CONFIG_AMD8111_ETH is not set
-# CONFIG_AMIGA_PARTITION is not set
-# CONFIG_AMILO_RFKILL is not set
-# CONFIG_ANDROID is not set
-CONFIG_ANON_INODES=y
-# CONFIG_APDS9802ALS is not set
-# CONFIG_APM8018X is not set
-# CONFIG_APPLICOM is not set
-# CONFIG_AR7 is not set
-# CONFIG_AR8216_PHY is not set
-# CONFIG_ARCH_AT91 is not set
-# CONFIG_ARCH_BCMRING is not set
-# CONFIG_ARCH_CLPS711X is not set
-# CONFIG_ARCH_CNS3XXX is not set
-# CONFIG_ARCH_DAVINCI is not set
-# CONFIG_ARCH_DMA_ADDR_T_64BIT is not set
-# CONFIG_ARCH_DOVE is not set
-# CONFIG_ARCH_EBSA110 is not set
-# CONFIG_ARCH_EP93XX is not set
-# CONFIG_ARCH_EXYNOS is not set
-CONFIG_ARCH_FLATMEM_ENABLE=y
-# CONFIG_ARCH_FOOTBRIDGE is not set
-# CONFIG_ARCH_GEMINI is not set
-# CONFIG_ARCH_H720X is not set
-# CONFIG_ARCH_HAS_ILOG2_U32 is not set
-# CONFIG_ARCH_HAS_ILOG2_U64 is not set
-# CONFIG_ARCH_HIGHBANK is not set
-# CONFIG_ARCH_INTEGRATOR is not set
-# CONFIG_ARCH_IOP13XX is not set
-# CONFIG_ARCH_IOP32X is not set
-# CONFIG_ARCH_IOP33X is not set
-# CONFIG_ARCH_IXP2000 is not set
-# CONFIG_ARCH_IXP23XX is not set
-# CONFIG_ARCH_IXP4XX is not set
-# CONFIG_ARCH_KIRKWOOD is not set
-# CONFIG_ARCH_KS8695 is not set
-# CONFIG_ARCH_LPC32XX is not set
-# CONFIG_ARCH_MMP is not set
-# CONFIG_ARCH_MSM is not set
-# CONFIG_ARCH_MV78XX0 is not set
-# CONFIG_ARCH_MXC is not set
-# CONFIG_ARCH_MXS is not set
-# CONFIG_ARCH_NETX is not set
-# CONFIG_ARCH_NOMADIK is not set
-# CONFIG_ARCH_NUC93X is not set
-# CONFIG_ARCH_OMAP is not set
-# CONFIG_ARCH_ORION5X is not set
-# CONFIG_ARCH_PHYS_ADDR_T_64BIT is not set
-# CONFIG_ARCH_PICOXCELL is not set
-# CONFIG_ARCH_PNX4008 is not set
-# CONFIG_ARCH_PRIMA2 is not set
-# CONFIG_ARCH_PXA is not set
-# CONFIG_ARCH_REALVIEW is not set
-# CONFIG_ARCH_RPC is not set
-# CONFIG_ARCH_S3C2410 is not set
-# CONFIG_ARCH_S3C64XX is not set
-# CONFIG_ARCH_S5P64X0 is not set
-# CONFIG_ARCH_S5PC100 is not set
-# CONFIG_ARCH_S5PV210 is not set
-# CONFIG_ARCH_SA1100 is not set
-# CONFIG_ARCH_SHARK is not set
-# CONFIG_ARCH_SHMOBILE is not set
-# CONFIG_ARCH_SUPPORTS_MSI is not set
-# CONFIG_ARCH_TCC_926 is not set
-# CONFIG_ARCH_TEGRA is not set
-# CONFIG_ARCH_U300 is not set
-# CONFIG_ARCH_U8500 is not set
-# CONFIG_ARCH_VERSATILE is not set
-# CONFIG_ARCH_VEXPRESS is not set
-# CONFIG_ARCH_VT8500 is not set
-# CONFIG_ARCH_W90X900 is not set
-# CONFIG_ARCH_ZYNQ is not set
-# CONFIG_ARCNET is not set
-CONFIG_ARM_CPU_TOPOLOGY=y
-CONFIG_ARM_DMA_MEM_BUFFERABLE=y
-# CONFIG_ARM_ERRATA_326103 is not set
-# CONFIG_ARM_ERRATA_364296 is not set
-# CONFIG_ARM_ERRATA_411920 is not set
-# CONFIG_ARM_ERRATA_430973 is not set
-# CONFIG_ARM_ERRATA_458693 is not set
-# CONFIG_ARM_ERRATA_460075 is not set
-# CONFIG_ARM_ERRATA_720789 is not set
-# CONFIG_ARM_ERRATA_742230 is not set
-# CONFIG_ARM_ERRATA_742231 is not set
-# CONFIG_ARM_ERRATA_743622 is not set
-# CONFIG_ARM_ERRATA_751472 is not set
-# CONFIG_ARM_ERRATA_754322 is not set
-# CONFIG_ARM_ERRATA_754327 is not set
-# CONFIG_ARM_ERRATA_764369 is not set
-# CONFIG_ARM_PATCH_PHYS_VIRT is not set
-# CONFIG_ARM_UNWIND is not set
-CONFIG_ARPD=y
-# CONFIG_ARTHUR is not set
-# CONFIG_ASUS_OLED is not set
-# CONFIG_ASYNC_RAID6_TEST is not set
-# CONFIG_ASYNC_TX_DMA is not set
-# CONFIG_AT76C50X_USB is not set
-# CONFIG_ATA is not set
-CONFIG_ATAGS_PROC=y
-# CONFIG_ATALK is not set
-# CONFIG_ATARI_PARTITION is not set
-# CONFIG_ATA_ACPI is not set
-CONFIG_ATA_BMDMA=y
-# CONFIG_ATA_GENERIC is not set
-# CONFIG_ATA_NONSTANDARD is not set
-# CONFIG_ATA_OVER_ETH is not set
-# CONFIG_ATA_PIIX is not set
-CONFIG_ATA_SFF=y
-# CONFIG_ATA_VERBOSE_ERROR is not set
-# CONFIG_ATH5K is not set
-# CONFIG_ATH6K_LEGACY is not set
-# CONFIG_ATH79 is not set
-# CONFIG_ATH9K is not set
-# CONFIG_ATL1 is not set
-# CONFIG_ATL1C is not set
-# CONFIG_ATL1E is not set
-# CONFIG_ATL2 is not set
-# CONFIG_ATM is not set
-# CONFIG_ATMEL is not set
-# CONFIG_ATMEL_PWM is not set
-# CONFIG_ATM_AMBASSADOR is not set
-# CONFIG_ATM_BR2684 is not set
-CONFIG_ATM_BR2684_IPFILTER=y
-# CONFIG_ATM_CLIP is not set
-CONFIG_ATM_CLIP_NO_ICMP=y
-# CONFIG_ATM_DRIVERS is not set
-# CONFIG_ATM_DUMMY is not set
-# CONFIG_ATM_ENI is not set
-# CONFIG_ATM_FIRESTREAM is not set
-# CONFIG_ATM_FORE200E is not set
-# CONFIG_ATM_HE is not set
-# CONFIG_ATM_HORIZON is not set
-# CONFIG_ATM_IA is not set
-# CONFIG_ATM_IDT77252 is not set
-# CONFIG_ATM_LANAI is not set
-# CONFIG_ATM_LANE is not set
-# CONFIG_ATM_MPOA is not set
-# CONFIG_ATM_NICSTAR is not set
-# CONFIG_ATM_SOLOS is not set
-# CONFIG_ATM_TCP is not set
-# CONFIG_ATM_ZATM is not set
-# CONFIG_ATOMIC64_SELFTEST is not set
-# CONFIG_ATP is not set
-# CONFIG_AUDIT is not set
-# CONFIG_AUDIT_LOGINUID_IMMUTABLE is not set
-# CONFIG_AUTOFS4_FS is not set
-# CONFIG_AUTO_ZRELADDR is not set
-# CONFIG_AUXDISPLAY is not set
-# CONFIG_AVERAGE is not set
-# CONFIG_AX25 is not set
-# CONFIG_AX25_DAMA_SLAVE is not set
-# CONFIG_AX88796 is not set
-# CONFIG_B43 is not set
-# CONFIG_B43LEGACY is not set
-# CONFIG_B44 is not set
-# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
-# CONFIG_BACKTRACE_SELF_TEST is not set
-CONFIG_BASE_FULL=y
-CONFIG_BASE_SMALL=0
-# CONFIG_BATMAN_ADV is not set
-# CONFIG_BATTERY_BQ27x00 is not set
-# CONFIG_BATTERY_DS2760 is not set
-# CONFIG_BATTERY_DS2780 is not set
-# CONFIG_BATTERY_DS2782 is not set
-# CONFIG_BATTERY_MAX17040 is not set
-# CONFIG_BATTERY_MAX17042 is not set
-# CONFIG_BATTERY_SBS is not set
-# CONFIG_BAYCOM_EPP is not set
-# CONFIG_BAYCOM_PAR is not set
-# CONFIG_BAYCOM_SER_FDX is not set
-# CONFIG_BAYCOM_SER_HDX is not set
-# CONFIG_BCM47XX is not set
-# CONFIG_BCM63XX is not set
-# CONFIG_BCM63XX_PHY is not set
-# CONFIG_BCMA is not set
-# CONFIG_BCMA_DRIVER_GPIO is not set
-CONFIG_BCMA_POSSIBLE=y
-# CONFIG_BCM_WIMAX is not set
-# CONFIG_BDI_SWITCH is not set
-# CONFIG_BE2ISCSI is not set
-# CONFIG_BE2NET is not set
-# CONFIG_BEFS_FS is not set
-# CONFIG_BFS_FS is not set
-# CONFIG_BINARY_PRINTF is not set
-# CONFIG_BINFMT_AOUT is not set
-CONFIG_BINFMT_ELF=y
-# CONFIG_BINFMT_MISC is not set
-CONFIG_BITREVERSE=y
-# CONFIG_BLK_CPQ_CISS_DA is not set
-# CONFIG_BLK_CPQ_DA is not set
-CONFIG_BLK_DEV=y
-# CONFIG_BLK_DEV_3W_XXXX_RAID is not set
-# CONFIG_BLK_DEV_4DRIVES is not set
-# CONFIG_BLK_DEV_AEC62XX is not set
-# CONFIG_BLK_DEV_ALI14XX is not set
-# CONFIG_BLK_DEV_ALI15X3 is not set
-# CONFIG_BLK_DEV_AMD74XX is not set
-# CONFIG_BLK_DEV_ATIIXP is not set
-# CONFIG_BLK_DEV_BSG is not set
-# CONFIG_BLK_DEV_BSGLIB is not set
-# CONFIG_BLK_DEV_CMD640 is not set
-# CONFIG_BLK_DEV_CMD64X is not set
-# CONFIG_BLK_DEV_COW_COMMON is not set
-# CONFIG_BLK_DEV_CRYPTOLOOP is not set
-# CONFIG_BLK_DEV_CS5520 is not set
-# CONFIG_BLK_DEV_CS5530 is not set
-# CONFIG_BLK_DEV_CS5535 is not set
-# CONFIG_BLK_DEV_CS5536 is not set
-# CONFIG_BLK_DEV_CY82C693 is not set
-# CONFIG_BLK_DEV_DAC960 is not set
-# CONFIG_BLK_DEV_DELKIN is not set
-# CONFIG_BLK_DEV_DRBD is not set
-# CONFIG_BLK_DEV_DTC2278 is not set
-# CONFIG_BLK_DEV_FD is not set
-# CONFIG_BLK_DEV_GENERIC is not set
-# CONFIG_BLK_DEV_HD is not set
-# CONFIG_BLK_DEV_HPT366 is not set
-# CONFIG_BLK_DEV_HT6560B is not set
-# CONFIG_BLK_DEV_IDEACPI is not set
-# CONFIG_BLK_DEV_IDECD is not set
-# CONFIG_BLK_DEV_IDECS is not set
-# CONFIG_BLK_DEV_IDEPCI is not set
-# CONFIG_BLK_DEV_IDEPNP is not set
-# CONFIG_BLK_DEV_IDETAPE is not set
-# CONFIG_BLK_DEV_IDE_AU1XXX is not set
-# CONFIG_BLK_DEV_IDE_SATA is not set
-CONFIG_BLK_DEV_INITRD=y
-# CONFIG_BLK_DEV_INTEGRITY is not set
-# CONFIG_BLK_DEV_IO_TRACE is not set
-# CONFIG_BLK_DEV_IT8172 is not set
-# CONFIG_BLK_DEV_IT8213 is not set
-# CONFIG_BLK_DEV_IT821X is not set
-# CONFIG_BLK_DEV_JMICRON is not set
-# CONFIG_BLK_DEV_LOOP is not set
-CONFIG_BLK_DEV_LOOP_MIN_COUNT=8
-# CONFIG_BLK_DEV_NBD is not set
-# CONFIG_BLK_DEV_NS87415 is not set
-# CONFIG_BLK_DEV_NVME is not set
-# CONFIG_BLK_DEV_OFFBOARD is not set
-# CONFIG_BLK_DEV_OPTI621 is not set
-# CONFIG_BLK_DEV_PCIESSD_MTIP32XX is not set
-# CONFIG_BLK_DEV_PDC202XX_NEW is not set
-# CONFIG_BLK_DEV_PDC202XX_OLD is not set
-# CONFIG_BLK_DEV_PIIX is not set
-# CONFIG_BLK_DEV_PLATFORM is not set
-# CONFIG_BLK_DEV_QD65XX is not set
-# CONFIG_BLK_DEV_RAM is not set
-# CONFIG_BLK_DEV_RBD is not set
-# CONFIG_BLK_DEV_RZ1000 is not set
-# CONFIG_BLK_DEV_SC1200 is not set
-# CONFIG_BLK_DEV_SD is not set
-# CONFIG_BLK_DEV_SIIMAGE is not set
-# CONFIG_BLK_DEV_SIS5513 is not set
-# CONFIG_BLK_DEV_SL82C105 is not set
-# CONFIG_BLK_DEV_SLC90E66 is not set
-# CONFIG_BLK_DEV_SR is not set
-# CONFIG_BLK_DEV_SVWKS is not set
-# CONFIG_BLK_DEV_SX8 is not set
-# CONFIG_BLK_DEV_TC86C001 is not set
-# CONFIG_BLK_DEV_THROTTLING is not set
-# CONFIG_BLK_DEV_TRIFLEX is not set
-# CONFIG_BLK_DEV_TRM290 is not set
-# CONFIG_BLK_DEV_UB is not set
-# CONFIG_BLK_DEV_UMC8672 is not set
-# CONFIG_BLK_DEV_UMEM is not set
-# CONFIG_BLK_DEV_VIA82CXXX is not set
-# CONFIG_BLK_DEV_XIP is not set
-CONFIG_BLOCK=y
-# CONFIG_BMP085 is not set
-# CONFIG_BNA is not set
-# CONFIG_BNX2 is not set
-# CONFIG_BNX2X is not set
-# CONFIG_BONDING is not set
-# CONFIG_BOOKE_WDT is not set
-# CONFIG_BOOT_PRINTK_DELAY is not set
-CONFIG_BOOT_RAW=y
-# CONFIG_BPQETHER is not set
-CONFIG_BQL=y
-CONFIG_BRANCH_PROFILE_NONE=y
-# CONFIG_BRCMFMAC is not set
-CONFIG_BRIDGE=y
-# CONFIG_BRIDGE_EBT_802_3 is not set
-# CONFIG_BRIDGE_EBT_AMONG is not set
-# CONFIG_BRIDGE_EBT_ARP is not set
-# CONFIG_BRIDGE_EBT_ARPREPLY is not set
-# CONFIG_BRIDGE_EBT_BROUTE is not set
-# CONFIG_BRIDGE_EBT_DNAT is not set
-# CONFIG_BRIDGE_EBT_IP is not set
-# CONFIG_BRIDGE_EBT_IP6 is not set
-# CONFIG_BRIDGE_EBT_LIMIT is not set
-# CONFIG_BRIDGE_EBT_LOG is not set
-# CONFIG_BRIDGE_EBT_MARK is not set
-# CONFIG_BRIDGE_EBT_MARK_T is not set
-# CONFIG_BRIDGE_EBT_NFLOG is not set
-# CONFIG_BRIDGE_EBT_PKTTYPE is not set
-# CONFIG_BRIDGE_EBT_REDIRECT is not set
-# CONFIG_BRIDGE_EBT_SNAT is not set
-# CONFIG_BRIDGE_EBT_STP is not set
-# CONFIG_BRIDGE_EBT_T_FILTER is not set
-# CONFIG_BRIDGE_EBT_T_NAT is not set
-# CONFIG_BRIDGE_EBT_ULOG is not set
-# CONFIG_BRIDGE_EBT_VLAN is not set
-# CONFIG_BRIDGE_IGMP_SNOOPING is not set
-# CONFIG_BRIDGE_NETFILTER is not set
-# CONFIG_BRIDGE_NF_EBTABLES is not set
-# CONFIG_BROADCOM_PHY is not set
-CONFIG_BROKEN_ON_SMP=y
-# CONFIG_BSD_DISKLABEL is not set
-# CONFIG_BSD_PROCESS_ACCT is not set
-# CONFIG_BSD_PROCESS_ACCT_V3 is not set
-# CONFIG_BT is not set
-# CONFIG_BTRFS_FS is not set
-# CONFIG_BT_ATH3K is not set
-# CONFIG_BT_BNEP is not set
-CONFIG_BT_BNEP_MC_FILTER=y
-CONFIG_BT_BNEP_PROTO_FILTER=y
-# CONFIG_BT_CMTP is not set
-# CONFIG_BT_HCIBCM203X is not set
-# CONFIG_BT_HCIBFUSB is not set
-# CONFIG_BT_HCIBLUECARD is not set
-# CONFIG_BT_HCIBPA10X is not set
-# CONFIG_BT_HCIBT3C is not set
-# CONFIG_BT_HCIBTSDIO is not set
-# CONFIG_BT_HCIBTUART is not set
-# CONFIG_BT_HCIBTUSB is not set
-# CONFIG_BT_HCIDTL1 is not set
-# CONFIG_BT_HCIUART is not set
-# CONFIG_BT_HCIUART_ATH3K is not set
-CONFIG_BT_HCIUART_BCSP=y
-CONFIG_BT_HCIUART_H4=y
-# CONFIG_BT_HCIUART_LL is not set
-# CONFIG_BT_HCIVHCI is not set
-# CONFIG_BT_HIDP is not set
-CONFIG_BT_L2CAP=y
-# CONFIG_BT_MRVL is not set
-# CONFIG_BT_RFCOMM is not set
-CONFIG_BT_RFCOMM_TTY=y
-CONFIG_BT_SCO=y
-CONFIG_BUG=y
-# CONFIG_C2PORT is not set
-# CONFIG_CAIF is not set
-# CONFIG_CAN is not set
-# CONFIG_CAPI_AVM is not set
-# CONFIG_CAPI_EICON is not set
-# CONFIG_CAPI_TRACE is not set
-CONFIG_CARDBUS=y
-# CONFIG_CARDMAN_4000 is not set
-# CONFIG_CARDMAN_4040 is not set
-# CONFIG_CARMA_FPGA is not set
-# CONFIG_CARMA_FPGA_PROGRAM is not set
-# CONFIG_CASSINI is not set
-CONFIG_CAVIUM_OCTEON_HELPER=y
-# CONFIG_CAVIUM_OCTEON_REFERENCE_BOARD is not set
-# CONFIG_CAVIUM_OCTEON_SIMULATOR is not set
-# CONFIG_CB710_CORE is not set
-# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set
-# CONFIG_CC_STACKPROTECTOR is not set
-# CONFIG_CDROM_PKTCDVD is not set
-# CONFIG_CEPH_FS is not set
-# CONFIG_CEPH_LIB is not set
-# CONFIG_CFG80211 is not set
-# CONFIG_CGROUPS is not set
-# CONFIG_CGROUP_DEBUG is not set
-# CONFIG_CHARGER_GPIO is not set
-# CONFIG_CHARGER_LP8727 is not set
-# CONFIG_CHARGER_MAX8903 is not set
-# CONFIG_CHECKPOINT_RESTORE is not set
-# CONFIG_CHELSIO_T1 is not set
-# CONFIG_CHELSIO_T3 is not set
-# CONFIG_CHELSIO_T4 is not set
-# CONFIG_CHELSIO_T4VF is not set
-# CONFIG_CHR_DEV_OSST is not set
-# CONFIG_CHR_DEV_SCH is not set
-# CONFIG_CHR_DEV_SG is not set
-# CONFIG_CHR_DEV_ST is not set
-# CONFIG_CICADA_PHY is not set
-# CONFIG_CIFS is not set
-# CONFIG_CIFS_ACL is not set
-# CONFIG_CIFS_DEBUG2 is not set
-# CONFIG_CIFS_FSCACHE is not set
-# CONFIG_CIFS_NFSD_EXPORT is not set
-CONFIG_CIFS_POSIX=y
-CONFIG_CIFS_STATS=y
-# CONFIG_CIFS_STATS2 is not set
-# CONFIG_CIFS_WEAK_PW_HASH is not set
-# CONFIG_CIFS_XATTR is not set
-# CONFIG_CLEANCACHE is not set
-CONFIG_CLS_U32_MARK=y
-# CONFIG_CLS_U32_PERF is not set
-CONFIG_CMDLINE=""
-# CONFIG_CMDLINE_BOOL is not set
-# CONFIG_CMDLINE_EXTEND is not set
-# CONFIG_CMDLINE_FORCE is not set
-# CONFIG_CMDLINE_FROM_BOOTLOADER is not set
-# CONFIG_CNIC is not set
-# CONFIG_CODA_FS is not set
-# CONFIG_CODE_PATCHING_SELFTEST is not set
-# CONFIG_COMEDI is not set
-# CONFIG_COMPACTION is not set
-# CONFIG_COMPAL_LAPTOP is not set
-# CONFIG_COMPAT_BRK is not set
-# CONFIG_CONFIGFS_FS is not set
-# CONFIG_CONNECTOR is not set
-CONFIG_CONSTRUCTORS=y
-# CONFIG_CONTEXT_SWITCH_TRACER is not set
-# CONFIG_COPS is not set
-# CONFIG_CORDIC is not set
-# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
-# CONFIG_CPA_DEBUG is not set
-# CONFIG_CPU_DCACHE_DISABLE is not set
-# CONFIG_CPU_FREQ is not set
-# CONFIG_CPU_IDLE is not set
-# CONFIG_CRAMFS is not set
-CONFIG_CRASHLOG=y
-# CONFIG_CRASH_DUMP is not set
-# CONFIG_CRC16 is not set
-CONFIG_CRC32=y
-# CONFIG_CRC7 is not set
-# CONFIG_CRC8 is not set
-# CONFIG_CRC_CCITT is not set
-# CONFIG_CRC_ITU_T is not set
-# CONFIG_CRC_T10DIF is not set
-CONFIG_CROSS_COMPILE=""
-CONFIG_CRYPTO=y
-# CONFIG_CRYPTO_AEAD is not set
-# CONFIG_CRYPTO_AES is not set
-# CONFIG_CRYPTO_AES_586 is not set
-# CONFIG_CRYPTO_AES_NI_INTEL is not set
-# CONFIG_CRYPTO_ALGAPI is not set
-# CONFIG_CRYPTO_ALGAPI2 is not set
-# CONFIG_CRYPTO_ANSI_CPRNG is not set
-# CONFIG_CRYPTO_ANUBIS is not set
-# CONFIG_CRYPTO_ARC4 is not set
-# CONFIG_CRYPTO_AUTHENC is not set
-# CONFIG_CRYPTO_BLKCIPHER is not set
-# CONFIG_CRYPTO_BLOWFISH is not set
-# CONFIG_CRYPTO_CAMELLIA is not set
-# CONFIG_CRYPTO_CAST5 is not set
-# CONFIG_CRYPTO_CAST6 is not set
-# CONFIG_CRYPTO_CBC is not set
-# CONFIG_CRYPTO_CCM is not set
-# CONFIG_CRYPTO_CRC32C is not set
-# CONFIG_CRYPTO_CRC32C_INTEL is not set
-# CONFIG_CRYPTO_CRYPTD is not set
-# CONFIG_CRYPTO_CTR is not set
-# CONFIG_CRYPTO_CTS is not set
-# CONFIG_CRYPTO_DEFLATE is not set
-# CONFIG_CRYPTO_DES is not set
-# CONFIG_CRYPTO_DEV_FSL_CAAM is not set
-# CONFIG_CRYPTO_DEV_HIFN_795X is not set
-# CONFIG_CRYPTO_DEV_MV_CESA is not set
-# CONFIG_CRYPTO_DEV_TALITOS is not set
-# CONFIG_CRYPTO_ECB is not set
-# CONFIG_CRYPTO_FCRYPT is not set
-# CONFIG_CRYPTO_FIPS is not set
-# CONFIG_CRYPTO_GCM is not set
-# CONFIG_CRYPTO_GF128MUL is not set
-# CONFIG_CRYPTO_GHASH is not set
-# CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL is not set
-# CONFIG_CRYPTO_HASH is not set
-# CONFIG_CRYPTO_HMAC is not set
-# CONFIG_CRYPTO_HW is not set
-# CONFIG_CRYPTO_KHAZAD is not set
-# CONFIG_CRYPTO_LRW is not set
-# CONFIG_CRYPTO_LZO is not set
-# CONFIG_CRYPTO_MANAGER is not set
-# CONFIG_CRYPTO_MANAGER2 is not set
-CONFIG_CRYPTO_MANAGER_DISABLE_TESTS=y
-# CONFIG_CRYPTO_MD4 is not set
-# CONFIG_CRYPTO_MD5 is not set
-# CONFIG_CRYPTO_MICHAEL_MIC is not set
-# CONFIG_CRYPTO_NULL is not set
-# CONFIG_CRYPTO_PCBC is not set
-# CONFIG_CRYPTO_PCOMP is not set
-# CONFIG_CRYPTO_PCOMP2 is not set
-# CONFIG_CRYPTO_PCRYPT is not set
-# CONFIG_CRYPTO_RMD128 is not set
-# CONFIG_CRYPTO_RMD160 is not set
-# CONFIG_CRYPTO_RMD256 is not set
-# CONFIG_CRYPTO_RMD320 is not set
-# CONFIG_CRYPTO_RNG is not set
-# CONFIG_CRYPTO_SALSA20 is not set
-# CONFIG_CRYPTO_SALSA20_586 is not set
-# CONFIG_CRYPTO_SEED is not set
-# CONFIG_CRYPTO_SEQIV is not set
-# CONFIG_CRYPTO_SERPENT is not set
-# CONFIG_CRYPTO_SHA1 is not set
-# CONFIG_CRYPTO_SHA256 is not set
-# CONFIG_CRYPTO_SHA512 is not set
-# CONFIG_CRYPTO_TEA is not set
-# CONFIG_CRYPTO_TEST is not set
-# CONFIG_CRYPTO_TGR192 is not set
-# CONFIG_CRYPTO_TWOFISH is not set
-# CONFIG_CRYPTO_TWOFISH_586 is not set
-# CONFIG_CRYPTO_TWOFISH_COMMON is not set
-# CONFIG_CRYPTO_USER is not set
-# CONFIG_CRYPTO_USER_API_HASH is not set
-# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
-# CONFIG_CRYPTO_VMAC is not set
-# CONFIG_CRYPTO_WP512 is not set
-# CONFIG_CRYPTO_XCBC is not set
-# CONFIG_CRYPTO_XTS is not set
-# CONFIG_CRYPTO_XZ is not set
-# CONFIG_CRYPTO_ZLIB is not set
-# CONFIG_CRYSTALHD is not set
-# CONFIG_CS5535_MFGPT is not set
-# CONFIG_CUSE is not set
-# CONFIG_CXT1E1 is not set
-# CONFIG_DAVICOM_PHY is not set
-# CONFIG_DCB is not set
-# CONFIG_DE600 is not set
-# CONFIG_DE620 is not set
-# CONFIG_DEBUG_ATOMIC_SLEEP is not set
-# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
-# CONFIG_DEBUG_BUGVERBOSE is not set
-# CONFIG_DEBUG_CREDENTIALS is not set
-# CONFIG_DEBUG_DEVRES is not set
-# CONFIG_DEBUG_DRIVER is not set
-# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
-CONFIG_DEBUG_FS=y
-# CONFIG_DEBUG_GPIO is not set
-# CONFIG_DEBUG_HIGHMEM is not set
-# CONFIG_DEBUG_ICEDCC is not set
-# CONFIG_DEBUG_INFO is not set
-CONFIG_DEBUG_INFO_REDUCED=y
-CONFIG_DEBUG_KERNEL=y
-# CONFIG_DEBUG_KMEMLEAK is not set
-# CONFIG_DEBUG_KOBJECT is not set
-# CONFIG_DEBUG_LIST is not set
-# CONFIG_DEBUG_LL is not set
-# CONFIG_DEBUG_LOCKDEP is not set
-# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
-# CONFIG_DEBUG_LOCK_ALLOC is not set
-# CONFIG_DEBUG_MEMORY_INIT is not set
-# CONFIG_DEBUG_MUTEXES is not set
-# CONFIG_DEBUG_NOTIFIERS is not set
-# CONFIG_DEBUG_NX_TEST is not set
-# CONFIG_DEBUG_OBJECTS is not set
-# CONFIG_DEBUG_PAGEALLOC is not set
-# CONFIG_DEBUG_PERF_USE_VMALLOC is not set
-# CONFIG_DEBUG_PER_CPU_MAPS is not set
-# CONFIG_DEBUG_PREEMPT is not set
-# CONFIG_DEBUG_RODATA is not set
-# CONFIG_DEBUG_RT_MUTEXES is not set
-# CONFIG_DEBUG_SECTION_MISMATCH is not set
-# CONFIG_DEBUG_SET_MODULE_RONX is not set
-# CONFIG_DEBUG_SG is not set
-# CONFIG_DEBUG_SHIRQ is not set
-# CONFIG_DEBUG_SLAB is not set
-# CONFIG_DEBUG_SPINLOCK is not set
-# CONFIG_DEBUG_STACKOVERFLOW is not set
-# CONFIG_DEBUG_STACK_USAGE is not set
-# CONFIG_DEBUG_STRICT_USER_COPY_CHECKS is not set
-# CONFIG_DEBUG_VM is not set
-# CONFIG_DEBUG_WRITECOUNT is not set
-# CONFIG_DECNET is not set
-CONFIG_DEFAULT_CUBIC=y
-CONFIG_DEFAULT_DEADLINE=y
-CONFIG_DEFAULT_HOSTNAME="(none)"
-CONFIG_DEFAULT_IOSCHED="deadline"
-CONFIG_DEFAULT_MESSAGE_LOGLEVEL=4
-CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
-# CONFIG_DEFAULT_NOOP is not set
-# CONFIG_DEFAULT_RENO is not set
-CONFIG_DEFAULT_SECURITY=""
-CONFIG_DEFAULT_SECURITY_DAC=y
-CONFIG_DEFAULT_TCP_CONG="cubic"
-CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
-# CONFIG_DEPRECATED_PARAM_STRUCT is not set
-# CONFIG_DETECT_HUNG_TASK is not set
-# CONFIG_DEVKMEM is not set
-CONFIG_DEVPORT=y
-# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set
-# CONFIG_DEVTMPFS is not set
-# CONFIG_DEVTMPFS_MOUNT is not set
-# CONFIG_DISCONTIGMEM_MANUAL is not set
-# CONFIG_DISPLAY_SUPPORT is not set
-# CONFIG_DL2K is not set
-# CONFIG_DLM is not set
-# CONFIG_DM9000 is not set
-# CONFIG_DMADEVICES is not set
-# CONFIG_DMADEVICES_DEBUG is not set
-# CONFIG_DMASCC is not set
-# CONFIG_DMATEST is not set
-# CONFIG_DMA_API_DEBUG is not set
-# CONFIG_DMA_ENGINE is not set
-# CONFIG_DMA_SHARED_BUFFER is not set
-# CONFIG_DM_DEBUG is not set
-# CONFIG_DM_DELAY is not set
-# CONFIG_DM_FLAKEY is not set
-# CONFIG_DM_LOG_USERSPACE is not set
-# CONFIG_DM_MULTIPATH is not set
-# CONFIG_DM_RAID is not set
-# CONFIG_DM_THIN_PROVISIONING is not set
-# CONFIG_DM_UEVENT is not set
-# CONFIG_DM_ZERO is not set
-# CONFIG_DNET is not set
-# CONFIG_DNOTIFY is not set
-CONFIG_DQL=y
-# CONFIG_DRAGONRISE_FF is not set
-# CONFIG_DRM is not set
-# CONFIG_DS1682 is not set
-# CONFIG_DTLK is not set
-# CONFIG_DUMMY is not set
-# CONFIG_DVB_CORE is not set
-# CONFIG_DW_WATCHDOG is not set
-# CONFIG_DX_SEP is not set
-# CONFIG_DYNAMIC_DEBUG is not set
-# CONFIG_E100 is not set
-# CONFIG_E1000 is not set
-# CONFIG_E1000E is not set
-# CONFIG_E2100 is not set
-# CONFIG_EASYCAP is not set
-# CONFIG_ECHO is not set
-# CONFIG_ECONET is not set
-# CONFIG_ECRYPT_FS is not set
-# CONFIG_EDAC is not set
-# CONFIG_EEPROM_93CX6 is not set
-# CONFIG_EEPROM_93XX46 is not set
-# CONFIG_EEPROM_AT24 is not set
-# CONFIG_EEPROM_AT25 is not set
-# CONFIG_EEPROM_DIGSY_MTC_CFG is not set
-# CONFIG_EEPROM_LEGACY is not set
-# CONFIG_EEPROM_MAX6875 is not set
-# CONFIG_EEXPRESS is not set
-# CONFIG_EEXPRESS_PRO is not set
-CONFIG_EFI_PARTITION=y
-# CONFIG_EFS_FS is not set
-# CONFIG_ELF_CORE is not set
-CONFIG_EMBEDDED=y
-# CONFIG_ENABLE_MUST_CHECK is not set
-CONFIG_ENABLE_WARN_DEPRECATED=y
-# CONFIG_ENC28J60 is not set
-# CONFIG_ENCLOSURE_SERVICES is not set
-# CONFIG_ENCRYPTED_KEYS is not set
-# CONFIG_ENIC is not set
-# CONFIG_EPIC100 is not set
-CONFIG_EPOLL=y
-# CONFIG_EQUALIZER is not set
-# CONFIG_ET131X is not set
-# CONFIG_ETH16I is not set
-CONFIG_ETHERNET=y
-# CONFIG_ETHOC is not set
-CONFIG_EVENTFD=y
-# CONFIG_EVENT_POWER_TRACING_DEPRECATED is not set
-# CONFIG_EWRK3 is not set
-CONFIG_EXPERIMENTAL=y
-CONFIG_EXPERT=y
-# CONFIG_EXPORTFS is not set
-# CONFIG_EXT2_FS is not set
-# CONFIG_EXT2_FS_XATTR is not set
-# CONFIG_EXT2_FS_XIP is not set
-# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
-# CONFIG_EXT3_FS is not set
-# CONFIG_EXT3_FS_XATTR is not set
-# CONFIG_EXT4_DEBUG is not set
-# CONFIG_EXT4_FS is not set
-# CONFIG_EXT4_FS_POSIX_ACL is not set
-# CONFIG_EXT4_FS_SECURITY is not set
-CONFIG_EXT4_FS_XATTR=y
-CONFIG_EXT4_USE_FOR_EXT23=y
-CONFIG_EXTRA_FIRMWARE=""
-CONFIG_EXTRA_TARGETS=""
-# CONFIG_EZX_PCAP is not set
-# CONFIG_FAIR_GROUP_SCHED is not set
-# CONFIG_FANOTIFY is not set
-CONFIG_FAT_DEFAULT_CODEPAGE=437
-CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1"
-# CONFIG_FAT_FS is not set
-# CONFIG_FAULT_INJECTION is not set
-# CONFIG_FB is not set
-# CONFIG_FB_3DFX is not set
-# CONFIG_FB_ARC is not set
-# CONFIG_FB_ARK is not set
-# CONFIG_FB_ARMCLCD is not set
-# CONFIG_FB_ASILIANT is not set
-# CONFIG_FB_ATY is not set
-# CONFIG_FB_ATY128 is not set
-# CONFIG_FB_BACKLIGHT is not set
-# CONFIG_FB_BOOT_VESA_SUPPORT is not set
-# CONFIG_FB_BROADSHEET is not set
-# CONFIG_FB_CARMINE is not set
-# CONFIG_FB_CFB_COPYAREA is not set
-# CONFIG_FB_CFB_FILLRECT is not set
-# CONFIG_FB_CFB_IMAGEBLIT is not set
-# CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set
-# CONFIG_FB_CIRRUS is not set
-# CONFIG_FB_CYBER2000 is not set
-# CONFIG_FB_DDC is not set
-# CONFIG_FB_FOREIGN_ENDIAN is not set
-# CONFIG_FB_GEODE is not set
-# CONFIG_FB_HGA is not set
-# CONFIG_FB_IBM_GXT4500 is not set
-# CONFIG_FB_IMSTT is not set
-# CONFIG_FB_KYRO is not set
-# CONFIG_FB_LE80578 is not set
-# CONFIG_FB_MACMODES is not set
-# CONFIG_FB_MATROX is not set
-# CONFIG_FB_MB862XX is not set
-# CONFIG_FB_METRONOME is not set
-# CONFIG_FB_MODE_HELPERS is not set
-# CONFIG_FB_N411 is not set
-# CONFIG_FB_NEOMAGIC is not set
-# CONFIG_FB_NVIDIA is not set
-# CONFIG_FB_OF is not set
-# CONFIG_FB_PM2 is not set
-# CONFIG_FB_PM3 is not set
-# CONFIG_FB_PS3 is not set
-# CONFIG_FB_PXA is not set
-# CONFIG_FB_RADEON is not set
-# CONFIG_FB_RIVA is not set
-# CONFIG_FB_S1D13XXX is not set
-# CONFIG_FB_S3 is not set
-# CONFIG_FB_SAVAGE is not set
-# CONFIG_FB_SIS is not set
-# CONFIG_FB_SM7XX is not set
-# CONFIG_FB_SMSCUFX is not set
-# CONFIG_FB_SVGALIB is not set
-# CONFIG_FB_SYS_COPYAREA is not set
-# CONFIG_FB_SYS_FILLRECT is not set
-# CONFIG_FB_SYS_FOPS is not set
-# CONFIG_FB_SYS_IMAGEBLIT is not set
-# CONFIG_FB_TILEBLITTING is not set
-# CONFIG_FB_TMIO is not set
-# CONFIG_FB_TRIDENT is not set
-# CONFIG_FB_UDL is not set
-# CONFIG_FB_VGA16 is not set
-# CONFIG_FB_VIA is not set
-# CONFIG_FB_VIRTUAL is not set
-# CONFIG_FB_VOODOO1 is not set
-# CONFIG_FB_VT8623 is not set
-# CONFIG_FB_XGI is not set
-# CONFIG_FCOE is not set
-# CONFIG_FCOE_FNIC is not set
-# CONFIG_FDDI is not set
-# CONFIG_FEALNX is not set
-# CONFIG_FHANDLE is not set
-CONFIG_FIB_RULES=y
-CONFIG_FILE_LOCKING=y
-# CONFIG_FIREWIRE is not set
-# CONFIG_FIREWIRE_NOSY is not set
-# CONFIG_FIRMWARE_EDID is not set
-# CONFIG_FIRMWARE_IN_KERNEL is not set
-# CONFIG_FIXED_PHY is not set
-CONFIG_FLATMEM=y
-CONFIG_FLATMEM_MANUAL=y
-CONFIG_FLAT_NODE_MEM_MAP=y
-# CONFIG_FORCEDETH is not set
-CONFIG_FORCE_MAX_ZONEORDER=11
-# CONFIG_FRAMEBUFFER_CONSOLE is not set
-# CONFIG_FRAME_POINTER is not set
-CONFIG_FRAME_WARN=1024
-# CONFIG_FREEZER is not set
-# CONFIG_FRONTSWAP is not set
-# CONFIG_FSCACHE is not set
-CONFIG_FSNOTIFY=y
-# CONFIG_FS_POSIX_ACL is not set
-# CONFIG_FT1000 is not set
-# CONFIG_FTGMAC100 is not set
-# CONFIG_FTL is not set
-# CONFIG_FTMAC100 is not set
-# CONFIG_FTRACE is not set
-# CONFIG_FTRACE_STARTUP_TEST is not set
-# CONFIG_FTR_FIXUP_SELFTEST is not set
-# CONFIG_FUJITSU_TABLET is not set
-# CONFIG_FUNCTION_TRACER is not set
-# CONFIG_FUSE_FS is not set
-# CONFIG_FUSION is not set
-# CONFIG_FUSION_FC is not set
-# CONFIG_FUSION_SAS is not set
-# CONFIG_FUSION_SPI is not set
-CONFIG_FUTEX=y
-CONFIG_FW_LOADER=y
-CONFIG_GACT_PROB=y
-# CONFIG_GAMEPORT is not set
-# CONFIG_GCOV is not set
-# CONFIG_GCOV_KERNEL is not set
-CONFIG_GENERIC_CALIBRATE_DELAY=y
-# CONFIG_GENERIC_CPU_DEVICES is not set
-CONFIG_GENERIC_HARDIRQS=y
-CONFIG_GENERIC_HWEIGHT=y
-CONFIG_GENERIC_IRQ_PROBE=y
-CONFIG_GENERIC_TIME=y
-# CONFIG_GFS2_FS is not set
-# CONFIG_GIGASET_CAPI is not set
-# CONFIG_GIGASET_DEBUG is not set
-# CONFIG_GPIOLIB is not set
-# CONFIG_GPIO_74X164 is not set
-# CONFIG_GPIO_ADP5588 is not set
-# CONFIG_GPIO_BT8XX is not set
-# CONFIG_GPIO_CS5535 is not set
-# CONFIG_GPIO_GENERIC_PLATFORM is not set
-# CONFIG_GPIO_IT8761E is not set
-# CONFIG_GPIO_LANGWELL is not set
-# CONFIG_GPIO_MAX7300 is not set
-# CONFIG_GPIO_MAX7301 is not set
-# CONFIG_GPIO_MAX732X is not set
-# CONFIG_GPIO_MC33880 is not set
-# CONFIG_GPIO_MCP23S08 is not set
-# CONFIG_GPIO_ML_IOH is not set
-# CONFIG_GPIO_PCA953X is not set
-# CONFIG_GPIO_PCF857X is not set
-# CONFIG_GPIO_PCH is not set
-# CONFIG_GPIO_PL061 is not set
-# CONFIG_GPIO_RDC321X is not set
-# CONFIG_GPIO_SCH is not set
-# CONFIG_GPIO_SX150X is not set
-# CONFIG_GPIO_SYSFS is not set
-# CONFIG_GPIO_VX855 is not set
-# CONFIG_GPIO_XILINX is not set
-# CONFIG_GREENASIA_FF is not set
-# CONFIG_HAMACHI is not set
-CONFIG_HAMRADIO=y
-# CONFIG_HAPPYMEAL is not set
-# CONFIG_HARDLOCKUP_DETECTOR is not set
-# CONFIG_HAVE_AOUT is not set
-CONFIG_HAVE_KPROBES=y
-CONFIG_HAVE_KRETPROBES=y
-# CONFIG_HCALL_STATS is not set
-# CONFIG_HDLC is not set
-# CONFIG_HDLC_CISCO is not set
-# CONFIG_HDLC_FR is not set
-# CONFIG_HDLC_PPP is not set
-# CONFIG_HDLC_RAW is not set
-# CONFIG_HDLC_RAW_ETH is not set
-# CONFIG_HEADERS_CHECK is not set
-# CONFIG_HERMES is not set
-# CONFIG_HFSPLUS_FS is not set
-# CONFIG_HFS_FS is not set
-# CONFIG_HIBERNATION is not set
-# CONFIG_HID is not set
-# CONFIG_HIDRAW is not set
-# CONFIG_HID_A4TECH is not set
-# CONFIG_HID_ACRUX is not set
-# CONFIG_HID_ACRUX_FF is not set
-# CONFIG_HID_APPLE is not set
-# CONFIG_HID_BELKIN is not set
-# CONFIG_HID_CHERRY is not set
-# CONFIG_HID_CHICONY is not set
-# CONFIG_HID_CYPRESS is not set
-# CONFIG_HID_DRAGONRISE is not set
-# CONFIG_HID_ELECOM is not set
-# CONFIG_HID_EMS_FF is not set
-# CONFIG_HID_EZKEY is not set
-# CONFIG_HID_GREENASIA is not set
-# CONFIG_HID_GYRATION is not set
-# CONFIG_HID_HOLTEK is not set
-# CONFIG_HID_KENSINGTON is not set
-# CONFIG_HID_KEYTOUCH is not set
-# CONFIG_HID_KYE is not set
-# CONFIG_HID_LCPOWER is not set
-# CONFIG_HID_LOGITECH is not set
-# CONFIG_HID_MAGICMOUSE is not set
-# CONFIG_HID_MICROSOFT is not set
-# CONFIG_HID_MONTEREY is not set
-# CONFIG_HID_MULTITOUCH is not set
-# CONFIG_HID_NTRIG is not set
-# CONFIG_HID_ORTEK is not set
-# CONFIG_HID_PANTHERLORD is not set
-# CONFIG_HID_PETALYNX is not set
-# CONFIG_HID_PICOLCD is not set
-# CONFIG_HID_PID is not set
-# CONFIG_HID_PRIMAX is not set
-# CONFIG_HID_PRODIKEYS is not set
-# CONFIG_HID_QUANTA is not set
-# CONFIG_HID_ROCCAT is not set
-# CONFIG_HID_ROCCAT_ARVO is not set
-# CONFIG_HID_ROCCAT_KONE is not set
-# CONFIG_HID_ROCCAT_KONEPLUS is not set
-# CONFIG_HID_ROCCAT_KOVAPLUS is not set
-# CONFIG_HID_ROCCAT_PYRA is not set
-# CONFIG_HID_SAMSUNG is not set
-# CONFIG_HID_SMARTJOYPLUS is not set
-# CONFIG_HID_SONY is not set
-# CONFIG_HID_SPEEDLINK is not set
-# CONFIG_HID_SUNPLUS is not set
-# CONFIG_HID_SUPPORT is not set
-# CONFIG_HID_THRUSTMASTER is not set
-# CONFIG_HID_TOPSEED is not set
-# CONFIG_HID_TWINHAN is not set
-# CONFIG_HID_UCLOGIC is not set
-# CONFIG_HID_WACOM is not set
-# CONFIG_HID_WALTOP is not set
-# CONFIG_HID_WIIMOTE is not set
-# CONFIG_HID_ZEROPLUS is not set
-# CONFIG_HID_ZYDACRON is not set
-# CONFIG_HIGHMEM is not set
-CONFIG_HIGH_RES_TIMERS=y
-# CONFIG_HIPPI is not set
-# CONFIG_HMC6352 is not set
-# CONFIG_HOSTAP is not set
-# CONFIG_HOSTAP_CS is not set
-# CONFIG_HOSTAP_PCI is not set
-# CONFIG_HOSTAP_PLX is not set
-CONFIG_HOTPLUG=y
-# CONFIG_HOTPLUG_CPU is not set
-# CONFIG_HOTPLUG_PCI is not set
-# CONFIG_HP100 is not set
-# CONFIG_HPFS_FS is not set
-# CONFIG_HPLAN is not set
-# CONFIG_HPLAN_PLUS is not set
-# CONFIG_HP_ILO is not set
-# CONFIG_HTC_EGPIO is not set
-# CONFIG_HTC_I2CPLD is not set
-# CONFIG_HTC_PASIC3 is not set
-# CONFIG_HUGETLB_PAGE is not set
-# CONFIG_HVC_DCC is not set
-# CONFIG_HVC_UDBG is not set
-# CONFIG_HWMON is not set
-# CONFIG_HWMON_DEBUG_CHIP is not set
-# CONFIG_HWMON_VID is not set
-# CONFIG_HWSPINLOCK_OMAP is not set
-CONFIG_HW_PERF_EVENTS=y
-# CONFIG_HW_RANDOM is not set
-# CONFIG_HW_RANDOM_AMD is not set
-# CONFIG_HW_RANDOM_GEODE is not set
-# CONFIG_HW_RANDOM_INTEL is not set
-# CONFIG_HW_RANDOM_PPC4XX is not set
-# CONFIG_HW_RANDOM_TIMERIOMEM is not set
-# CONFIG_HW_RANDOM_VIA is not set
-# CONFIG_HYPERV is not set
-# CONFIG_HYSDN is not set
-CONFIG_HZ=100
-CONFIG_HZ_100=y
-# CONFIG_HZ_1000 is not set
-# CONFIG_HZ_1024 is not set
-# CONFIG_HZ_128 is not set
-# CONFIG_HZ_250 is not set
-# CONFIG_HZ_256 is not set
-# CONFIG_HZ_300 is not set
-# CONFIG_HZ_48 is not set
-# CONFIG_I2C is not set
-# CONFIG_I2C_ALGOBIT is not set
-# CONFIG_I2C_ALGOPCA is not set
-# CONFIG_I2C_ALGOPCF is not set
-# CONFIG_I2C_ALI1535 is not set
-# CONFIG_I2C_ALI1563 is not set
-# CONFIG_I2C_ALI15X3 is not set
-# CONFIG_I2C_AMD756 is not set
-# CONFIG_I2C_AMD8111 is not set
-# CONFIG_I2C_CHARDEV is not set
-# CONFIG_I2C_COMPAT is not set
-# CONFIG_I2C_DEBUG_ALGO is not set
-# CONFIG_I2C_DEBUG_BUS is not set
-# CONFIG_I2C_DEBUG_CORE is not set
-# CONFIG_I2C_DESIGNWARE is not set
-# CONFIG_I2C_DESIGNWARE_PCI is not set
-# CONFIG_I2C_DESIGNWARE_PLATFORM is not set
-# CONFIG_I2C_DIOLAN_U2C is not set
-# CONFIG_I2C_EG20T is not set
-# CONFIG_I2C_ELEKTOR is not set
-# CONFIG_I2C_GPIO is not set
-# CONFIG_I2C_HELPER_AUTO is not set
-# CONFIG_I2C_I801 is not set
-# CONFIG_I2C_IBM_IIC is not set
-# CONFIG_I2C_INTEL_MID is not set
-# CONFIG_I2C_ISCH is not set
-# CONFIG_I2C_MPC is not set
-# CONFIG_I2C_MUX is not set
-# CONFIG_I2C_MV64XXX is not set
-# CONFIG_I2C_NFORCE2 is not set
-# CONFIG_I2C_OCORES is not set
-# CONFIG_I2C_PARPORT is not set
-# CONFIG_I2C_PARPORT_LIGHT is not set
-# CONFIG_I2C_PCA_ISA is not set
-# CONFIG_I2C_PCA_PLATFORM is not set
-# CONFIG_I2C_PIIX4 is not set
-# CONFIG_I2C_PXA_PCI is not set
-# CONFIG_I2C_SCMI is not set
-# CONFIG_I2C_SIMTEC is not set
-# CONFIG_I2C_SIS5595 is not set
-# CONFIG_I2C_SIS630 is not set
-# CONFIG_I2C_SIS96X is not set
-# CONFIG_I2C_SMBUS is not set
-# CONFIG_I2C_STUB is not set
-# CONFIG_I2C_TAOS_EVM is not set
-# CONFIG_I2C_TINY_USB is not set
-# CONFIG_I2C_VERSATILE is not set
-# CONFIG_I2C_VIA is not set
-# CONFIG_I2C_VIAPRO is not set
-# CONFIG_I2C_XILINX is not set
-# CONFIG_I2O is not set
-# CONFIG_I82092 is not set
-# CONFIG_I82365 is not set
-# CONFIG_IBM_ASM is not set
-# CONFIG_IBM_EMAC_DEBUG is not set
-# CONFIG_IBM_EMAC_EMAC4 is not set
-# CONFIG_IBM_EMAC_MAL_CLR_ICINTSTAT is not set
-# CONFIG_IBM_EMAC_MAL_COMMON_ERR is not set
-# CONFIG_IBM_EMAC_NO_FLOW_CTRL is not set
-# CONFIG_IBM_EMAC_RGMII is not set
-# CONFIG_IBM_EMAC_TAH is not set
-# CONFIG_IBM_EMAC_ZMII is not set
-# CONFIG_ICPLUS_PHY is not set
-# CONFIG_ICS932S401 is not set
-# CONFIG_IDE is not set
-# CONFIG_IDEAPAD_LAPTOP is not set
-# CONFIG_IDE_GD is not set
-# CONFIG_IDE_PHISON is not set
-# CONFIG_IDE_PROC_FS is not set
-# CONFIG_IDE_TASK_IOCTL is not set
-# CONFIG_IEEE802154 is not set
-# CONFIG_IFB is not set
-# CONFIG_IGB is not set
-# CONFIG_IGBVF is not set
-# CONFIG_IIO is not set
-# CONFIG_IKCONFIG is not set
-# CONFIG_IKCONFIG_PROC is not set
-# CONFIG_IMAGE_CMDLINE_HACK is not set
-CONFIG_INET=y
-# CONFIG_INET6_AH is not set
-# CONFIG_INET6_ESP is not set
-# CONFIG_INET6_IPCOMP is not set
-# CONFIG_INET6_TUNNEL is not set
-# CONFIG_INET6_XFRM_MODE_BEET is not set
-# CONFIG_INET6_XFRM_MODE_ROUTEOPTIMIZATION is not set
-# CONFIG_INET6_XFRM_MODE_TRANSPORT is not set
-# CONFIG_INET6_XFRM_MODE_TUNNEL is not set
-# CONFIG_INET6_XFRM_TUNNEL is not set
-# CONFIG_INET_AH is not set
-# CONFIG_INET_DIAG is not set
-# CONFIG_INET_ESP is not set
-# CONFIG_INET_IPCOMP is not set
-# CONFIG_INET_LRO is not set
-# CONFIG_INET_TCP_DIAG is not set
-# CONFIG_INET_TUNNEL is not set
-# CONFIG_INET_UDP_DIAG is not set
-# CONFIG_INET_XFRM_MODE_BEET is not set
-# CONFIG_INET_XFRM_MODE_TRANSPORT is not set
-# CONFIG_INET_XFRM_MODE_TUNNEL is not set
-# CONFIG_INET_XFRM_TUNNEL is not set
-# CONFIG_INFINIBAND is not set
-# CONFIG_INFTL is not set
-# CONFIG_INITRAMFS_COMPRESSION_BZIP2 is not set
-# CONFIG_INITRAMFS_COMPRESSION_GZIP is not set
-# CONFIG_INITRAMFS_COMPRESSION_LZMA is not set
-CONFIG_INITRAMFS_COMPRESSION_NONE=y
-CONFIG_INIT_ENV_ARG_LIMIT=32
-# CONFIG_INLINE_READ_LOCK is not set
-# CONFIG_INLINE_READ_LOCK_BH is not set
-# CONFIG_INLINE_READ_LOCK_IRQ is not set
-# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
-# CONFIG_INLINE_READ_TRYLOCK is not set
-CONFIG_INLINE_READ_UNLOCK=y
-# CONFIG_INLINE_READ_UNLOCK_BH is not set
-CONFIG_INLINE_READ_UNLOCK_IRQ=y
-# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_SPIN_LOCK is not set
-# CONFIG_INLINE_SPIN_LOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
-# CONFIG_INLINE_SPIN_TRYLOCK is not set
-# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
-CONFIG_INLINE_SPIN_UNLOCK=y
-# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
-CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
-# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_WRITE_LOCK is not set
-# CONFIG_INLINE_WRITE_LOCK_BH is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
-# CONFIG_INLINE_WRITE_TRYLOCK is not set
-CONFIG_INLINE_WRITE_UNLOCK=y
-# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
-CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
-# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
-CONFIG_INOTIFY_USER=y
-# CONFIG_INPUT is not set
-# CONFIG_INPUT_AD714X is not set
-# CONFIG_INPUT_ADXL34X is not set
-# CONFIG_INPUT_APANEL is not set
-# CONFIG_INPUT_ATI_REMOTE is not set
-# CONFIG_INPUT_ATI_REMOTE2 is not set
-# CONFIG_INPUT_ATLAS_BTNS is not set
-# CONFIG_INPUT_BMA150 is not set
-# CONFIG_INPUT_CM109 is not set
-# CONFIG_INPUT_CMA3000 is not set
-# CONFIG_INPUT_EVBUG is not set
-# CONFIG_INPUT_EVDEV is not set
-# CONFIG_INPUT_FF_MEMLESS is not set
-# CONFIG_INPUT_GP2A is not set
-# CONFIG_INPUT_GPIO_ROTARY_ENCODER is not set
-# CONFIG_INPUT_GPIO_TILT_POLLED is not set
-# CONFIG_INPUT_JOYDEV is not set
-# CONFIG_INPUT_JOYSTICK is not set
-# CONFIG_INPUT_KEYBOARD is not set
-# CONFIG_INPUT_KEYSPAN_REMOTE is not set
-# CONFIG_INPUT_KXTJ9 is not set
-CONFIG_INPUT_MISC=y
-# CONFIG_INPUT_MMA8450 is not set
-# CONFIG_INPUT_MOUSE is not set
-# CONFIG_INPUT_MOUSEDEV is not set
-# CONFIG_INPUT_MPU3050 is not set
-# CONFIG_INPUT_PCF8574 is not set
-# CONFIG_INPUT_PCSPKR is not set
-# CONFIG_INPUT_POLLDEV is not set
-# CONFIG_INPUT_POWERMATE is not set
-# CONFIG_INPUT_SPARSEKMAP is not set
-# CONFIG_INPUT_TABLET is not set
-# CONFIG_INPUT_TOUCHSCREEN is not set
-# CONFIG_INPUT_UINPUT is not set
-# CONFIG_INPUT_WISTRON_BTNS is not set
-# CONFIG_INPUT_YEALINK is not set
-# CONFIG_INTEL_IDLE is not set
-# CONFIG_INTEL_MID_PTI is not set
-# CONFIG_INTEL_OAKTRAIL is not set
-# CONFIG_IOMMU_SUPPORT is not set
-# CONFIG_IOSCHED_CFQ is not set
-CONFIG_IOSCHED_DEADLINE=y
-CONFIG_IOSCHED_NOOP=y
-# CONFIG_IP1000 is not set
-# CONFIG_IP17XX_PHY is not set
-# CONFIG_IP6_NF_FILTER is not set
-# CONFIG_IP6_NF_IPTABLES is not set
-# CONFIG_IP6_NF_MANGLE is not set
-# CONFIG_IP6_NF_MATCH_AH is not set
-# CONFIG_IP6_NF_MATCH_EUI64 is not set
-# CONFIG_IP6_NF_MATCH_FRAG is not set
-# CONFIG_IP6_NF_MATCH_HL is not set
-# CONFIG_IP6_NF_MATCH_IPV6HEADER is not set
-# CONFIG_IP6_NF_MATCH_MH is not set
-# CONFIG_IP6_NF_MATCH_OPTS is not set
-# CONFIG_IP6_NF_MATCH_RPFILTER is not set
-# CONFIG_IP6_NF_MATCH_RT is not set
-# CONFIG_IP6_NF_QUEUE is not set
-# CONFIG_IP6_NF_RAW is not set
-# CONFIG_IP6_NF_TARGET_HL is not set
-# CONFIG_IP6_NF_TARGET_LOG is not set
-# CONFIG_IP6_NF_TARGET_REJECT is not set
-# CONFIG_IPC_NS is not set
-# CONFIG_IPMI_HANDLER is not set
-# CONFIG_IPV6 is not set
-# CONFIG_IPV6_MIP6 is not set
-# CONFIG_IPV6_MROUTE is not set
-# CONFIG_IPV6_MROUTE_MULTIPLE_TABLES is not set
-# CONFIG_IPV6_MULTIPLE_TABLES is not set
-CONFIG_IPV6_NDISC_NODETYPE=y
-# CONFIG_IPV6_OPTIMISTIC_DAD is not set
-# CONFIG_IPV6_PRIVACY is not set
-# CONFIG_IPV6_ROUTER_PREF is not set
-# CONFIG_IPV6_ROUTE_INFO is not set
-# CONFIG_IPV6_SIT is not set
-# CONFIG_IPV6_SIT_6RD is not set
-# CONFIG_IPV6_TUNNEL is not set
-# CONFIG_IPW2100 is not set
-# CONFIG_IPW2100_DEBUG is not set
-CONFIG_IPW2100_MONITOR=y
-# CONFIG_IPW2200 is not set
-# CONFIG_IPW2200_DEBUG is not set
-CONFIG_IPW2200_MONITOR=y
-# CONFIG_IPW2200_PROMISCUOUS is not set
-# CONFIG_IPW2200_QOS is not set
-# CONFIG_IPW2200_RADIOTAP is not set
-# CONFIG_IPWIRELESS is not set
-# CONFIG_IPX is not set
-CONFIG_IP_ADVANCED_ROUTER=y
-# CONFIG_IP_DCCP is not set
-# CONFIG_IP_FIB_TRIE_STATS is not set
-CONFIG_IP_MROUTE=y
-CONFIG_IP_MROUTE_MULTIPLE_TABLES=y
-CONFIG_IP_MULTICAST=y
-CONFIG_IP_MULTIPLE_TABLES=y
-# CONFIG_IP_NF_ARPFILTER is not set
-# CONFIG_IP_NF_ARPTABLES is not set
-# CONFIG_IP_NF_ARP_MANGLE is not set
-# CONFIG_IP_NF_FILTER is not set
-# CONFIG_IP_NF_IPTABLES is not set
-# CONFIG_IP_NF_MANGLE is not set
-# CONFIG_IP_NF_MATCH_AH is not set
-# CONFIG_IP_NF_MATCH_ECN is not set
-# CONFIG_IP_NF_MATCH_RPFILTER is not set
-# CONFIG_IP_NF_MATCH_TTL is not set
-# CONFIG_IP_NF_QUEUE is not set
-# CONFIG_IP_NF_RAW is not set
-# CONFIG_IP_NF_SECURITY is not set
-# CONFIG_IP_NF_TARGET_CLUSTERIP is not set
-# CONFIG_IP_NF_TARGET_ECN is not set
-# CONFIG_IP_NF_TARGET_LOG is not set
-# CONFIG_IP_NF_TARGET_MASQUERADE is not set
-# CONFIG_IP_NF_TARGET_NETMAP is not set
-# CONFIG_IP_NF_TARGET_REDIRECT is not set
-# CONFIG_IP_NF_TARGET_REJECT is not set
-# CONFIG_IP_NF_TARGET_TTL is not set
-# CONFIG_IP_NF_TARGET_ULOG is not set
-# CONFIG_IP_PIMSM_V1 is not set
-# CONFIG_IP_PIMSM_V2 is not set
-# CONFIG_IP_PNP is not set
-CONFIG_IP_ROUTE_MULTIPATH=y
-CONFIG_IP_ROUTE_VERBOSE=y
-# CONFIG_IP_SCTP is not set
-# CONFIG_IP_SET is not set
-# CONFIG_IP_VS is not set
-# CONFIG_IRDA is not set
-# CONFIG_IRQSOFF_TRACER is not set
-# CONFIG_IRQ_ALL_CPUS is not set
-# CONFIG_IR_IMON is not set
-# CONFIG_IR_JVC_DECODER is not set
-# CONFIG_IR_LIRC_CODEC is not set
-# CONFIG_IR_MCEUSB is not set
-# CONFIG_IR_NEC_DECODER is not set
-# CONFIG_IR_RC5_DECODER is not set
-# CONFIG_IR_RC5_SZ_DECODER is not set
-# CONFIG_IR_RC6_DECODER is not set
-# CONFIG_IR_SONY_DECODER is not set
-# CONFIG_IR_STREAMZAP is not set
-# CONFIG_ISCSI_BOOT_SYSFS is not set
-# CONFIG_ISCSI_TCP is not set
-CONFIG_ISDN=y
-# CONFIG_ISDN_AUDIO is not set
-# CONFIG_ISDN_CAPI is not set
-# CONFIG_ISDN_CAPI_CAPIDRV is not set
-# CONFIG_ISDN_DIVERSION is not set
-# CONFIG_ISDN_DRV_ACT2000 is not set
-# CONFIG_ISDN_DRV_AVMB1_VERBOSE_REASON is not set
-# CONFIG_ISDN_DRV_GIGASET is not set
-# CONFIG_ISDN_DRV_HISAX is not set
-# CONFIG_ISDN_DRV_ICN is not set
-# CONFIG_ISDN_DRV_LOOP is not set
-# CONFIG_ISDN_DRV_PCBIT is not set
-# CONFIG_ISDN_DRV_SC is not set
-# CONFIG_ISDN_I4L is not set
-# CONFIG_ISL29003 is not set
-# CONFIG_ISL29020 is not set
-# CONFIG_ISO9660_FS is not set
-# CONFIG_ISS4xx is not set
-# CONFIG_IWL3945 is not set
-# CONFIG_IWLAGN is not set
-# CONFIG_IWLWIFI is not set
-# CONFIG_IWMC3200TOP is not set
-# CONFIG_IXGB is not set
-# CONFIG_IXGBE is not set
-# CONFIG_IXGBEVF is not set
-# CONFIG_JBD is not set
-# CONFIG_JBD2_DEBUG is not set
-# CONFIG_JBD_DEBUG is not set
-# CONFIG_JFFS2_CMODE_FAVOURLZO is not set
-# CONFIG_JFFS2_CMODE_NONE is not set
-CONFIG_JFFS2_CMODE_PRIORITY=y
-# CONFIG_JFFS2_CMODE_SIZE is not set
-CONFIG_JFFS2_COMPRESSION_OPTIONS=y
-CONFIG_JFFS2_FS=y
-CONFIG_JFFS2_FS_DEBUG=0
-# CONFIG_JFFS2_FS_POSIX_ACL is not set
-# CONFIG_JFFS2_FS_SECURITY is not set
-# CONFIG_JFFS2_FS_WBUF_VERIFY is not set
-CONFIG_JFFS2_FS_WRITEBUFFER=y
-CONFIG_JFFS2_FS_XATTR=y
-CONFIG_JFFS2_LZMA=y
-# CONFIG_JFFS2_LZO is not set
-CONFIG_JFFS2_RTIME=y
-# CONFIG_JFFS2_RUBIN is not set
-CONFIG_JFFS2_SUMMARY=y
-# CONFIG_JFFS2_ZLIB is not set
-# CONFIG_JFS_DEBUG is not set
-# CONFIG_JFS_FS is not set
-# CONFIG_JFS_POSIX_ACL is not set
-# CONFIG_JFS_SECURITY is not set
-# CONFIG_JFS_STATISTICS is not set
-# CONFIG_JME is not set
-CONFIG_JOLIET=y
-# CONFIG_JUMP_LABEL is not set
-# CONFIG_KALLSYMS is not set
-# CONFIG_KALLSYMS_ALL is not set
-# CONFIG_KARMA_PARTITION is not set
-# CONFIG_KERNEL_BZIP2 is not set
-# CONFIG_KERNEL_GZIP is not set
-# CONFIG_KERNEL_LZMA is not set
-# CONFIG_KERNEL_LZO is not set
-CONFIG_KERNEL_XZ=y
-# CONFIG_KEXEC is not set
-# CONFIG_KEYBOARD_ADP5588 is not set
-# CONFIG_KEYBOARD_ADP5589 is not set
-# CONFIG_KEYBOARD_ATKBD is not set
-# CONFIG_KEYBOARD_GPIO_POLLED is not set
-# CONFIG_KEYBOARD_LKKBD is not set
-# CONFIG_KEYBOARD_LM8323 is not set
-# CONFIG_KEYBOARD_MATRIX is not set
-# CONFIG_KEYBOARD_MAX7359 is not set
-# CONFIG_KEYBOARD_MCS is not set
-# CONFIG_KEYBOARD_MPR121 is not set
-# CONFIG_KEYBOARD_NEWTON is not set
-# CONFIG_KEYBOARD_OPENCORES is not set
-# CONFIG_KEYBOARD_PXA27x is not set
-# CONFIG_KEYBOARD_QT1070 is not set
-# CONFIG_KEYBOARD_QT2160 is not set
-# CONFIG_KEYBOARD_SAMSUNG is not set
-# CONFIG_KEYBOARD_STOWAWAY is not set
-# CONFIG_KEYBOARD_SUNKBD is not set
-# CONFIG_KEYBOARD_TCA6416 is not set
-# CONFIG_KEYBOARD_TCA8418 is not set
-# CONFIG_KEYBOARD_XTKBD is not set
-# CONFIG_KEYS is not set
-# CONFIG_KEYS_DEBUG_PROC_KEYS is not set
-# CONFIG_KGDB is not set
-# CONFIG_KMEMCHECK is not set
-# CONFIG_KPROBES is not set
-# CONFIG_KS8842 is not set
-# CONFIG_KS8851 is not set
-# CONFIG_KS8851_MLL is not set
-# CONFIG_KSM is not set
-# CONFIG_KSZ884X_PCI is not set
-# CONFIG_KVM_GUEST is not set
-# CONFIG_L2TP is not set
-# CONFIG_L2TP_ETH is not set
-# CONFIG_L2TP_IP is not set
-# CONFIG_L2TP_V3 is not set
-# CONFIG_LANMEDIA is not set
-# CONFIG_LANTIQ is not set
-# CONFIG_LAPB is not set
-# CONFIG_LASAT is not set
-# CONFIG_LATENCYTOP is not set
-CONFIG_LBDAF=y
-# CONFIG_LDM_PARTITION is not set
-# CONFIG_LEDS_BD2802 is not set
-CONFIG_LEDS_CLASS=y
-# CONFIG_LEDS_DAC124S085 is not set
-# CONFIG_LEDS_GPIO is not set
-CONFIG_LEDS_GPIO_OF=y
-CONFIG_LEDS_GPIO_PLATFORM=y
-# CONFIG_LEDS_INTEL_SS4200 is not set
-# CONFIG_LEDS_LM3530 is not set
-# CONFIG_LEDS_LP3944 is not set
-# CONFIG_LEDS_LP5521 is not set
-# CONFIG_LEDS_LP5523 is not set
-# CONFIG_LEDS_LT3593 is not set
-# CONFIG_LEDS_NET5501 is not set
-# CONFIG_LEDS_OT200 is not set
-# CONFIG_LEDS_PCA9532 is not set
-# CONFIG_LEDS_PCA955X is not set
-# CONFIG_LEDS_RENESAS_TPU is not set
-# CONFIG_LEDS_TCA6507 is not set
-CONFIG_LEDS_TRIGGERS=y
-# CONFIG_LEDS_TRIGGER_BACKLIGHT is not set
-CONFIG_LEDS_TRIGGER_DEFAULT_ON=y
-# CONFIG_LEDS_TRIGGER_GPIO is not set
-# CONFIG_LEDS_TRIGGER_HEARTBEAT is not set
-# CONFIG_LEDS_TRIGGER_IDE_DISK is not set
-# CONFIG_LEDS_TRIGGER_MORSE is not set
-CONFIG_LEDS_TRIGGER_NETDEV=y
-CONFIG_LEDS_TRIGGER_TIMER=y
-# CONFIG_LEDS_TRIGGER_USBDEV is not set
-# CONFIG_LEGACY_PTYS is not set
-# CONFIG_LIB80211 is not set
-# CONFIG_LIB80211_CRYPT_CCMP is not set
-# CONFIG_LIB80211_CRYPT_TKIP is not set
-# CONFIG_LIB80211_CRYPT_WEP is not set
-# CONFIG_LIB80211_DEBUG is not set
-# CONFIG_LIBCRC32C is not set
-# CONFIG_LIBERTAS is not set
-# CONFIG_LIBERTAS_THINFIRM is not set
-# CONFIG_LIBERTAS_USB is not set
-# CONFIG_LIBFC is not set
-# CONFIG_LIBFCOE is not set
-# CONFIG_LIBIPW_DEBUG is not set
-# CONFIG_LINE6_USB is not set
-# CONFIG_LIRC_STAGING is not set
-# CONFIG_LKDTM is not set
-CONFIG_LLC=y
-# CONFIG_LLC2 is not set
-CONFIG_LOCALVERSION=""
-# CONFIG_LOCALVERSION_AUTO is not set
-# CONFIG_LOCKD is not set
-CONFIG_LOCKDEP_SUPPORT=y
-CONFIG_LOCKD_V4=y
-# CONFIG_LOCKUP_DETECTOR is not set
-# CONFIG_LOCK_STAT is not set
-# CONFIG_LOGFS is not set
-# CONFIG_LOGIRUMBLEPAD2_FF is not set
-# CONFIG_LOGITECH_FF is not set
-# CONFIG_LOGO is not set
-CONFIG_LOG_BUF_SHIFT=17
-# CONFIG_LOONGSON_MC146818 is not set
-# CONFIG_LP486E is not set
-# CONFIG_LPC_SCH is not set
-# CONFIG_LP_CONSOLE is not set
-# CONFIG_LSI_ET1011C_PHY is not set
-# CONFIG_LTPC is not set
-# CONFIG_LXT_PHY is not set
-CONFIG_LZMA_COMPRESS=y
-CONFIG_LZMA_DECOMPRESS=y
-# CONFIG_LZO_COMPRESS is not set
-# CONFIG_LZO_DECOMPRESS is not set
-# CONFIG_M25PXX_PREFER_SMALL_SECTOR_ERASE is not set
-# CONFIG_MAC80211 is not set
-# CONFIG_MACH_DECSTATION is not set
-# CONFIG_MACH_JAZZ is not set
-# CONFIG_MACH_JZ4740 is not set
-# CONFIG_MACH_LOONGSON is not set
-# CONFIG_MACH_NO_WESTBRIDGE is not set
-# CONFIG_MACH_TX39XX is not set
-# CONFIG_MACH_TX49XX is not set
-# CONFIG_MACH_VR41XX is not set
-# CONFIG_MACINTOSH_DRIVERS is not set
-# CONFIG_MACVLAN is not set
-# CONFIG_MACVTAP is not set
-# CONFIG_MAC_EMUMOUSEBTN is not set
-# CONFIG_MAC_PARTITION is not set
-# CONFIG_MAGIC_SYSRQ is not set
-# CONFIG_MARVELL_PHY is not set
-# CONFIG_MAX63XX_WATCHDOG is not set
-# CONFIG_MD is not set
-# CONFIG_MDIO_BITBANG is not set
-# CONFIG_MD_FAULTY is not set
-# CONFIG_MEDIA_ATTACH is not set
-# CONFIG_MEDIA_CONTROLLER is not set
-# CONFIG_MEDIA_SUPPORT is not set
-# CONFIG_MEDIA_TUNER_CUSTOMISE is not set
-# CONFIG_MEGARAID_LEGACY is not set
-# CONFIG_MEGARAID_NEWGEN is not set
-# CONFIG_MEGARAID_SAS is not set
-# CONFIG_MEMORY_FAILURE is not set
-# CONFIG_MEMSTICK is not set
-# CONFIG_MFD_88PM860X is not set
-# CONFIG_MFD_AAT2870_CORE is not set
-# CONFIG_MFD_ASIC3 is not set
-# CONFIG_MFD_CORE is not set
-# CONFIG_MFD_CS5535 is not set
-# CONFIG_MFD_DA9052_I2C is not set
-# CONFIG_MFD_DA9052_SPI is not set
-# CONFIG_MFD_JANZ_CMODIO is not set
-# CONFIG_MFD_MAX8925 is not set
-# CONFIG_MFD_MAX8997 is not set
-# CONFIG_MFD_MAX8998 is not set
-# CONFIG_MFD_MC13783 is not set
-# CONFIG_MFD_MC13XXX is not set
-# CONFIG_MFD_PCF50633 is not set
-# CONFIG_MFD_RDC321X is not set
-# CONFIG_MFD_S5M_CORE is not set
-# CONFIG_MFD_SM501 is not set
-# CONFIG_MFD_STMPE is not set
-CONFIG_MFD_SUPPORT=y
-# CONFIG_MFD_TC3589X is not set
-# CONFIG_MFD_TC6387XB is not set
-# CONFIG_MFD_TC6393XB is not set
-# CONFIG_MFD_TIMBERDALE is not set
-# CONFIG_MFD_TMIO is not set
-# CONFIG_MFD_TPS6586X is not set
-# CONFIG_MFD_TPS65910 is not set
-# CONFIG_MFD_TPS65912_I2C is not set
-# CONFIG_MFD_TPS65912_SPI is not set
-# CONFIG_MFD_VX855 is not set
-# CONFIG_MFD_WL1273_CORE is not set
-# CONFIG_MFD_WM831X is not set
-# CONFIG_MFD_WM831X_I2C is not set
-# CONFIG_MFD_WM831X_SPI is not set
-# CONFIG_MFD_WM8350_I2C is not set
-# CONFIG_MFD_WM8400 is not set
-# CONFIG_MFD_WM8994 is not set
-# CONFIG_MG_DISK is not set
-# CONFIG_MICREL_KS8995MA is not set
-# CONFIG_MICREL_PHY is not set
-# CONFIG_MIGRATION is not set
-CONFIG_MII=y
-# CONFIG_MIKROTIK_RB532 is not set
-# CONFIG_MINIX_FS is not set
-# CONFIG_MINIX_FS_NATIVE_ENDIAN is not set
-# CONFIG_MINIX_SUBPARTITION is not set
-# CONFIG_MIPS_ALCHEMY is not set
-# CONFIG_MIPS_COBALT is not set
-# CONFIG_MIPS_FPU_EMU is not set
-# CONFIG_MIPS_MALTA is not set
-# CONFIG_MIPS_SIM is not set
-CONFIG_MISC_DEVICES=y
-CONFIG_MISC_FILESYSTEMS=y
-# CONFIG_MISDN is not set
-# CONFIG_MISDN_AVMFRITZ is not set
-# CONFIG_MISDN_HFCPCI is not set
-# CONFIG_MISDN_HFCUSB is not set
-# CONFIG_MISDN_INFINEON is not set
-# CONFIG_MISDN_NETJET is not set
-# CONFIG_MISDN_SPEEDFAX is not set
-# CONFIG_MISDN_W6692 is not set
-# CONFIG_MKISS is not set
-# CONFIG_MLX4_CORE is not set
-# CONFIG_MLX4_EN is not set
-# CONFIG_MMC is not set
-# CONFIG_MMC_ARMMMCI is not set
-# CONFIG_MMC_AU1X is not set
-# CONFIG_MMC_BLOCK is not set
-CONFIG_MMC_BLOCK_BOUNCE=y
-CONFIG_MMC_BLOCK_MINORS=8
-# CONFIG_MMC_CB710 is not set
-# CONFIG_MMC_CLKGATE is not set
-# CONFIG_MMC_DEBUG is not set
-# CONFIG_MMC_DW is not set
-# CONFIG_MMC_MVSDIO is not set
-# CONFIG_MMC_S3C is not set
-# CONFIG_MMC_SDHCI is not set
-# CONFIG_MMC_SDHCI_OF_ESDHC is not set
-# CONFIG_MMC_SDHCI_OF_HLWD is not set
-# CONFIG_MMC_SDHCI_PXAV2 is not set
-# CONFIG_MMC_SDHCI_PXAV3 is not set
-# CONFIG_MMC_SDRICOH_CS is not set
-# CONFIG_MMC_SPI is not set
-# CONFIG_MMC_TEST is not set
-# CONFIG_MMC_UNSAFE_RESUME is not set
-# CONFIG_MMC_USHC is not set
-# CONFIG_MMC_VIA_SDMMC is not set
-# CONFIG_MMC_VUB300 is not set
-CONFIG_MMU=y
-CONFIG_MODULES=y
-# CONFIG_MODULE_FORCE_LOAD is not set
-# CONFIG_MODULE_FORCE_UNLOAD is not set
-# CONFIG_MODULE_SRCVERSION_ALL is not set
-CONFIG_MODULE_UNLOAD=y
-# CONFIG_MODVERSIONS is not set
-# CONFIG_MOUSE_APPLETOUCH is not set
-# CONFIG_MOUSE_GPIO is not set
-# CONFIG_MOUSE_INPORT is not set
-# CONFIG_MOUSE_LOGIBM is not set
-# CONFIG_MOUSE_PC110PAD is not set
-# CONFIG_MOUSE_PS2_SENTELIC is not set
-# CONFIG_MOUSE_SYNAPTICS_I2C is not set
-# CONFIG_MSDOS_FS is not set
-CONFIG_MSDOS_PARTITION=y
-# CONFIG_MSI_BITMAP_SELFTEST is not set
-# CONFIG_MSI_LAPTOP is not set
-CONFIG_MTD=y
-# CONFIG_MTD_ABSENT is not set
-# CONFIG_MTD_AFS_PARTS is not set
-# CONFIG_MTD_ALAUDA is not set
-# CONFIG_MTD_AR7_PARTS is not set
-# CONFIG_MTD_ARM_INTEGRATOR is not set
-CONFIG_MTD_BLKDEVS=y
-CONFIG_MTD_BLOCK=y
-# CONFIG_MTD_BLOCK2MTD is not set
-CONFIG_MTD_CFI=y
-# CONFIG_MTD_CFI_ADV_OPTIONS is not set
-CONFIG_MTD_CFI_AMDSTD=y
-# CONFIG_MTD_CFI_BE_BYTE_SWAP is not set
-CONFIG_MTD_CFI_I1=y
-CONFIG_MTD_CFI_I2=y
-# CONFIG_MTD_CFI_I4 is not set
-# CONFIG_MTD_CFI_I8 is not set
-CONFIG_MTD_CFI_INTELEXT=y
-# CONFIG_MTD_CFI_LE_BYTE_SWAP is not set
-CONFIG_MTD_CFI_NOSWAP=y
-# CONFIG_MTD_CFI_STAA is not set
-CONFIG_MTD_CFI_UTIL=y
-CONFIG_MTD_CHAR=y
-# CONFIG_MTD_CMDLINE_PARTS is not set
-CONFIG_MTD_COMPLEX_MAPPINGS=y
-# CONFIG_MTD_DATAFLASH is not set
-# CONFIG_MTD_DEBUG is not set
-# CONFIG_MTD_DOC2000 is not set
-# CONFIG_MTD_DOC2001 is not set
-# CONFIG_MTD_DOC2001PLUS is not set
-# CONFIG_MTD_DOCG3 is not set
-CONFIG_MTD_GEN_PROBE=y
-# CONFIG_MTD_GPIO_ADDR is not set
-# CONFIG_MTD_INTEL_VR_NOR is not set
-# CONFIG_MTD_JEDECPROBE is not set
-# CONFIG_MTD_LATCH_ADDR is not set
-# CONFIG_MTD_LPDDR is not set
-# CONFIG_MTD_M25P80 is not set
-CONFIG_MTD_MAP_BANK_WIDTH_1=y
-# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
-CONFIG_MTD_MAP_BANK_WIDTH_2=y
-# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
-CONFIG_MTD_MAP_BANK_WIDTH_4=y
-# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
-# CONFIG_MTD_MTDRAM is not set
-# CONFIG_MTD_MYLOADER_PARTS is not set
-# CONFIG_MTD_NAND is not set
-# CONFIG_MTD_NAND_AMS_DELTA is not set
-# CONFIG_MTD_NAND_AR934X is not set
-# CONFIG_MTD_NAND_ATMEL is not set
-# CONFIG_MTD_NAND_AU1550 is not set
-# CONFIG_MTD_NAND_AUTCPU12 is not set
-# CONFIG_MTD_NAND_BCH is not set
-# CONFIG_MTD_NAND_BCM_UMI is not set
-# CONFIG_MTD_NAND_BF5XX is not set
-# CONFIG_MTD_NAND_CAFE is not set
-# CONFIG_MTD_NAND_CM_X270 is not set
-# CONFIG_MTD_NAND_CS553X is not set
-# CONFIG_MTD_NAND_DAVINCI is not set
-# CONFIG_MTD_NAND_DENALI is not set
-CONFIG_MTD_NAND_DENALI_SCRATCH_REG_ADDR=0xff108018
-# CONFIG_MTD_NAND_DISKONCHIP is not set
-# CONFIG_MTD_NAND_ECC is not set
-# CONFIG_MTD_NAND_ECC_BCH is not set
-# CONFIG_MTD_NAND_ECC_SMC is not set
-# CONFIG_MTD_NAND_FSL_ELBC is not set
-# CONFIG_MTD_NAND_FSL_UPM is not set
-# CONFIG_MTD_NAND_FSMC is not set
-# CONFIG_MTD_NAND_GPIO is not set
-# CONFIG_MTD_NAND_GPMI_NAND is not set
-# CONFIG_MTD_NAND_H1900 is not set
-CONFIG_MTD_NAND_IDS=y
-# CONFIG_MTD_NAND_JZ4740 is not set
-# CONFIG_MTD_NAND_MPC5121_NFC is not set
-# CONFIG_MTD_NAND_MUSEUM_IDS is not set
-# CONFIG_MTD_NAND_MXC is not set
-# CONFIG_MTD_NAND_NANDSIM is not set
-# CONFIG_MTD_NAND_NDFC is not set
-# CONFIG_MTD_NAND_NOMADIK is not set
-# CONFIG_MTD_NAND_NUC900 is not set
-# CONFIG_MTD_NAND_OMAP2 is not set
-# CONFIG_MTD_NAND_ORION is not set
-# CONFIG_MTD_NAND_PASEMI is not set
-# CONFIG_MTD_NAND_PLATFORM is not set
-# CONFIG_MTD_NAND_PPCHAMELEONEVB is not set
-# CONFIG_MTD_NAND_PXA3xx is not set
-# CONFIG_MTD_NAND_RB4XX is not set
-# CONFIG_MTD_NAND_RB750 is not set
-# CONFIG_MTD_NAND_RICOH is not set
-# CONFIG_MTD_NAND_RTC_FROM4 is not set
-# CONFIG_MTD_NAND_S3C2410 is not set
-# CONFIG_MTD_NAND_SHARPSL is not set
-# CONFIG_MTD_NAND_SH_FLCTL is not set
-# CONFIG_MTD_NAND_SOCRATES is not set
-# CONFIG_MTD_NAND_SPIA is not set
-# CONFIG_MTD_NAND_TMIO is not set
-# CONFIG_MTD_NAND_TXX9NDFMC is not set
-# CONFIG_MTD_NAND_VERIFY_WRITE is not set
-# CONFIG_MTD_ONENAND is not set
-# CONFIG_MTD_OOPS is not set
-# CONFIG_MTD_OTP is not set
-# CONFIG_MTD_PCI is not set
-# CONFIG_MTD_PCMCIA is not set
-# CONFIG_MTD_PHRAM is not set
-# CONFIG_MTD_PHYSMAP is not set
-# CONFIG_MTD_PHYSMAP_COMPAT is not set
-# CONFIG_MTD_PLATRAM is not set
-# CONFIG_MTD_PMC551 is not set
-# CONFIG_MTD_RAM is not set
-CONFIG_MTD_REDBOOT_DIRECTORY_BLOCK=-1
-# CONFIG_MTD_REDBOOT_PARTS is not set
-# CONFIG_MTD_REDBOOT_PARTS_READONLY is not set
-# CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED is not set
-# CONFIG_MTD_ROM is not set
-CONFIG_MTD_ROOTFS_ROOT_DEV=y
-CONFIG_MTD_ROOTFS_SPLIT=y
-# CONFIG_MTD_SLRAM is not set
-# CONFIG_MTD_SST25L is not set
-# CONFIG_MTD_SWAP is not set
-# CONFIG_MTD_TESTS is not set
-# CONFIG_MTD_UBI is not set
-# CONFIG_MUTEX_SPIN_ON_OWNER is not set
-# CONFIG_MV643XX_ETH is not set
-# CONFIG_MVSWITCH_PHY is not set
-# CONFIG_MWAVE is not set
-# CONFIG_MWL8K is not set
-# CONFIG_MYRI10GE is not set
-# CONFIG_NAMESPACES is not set
-# CONFIG_NATIONAL_PHY is not set
-# CONFIG_NATSEMI is not set
-# CONFIG_NCP_FS is not set
-# CONFIG_NE2000 is not set
-# CONFIG_NE2K_PCI is not set
-# CONFIG_NEC_MARKEINS is not set
-CONFIG_NET=y
-# CONFIG_NETCONSOLE is not set
-CONFIG_NETDEVICES=y
-CONFIG_NETDEV_1000=y
-# CONFIG_NETDEV_10000 is not set
-# CONFIG_NETFILTER is not set
-# CONFIG_NETFILTER_ADVANCED is not set
-# CONFIG_NETFILTER_DEBUG is not set
-# CONFIG_NETFILTER_NETLINK is not set
-# CONFIG_NETFILTER_NETLINK_ACCT is not set
-# CONFIG_NETFILTER_NETLINK_LOG is not set
-# CONFIG_NETFILTER_NETLINK_QUEUE is not set
-# CONFIG_NETFILTER_TPROXY is not set
-# CONFIG_NETFILTER_XTABLES is not set
-# CONFIG_NETFILTER_XT_CONNMARK is not set
-# CONFIG_NETFILTER_XT_MARK is not set
-# CONFIG_NETFILTER_XT_MATCH_ADDRTYPE is not set
-# CONFIG_NETFILTER_XT_MATCH_CLUSTER is not set
-# CONFIG_NETFILTER_XT_MATCH_COMMENT is not set
-# CONFIG_NETFILTER_XT_MATCH_CONNBYTES is not set
-# CONFIG_NETFILTER_XT_MATCH_CONNLIMIT is not set
-# CONFIG_NETFILTER_XT_MATCH_CONNMARK is not set
-# CONFIG_NETFILTER_XT_MATCH_CONNTRACK is not set
-# CONFIG_NETFILTER_XT_MATCH_CPU is not set
-# CONFIG_NETFILTER_XT_MATCH_DCCP is not set
-# CONFIG_NETFILTER_XT_MATCH_DEVGROUP is not set
-# CONFIG_NETFILTER_XT_MATCH_DSCP is not set
-# CONFIG_NETFILTER_XT_MATCH_ECN is not set
-# CONFIG_NETFILTER_XT_MATCH_ESP is not set
-# CONFIG_NETFILTER_XT_MATCH_HASHLIMIT is not set
-# CONFIG_NETFILTER_XT_MATCH_HELPER is not set
-# CONFIG_NETFILTER_XT_MATCH_HL is not set
-# CONFIG_NETFILTER_XT_MATCH_IPRANGE is not set
-# CONFIG_NETFILTER_XT_MATCH_LAYER7 is not set
-# CONFIG_NETFILTER_XT_MATCH_LAYER7_DEBUG is not set
-# CONFIG_NETFILTER_XT_MATCH_LENGTH is not set
-# CONFIG_NETFILTER_XT_MATCH_LIMIT is not set
-# CONFIG_NETFILTER_XT_MATCH_MAC is not set
-# CONFIG_NETFILTER_XT_MATCH_MARK is not set
-# CONFIG_NETFILTER_XT_MATCH_MULTIPORT is not set
-# CONFIG_NETFILTER_XT_MATCH_NFACCT is not set
-# CONFIG_NETFILTER_XT_MATCH_OSF is not set
-# CONFIG_NETFILTER_XT_MATCH_OWNER is not set
-# CONFIG_NETFILTER_XT_MATCH_PHYSDEV is not set
-# CONFIG_NETFILTER_XT_MATCH_PKTTYPE is not set
-# CONFIG_NETFILTER_XT_MATCH_POLICY is not set
-# CONFIG_NETFILTER_XT_MATCH_QUOTA is not set
-# CONFIG_NETFILTER_XT_MATCH_RATEEST is not set
-# CONFIG_NETFILTER_XT_MATCH_REALM is not set
-# CONFIG_NETFILTER_XT_MATCH_RECENT is not set
-# CONFIG_NETFILTER_XT_MATCH_SCTP is not set
-# CONFIG_NETFILTER_XT_MATCH_SOCKET is not set
-# CONFIG_NETFILTER_XT_MATCH_STATE is not set
-# CONFIG_NETFILTER_XT_MATCH_STATISTIC is not set
-# CONFIG_NETFILTER_XT_MATCH_STRING is not set
-# CONFIG_NETFILTER_XT_MATCH_TCPMSS is not set
-# CONFIG_NETFILTER_XT_MATCH_TIME is not set
-# CONFIG_NETFILTER_XT_MATCH_U32 is not set
-# CONFIG_NETFILTER_XT_TARGET_AUDIT is not set
-# CONFIG_NETFILTER_XT_TARGET_CHECKSUM is not set
-# CONFIG_NETFILTER_XT_TARGET_CLASSIFY is not set
-# CONFIG_NETFILTER_XT_TARGET_CONNMARK is not set
-# CONFIG_NETFILTER_XT_TARGET_CT is not set
-# CONFIG_NETFILTER_XT_TARGET_DSCP is not set
-# CONFIG_NETFILTER_XT_TARGET_HL is not set
-# CONFIG_NETFILTER_XT_TARGET_IDLETIMER is not set
-# CONFIG_NETFILTER_XT_TARGET_LED is not set
-# CONFIG_NETFILTER_XT_TARGET_MARK is not set
-# CONFIG_NETFILTER_XT_TARGET_NFLOG is not set
-# CONFIG_NETFILTER_XT_TARGET_NFQUEUE is not set
-# CONFIG_NETFILTER_XT_TARGET_NOTRACK is not set
-# CONFIG_NETFILTER_XT_TARGET_RATEEST is not set
-# CONFIG_NETFILTER_XT_TARGET_TCPMSS is not set
-# CONFIG_NETFILTER_XT_TARGET_TCPOPTSTRIP is not set
-# CONFIG_NETFILTER_XT_TARGET_TEE is not set
-# CONFIG_NETFILTER_XT_TARGET_TPROXY is not set
-# CONFIG_NETFILTER_XT_TARGET_TRACE is not set
-# CONFIG_NETPOLL is not set
-# CONFIG_NETROM is not set
-CONFIG_NETWORK_FILESYSTEMS=y
-# CONFIG_NETWORK_PHY_TIMESTAMPING is not set
-# CONFIG_NETWORK_SECMARK is not set
-# CONFIG_NETXEN_NIC is not set
-# CONFIG_NET_9P is not set
-# CONFIG_NET_ACT_CSUM is not set
-# CONFIG_NET_ACT_GACT is not set
-# CONFIG_NET_ACT_IPT is not set
-# CONFIG_NET_ACT_MIRRED is not set
-# CONFIG_NET_ACT_NAT is not set
-# CONFIG_NET_ACT_PEDIT is not set
-# CONFIG_NET_ACT_POLICE is not set
-# CONFIG_NET_ACT_SIMP is not set
-# CONFIG_NET_ACT_SKBEDIT is not set
-CONFIG_NET_CADENCE=y
-# CONFIG_NET_CALXEDA_XGMAC is not set
-CONFIG_NET_CLS=y
-# CONFIG_NET_CLS_ACT is not set
-# CONFIG_NET_CLS_BASIC is not set
-# CONFIG_NET_CLS_FLOW is not set
-# CONFIG_NET_CLS_FW is not set
-CONFIG_NET_CLS_IND=y
-# CONFIG_NET_CLS_ROUTE4 is not set
-# CONFIG_NET_CLS_RSVP is not set
-# CONFIG_NET_CLS_RSVP6 is not set
-# CONFIG_NET_CLS_TCINDEX is not set
-# CONFIG_NET_CLS_U32 is not set
-CONFIG_NET_CORE=y
-# CONFIG_NET_DROP_MONITOR is not set
-# CONFIG_NET_DSA is not set
-# CONFIG_NET_DSA_MV88E6123_61_65 is not set
-# CONFIG_NET_DSA_MV88E6131 is not set
-# CONFIG_NET_DSA_MV88E6XXX is not set
-# CONFIG_NET_DSA_MV88E6XXX_NEED_PPU is not set
-# CONFIG_NET_DSA_TAG_DSA is not set
-# CONFIG_NET_DSA_TAG_EDSA is not set
-# CONFIG_NET_EMATCH is not set
-# CONFIG_NET_EMATCH_CMP is not set
-# CONFIG_NET_EMATCH_META is not set
-# CONFIG_NET_EMATCH_NBYTE is not set
-CONFIG_NET_EMATCH_STACK=32
-# CONFIG_NET_EMATCH_TEXT is not set
-# CONFIG_NET_EMATCH_U32 is not set
-CONFIG_NET_ETHERNET=y
-# CONFIG_NET_FC is not set
-# CONFIG_NET_IPGRE is not set
-CONFIG_NET_IPGRE_BROADCAST=y
-# CONFIG_NET_IPGRE_DEMUX is not set
-# CONFIG_NET_IPIP is not set
-# CONFIG_NET_ISA is not set
-# CONFIG_NET_KEY is not set
-# CONFIG_NET_KEY_MIGRATE is not set
-# CONFIG_NET_PACKET_ENGINE is not set
-CONFIG_NET_PCI=y
-# CONFIG_NET_PCMCIA is not set
-# CONFIG_NET_PKTGEN is not set
-# CONFIG_NET_POCKET is not set
-# CONFIG_NET_POLL_CONTROLLER is not set
-# CONFIG_NET_SB1000 is not set
-CONFIG_NET_SCHED=y
-# CONFIG_NET_SCH_ATM is not set
-# CONFIG_NET_SCH_CBQ is not set
-# CONFIG_NET_SCH_CHOKE is not set
-# CONFIG_NET_SCH_CODEL is not set
-# CONFIG_NET_SCH_DRR is not set
-# CONFIG_NET_SCH_DSMARK is not set
-# CONFIG_NET_SCH_ESFQ is not set
-CONFIG_NET_SCH_ESFQ_NFCT=y
-CONFIG_NET_SCH_FIFO=y
-# CONFIG_NET_SCH_FQ_CODEL is not set
-# CONFIG_NET_SCH_GRED is not set
-# CONFIG_NET_SCH_HFSC is not set
-# CONFIG_NET_SCH_HTB is not set
-# CONFIG_NET_SCH_INGRESS is not set
-# CONFIG_NET_SCH_MQPRIO is not set
-# CONFIG_NET_SCH_MULTIQ is not set
-# CONFIG_NET_SCH_NETEM is not set
-# CONFIG_NET_SCH_PRIO is not set
-# CONFIG_NET_SCH_QFQ is not set
-# CONFIG_NET_SCH_RED is not set
-# CONFIG_NET_SCH_SFB is not set
-# CONFIG_NET_SCH_SFQ is not set
-# CONFIG_NET_SCH_TBF is not set
-# CONFIG_NET_SCH_TEQL is not set
-# CONFIG_NET_TEAM is not set
-# CONFIG_NET_TULIP is not set
-CONFIG_NET_VENDOR_3COM=y
-CONFIG_NET_VENDOR_8390=y
-CONFIG_NET_VENDOR_ADAPTEC=y
-CONFIG_NET_VENDOR_ALTEON=y
-CONFIG_NET_VENDOR_AMD=y
-CONFIG_NET_VENDOR_ATHEROS=y
-CONFIG_NET_VENDOR_BROADCOM=y
-CONFIG_NET_VENDOR_BROCADE=y
-CONFIG_NET_VENDOR_CHELSIO=y
-CONFIG_NET_VENDOR_CIRRUS=y
-CONFIG_NET_VENDOR_CISCO=y
-CONFIG_NET_VENDOR_DEC=y
-CONFIG_NET_VENDOR_DLINK=y
-CONFIG_NET_VENDOR_EMULEX=y
-CONFIG_NET_VENDOR_EXAR=y
-CONFIG_NET_VENDOR_FARADAY=y
-CONFIG_NET_VENDOR_FREESCALE=y
-CONFIG_NET_VENDOR_FUJITSU=y
-CONFIG_NET_VENDOR_HP=y
-CONFIG_NET_VENDOR_I825XX=y
-CONFIG_NET_VENDOR_IBM=y
-CONFIG_NET_VENDOR_INTEL=y
-CONFIG_NET_VENDOR_MARVELL=y
-CONFIG_NET_VENDOR_MELLANOX=y
-CONFIG_NET_VENDOR_MICREL=y
-CONFIG_NET_VENDOR_MICROCHIP=y
-CONFIG_NET_VENDOR_MYRI=y
-CONFIG_NET_VENDOR_NATSEMI=y
-CONFIG_NET_VENDOR_NVIDIA=y
-CONFIG_NET_VENDOR_OKI=y
-CONFIG_NET_VENDOR_QLOGIC=y
-CONFIG_NET_VENDOR_RDC=y
-CONFIG_NET_VENDOR_REALTEK=y
-CONFIG_NET_VENDOR_SEEQ=y
-CONFIG_NET_VENDOR_SILAN=y
-CONFIG_NET_VENDOR_SIS=y
-CONFIG_NET_VENDOR_SMSC=y
-CONFIG_NET_VENDOR_STMICRO=y
-CONFIG_NET_VENDOR_SUN=y
-CONFIG_NET_VENDOR_TEHUTI=y
-CONFIG_NET_VENDOR_TI=y
-CONFIG_NET_VENDOR_TOSHIBA=y
-CONFIG_NET_VENDOR_VIA=y
-CONFIG_NET_VENDOR_XILINX=y
-CONFIG_NET_VENDOR_XIRCOM=y
-CONFIG_NEW_LEDS=y
-# CONFIG_NFC is not set
-# CONFIG_NFC_DEVICES is not set
-# CONFIG_NFSD is not set
-# CONFIG_NFSD_DEPRECATED is not set
-# CONFIG_NFSD_V2_ACL is not set
-CONFIG_NFSD_V3=y
-# CONFIG_NFSD_V3_ACL is not set
-# CONFIG_NFSD_V4 is not set
-# CONFIG_NFS_ACL_SUPPORT is not set
-CONFIG_NFS_COMMON=y
-# CONFIG_NFS_FS is not set
-# CONFIG_NFS_FSCACHE is not set
-CONFIG_NFS_V3=y
-# CONFIG_NFS_V3_ACL is not set
-# CONFIG_NFS_V4 is not set
-# CONFIG_NFS_V4_1 is not set
-# CONFIG_NFTL is not set
-# CONFIG_NF_CONNTRACK is not set
-# CONFIG_NF_CONNTRACK_AMANDA is not set
-# CONFIG_NF_CONNTRACK_EVENTS is not set
-# CONFIG_NF_CONNTRACK_FTP is not set
-# CONFIG_NF_CONNTRACK_H323 is not set
-# CONFIG_NF_CONNTRACK_IPV4 is not set
-# CONFIG_NF_CONNTRACK_IPV6 is not set
-# CONFIG_NF_CONNTRACK_IRC is not set
-# CONFIG_NF_CONNTRACK_MARK is not set
-# CONFIG_NF_CONNTRACK_NETBIOS_NS is not set
-# CONFIG_NF_CONNTRACK_PPTP is not set
-CONFIG_NF_CONNTRACK_PROCFS=y
-# CONFIG_NF_CONNTRACK_PROC_COMPAT is not set
-# CONFIG_NF_CONNTRACK_RTSP is not set
-# CONFIG_NF_CONNTRACK_SANE is not set
-# CONFIG_NF_CONNTRACK_SIP is not set
-# CONFIG_NF_CONNTRACK_SNMP is not set
-# CONFIG_NF_CONNTRACK_TFTP is not set
-# CONFIG_NF_CONNTRACK_TIMESTAMP is not set
-# CONFIG_NF_CONNTRACK_ZONES is not set
-# CONFIG_NF_CT_NETLINK is not set
-# CONFIG_NF_CT_PROTO_DCCP is not set
-# CONFIG_NF_CT_PROTO_GRE is not set
-# CONFIG_NF_CT_PROTO_SCTP is not set
-# CONFIG_NF_CT_PROTO_UDPLITE is not set
-# CONFIG_NF_DEFRAG_IPV4 is not set
-# CONFIG_NF_NAT is not set
-# CONFIG_NF_NAT_AMANDA is not set
-# CONFIG_NF_NAT_FTP is not set
-# CONFIG_NF_NAT_H323 is not set
-# CONFIG_NF_NAT_IRC is not set
-# CONFIG_NF_NAT_NEEDED is not set
-# CONFIG_NF_NAT_PPTP is not set
-# CONFIG_NF_NAT_PROTO_GRE is not set
-# CONFIG_NF_NAT_RTSP is not set
-# CONFIG_NF_NAT_SIP is not set
-# CONFIG_NF_NAT_SNMP_BASIC is not set
-# CONFIG_NF_NAT_TFTP is not set
-# CONFIG_NI52 is not set
-# CONFIG_NI65 is not set
-# CONFIG_NILFS2_FS is not set
-# CONFIG_NIU is not set
-CONFIG_NLATTR=y
-# CONFIG_NLM_XLP_BOARD is not set
-# CONFIG_NLM_XLR_BOARD is not set
-# CONFIG_NLS is not set
-# CONFIG_NLS_ASCII is not set
-# CONFIG_NLS_CODEPAGE_1250 is not set
-# CONFIG_NLS_CODEPAGE_1251 is not set
-# CONFIG_NLS_CODEPAGE_437 is not set
-# CONFIG_NLS_CODEPAGE_737 is not set
-# CONFIG_NLS_CODEPAGE_775 is not set
-# CONFIG_NLS_CODEPAGE_850 is not set
-# CONFIG_NLS_CODEPAGE_852 is not set
-# CONFIG_NLS_CODEPAGE_855 is not set
-# CONFIG_NLS_CODEPAGE_857 is not set
-# CONFIG_NLS_CODEPAGE_860 is not set
-# CONFIG_NLS_CODEPAGE_861 is not set
-# CONFIG_NLS_CODEPAGE_862 is not set
-# CONFIG_NLS_CODEPAGE_863 is not set
-# CONFIG_NLS_CODEPAGE_864 is not set
-# CONFIG_NLS_CODEPAGE_865 is not set
-# CONFIG_NLS_CODEPAGE_866 is not set
-# CONFIG_NLS_CODEPAGE_869 is not set
-# CONFIG_NLS_CODEPAGE_874 is not set
-# CONFIG_NLS_CODEPAGE_932 is not set
-# CONFIG_NLS_CODEPAGE_936 is not set
-# CONFIG_NLS_CODEPAGE_949 is not set
-# CONFIG_NLS_CODEPAGE_950 is not set
-CONFIG_NLS_DEFAULT="iso8859-1"
-# CONFIG_NLS_ISO8859_1 is not set
-# CONFIG_NLS_ISO8859_13 is not set
-# CONFIG_NLS_ISO8859_14 is not set
-# CONFIG_NLS_ISO8859_15 is not set
-# CONFIG_NLS_ISO8859_2 is not set
-# CONFIG_NLS_ISO8859_3 is not set
-# CONFIG_NLS_ISO8859_4 is not set
-# CONFIG_NLS_ISO8859_5 is not set
-# CONFIG_NLS_ISO8859_6 is not set
-# CONFIG_NLS_ISO8859_7 is not set
-# CONFIG_NLS_ISO8859_8 is not set
-# CONFIG_NLS_ISO8859_9 is not set
-# CONFIG_NLS_KOI8_R is not set
-# CONFIG_NLS_KOI8_U is not set
-# CONFIG_NLS_UTF8 is not set
-# CONFIG_NOP_USB_XCEIV is not set
-# CONFIG_NORTEL_HERMES is not set
-# CONFIG_NOZOMI is not set
-# CONFIG_NO_BOOTMEM is not set
-# CONFIG_NO_HZ is not set
-# CONFIG_NO_IOPORT is not set
-# CONFIG_NS83820 is not set
-# CONFIG_NTFS_DEBUG is not set
-# CONFIG_NTFS_FS is not set
-# CONFIG_NTFS_RW is not set
-# CONFIG_NTP_PPS is not set
-# CONFIG_NVRAM is not set
-# CONFIG_NV_TCO is not set
-# CONFIG_NXP_STB220 is not set
-# CONFIG_NXP_STB225 is not set
-# CONFIG_N_GSM is not set
-# CONFIG_OABI_COMPAT is not set
-# CONFIG_OBS600 is not set
-# CONFIG_OCFS2_FS is not set
-# CONFIG_OCF_BENCH is not set
-# CONFIG_OCF_C7108 is not set
-# CONFIG_OCF_CRYPTOCTEON is not set
-# CONFIG_OCF_EP80579 is not set
-# CONFIG_OCF_HIFN is not set
-# CONFIG_OCF_HIFNHIPP is not set
-# CONFIG_OCF_IXP4XX is not set
-# CONFIG_OCF_KIRKWOOD is not set
-# CONFIG_OCF_OCF is not set
-# CONFIG_OCF_OCFNULL is not set
-# CONFIG_OCF_SAFE is not set
-# CONFIG_OCF_TALITOS is not set
-# CONFIG_OCF_UBSEC_SSB is not set
-# CONFIG_OC_ETM is not set
-# CONFIG_OF_SELFTEST is not set
-# CONFIG_OMFS_FS is not set
-# CONFIG_OPENVSWITCH is not set
-# CONFIG_ORION_WATCHDOG is not set
-# CONFIG_OSF_PARTITION is not set
-CONFIG_OVERLAYFS_FS=y
-# CONFIG_P54_COMMON is not set
-CONFIG_PACKET=y
-# CONFIG_PAGE_POISONING is not set
-# CONFIG_PAGE_SIZE_16KB is not set
-# CONFIG_PAGE_SIZE_32KB is not set
-CONFIG_PAGE_SIZE_4KB=y
-# CONFIG_PAGE_SIZE_64KB is not set
-# CONFIG_PAGE_SIZE_8KB is not set
-# CONFIG_PANEL is not set
-# CONFIG_PANTHERLORD_FF is not set
-# CONFIG_PARPORT is not set
-# CONFIG_PARPORT_1284 is not set
-# CONFIG_PARPORT_AX88796 is not set
-# CONFIG_PARPORT_PC is not set
-CONFIG_PARTITION_ADVANCED=y
-# CONFIG_PATA_ALI is not set
-# CONFIG_PATA_AMD is not set
-# CONFIG_PATA_ARASAN_CF is not set
-# CONFIG_PATA_ARTOP is not set
-# CONFIG_PATA_ATIIXP is not set
-# CONFIG_PATA_ATP867X is not set
-# CONFIG_PATA_CMD640_PCI is not set
-# CONFIG_PATA_CMD64X is not set
-# CONFIG_PATA_CS5520 is not set
-# CONFIG_PATA_CS5530 is not set
-# CONFIG_PATA_CS5535 is not set
-# CONFIG_PATA_CS5536 is not set
-# CONFIG_PATA_CYPRESS is not set
-# CONFIG_PATA_EFAR is not set
-# CONFIG_PATA_HPT366 is not set
-# CONFIG_PATA_HPT37X is not set
-# CONFIG_PATA_HPT3X2N is not set
-# CONFIG_PATA_HPT3X3 is not set
-# CONFIG_PATA_ISAPNP is not set
-# CONFIG_PATA_IT8213 is not set
-# CONFIG_PATA_IT821X is not set
-# CONFIG_PATA_JMICRON is not set
-# CONFIG_PATA_LEGACY is not set
-# CONFIG_PATA_MARVELL is not set
-# CONFIG_PATA_MPIIX is not set
-# CONFIG_PATA_NETCELL is not set
-# CONFIG_PATA_NINJA32 is not set
-# CONFIG_PATA_NS87410 is not set
-# CONFIG_PATA_NS87415 is not set
-# CONFIG_PATA_OLDPIIX is not set
-# CONFIG_PATA_OPTI is not set
-# CONFIG_PATA_OPTIDMA is not set
-# CONFIG_PATA_PCMCIA is not set
-# CONFIG_PATA_PDC2027X is not set
-# CONFIG_PATA_PDC_OLD is not set
-# CONFIG_PATA_PLATFORM is not set
-# CONFIG_PATA_QDI is not set
-# CONFIG_PATA_RADISYS is not set
-# CONFIG_PATA_RDC is not set
-# CONFIG_PATA_RZ1000 is not set
-# CONFIG_PATA_SC1200 is not set
-# CONFIG_PATA_SCH is not set
-# CONFIG_PATA_SERVERWORKS is not set
-# CONFIG_PATA_SIL680 is not set
-# CONFIG_PATA_SIS is not set
-# CONFIG_PATA_TOSHIBA is not set
-# CONFIG_PATA_TRIFLEX is not set
-# CONFIG_PATA_VIA is not set
-# CONFIG_PATA_WINBOND is not set
-# CONFIG_PATA_WINBOND_VLB is not set
-# CONFIG_PC300TOO is not set
-# CONFIG_PCCARD is not set
-# CONFIG_PCH_GBE is not set
-# CONFIG_PCH_PHUB is not set
-# CONFIG_PCI200SYN is not set
-# CONFIG_PCIEAER_INJECT is not set
-# CONFIG_PCIEASPM is not set
-# CONFIG_PCIE_ECRC is not set
-# CONFIG_PCIPCWATCHDOG is not set
-# CONFIG_PCI_ATMEL is not set
-# CONFIG_PCI_CNB20LE_QUIRK is not set
-# CONFIG_PCI_DEBUG is not set
-# CONFIG_PCI_DISABLE_COMMON_QUIRKS is not set
-# CONFIG_PCI_HERMES is not set
-# CONFIG_PCI_IOV is not set
-# CONFIG_PCI_MSI is not set
-# CONFIG_PCI_PASID is not set
-# CONFIG_PCI_PRI is not set
-CONFIG_PCI_QUIRKS=y
-# CONFIG_PCI_STUB is not set
-CONFIG_PCI_SYSCALL=y
-# CONFIG_PCMCIA is not set
-# CONFIG_PCMCIA_3C574 is not set
-# CONFIG_PCMCIA_3C589 is not set
-# CONFIG_PCMCIA_AHA152X is not set
-# CONFIG_PCMCIA_ATMEL is not set
-# CONFIG_PCMCIA_AXNET is not set
-# CONFIG_PCMCIA_DEBUG is not set
-# CONFIG_PCMCIA_FDOMAIN is not set
-# CONFIG_PCMCIA_FMVJ18X is not set
-# CONFIG_PCMCIA_HERMES is not set
-# CONFIG_PCMCIA_LOAD_CIS is not set
-# CONFIG_PCMCIA_NINJA_SCSI is not set
-# CONFIG_PCMCIA_NMCLAN is not set
-# CONFIG_PCMCIA_PCNET is not set
-# CONFIG_PCMCIA_QLOGIC is not set
-# CONFIG_PCMCIA_RAYCS is not set
-# CONFIG_PCMCIA_SMC91C92 is not set
-# CONFIG_PCMCIA_SPECTRUM is not set
-# CONFIG_PCMCIA_SYM53C500 is not set
-# CONFIG_PCMCIA_WL3501 is not set
-# CONFIG_PCMCIA_XIRC2PS is not set
-# CONFIG_PCMCIA_XIRCOM is not set
-# CONFIG_PCNET32 is not set
-# CONFIG_PCSPKR_PLATFORM is not set
-# CONFIG_PD6729 is not set
-# CONFIG_PDC_ADMA is not set
-# CONFIG_PERF_COUNTERS is not set
-# CONFIG_PERF_EVENTS is not set
-# CONFIG_PHANTOM is not set
-# CONFIG_PHONE is not set
-# CONFIG_PHONET is not set
-# CONFIG_PHYLIB is not set
-# CONFIG_PHYS_ADDR_T_64BIT is not set
-# CONFIG_PID_NS is not set
-# CONFIG_PINCTRL is not set
-# CONFIG_PLAT_SPEAR is not set
-# CONFIG_PLIP is not set
-# CONFIG_PLX_HERMES is not set
-# CONFIG_PM is not set
-# CONFIG_PMBUS is not set
-# CONFIG_PMC_MSP is not set
-# CONFIG_PMC_YOSEMITE is not set
-# CONFIG_PMIC_ADP5520 is not set
-# CONFIG_PMIC_DA903X is not set
-# CONFIG_PM_DEVFREQ is not set
-# CONFIG_PM_RUNTIME is not set
-# CONFIG_PNX8550_JBS is not set
-# CONFIG_PNX8550_STB810 is not set
-# CONFIG_POHMELFS is not set
-# CONFIG_POSIX_MQUEUE is not set
-# CONFIG_POWERTV is not set
-# CONFIG_POWER_SUPPLY is not set
-# CONFIG_POWER_SUPPLY_DEBUG is not set
-# CONFIG_PPC4xx_GPIO is not set
-# CONFIG_PPC_16K_PAGES is not set
-# CONFIG_PPC_256K_PAGES is not set
-CONFIG_PPC_4K_PAGES=y
-# CONFIG_PPC_64K_PAGES is not set
-# CONFIG_PPC_DISABLE_WERROR is not set
-# CONFIG_PPC_EMULATED_STATS is not set
-# CONFIG_PPC_EPAPR_HV_BYTECHAN is not set
-# CONFIG_PPP is not set
-# CONFIG_PPPOATM is not set
-# CONFIG_PPPOE is not set
-# CONFIG_PPPOL2TP is not set
-# CONFIG_PPP_ASYNC is not set
-# CONFIG_PPP_BSDCOMP is not set
-# CONFIG_PPP_DEFLATE is not set
-CONFIG_PPP_FILTER=y
-# CONFIG_PPP_MPPE is not set
-CONFIG_PPP_MULTILINK=y
-# CONFIG_PPP_SYNC_TTY is not set
-# CONFIG_PPS is not set
-# CONFIG_PPS_CLIENT_GPIO is not set
-# CONFIG_PPS_CLIENT_KTIMER is not set
-# CONFIG_PPS_CLIENT_LDISC is not set
-# CONFIG_PPS_CLIENT_PARPORT is not set
-# CONFIG_PPS_DEBUG is not set
-# CONFIG_PPTP is not set
-# CONFIG_PREEMPT is not set
-CONFIG_PREEMPT_NONE=y
-# CONFIG_PREEMPT_VOLUNTARY is not set
-CONFIG_PREVENT_FIRMWARE_BUILD=y
-CONFIG_PRINTK=y
-# CONFIG_PRINTK_TIME is not set
-CONFIG_PRINT_STACK_DEPTH=64
-# CONFIG_PRISM2_USB is not set
-# CONFIG_PRISM54 is not set
-# CONFIG_PROBE_INITRD_HEADER is not set
-CONFIG_PROC_FS=y
-# CONFIG_PROC_KCORE is not set
-# CONFIG_PROC_PAGE_MONITOR is not set
-CONFIG_PROC_SYSCTL=y
-# CONFIG_PROFILE_ALL_BRANCHES is not set
-# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set
-# CONFIG_PROFILING is not set
-# CONFIG_PROVE_LOCKING is not set
-# CONFIG_PROVE_RCU is not set
-# CONFIG_PSB6970_PHY is not set
-# CONFIG_PSTORE is not set
-# CONFIG_PTP_1588_CLOCK_IXP46X is not set
-# CONFIG_QLA3XXX is not set
-# CONFIG_QLCNIC is not set
-# CONFIG_QLGE is not set
-# CONFIG_QNX4FS_FS is not set
-# CONFIG_QSEMI_PHY is not set
-# CONFIG_QUOTA is not set
-# CONFIG_QUOTACTL is not set
-# CONFIG_QUOTA_DEBUG is not set
-# CONFIG_R3964 is not set
-# CONFIG_R6040 is not set
-# CONFIG_R8169 is not set
-# CONFIG_R8187SE is not set
-# CONFIG_R8712U is not set
-# CONFIG_RADIO_ADAPTERS is not set
-# CONFIG_RADIO_AZTECH is not set
-# CONFIG_RADIO_CADET is not set
-# CONFIG_RADIO_GEMTEK is not set
-# CONFIG_RADIO_MAXIRADIO is not set
-# CONFIG_RADIO_RTRACK is not set
-# CONFIG_RADIO_RTRACK2 is not set
-# CONFIG_RADIO_SF16FMI is not set
-# CONFIG_RADIO_SF16FMR2 is not set
-# CONFIG_RADIO_TERRATEC is not set
-# CONFIG_RADIO_TRUST is not set
-# CONFIG_RADIO_TYPHOON is not set
-# CONFIG_RADIO_ZOLTRIX is not set
-# CONFIG_RAID_ATTRS is not set
-# CONFIG_RAMOOPS is not set
-# CONFIG_RAPIDIO is not set
-# CONFIG_RAR_REGISTER is not set
-# CONFIG_RAW_DRIVER is not set
-CONFIG_RCU_CPU_STALL_TIMEOUT=60
-CONFIG_RCU_FANOUT=32
-# CONFIG_RCU_FANOUT_EXACT is not set
-# CONFIG_RCU_FAST_NO_HZ is not set
-# CONFIG_RCU_TORTURE_TEST is not set
-# CONFIG_RCU_TRACE is not set
-# CONFIG_RC_CORE is not set
-# CONFIG_RC_MAP is not set
-# CONFIG_RDS is not set
-# CONFIG_RD_BZIP2 is not set
-# CONFIG_RD_GZIP is not set
-# CONFIG_RD_LZMA is not set
-# CONFIG_RD_LZO is not set
-# CONFIG_RD_XZ is not set
-# CONFIG_REALTEK_PHY is not set
-# CONFIG_REDWOOD is not set
-# CONFIG_REGMAP is not set
-# CONFIG_REGMAP_I2C is not set
-# CONFIG_REGMAP_SPI is not set
-# CONFIG_REGULATOR is not set
-# CONFIG_REGULATOR_BQ24022 is not set
-# CONFIG_REGULATOR_FIXED_VOLTAGE is not set
-# CONFIG_REGULATOR_GPIO is not set
-# CONFIG_REGULATOR_VIRTUAL_CONSUMER is not set
-# CONFIG_REISERFS_CHECK is not set
-# CONFIG_REISERFS_FS is not set
-# CONFIG_REISERFS_FS_POSIX_ACL is not set
-# CONFIG_REISERFS_FS_SECURITY is not set
-# CONFIG_REISERFS_FS_XATTR is not set
-# CONFIG_REISERFS_PROC_INFO is not set
-# CONFIG_RELAY is not set
-# CONFIG_RFD_FTL is not set
-# CONFIG_RFKILL is not set
-# CONFIG_RFKILL_INPUT is not set
-# CONFIG_RING_BUFFER_BENCHMARK is not set
-# CONFIG_ROMFS_FS is not set
-# CONFIG_ROSE is not set
-# CONFIG_RPCSEC_GSS_KRB5 is not set
-# CONFIG_RT2X00 is not set
-# CONFIG_RTC_CLASS is not set
-# CONFIG_RTC_DEBUG is not set
-# CONFIG_RTC_DRV_AU1XXX is not set
-# CONFIG_RTC_DRV_BQ32K is not set
-# CONFIG_RTC_DRV_BQ4802 is not set
-CONFIG_RTC_DRV_CMOS=y
-# CONFIG_RTC_DRV_DS1286 is not set
-# CONFIG_RTC_DRV_DS1305 is not set
-# CONFIG_RTC_DRV_DS1307 is not set
-# CONFIG_RTC_DRV_DS1374 is not set
-# CONFIG_RTC_DRV_DS1390 is not set
-# CONFIG_RTC_DRV_DS1511 is not set
-# CONFIG_RTC_DRV_DS1553 is not set
-# CONFIG_RTC_DRV_DS1672 is not set
-# CONFIG_RTC_DRV_DS1742 is not set
-# CONFIG_RTC_DRV_DS3232 is not set
-# CONFIG_RTC_DRV_DS3234 is not set
-# CONFIG_RTC_DRV_EM3027 is not set
-# CONFIG_RTC_DRV_EP93XX is not set
-# CONFIG_RTC_DRV_FM3130 is not set
-# CONFIG_RTC_DRV_GENERIC is not set
-# CONFIG_RTC_DRV_ISL12022 is not set
-# CONFIG_RTC_DRV_ISL1208 is not set
-# CONFIG_RTC_DRV_M41T80 is not set
-# CONFIG_RTC_DRV_M41T93 is not set
-# CONFIG_RTC_DRV_M41T94 is not set
-# CONFIG_RTC_DRV_M48T35 is not set
-# CONFIG_RTC_DRV_M48T59 is not set
-# CONFIG_RTC_DRV_M48T86 is not set
-# CONFIG_RTC_DRV_MAX6900 is not set
-# CONFIG_RTC_DRV_MAX6902 is not set
-# CONFIG_RTC_DRV_MPC5121 is not set
-# CONFIG_RTC_DRV_MSM6242 is not set
-# CONFIG_RTC_DRV_PCF2123 is not set
-# CONFIG_RTC_DRV_PCF8563 is not set
-# CONFIG_RTC_DRV_PCF8583 is not set
-# CONFIG_RTC_DRV_PL030 is not set
-# CONFIG_RTC_DRV_PL031 is not set
-# CONFIG_RTC_DRV_PS3 is not set
-# CONFIG_RTC_DRV_PT7C4338 is not set
-# CONFIG_RTC_DRV_R9701 is not set
-# CONFIG_RTC_DRV_RP5C01 is not set
-# CONFIG_RTC_DRV_RS5C348 is not set
-# CONFIG_RTC_DRV_RS5C372 is not set
-# CONFIG_RTC_DRV_RTC7301 is not set
-# CONFIG_RTC_DRV_RV3029C2 is not set
-# CONFIG_RTC_DRV_RX8025 is not set
-# CONFIG_RTC_DRV_RX8581 is not set
-# CONFIG_RTC_DRV_S35390A is not set
-# CONFIG_RTC_DRV_STK17TA8 is not set
-# CONFIG_RTC_DRV_TEST is not set
-# CONFIG_RTC_DRV_V3020 is not set
-# CONFIG_RTC_DRV_X1205 is not set
-CONFIG_RTC_HCTOSYS=y
-CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
-CONFIG_RTC_INTF_DEV=y
-# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
-CONFIG_RTC_INTF_PROC=y
-CONFIG_RTC_INTF_SYSFS=y
-CONFIG_RTC_LIB=y
-# CONFIG_RTL8180 is not set
-# CONFIG_RTL8187 is not set
-# CONFIG_RTL8192E is not set
-# CONFIG_RTL8192U is not set
-# CONFIG_RTL8306_PHY is not set
-# CONFIG_RTL8366RB_PHY is not set
-# CONFIG_RTL8366S_PHY is not set
-# CONFIG_RTL8366_SMI is not set
-# CONFIG_RTL8366_SMI_DEBUG_FS is not set
-# CONFIG_RTL8367B_PHY is not set
-# CONFIG_RTL8367_PHY is not set
-# CONFIG_RTLLIB is not set
-# CONFIG_RTS5139 is not set
-# CONFIG_RTS_PSTOR is not set
-CONFIG_RT_MUTEXES=y
-# CONFIG_RT_MUTEX_TESTER is not set
-# CONFIG_RUNTIME_DEBUG is not set
-CONFIG_RWSEM_GENERIC_SPINLOCK=y
-# CONFIG_S2IO is not set
-# CONFIG_SAMPLES is not set
-# CONFIG_SAMSUNG_LAPTOP is not set
-# CONFIG_SATA_ACARD_AHCI is not set
-# CONFIG_SATA_AHCI is not set
-# CONFIG_SATA_AHCI_PLATFORM is not set
-# CONFIG_SATA_DWC is not set
-# CONFIG_SATA_FSL is not set
-# CONFIG_SATA_INIC162X is not set
-# CONFIG_SATA_MV is not set
-# CONFIG_SATA_NV is not set
-# CONFIG_SATA_PMP is not set
-# CONFIG_SATA_PROMISE is not set
-# CONFIG_SATA_QSTOR is not set
-# CONFIG_SATA_SIL is not set
-# CONFIG_SATA_SIL24 is not set
-# CONFIG_SATA_SIS is not set
-# CONFIG_SATA_SVW is not set
-# CONFIG_SATA_SX4 is not set
-# CONFIG_SATA_ULI is not set
-# CONFIG_SATA_VIA is not set
-# CONFIG_SATA_VITESSE is not set
-# CONFIG_SBC_FITPC2_WATCHDOG is not set
-# CONFIG_SBE_2T3E3 is not set
-# CONFIG_SC92031 is not set
-# CONFIG_SCC is not set
-# CONFIG_SCHEDSTATS is not set
-# CONFIG_SCHED_AUTOGROUP is not set
-# CONFIG_SCHED_DEBUG is not set
-# CONFIG_SCHED_MC is not set
-CONFIG_SCHED_OMIT_FRAME_POINTER=y
-# CONFIG_SCHED_SMT is not set
-# CONFIG_SCHED_TRACER is not set
-# CONFIG_SCSI is not set
-# CONFIG_SCSI_3W_9XXX is not set
-# CONFIG_SCSI_3W_SAS is not set
-# CONFIG_SCSI_7000FASST is not set
-# CONFIG_SCSI_AACRAID is not set
-# CONFIG_SCSI_ACARD is not set
-# CONFIG_SCSI_ADVANSYS is not set
-# CONFIG_SCSI_AHA152X is not set
-# CONFIG_SCSI_AHA1542 is not set
-# CONFIG_SCSI_AIC79XX is not set
-# CONFIG_SCSI_AIC7XXX is not set
-# CONFIG_SCSI_AIC7XXX_OLD is not set
-# CONFIG_SCSI_AIC94XX is not set
-# CONFIG_SCSI_ARCMSR is not set
-# CONFIG_SCSI_BFA_FC is not set
-# CONFIG_SCSI_BNX2X_FCOE is not set
-# CONFIG_SCSI_BNX2_ISCSI is not set
-# CONFIG_SCSI_BUSLOGIC is not set
-# CONFIG_SCSI_CONSTANTS is not set
-# CONFIG_SCSI_CXGB3_ISCSI is not set
-# CONFIG_SCSI_CXGB4_ISCSI is not set
-# CONFIG_SCSI_DC390T is not set
-# CONFIG_SCSI_DC395x is not set
-# CONFIG_SCSI_DEBUG is not set
-# CONFIG_SCSI_DH is not set
-CONFIG_SCSI_DMA=y
-# CONFIG_SCSI_DMX3191D is not set
-# CONFIG_SCSI_DPT_I2O is not set
-# CONFIG_SCSI_DTC3280 is not set
-# CONFIG_SCSI_EATA is not set
-# CONFIG_SCSI_FC_ATTRS is not set
-# CONFIG_SCSI_FUTURE_DOMAIN is not set
-# CONFIG_SCSI_GDTH is not set
-# CONFIG_SCSI_GENERIC_NCR5380 is not set
-# CONFIG_SCSI_GENERIC_NCR5380_MMIO is not set
-# CONFIG_SCSI_HPSA is not set
-# CONFIG_SCSI_HPTIOP is not set
-# CONFIG_SCSI_IN2000 is not set
-# CONFIG_SCSI_INIA100 is not set
-# CONFIG_SCSI_INITIO is not set
-# CONFIG_SCSI_IPR is not set
-# CONFIG_SCSI_IPS is not set
-# CONFIG_SCSI_ISCI is not set
-# CONFIG_SCSI_ISCSI_ATTRS is not set
-# CONFIG_SCSI_LOGGING is not set
-CONFIG_SCSI_LOWLEVEL=y
-# CONFIG_SCSI_LOWLEVEL_PCMCIA is not set
-# CONFIG_SCSI_LPFC is not set
-CONFIG_SCSI_MOD=y
-# CONFIG_SCSI_MPT2SAS is not set
-CONFIG_SCSI_MULTI_LUN=y
-# CONFIG_SCSI_MVSAS is not set
-# CONFIG_SCSI_MVSAS_DEBUG is not set
-# CONFIG_SCSI_MVUMI is not set
-# CONFIG_SCSI_NCR53C406A is not set
-# CONFIG_SCSI_NETLINK is not set
-# CONFIG_SCSI_NSP32 is not set
-# CONFIG_SCSI_OSD_INITIATOR is not set
-# CONFIG_SCSI_PAS16 is not set
-# CONFIG_SCSI_PM8001 is not set
-# CONFIG_SCSI_PMCRAID is not set
-CONFIG_SCSI_PROC_FS=y
-# CONFIG_SCSI_QLA_FC is not set
-# CONFIG_SCSI_QLA_ISCSI is not set
-# CONFIG_SCSI_QLOGIC_1280 is not set
-# CONFIG_SCSI_QLOGIC_FAS is not set
-# CONFIG_SCSI_SAS_ATTRS is not set
-# CONFIG_SCSI_SAS_LIBSAS is not set
-# CONFIG_SCSI_SCAN_ASYNC is not set
-# CONFIG_SCSI_SPI_ATTRS is not set
-# CONFIG_SCSI_SRP is not set
-# CONFIG_SCSI_SRP_ATTRS is not set
-# CONFIG_SCSI_STEX is not set
-# CONFIG_SCSI_SYM53C416 is not set
-# CONFIG_SCSI_SYM53C8XX_2 is not set
-# CONFIG_SCSI_T128 is not set
-# CONFIG_SCSI_TGT is not set
-# CONFIG_SCSI_U14_34F is not set
-# CONFIG_SCSI_ULTRASTOR is not set
-# CONFIG_SDIO_UART is not set
-# CONFIG_SECURITY is not set
-# CONFIG_SECURITYFS is not set
-# CONFIG_SECURITY_DMESG_RESTRICT is not set
-# CONFIG_SEEQ8005 is not set
-CONFIG_SELECT_MEMORY_MODEL=y
-# CONFIG_SENSORS_ABITUGURU is not set
-# CONFIG_SENSORS_ABITUGURU3 is not set
-# CONFIG_SENSORS_ACPI_POWER is not set
-# CONFIG_SENSORS_AD7314 is not set
-# CONFIG_SENSORS_AD7414 is not set
-# CONFIG_SENSORS_AD7418 is not set
-# CONFIG_SENSORS_ADCXX is not set
-# CONFIG_SENSORS_ADM1021 is not set
-# CONFIG_SENSORS_ADM1025 is not set
-# CONFIG_SENSORS_ADM1026 is not set
-# CONFIG_SENSORS_ADM1029 is not set
-# CONFIG_SENSORS_ADM1031 is not set
-# CONFIG_SENSORS_ADM9240 is not set
-# CONFIG_SENSORS_ADS1015 is not set
-# CONFIG_SENSORS_ADS7828 is not set
-# CONFIG_SENSORS_ADS7871 is not set
-# CONFIG_SENSORS_ADT7411 is not set
-# CONFIG_SENSORS_ADT7462 is not set
-# CONFIG_SENSORS_ADT7470 is not set
-# CONFIG_SENSORS_ADT7475 is not set
-# CONFIG_SENSORS_AMC6821 is not set
-# CONFIG_SENSORS_APDS990X is not set
-# CONFIG_SENSORS_APPLESMC is not set
-# CONFIG_SENSORS_ASB100 is not set
-# CONFIG_SENSORS_ASC7621 is not set
-# CONFIG_SENSORS_ATK0110 is not set
-# CONFIG_SENSORS_ATXP1 is not set
-# CONFIG_SENSORS_BH1770 is not set
-# CONFIG_SENSORS_BH1780 is not set
-# CONFIG_SENSORS_CORETEMP is not set
-# CONFIG_SENSORS_DME1737 is not set
-# CONFIG_SENSORS_DS1621 is not set
-# CONFIG_SENSORS_DS620 is not set
-# CONFIG_SENSORS_EMC1403 is not set
-# CONFIG_SENSORS_EMC2103 is not set
-# CONFIG_SENSORS_EMC6W201 is not set
-# CONFIG_SENSORS_F71805F is not set
-# CONFIG_SENSORS_F71882FG is not set
-# CONFIG_SENSORS_F75375S is not set
-# CONFIG_SENSORS_FAM15H_POWER is not set
-# CONFIG_SENSORS_FSCHMD is not set
-# CONFIG_SENSORS_G760A is not set
-# CONFIG_SENSORS_GL518SM is not set
-# CONFIG_SENSORS_GL520SM is not set
-# CONFIG_SENSORS_GPIO_FAN is not set
-# CONFIG_SENSORS_GSC is not set
-# CONFIG_SENSORS_HDAPS is not set
-# CONFIG_SENSORS_I5K_AMB is not set
-# CONFIG_SENSORS_IT87 is not set
-# CONFIG_SENSORS_JC42 is not set
-# CONFIG_SENSORS_K10TEMP is not set
-# CONFIG_SENSORS_K8TEMP is not set
-# CONFIG_SENSORS_LINEAGE is not set
-# CONFIG_SENSORS_LIS3LV02D is not set
-# CONFIG_SENSORS_LIS3_I2C is not set
-# CONFIG_SENSORS_LIS3_SPI is not set
-# CONFIG_SENSORS_LM63 is not set
-# CONFIG_SENSORS_LM70 is not set
-# CONFIG_SENSORS_LM73 is not set
-# CONFIG_SENSORS_LM75 is not set
-# CONFIG_SENSORS_LM77 is not set
-# CONFIG_SENSORS_LM78 is not set
-# CONFIG_SENSORS_LM80 is not set
-# CONFIG_SENSORS_LM83 is not set
-# CONFIG_SENSORS_LM85 is not set
-# CONFIG_SENSORS_LM87 is not set
-# CONFIG_SENSORS_LM90 is not set
-# CONFIG_SENSORS_LM92 is not set
-# CONFIG_SENSORS_LM93 is not set
-# CONFIG_SENSORS_LM95241 is not set
-# CONFIG_SENSORS_LM95245 is not set
-# CONFIG_SENSORS_LTC4151 is not set
-# CONFIG_SENSORS_LTC4215 is not set
-# CONFIG_SENSORS_LTC4245 is not set
-# CONFIG_SENSORS_LTC4261 is not set
-# CONFIG_SENSORS_MAX1111 is not set
-# CONFIG_SENSORS_MAX16065 is not set
-# CONFIG_SENSORS_MAX1619 is not set
-# CONFIG_SENSORS_MAX1668 is not set
-# CONFIG_SENSORS_MAX6639 is not set
-# CONFIG_SENSORS_MAX6642 is not set
-# CONFIG_SENSORS_MAX6650 is not set
-# CONFIG_SENSORS_NTC_THERMISTOR is not set
-# CONFIG_SENSORS_PC87360 is not set
-# CONFIG_SENSORS_PC87427 is not set
-# CONFIG_SENSORS_PCF8591 is not set
-# CONFIG_SENSORS_SCH5627 is not set
-# CONFIG_SENSORS_SCH5636 is not set
-# CONFIG_SENSORS_SCH56XX_COMMON is not set
-# CONFIG_SENSORS_SHT15 is not set
-# CONFIG_SENSORS_SHT21 is not set
-# CONFIG_SENSORS_SIS5595 is not set
-# CONFIG_SENSORS_SMM665 is not set
-# CONFIG_SENSORS_SMSC47B397 is not set
-# CONFIG_SENSORS_SMSC47M1 is not set
-# CONFIG_SENSORS_SMSC47M192 is not set
-# CONFIG_SENSORS_THMC50 is not set
-# CONFIG_SENSORS_TMP102 is not set
-# CONFIG_SENSORS_TMP401 is not set
-# CONFIG_SENSORS_TMP421 is not set
-# CONFIG_SENSORS_TSL2550 is not set
-# CONFIG_SENSORS_VIA686A is not set
-# CONFIG_SENSORS_VIA_CPUTEMP is not set
-# CONFIG_SENSORS_VT1211 is not set
-# CONFIG_SENSORS_VT8231 is not set
-# CONFIG_SENSORS_W83627EHF is not set
-# CONFIG_SENSORS_W83627HF is not set
-# CONFIG_SENSORS_W83781D is not set
-# CONFIG_SENSORS_W83791D is not set
-# CONFIG_SENSORS_W83792D is not set
-# CONFIG_SENSORS_W83793 is not set
-# CONFIG_SENSORS_W83795 is not set
-# CONFIG_SENSORS_W83L785TS is not set
-# CONFIG_SENSORS_W83L786NG is not set
-CONFIG_SERIAL_8250=y
-# CONFIG_SERIAL_8250_ACCENT is not set
-# CONFIG_SERIAL_8250_BOCA is not set
-CONFIG_SERIAL_8250_CONSOLE=y
-# CONFIG_SERIAL_8250_CS is not set
-# CONFIG_SERIAL_8250_DW is not set
-# CONFIG_SERIAL_8250_EXAR_ST16C554 is not set
-# CONFIG_SERIAL_8250_EXTENDED is not set
-# CONFIG_SERIAL_8250_FOURPORT is not set
-# CONFIG_SERIAL_8250_HUB6 is not set
-CONFIG_SERIAL_8250_NR_UARTS=2
-# CONFIG_SERIAL_8250_PCI is not set
-CONFIG_SERIAL_8250_RUNTIME_UARTS=2
-# CONFIG_SERIAL_ALTERA_JTAGUART is not set
-# CONFIG_SERIAL_ALTERA_UART is not set
-CONFIG_SERIAL_CORE=y
-CONFIG_SERIAL_CORE_CONSOLE=y
-# CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set
-# CONFIG_SERIAL_IFX6X60 is not set
-# CONFIG_SERIAL_JSM is not set
-# CONFIG_SERIAL_MAX3100 is not set
-# CONFIG_SERIAL_MAX3107 is not set
-# CONFIG_SERIAL_MFD_HSU is not set
-# CONFIG_SERIAL_NONSTANDARD is not set
-# CONFIG_SERIAL_OF_PLATFORM is not set
-# CONFIG_SERIAL_OF_PLATFORM_NWPSERIAL is not set
-# CONFIG_SERIAL_PCH_UART is not set
-# CONFIG_SERIAL_TIMBERDALE is not set
-# CONFIG_SERIAL_UARTLITE is not set
-# CONFIG_SERIAL_XILINX_PS_UART is not set
-# CONFIG_SERIO is not set
-# CONFIG_SERIO_ALTERA_PS2 is not set
-# CONFIG_SERIO_AMBAKMI is not set
-# CONFIG_SERIO_I8042 is not set
-# CONFIG_SERIO_LIBPS2 is not set
-# CONFIG_SERIO_PARKBD is not set
-# CONFIG_SERIO_PCIPS2 is not set
-# CONFIG_SERIO_PS2MULT is not set
-# CONFIG_SERIO_RAW is not set
-# CONFIG_SERIO_SERPORT is not set
-# CONFIG_SFC is not set
-# CONFIG_SFI is not set
-# CONFIG_SGI_IOC4 is not set
-# CONFIG_SGI_IP22 is not set
-# CONFIG_SGI_IP27 is not set
-# CONFIG_SGI_IP28 is not set
-# CONFIG_SGI_IP32 is not set
-# CONFIG_SGI_PARTITION is not set
-CONFIG_SHMEM=y
-# CONFIG_SIBYTE_BIGSUR is not set
-# CONFIG_SIBYTE_CARMEL is not set
-# CONFIG_SIBYTE_CRHINE is not set
-# CONFIG_SIBYTE_CRHONE is not set
-# CONFIG_SIBYTE_LITTLESUR is not set
-# CONFIG_SIBYTE_RHONE is not set
-# CONFIG_SIBYTE_SENTOSA is not set
-# CONFIG_SIBYTE_SWARM is not set
-# CONFIG_SIGMA is not set
-CONFIG_SIGNALFD=y
-# CONFIG_SIMPLE_GPIO is not set
-# CONFIG_SIS190 is not set
-# CONFIG_SIS900 is not set
-# CONFIG_SKGE is not set
-# CONFIG_SKY2 is not set
-# CONFIG_SKY2_DEBUG is not set
-CONFIG_SLAB=y
-CONFIG_SLABINFO=y
-# CONFIG_SLHC is not set
-# CONFIG_SLICOSS is not set
-# CONFIG_SLIP is not set
-# CONFIG_SLOB is not set
-# CONFIG_SLUB is not set
-# CONFIG_SLUB_DEBUG is not set
-# CONFIG_SLUB_STATS is not set
-# CONFIG_SMARTJOYPLUS_FF is not set
-# CONFIG_SMC911X is not set
-# CONFIG_SMC9194 is not set
-# CONFIG_SMC91X is not set
-# CONFIG_SMP is not set
-# CONFIG_SMSC911X is not set
-# CONFIG_SMSC9420 is not set
-# CONFIG_SMSC_PHY is not set
-# CONFIG_SM_FTL is not set
-# CONFIG_SND is not set
-# CONFIG_SND_AC97_POWER_SAVE is not set
-# CONFIG_SND_AD1816A is not set
-# CONFIG_SND_AD1848 is not set
-# CONFIG_SND_AD1889 is not set
-# CONFIG_SND_ADLIB is not set
-# CONFIG_SND_ALI5451 is not set
-# CONFIG_SND_ALOOP is not set
-# CONFIG_SND_ALS100 is not set
-# CONFIG_SND_ALS300 is not set
-# CONFIG_SND_ALS4000 is not set
-# CONFIG_SND_ARM is not set
-# CONFIG_SND_ASIHPI is not set
-# CONFIG_SND_ATIIXP is not set
-# CONFIG_SND_ATIIXP_MODEM is not set
-# CONFIG_SND_ATMEL_AC97C is not set
-# CONFIG_SND_ATMEL_SOC is not set
-# CONFIG_SND_AU8810 is not set
-# CONFIG_SND_AU8820 is not set
-# CONFIG_SND_AU8830 is not set
-# CONFIG_SND_AW2 is not set
-# CONFIG_SND_AZT2320 is not set
-# CONFIG_SND_AZT3328 is not set
-# CONFIG_SND_BT87X is not set
-# CONFIG_SND_CA0106 is not set
-# CONFIG_SND_CMI8330 is not set
-# CONFIG_SND_CMIPCI is not set
-# CONFIG_SND_CS4231 is not set
-# CONFIG_SND_CS4236 is not set
-# CONFIG_SND_CS4281 is not set
-# CONFIG_SND_CS46XX is not set
-# CONFIG_SND_CS5530 is not set
-# CONFIG_SND_CS5535AUDIO is not set
-# CONFIG_SND_CTXFI is not set
-# CONFIG_SND_DARLA20 is not set
-# CONFIG_SND_DARLA24 is not set
-# CONFIG_SND_DEBUG is not set
-CONFIG_SND_DRIVERS=y
-# CONFIG_SND_DUMMY is not set
-# CONFIG_SND_DYNAMIC_MINORS is not set
-# CONFIG_SND_ECHO3G is not set
-# CONFIG_SND_EMU10K1 is not set
-# CONFIG_SND_EMU10K1X is not set
-# CONFIG_SND_ENS1370 is not set
-# CONFIG_SND_ENS1371 is not set
-# CONFIG_SND_ES1688 is not set
-# CONFIG_SND_ES18XX is not set
-# CONFIG_SND_ES1938 is not set
-# CONFIG_SND_ES1968 is not set
-# CONFIG_SND_FIREWIRE is not set
-# CONFIG_SND_FM801 is not set
-# CONFIG_SND_GINA20 is not set
-# CONFIG_SND_GINA24 is not set
-# CONFIG_SND_GUSCLASSIC is not set
-# CONFIG_SND_GUSEXTREME is not set
-# CONFIG_SND_GUSMAX is not set
-# CONFIG_SND_HDA_INTEL is not set
-# CONFIG_SND_HDSP is not set
-# CONFIG_SND_HDSPM is not set
-# CONFIG_SND_HRTIMER is not set
-# CONFIG_SND_HWDEP is not set
-# CONFIG_SND_ICE1712 is not set
-# CONFIG_SND_ICE1724 is not set
-# CONFIG_SND_INDIGO is not set
-# CONFIG_SND_INDIGODJ is not set
-# CONFIG_SND_INDIGODJX is not set
-# CONFIG_SND_INDIGOIO is not set
-# CONFIG_SND_INDIGOIOX is not set
-# CONFIG_SND_INTEL8X0 is not set
-# CONFIG_SND_INTEL8X0M is not set
-# CONFIG_SND_INTERWAVE is not set
-# CONFIG_SND_INTERWAVE_STB is not set
-# CONFIG_SND_ISA is not set
-# CONFIG_SND_KIRKWOOD_SOC is not set
-# CONFIG_SND_KORG1212 is not set
-# CONFIG_SND_LAYLA20 is not set
-# CONFIG_SND_LAYLA24 is not set
-# CONFIG_SND_LOLA is not set
-# CONFIG_SND_LX6464ES is not set
-# CONFIG_SND_MAESTRO3 is not set
-# CONFIG_SND_MIA is not set
-# CONFIG_SND_MIPS is not set
-# CONFIG_SND_MIRO is not set
-# CONFIG_SND_MIXART is not set
-# CONFIG_SND_MIXER_OSS is not set
-# CONFIG_SND_MONA is not set
-# CONFIG_SND_MPC52xx_SOC_EFIKA is not set
-# CONFIG_SND_MPU401 is not set
-# CONFIG_SND_MTPAV is not set
-# CONFIG_SND_MTS64 is not set
-# CONFIG_SND_NM256 is not set
-# CONFIG_SND_OPL3SA2 is not set
-# CONFIG_SND_OPTI92X_AD1848 is not set
-# CONFIG_SND_OPTI92X_CS4231 is not set
-# CONFIG_SND_OPTI93X is not set
-CONFIG_SND_OSSEMUL=y
-# CONFIG_SND_OXYGEN is not set
-CONFIG_SND_PCI=y
-# CONFIG_SND_PCM is not set
-# CONFIG_SND_PCMCIA is not set
-# CONFIG_SND_PCM_OSS is not set
-CONFIG_SND_PCM_OSS_PLUGINS=y
-# CONFIG_SND_PCXHR is not set
-# CONFIG_SND_PDAUDIOCF is not set
-# CONFIG_SND_PORTMAN2X4 is not set
-# CONFIG_SND_PPC is not set
-# CONFIG_SND_RAWMIDI is not set
-# CONFIG_SND_RIPTIDE is not set
-# CONFIG_SND_RME32 is not set
-# CONFIG_SND_RME96 is not set
-# CONFIG_SND_RME9652 is not set
-# CONFIG_SND_RTCTIMER is not set
-# CONFIG_SND_SB16 is not set
-# CONFIG_SND_SB8 is not set
-# CONFIG_SND_SBAWE is not set
-# CONFIG_SND_SEQUENCER is not set
-# CONFIG_SND_SERIAL_U16550 is not set
-# CONFIG_SND_SIS7019 is not set
-# CONFIG_SND_SOC is not set
-# CONFIG_SND_SOC_AU1XAUDIO is not set
-# CONFIG_SND_SOC_AU1XPSC is not set
-# CONFIG_SND_SOC_CACHE_LZO is not set
-# CONFIG_SND_SOC_MPC5200_AC97 is not set
-# CONFIG_SND_SOC_MPC5200_I2S is not set
-# CONFIG_SND_SONICVIBES is not set
-# CONFIG_SND_SPI is not set
-# CONFIG_SND_SSCAPE is not set
-# CONFIG_SND_SUPPORT_OLD_API is not set
-# CONFIG_SND_TIMER is not set
-# CONFIG_SND_TRIDENT is not set
-CONFIG_SND_USB=y
-# CONFIG_SND_USB_6FIRE is not set
-# CONFIG_SND_USB_AUDIO is not set
-# CONFIG_SND_USB_CAIAQ is not set
-# CONFIG_SND_USB_UA101 is not set
-# CONFIG_SND_USB_US122L is not set
-# CONFIG_SND_USB_USX2Y is not set
-# CONFIG_SND_VERBOSE_PRINTK is not set
-CONFIG_SND_VERBOSE_PROCFS=y
-# CONFIG_SND_VIA82XX is not set
-# CONFIG_SND_VIA82XX_MODEM is not set
-# CONFIG_SND_VIRTUOSO is not set
-# CONFIG_SND_VX222 is not set
-# CONFIG_SND_VXPOCKET is not set
-# CONFIG_SND_WAVEFRONT is not set
-# CONFIG_SND_YMFPCI is not set
-# CONFIG_SNI_RM is not set
-# CONFIG_SOC_CAMERA is not set
-# CONFIG_SOFT_WATCHDOG is not set
-# CONFIG_SOLARIS_X86_PARTITION is not set
-# CONFIG_SOLO6X10 is not set
-# CONFIG_SONYPI is not set
-# CONFIG_SONY_LAPTOP is not set
-# CONFIG_SOUND is not set
-# CONFIG_SOUND_PRIME is not set
-# CONFIG_SP5100_TCO is not set
-# CONFIG_SPARSEMEM_MANUAL is not set
-# CONFIG_SPARSEMEM_STATIC is not set
-# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set
-# CONFIG_SPARSE_IRQ is not set
-# CONFIG_SPARSE_RCU_POINTER is not set
-# CONFIG_SPEAKUP is not set
-# CONFIG_SPI is not set
-# CONFIG_SPINLOCK_TEST is not set
-# CONFIG_SPI_ALTERA is not set
-# CONFIG_SPI_AU1550 is not set
-# CONFIG_SPI_BITBANG is not set
-# CONFIG_SPI_BUTTERFLY is not set
-# CONFIG_SPI_DEBUG is not set
-# CONFIG_SPI_DESIGNWARE is not set
-# CONFIG_SPI_FSL_ESPI is not set
-# CONFIG_SPI_FSL_SPI is not set
-# CONFIG_SPI_GPIO is not set
-# CONFIG_SPI_GPIO_OLD is not set
-# CONFIG_SPI_LM70_LLP is not set
-# CONFIG_SPI_MASTER is not set
-# CONFIG_SPI_MPC52xx is not set
-# CONFIG_SPI_MPC52xx_PSC is not set
-# CONFIG_SPI_OC_TINY is not set
-# CONFIG_SPI_ORION is not set
-# CONFIG_SPI_PL022 is not set
-# CONFIG_SPI_PPC4xx is not set
-# CONFIG_SPI_PXA2XX is not set
-# CONFIG_SPI_PXA2XX_PCI is not set
-# CONFIG_SPI_RAMIPS is not set
-# CONFIG_SPI_SPIDEV is not set
-# CONFIG_SPI_TLE62X0 is not set
-# CONFIG_SPI_TOPCLIFF_PCH is not set
-# CONFIG_SPI_XILINX is not set
-# CONFIG_SPI_XWAY is not set
-CONFIG_SPLIT_PTLOCK_CPUS=4
-CONFIG_SQUASHFS=y
-# CONFIG_SQUASHFS_4K_DEVBLK_SIZE is not set
-# CONFIG_SQUASHFS_EMBEDDED is not set
-CONFIG_SQUASHFS_FRAGMENT_CACHE_SIZE=3
-# CONFIG_SQUASHFS_LZO is not set
-# CONFIG_SQUASHFS_XATTR is not set
-CONFIG_SQUASHFS_XZ=y
-# CONFIG_SQUASHFS_ZLIB is not set
-# CONFIG_SSB is not set
-# CONFIG_SSB_DEBUG is not set
-# CONFIG_SSB_DRIVER_GPIO is not set
-# CONFIG_SSB_PCMCIAHOST is not set
-CONFIG_SSB_POSSIBLE=y
-# CONFIG_SSB_SDIOHOST is not set
-# CONFIG_SSB_SILENT is not set
-# CONFIG_SSFDC is not set
-CONFIG_STACKTRACE_SUPPORT=y
-# CONFIG_STACK_TRACER is not set
-CONFIG_STAGING=y
-# CONFIG_STAGING_MEDIA is not set
-CONFIG_STANDALONE=y
-CONFIG_STDBINUTILS=y
-# CONFIG_STE10XP is not set
-# CONFIG_STMMAC_ETH is not set
-CONFIG_STP=y
-# CONFIG_STRICT_DEVMEM is not set
-CONFIG_STRIP_ASM_SYMS=y
-# CONFIG_STUB_POULSBO is not set
-# CONFIG_SUNDANCE is not set
-# CONFIG_SUNGEM is not set
-# CONFIG_SUNRPC is not set
-# CONFIG_SUNRPC_GSS is not set
-# CONFIG_SUN_PARTITION is not set
-# CONFIG_SUSPEND is not set
-CONFIG_SWAP=y
-# CONFIG_SWCONFIG is not set
-# CONFIG_SWCONFIG_LEDS is not set
-# CONFIG_SYNCLINK_CS is not set
-CONFIG_SYN_COOKIES=y
-CONFIG_SYSCTL=y
-# CONFIG_SYSCTL_SYSCALL is not set
-# CONFIG_SYSCTL_SYSCALL_CHECK is not set
-CONFIG_SYSFS=y
-# CONFIG_SYSFS_DEPRECATED is not set
-# CONFIG_SYSFS_DEPRECATED_V2 is not set
-# CONFIG_SYSV68_PARTITION is not set
-CONFIG_SYSVIPC=y
-CONFIG_SYSVIPC_SYSCTL=y
-# CONFIG_SYSV_FS is not set
-# CONFIG_SYS_HYPERVISOR is not set
-# CONFIG_TARGET_CORE is not set
-# CONFIG_TASKSTATS is not set
-# CONFIG_TC35815 is not set
-# CONFIG_TCG_TPM is not set
-# CONFIG_TCIC is not set
-CONFIG_TCP_CONG_ADVANCED=y
-# CONFIG_TCP_CONG_BIC is not set
-CONFIG_TCP_CONG_CUBIC=y
-# CONFIG_TCP_CONG_HSTCP is not set
-# CONFIG_TCP_CONG_HTCP is not set
-# CONFIG_TCP_CONG_HYBLA is not set
-# CONFIG_TCP_CONG_ILLINOIS is not set
-# CONFIG_TCP_CONG_LP is not set
-# CONFIG_TCP_CONG_SCALABLE is not set
-# CONFIG_TCP_CONG_VEGAS is not set
-# CONFIG_TCP_CONG_VENO is not set
-# CONFIG_TCP_CONG_WESTWOOD is not set
-# CONFIG_TCP_CONG_YEAH is not set
-# CONFIG_TCP_MD5SIG is not set
-# CONFIG_TEHUTI is not set
-# CONFIG_TEST_KSTRTOX is not set
-# CONFIG_TEST_LIST_SORT is not set
-# CONFIG_TEST_POWER is not set
-CONFIG_TEXTSEARCH=y
-# CONFIG_TEXTSEARCH_BM is not set
-# CONFIG_TEXTSEARCH_FSM is not set
-# CONFIG_TEXTSEARCH_KMP is not set
-# CONFIG_THERMAL is not set
-# CONFIG_THERMAL_HWMON is not set
-# CONFIG_THRUSTMASTER_FF is not set
-CONFIG_TICK_ONESHOT=y
-# CONFIG_TIFM_CORE is not set
-# CONFIG_TIGON3 is not set
-# CONFIG_TIMB_DMA is not set
-CONFIG_TIMERFD=y
-# CONFIG_TIMER_STATS is not set
-CONFIG_TINY_RCU=y
-# CONFIG_TIPC is not set
-# CONFIG_TI_DAC7512 is not set
-# CONFIG_TI_ST is not set
-# CONFIG_TLAN is not set
-# CONFIG_TMD_HERMES is not set
-CONFIG_TMPFS=y
-# CONFIG_TMPFS_POSIX_ACL is not set
-CONFIG_TMPFS_XATTR=y
-# CONFIG_TOUCHSCREEN_AD7877 is not set
-# CONFIG_TOUCHSCREEN_AD7879 is not set
-# CONFIG_TOUCHSCREEN_AD7879_I2C is not set
-# CONFIG_TOUCHSCREEN_AD7879_SPI is not set
-# CONFIG_TOUCHSCREEN_ADS7846 is not set
-# CONFIG_TOUCHSCREEN_CLEARPAD_TM1217 is not set
-# CONFIG_TOUCHSCREEN_CY8CTMG110 is not set
-# CONFIG_TOUCHSCREEN_EETI is not set
-# CONFIG_TOUCHSCREEN_ELO is not set
-# CONFIG_TOUCHSCREEN_FUJITSU is not set
-# CONFIG_TOUCHSCREEN_GUNZE is not set
-# CONFIG_TOUCHSCREEN_INEXIO is not set
-# CONFIG_TOUCHSCREEN_MCS5000 is not set
-# CONFIG_TOUCHSCREEN_MK712 is not set
-# CONFIG_TOUCHSCREEN_MTOUCH is not set
-# CONFIG_TOUCHSCREEN_PENMOUNT is not set
-# CONFIG_TOUCHSCREEN_S3C2410 is not set
-# CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set
-# CONFIG_TOUCHSCREEN_TOUCHIT213 is not set
-# CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set
-# CONFIG_TOUCHSCREEN_TOUCHWIN is not set
-# CONFIG_TOUCHSCREEN_TPS6507X is not set
-# CONFIG_TOUCHSCREEN_TSC2007 is not set
-# CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set
-# CONFIG_TOUCHSCREEN_W90X900 is not set
-# CONFIG_TOUCHSCREEN_WACOM_W8001 is not set
-# CONFIG_TOUCHSCREEN_WM97XX is not set
-# CONFIG_TPS6105X is not set
-# CONFIG_TPS65010 is not set
-# CONFIG_TPS6507X is not set
-# CONFIG_TR is not set
-# CONFIG_TRACE_BRANCH_PROFILING is not set
-CONFIG_TRACE_IRQFLAGS_SUPPORT=y
-# CONFIG_TRACE_SINK is not set
-CONFIG_TRACING_SUPPORT=y
-CONFIG_TRAD_SIGNALS=y
-# CONFIG_TRANZPORT is not set
-# CONFIG_TREE_PREEMPT_RCU is not set
-# CONFIG_TREE_RCU is not set
-# CONFIG_TREE_RCU_TRACE is not set
-# CONFIG_TTY_PRINTK is not set
-# CONFIG_TUN is not set
-# CONFIG_TWL4030_CORE is not set
-# CONFIG_TYPHOON is not set
-# CONFIG_UACCESS_WITH_MEMCPY is not set
-# CONFIG_UCB1400_CORE is not set
-# CONFIG_UDF_FS is not set
-CONFIG_UDF_NLS=y
-CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
-# CONFIG_UFS_FS is not set
-# CONFIG_UIO is not set
-# CONFIG_ULTRA is not set
-# CONFIG_ULTRIX_PARTITION is not set
-CONFIG_UNIX=y
-CONFIG_UNIX98_PTYS=y
-# CONFIG_UNIXWARE_DISKLABEL is not set
-# CONFIG_UNIX_DIAG is not set
-# CONFIG_UNUSED_SYMBOLS is not set
-# CONFIG_USB is not set
-# CONFIG_USBIP_CORE is not set
-# CONFIG_USBPCWATCHDOG is not set
-# CONFIG_USB_ACM is not set
-# CONFIG_USB_ADUTUX is not set
-CONFIG_USB_ALI_M5632=y
-# CONFIG_USB_AMD5536UDC is not set
-CONFIG_USB_AN2720=y
-# CONFIG_USB_ANNOUNCE_NEW_DEVICES is not set
-# CONFIG_USB_APPLEDISPLAY is not set
-CONFIG_USB_ARCH_HAS_EHCI=y
-CONFIG_USB_ARCH_HAS_HCD=y
-CONFIG_USB_ARCH_HAS_OHCI=y
-CONFIG_USB_ARMLINUX=y
-# CONFIG_USB_ATM is not set
-CONFIG_USB_BELKIN=y
-# CONFIG_USB_C67X00_HCD is not set
-# CONFIG_USB_CATC is not set
-# CONFIG_USB_CDC_COMPOSITE is not set
-# CONFIG_USB_CXACRU is not set
-# CONFIG_USB_CYPRESS_CY7C63 is not set
-# CONFIG_USB_CYTHERM is not set
-# CONFIG_USB_DEBUG is not set
-CONFIG_USB_DEVICEFS=y
-# CONFIG_USB_DEVICE_CLASS is not set
-# CONFIG_USB_DSBR is not set
-# CONFIG_USB_DUMMY_HCD is not set
-# CONFIG_USB_DWC3 is not set
-# CONFIG_USB_DWC_OTG_LPM is not set
-# CONFIG_USB_DYNAMIC_MINORS is not set
-# CONFIG_USB_EG20T is not set
-# CONFIG_USB_EHCI_HCD_PLATFORM is not set
-# CONFIG_USB_EHCI_HCD_PPC_OF is not set
-# CONFIG_USB_EHCI_MV is not set
-CONFIG_USB_EHCI_ROOT_HUB_TT=y
-CONFIG_USB_EHCI_TT_NEWSCHED=y
-# CONFIG_USB_EMI26 is not set
-# CONFIG_USB_EMI62 is not set
-# CONFIG_USB_ENESTORAGE is not set
-# CONFIG_USB_EPSON2888 is not set
-# CONFIG_USB_ET61X251 is not set
-CONFIG_USB_EZUSB=y
-# CONFIG_USB_FILE_STORAGE is not set
-# CONFIG_USB_FSL_USB2 is not set
-# CONFIG_USB_FTDI_ELAN is not set
-# CONFIG_USB_FUNCTIONFS is not set
-# CONFIG_USB_FUSB300 is not set
-# CONFIG_USB_GADGET is not set
-# CONFIG_USB_GADGETFS is not set
-# CONFIG_USB_GADGET_DEBUG is not set
-# CONFIG_USB_GADGET_DEBUG_FILES is not set
-# CONFIG_USB_GADGET_DEBUG_FS is not set
-CONFIG_USB_GADGET_STORAGE_NUM_BUFFERS=2
-CONFIG_USB_GADGET_VBUS_DRAW=2
-# CONFIG_USB_GL860 is not set
-# CONFIG_USB_GOKU is not set
-# CONFIG_USB_GPIO_VBUS is not set
-# CONFIG_USB_GSPCA is not set
-# CONFIG_USB_GSPCA_BENQ is not set
-# CONFIG_USB_GSPCA_CONEX is not set
-# CONFIG_USB_GSPCA_CPIA1 is not set
-# CONFIG_USB_GSPCA_ETOMS is not set
-# CONFIG_USB_GSPCA_FINEPIX is not set
-# CONFIG_USB_GSPCA_JEILINJ is not set
-# CONFIG_USB_GSPCA_JL2005BCD is not set
-# CONFIG_USB_GSPCA_KINECT is not set
-# CONFIG_USB_GSPCA_KONICA is not set
-# CONFIG_USB_GSPCA_MARS is not set
-# CONFIG_USB_GSPCA_MR97310A is not set
-# CONFIG_USB_GSPCA_NW80X is not set
-# CONFIG_USB_GSPCA_OV519 is not set
-# CONFIG_USB_GSPCA_OV534 is not set
-# CONFIG_USB_GSPCA_OV534_9 is not set
-# CONFIG_USB_GSPCA_PAC207 is not set
-# CONFIG_USB_GSPCA_PAC7302 is not set
-# CONFIG_USB_GSPCA_PAC7311 is not set
-# CONFIG_USB_GSPCA_SE401 is not set
-# CONFIG_USB_GSPCA_SN9C2028 is not set
-# CONFIG_USB_GSPCA_SN9C20X is not set
-# CONFIG_USB_GSPCA_SONIXB is not set
-# CONFIG_USB_GSPCA_SONIXJ is not set
-# CONFIG_USB_GSPCA_SPCA1528 is not set
-# CONFIG_USB_GSPCA_SPCA500 is not set
-# CONFIG_USB_GSPCA_SPCA501 is not set
-# CONFIG_USB_GSPCA_SPCA505 is not set
-# CONFIG_USB_GSPCA_SPCA506 is not set
-# CONFIG_USB_GSPCA_SPCA508 is not set
-# CONFIG_USB_GSPCA_SPCA561 is not set
-# CONFIG_USB_GSPCA_SQ905 is not set
-# CONFIG_USB_GSPCA_SQ905C is not set
-# CONFIG_USB_GSPCA_SQ930X is not set
-# CONFIG_USB_GSPCA_STK014 is not set
-# CONFIG_USB_GSPCA_STV0680 is not set
-# CONFIG_USB_GSPCA_SUNPLUS is not set
-# CONFIG_USB_GSPCA_T613 is not set
-# CONFIG_USB_GSPCA_TOPRO is not set
-# CONFIG_USB_GSPCA_TV8532 is not set
-# CONFIG_USB_GSPCA_VC032X is not set
-# CONFIG_USB_GSPCA_VICAM is not set
-# CONFIG_USB_GSPCA_XIRLINK_CIT is not set
-# CONFIG_USB_GSPCA_ZC3XX is not set
-# CONFIG_USB_G_ACM_MS is not set
-# CONFIG_USB_G_DBGP is not set
-# CONFIG_USB_G_HID is not set
-# CONFIG_USB_G_MULTI is not set
-# CONFIG_USB_G_NCM is not set
-# CONFIG_USB_G_NOKIA is not set
-# CONFIG_USB_G_PRINTER is not set
-# CONFIG_USB_G_SERIAL is not set
-# CONFIG_USB_G_WEBCAM is not set
-# CONFIG_USB_HID is not set
-# CONFIG_USB_HIDDEV is not set
-# CONFIG_USB_HSO is not set
-# CONFIG_USB_HWA_HCD is not set
-# CONFIG_USB_IBMCAM is not set
-# CONFIG_USB_IDMOUSE is not set
-# CONFIG_USB_IOWARRIOR is not set
-# CONFIG_USB_IPHETH is not set
-# CONFIG_USB_IP_COMMON is not set
-# CONFIG_USB_ISIGHTFW is not set
-# CONFIG_USB_ISP116X_HCD is not set
-# CONFIG_USB_ISP1362_HCD is not set
-# CONFIG_USB_ISP1760_HCD is not set
-# CONFIG_USB_KAWETH is not set
-# CONFIG_USB_KBD is not set
-# CONFIG_USB_KC2190 is not set
-# CONFIG_USB_KONICAWC is not set
-# CONFIG_USB_LCD is not set
-# CONFIG_USB_LD is not set
-# CONFIG_USB_LED is not set
-# CONFIG_USB_LEGOTOWER is not set
-# CONFIG_USB_LIBUSUAL is not set
-# CONFIG_USB_M5602 is not set
-# CONFIG_USB_M66592 is not set
-# CONFIG_USB_MASS_STORAGE is not set
-# CONFIG_USB_MDC800 is not set
-# CONFIG_USB_MICROTEK is not set
-# CONFIG_USB_MIDI_GADGET is not set
-# CONFIG_USB_MON is not set
-# CONFIG_USB_MOUSE is not set
-# CONFIG_USB_MUSB_HDRC is not set
-# CONFIG_USB_MV_UDC is not set
-# CONFIG_USB_NET2272 is not set
-# CONFIG_USB_NET2280 is not set
-# CONFIG_USB_NET_AX8817X is not set
-# CONFIG_USB_NET_CDCETHER is not set
-# CONFIG_USB_NET_CDC_EEM is not set
-# CONFIG_USB_NET_CDC_NCM is not set
-# CONFIG_USB_NET_CDC_SUBSET is not set
-# CONFIG_USB_NET_CX82310_ETH is not set
-# CONFIG_USB_NET_DM9601 is not set
-# CONFIG_USB_NET_GL620A is not set
-# CONFIG_USB_NET_INT51X1 is not set
-# CONFIG_USB_NET_KALMIA is not set
-# CONFIG_USB_NET_MCS7830 is not set
-# CONFIG_USB_NET_NET1080 is not set
-# CONFIG_USB_NET_PLUSB is not set
-# CONFIG_USB_NET_RNDIS_HOST is not set
-# CONFIG_USB_NET_RNDIS_WLAN is not set
-# CONFIG_USB_NET_SMSC75XX is not set
-# CONFIG_USB_NET_SMSC95XX is not set
-# CONFIG_USB_NET_ZAURUS is not set
-# CONFIG_USB_OHCI_HCD is not set
-# CONFIG_USB_OHCI_HCD_PCI is not set
-# CONFIG_USB_OHCI_HCD_PLATFORM is not set
-# CONFIG_USB_OHCI_HCD_PPC_OF is not set
-# CONFIG_USB_OHCI_HCD_PPC_OF_BE is not set
-# CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set
-# CONFIG_USB_OHCI_HCD_PPC_SOC is not set
-# CONFIG_USB_OHCI_HCD_SSB is not set
-CONFIG_USB_OHCI_LITTLE_ENDIAN=y
-# CONFIG_USB_OTG is not set
-# CONFIG_USB_OTG_BLACKLIST_HUB is not set
-# CONFIG_USB_OTG_WHITELIST is not set
-# CONFIG_USB_OXU210HP_HCD is not set
-# CONFIG_USB_PEGASUS is not set
-# CONFIG_USB_PRINTER is not set
-# CONFIG_USB_PWC_INPUT_EVDEV is not set
-# CONFIG_USB_PXA27X is not set
-# CONFIG_USB_R8A66597 is not set
-# CONFIG_USB_R8A66597_HCD is not set
-# CONFIG_USB_RENESAS_USBHS is not set
-# CONFIG_USB_RIO500 is not set
-# CONFIG_USB_RTL8150 is not set
-# CONFIG_USB_S2255 is not set
-# CONFIG_USB_SE401 is not set
-# CONFIG_USB_SERIAL is not set
-# CONFIG_USB_SERIAL_AIRCABLE is not set
-# CONFIG_USB_SERIAL_ARK3116 is not set
-# CONFIG_USB_SERIAL_BELKIN is not set
-# CONFIG_USB_SERIAL_CH341 is not set
-# CONFIG_USB_SERIAL_CP210X is not set
-# CONFIG_USB_SERIAL_CYBERJACK is not set
-# CONFIG_USB_SERIAL_CYPRESS_M8 is not set
-# CONFIG_USB_SERIAL_DEBUG is not set
-# CONFIG_USB_SERIAL_DIGI_ACCELEPORT is not set
-# CONFIG_USB_SERIAL_EDGEPORT is not set
-# CONFIG_USB_SERIAL_EDGEPORT_TI is not set
-# CONFIG_USB_SERIAL_EMPEG is not set
-# CONFIG_USB_SERIAL_FTDI_SIO is not set
-# CONFIG_USB_SERIAL_FUNSOFT is not set
-# CONFIG_USB_SERIAL_GARMIN is not set
-CONFIG_USB_SERIAL_GENERIC=y
-# CONFIG_USB_SERIAL_HP4X is not set
-# CONFIG_USB_SERIAL_IPAQ is not set
-# CONFIG_USB_SERIAL_IPW is not set
-# CONFIG_USB_SERIAL_IR is not set
-# CONFIG_USB_SERIAL_IUU is not set
-# CONFIG_USB_SERIAL_KEYSPAN is not set
-CONFIG_USB_SERIAL_KEYSPAN_MPR=y
-# CONFIG_USB_SERIAL_KEYSPAN_PDA is not set
-CONFIG_USB_SERIAL_KEYSPAN_USA18X=y
-CONFIG_USB_SERIAL_KEYSPAN_USA19=y
-CONFIG_USB_SERIAL_KEYSPAN_USA19QI=y
-CONFIG_USB_SERIAL_KEYSPAN_USA19QW=y
-CONFIG_USB_SERIAL_KEYSPAN_USA19W=y
-CONFIG_USB_SERIAL_KEYSPAN_USA28=y
-CONFIG_USB_SERIAL_KEYSPAN_USA28X=y
-CONFIG_USB_SERIAL_KEYSPAN_USA28XA=y
-CONFIG_USB_SERIAL_KEYSPAN_USA28XB=y
-CONFIG_USB_SERIAL_KEYSPAN_USA49W=y
-CONFIG_USB_SERIAL_KEYSPAN_USA49WLC=y
-# CONFIG_USB_SERIAL_KLSI is not set
-# CONFIG_USB_SERIAL_KOBIL_SCT is not set
-# CONFIG_USB_SERIAL_MCT_U232 is not set
-# CONFIG_USB_SERIAL_MOS7715_PARPORT is not set
-# CONFIG_USB_SERIAL_MOS7720 is not set
-# CONFIG_USB_SERIAL_MOS7840 is not set
-# CONFIG_USB_SERIAL_MOTOROLA is not set
-# CONFIG_USB_SERIAL_NAVMAN is not set
-# CONFIG_USB_SERIAL_OMNINET is not set
-# CONFIG_USB_SERIAL_OPTICON is not set
-# CONFIG_USB_SERIAL_OPTION is not set
-# CONFIG_USB_SERIAL_OTI6858 is not set
-# CONFIG_USB_SERIAL_PL2303 is not set
-# CONFIG_USB_SERIAL_QCAUX is not set
-# CONFIG_USB_SERIAL_QUALCOMM is not set
-# CONFIG_USB_SERIAL_QUATECH2 is not set
-# CONFIG_USB_SERIAL_QUATECH_USB2 is not set
-# CONFIG_USB_SERIAL_SAFE is not set
-CONFIG_USB_SERIAL_SAFE_PADDED=y
-# CONFIG_USB_SERIAL_SIEMENS_MPI is not set
-# CONFIG_USB_SERIAL_SIERRAWIRELESS is not set
-# CONFIG_USB_SERIAL_SPCP8X5 is not set
-# CONFIG_USB_SERIAL_SSU100 is not set
-# CONFIG_USB_SERIAL_SYMBOL is not set
-# CONFIG_USB_SERIAL_TI is not set
-# CONFIG_USB_SERIAL_VISOR is not set
-# CONFIG_USB_SERIAL_VIVOPAY_SERIAL is not set
-# CONFIG_USB_SERIAL_WHITEHEAT is not set
-# CONFIG_USB_SERIAL_XIRCOM is not set
-# CONFIG_USB_SERIAL_ZIO is not set
-# CONFIG_USB_SEVSEG is not set
-# CONFIG_USB_SIERRA_NET is not set
-# CONFIG_USB_SISUSBVGA is not set
-# CONFIG_USB_SL811_HCD is not set
-# CONFIG_USB_SN9C102 is not set
-# CONFIG_USB_SPEEDTOUCH is not set
-# CONFIG_USB_STKWEBCAM is not set
-# CONFIG_USB_STORAGE is not set
-# CONFIG_USB_STORAGE_ALAUDA is not set
-# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set
-# CONFIG_USB_STORAGE_DATAFAB is not set
-# CONFIG_USB_STORAGE_DEBUG is not set
-# CONFIG_USB_STORAGE_ENE_UB6250 is not set
-# CONFIG_USB_STORAGE_FREECOM is not set
-# CONFIG_USB_STORAGE_ISD200 is not set
-# CONFIG_USB_STORAGE_JUMPSHOT is not set
-# CONFIG_USB_STORAGE_KARMA is not set
-# CONFIG_USB_STORAGE_ONETOUCH is not set
-# CONFIG_USB_STORAGE_REALTEK is not set
-# CONFIG_USB_STORAGE_SDDR09 is not set
-# CONFIG_USB_STORAGE_SDDR55 is not set
-# CONFIG_USB_STORAGE_USBAT is not set
-# CONFIG_USB_STV06XX is not set
-# CONFIG_USB_SUPPORT is not set
-# CONFIG_USB_SUSPEND is not set
-# CONFIG_USB_SWITCH_FSA9480 is not set
-# CONFIG_USB_TEST is not set
-# CONFIG_USB_TMC is not set
-# CONFIG_USB_TRANCEVIBRATOR is not set
-# CONFIG_USB_UAS is not set
-# CONFIG_USB_UEAGLEATM is not set
-# CONFIG_USB_ULPI is not set
-# CONFIG_USB_USBNET is not set
-# CONFIG_USB_USS720 is not set
-# CONFIG_USB_VIDEO_CLASS is not set
-CONFIG_USB_VIDEO_CLASS_INPUT_EVDEV=y
-# CONFIG_USB_VL600 is not set
-# CONFIG_USB_WDM is not set
-# CONFIG_USB_WHCI_HCD is not set
-# CONFIG_USB_WUSB is not set
-# CONFIG_USB_WUSB_CBAF is not set
-# CONFIG_USB_XHCI_HCD is not set
-# CONFIG_USB_XUSBATM is not set
-# CONFIG_USB_YUREX is not set
-# CONFIG_USB_ZD1201 is not set
-# CONFIG_USB_ZERO is not set
-# CONFIG_USB_ZR364XX is not set
-# CONFIG_USE_GENERIC_SMP_HELPERS is not set
-# CONFIG_USE_OF is not set
-# CONFIG_UTS_NS is not set
-# CONFIG_UWB is not set
-# CONFIG_V4L_MEM2MEM_DRIVERS is not set
-# CONFIG_VETH is not set
-# CONFIG_VFAT_FS is not set
-# CONFIG_VGASTATE is not set
-# CONFIG_VGA_ARB is not set
-# CONFIG_VGA_SWITCHEROO is not set
-# CONFIG_VIA_RHINE is not set
-# CONFIG_VIA_VELOCITY is not set
-# CONFIG_VIDEO_ADV7170 is not set
-# CONFIG_VIDEO_ADV7175 is not set
-# CONFIG_VIDEO_ADV7180 is not set
-# CONFIG_VIDEO_ADV7343 is not set
-# CONFIG_VIDEO_ADV_DEBUG is not set
-# CONFIG_VIDEO_AK881X is not set
-# CONFIG_VIDEO_BT819 is not set
-# CONFIG_VIDEO_BT848 is not set
-# CONFIG_VIDEO_BT856 is not set
-# CONFIG_VIDEO_BT866 is not set
-# CONFIG_VIDEO_BWQCAM is not set
-# CONFIG_VIDEO_CAFE_CCIC is not set
-# CONFIG_VIDEO_CAPTURE_DRIVERS is not set
-# CONFIG_VIDEO_CPIA is not set
-# CONFIG_VIDEO_CQCAM is not set
-# CONFIG_VIDEO_CS5345 is not set
-# CONFIG_VIDEO_CS53L32A is not set
-# CONFIG_VIDEO_CX231XX is not set
-# CONFIG_VIDEO_CX2341X is not set
-# CONFIG_VIDEO_CX25840 is not set
-# CONFIG_VIDEO_CX88 is not set
-# CONFIG_VIDEO_DEV is not set
-# CONFIG_VIDEO_DT3155 is not set
-# CONFIG_VIDEO_EM28XX is not set
-# CONFIG_VIDEO_FIXED_MINOR_RANGES is not set
-# CONFIG_VIDEO_GO7007 is not set
-# CONFIG_VIDEO_HDPVR is not set
-# CONFIG_VIDEO_HELPER_CHIPS_AUTO is not set
-# CONFIG_VIDEO_HEXIUM_GEMINI is not set
-# CONFIG_VIDEO_HEXIUM_ORION is not set
-# CONFIG_VIDEO_IR_I2C is not set
-# CONFIG_VIDEO_IVTV is not set
-# CONFIG_VIDEO_KS0127 is not set
-# CONFIG_VIDEO_M52790 is not set
-# CONFIG_VIDEO_MEDIA is not set
-# CONFIG_VIDEO_MSP3400 is not set
-# CONFIG_VIDEO_MT9V011 is not set
-# CONFIG_VIDEO_MXB is not set
-# CONFIG_VIDEO_NOON010PC30 is not set
-# CONFIG_VIDEO_OUTPUT_CONTROL is not set
-# CONFIG_VIDEO_OV7670 is not set
-# CONFIG_VIDEO_PMS is not set
-# CONFIG_VIDEO_PVRUSB2 is not set
-# CONFIG_VIDEO_SAA6588 is not set
-# CONFIG_VIDEO_SAA7110 is not set
-# CONFIG_VIDEO_SAA711X is not set
-# CONFIG_VIDEO_SAA7127 is not set
-# CONFIG_VIDEO_SAA7134 is not set
-# CONFIG_VIDEO_SAA717X is not set
-# CONFIG_VIDEO_SAA7185 is not set
-# CONFIG_VIDEO_SAA7191 is not set
-# CONFIG_VIDEO_SH_MOBILE_CEU is not set
-# CONFIG_VIDEO_SR030PC30 is not set
-# CONFIG_VIDEO_TCM825X is not set
-# CONFIG_VIDEO_TDA7432 is not set
-# CONFIG_VIDEO_TDA9840 is not set
-# CONFIG_VIDEO_TEA6415C is not set
-# CONFIG_VIDEO_TEA6420 is not set
-# CONFIG_VIDEO_THS7303 is not set
-# CONFIG_VIDEO_TIMBERDALE is not set
-# CONFIG_VIDEO_TLV320AIC23B is not set
-# CONFIG_VIDEO_TM6000 is not set
-# CONFIG_VIDEO_TVAUDIO is not set
-# CONFIG_VIDEO_TVP514X is not set
-# CONFIG_VIDEO_TVP5150 is not set
-# CONFIG_VIDEO_TVP7002 is not set
-# CONFIG_VIDEO_UPD64031A is not set
-# CONFIG_VIDEO_UPD64083 is not set
-# CONFIG_VIDEO_USBVISION is not set
-# CONFIG_VIDEO_V4L2 is not set
-# CONFIG_VIDEO_V4L2_COMMON is not set
-# CONFIG_VIDEO_VIVI is not set
-# CONFIG_VIDEO_VP27SMPX is not set
-# CONFIG_VIDEO_VPX3220 is not set
-# CONFIG_VIDEO_WM8739 is not set
-# CONFIG_VIDEO_WM8775 is not set
-# CONFIG_VIDEO_ZORAN is not set
-# CONFIG_VIRQ_DEBUG is not set
-# CONFIG_VIRTIO_BALLOON is not set
-# CONFIG_VIRTIO_MMIO is not set
-# CONFIG_VIRTIO_PCI is not set
-# CONFIG_VIRTUALIZATION is not set
-# CONFIG_VIRT_DRIVERS is not set
-CONFIG_VIRT_TO_BUS=y
-# CONFIG_VITESSE_PHY is not set
-CONFIG_VLAN_8021Q=y
-# CONFIG_VLAN_8021Q_GVRP is not set
-# CONFIG_VME_BUS is not set
-# CONFIG_VMSPLIT_1G is not set
-# CONFIG_VMSPLIT_2G is not set
-# CONFIG_VMSPLIT_2G_OPT is not set
-CONFIG_VMSPLIT_3G=y
-# CONFIG_VMSPLIT_3G_OPT is not set
-# CONFIG_VMWARE_PVSCSI is not set
-# CONFIG_VMXNET3 is not set
-# CONFIG_VM_EVENT_COUNTERS is not set
-# CONFIG_VORTEX is not set
-# CONFIG_VT is not set
-# CONFIG_VT6655 is not set
-# CONFIG_VT6656 is not set
-# CONFIG_VXFS_FS is not set
-# CONFIG_VXGE is not set
-# CONFIG_W1 is not set
-# CONFIG_W1_CON is not set
-# CONFIG_W1_MASTER_DS1WM is not set
-# CONFIG_W1_MASTER_DS2482 is not set
-# CONFIG_W1_MASTER_DS2490 is not set
-# CONFIG_W1_MASTER_GPIO is not set
-# CONFIG_W1_MASTER_MATROX is not set
-# CONFIG_W1_SLAVE_BQ27000 is not set
-# CONFIG_W1_SLAVE_DS2408 is not set
-# CONFIG_W1_SLAVE_DS2423 is not set
-# CONFIG_W1_SLAVE_DS2431 is not set
-# CONFIG_W1_SLAVE_DS2433 is not set
-# CONFIG_W1_SLAVE_DS2760 is not set
-# CONFIG_W1_SLAVE_DS2780 is not set
-# CONFIG_W1_SLAVE_SMEM is not set
-# CONFIG_W1_SLAVE_THERM is not set
-# CONFIG_W83627HF_WDT is not set
-# CONFIG_W83697HF_WDT is not set
-# CONFIG_W83877F_WDT is not set
-# CONFIG_W83977F_WDT is not set
-# CONFIG_WAN is not set
-# CONFIG_WANXL is not set
-# CONFIG_WAN_ROUTER is not set
-CONFIG_WATCHDOG=y
-# CONFIG_WATCHDOG_CORE is not set
-# CONFIG_WATCHDOG_NOWAYOUT is not set
-# CONFIG_WD80x3 is not set
-# CONFIG_WDTPCI is not set
-CONFIG_WEXT_CORE=y
-CONFIG_WEXT_PRIV=y
-CONFIG_WEXT_PROC=y
-CONFIG_WEXT_SPY=y
-# CONFIG_WIMAX is not set
-CONFIG_WIRELESS=y
-CONFIG_WIRELESS_EXT=y
-# CONFIG_WIRELESS_EXT_SYSFS is not set
-# CONFIG_WLAGS49_H2 is not set
-# CONFIG_WLAGS49_H25 is not set
-CONFIG_WLAN=y
-# CONFIG_WR_PPMC is not set
-# CONFIG_X25 is not set
-CONFIG_XFRM=y
-# CONFIG_XFRM_IPCOMP is not set
-# CONFIG_XFRM_MIGRATE is not set
-# CONFIG_XFRM_STATISTICS is not set
-# CONFIG_XFRM_SUB_POLICY is not set
-# CONFIG_XFRM_USER is not set
-# CONFIG_XFS_DEBUG is not set
-# CONFIG_XFS_FS is not set
-# CONFIG_XFS_POSIX_ACL is not set
-# CONFIG_XFS_QUOTA is not set
-# CONFIG_XFS_RT is not set
-# CONFIG_XILINX_EMACLITE is not set
-# CONFIG_XILINX_LL_TEMAC is not set
-# CONFIG_XIP_KERNEL is not set
-# CONFIG_XMON is not set
-# CONFIG_XVMALLOC is not set
-CONFIG_XZ_DEC=y
-# CONFIG_XZ_DEC_ARM is not set
-# CONFIG_XZ_DEC_ARMTHUMB is not set
-# CONFIG_XZ_DEC_BCJ is not set
-# CONFIG_XZ_DEC_IA64 is not set
-# CONFIG_XZ_DEC_POWERPC is not set
-# CONFIG_XZ_DEC_SPARC is not set
-# CONFIG_XZ_DEC_TEST is not set
-# CONFIG_XZ_DEC_X86 is not set
-# CONFIG_YAM is not set
-# CONFIG_YELLOWFIN is not set
-# CONFIG_YENTA is not set
-# CONFIG_YENTA_O2 is not set
-# CONFIG_YENTA_RICOH is not set
-# CONFIG_YENTA_TI is not set
-# CONFIG_YENTA_TOSHIBA is not set
-# CONFIG_ZD1211RW is not set
-# CONFIG_ZD1211RW_DEBUG is not set
-# CONFIG_ZEROPLUS_FF is not set
-# CONFIG_ZISOFS is not set
-# CONFIG_ZLIB_DEFLATE is not set
-# CONFIG_ZLIB_INFLATE is not set
-# CONFIG_ZNET is not set
-CONFIG_ZONE_DMA=y
-CONFIG_ZONE_DMA_FLAG=1
-# CONFIG_ZRAM is not set
diff --git a/target/linux/generic/patches-3.3/001-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch b/target/linux/generic/patches-3.3/001-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch
deleted file mode 100644 (file)
index 07061b0..0000000
+++ /dev/null
@@ -1,250 +0,0 @@
-From 455bd4c430b0c0a361f38e8658a0d6cb469942b5 Mon Sep 17 00:00:00 2001
-From: Ivan Djelic <ivan.djelic@parrot.com>
-Date: Wed, 6 Mar 2013 20:09:27 +0100
-Subject: [PATCH] ARM: 7668/1: fix memset-related crashes caused by recent GCC
- (4.7.2) optimizations
-
-Recent GCC versions (e.g. GCC-4.7.2) perform optimizations based on
-assumptions about the implementation of memset and similar functions.
-The current ARM optimized memset code does not return the value of
-its first argument, as is usually expected from standard implementations.
-
-For instance in the following function:
-
-void debug_mutex_lock_common(struct mutex *lock, struct mutex_waiter *waiter)
-{
-       memset(waiter, MUTEX_DEBUG_INIT, sizeof(*waiter));
-       waiter->magic = waiter;
-       INIT_LIST_HEAD(&waiter->list);
-}
-
-compiled as:
-
-800554d0 <debug_mutex_lock_common>:
-800554d0:       e92d4008        push    {r3, lr}
-800554d4:       e1a00001        mov     r0, r1
-800554d8:       e3a02010        mov     r2, #16 ; 0x10
-800554dc:       e3a01011        mov     r1, #17 ; 0x11
-800554e0:       eb04426e        bl      80165ea0 <memset>
-800554e4:       e1a03000        mov     r3, r0
-800554e8:       e583000c        str     r0, [r3, #12]
-800554ec:       e5830000        str     r0, [r3]
-800554f0:       e5830004        str     r0, [r3, #4]
-800554f4:       e8bd8008        pop     {r3, pc}
-
-GCC assumes memset returns the value of pointer 'waiter' in register r0; causing
-register/memory corruptions.
-
-This patch fixes the return value of the assembly version of memset.
-It adds a 'mov' instruction and merges an additional load+store into
-existing load/store instructions.
-For ease of review, here is a breakdown of the patch into 4 simple steps:
-
-Step 1
-======
-Perform the following substitutions:
-ip -> r8, then
-r0 -> ip,
-and insert 'mov ip, r0' as the first statement of the function.
-At this point, we have a memset() implementation returning the proper result,
-but corrupting r8 on some paths (the ones that were using ip).
-
-Step 2
-======
-Make sure r8 is saved and restored when (! CALGN(1)+0) == 1:
-
-save r8:
--       str     lr, [sp, #-4]!
-+       stmfd   sp!, {r8, lr}
-
-and restore r8 on both exit paths:
--       ldmeqfd sp!, {pc}               @ Now <64 bytes to go.
-+       ldmeqfd sp!, {r8, pc}           @ Now <64 bytes to go.
-(...)
-        tst     r2, #16
-        stmneia ip!, {r1, r3, r8, lr}
--       ldr     lr, [sp], #4
-+       ldmfd   sp!, {r8, lr}
-
-Step 3
-======
-Make sure r8 is saved and restored when (! CALGN(1)+0) == 0:
-
-save r8:
--       stmfd   sp!, {r4-r7, lr}
-+       stmfd   sp!, {r4-r8, lr}
-
-and restore r8 on both exit paths:
-        bgt     3b
--       ldmeqfd sp!, {r4-r7, pc}
-+       ldmeqfd sp!, {r4-r8, pc}
-(...)
-        tst     r2, #16
-        stmneia ip!, {r4-r7}
--       ldmfd   sp!, {r4-r7, lr}
-+       ldmfd   sp!, {r4-r8, lr}
-
-Step 4
-======
-Rewrite register list "r4-r7, r8" as "r4-r8".
-
-Signed-off-by: Ivan Djelic <ivan.djelic@parrot.com>
-Reviewed-by: Nicolas Pitre <nico@linaro.org>
-Signed-off-by: Dirk Behme <dirk.behme@gmail.com>
-Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
----
- arch/arm/lib/memset.S | 85 ++++++++++++++++++++++++++-------------------------
- 1 file changed, 44 insertions(+), 41 deletions(-)
-
---- a/arch/arm/lib/memset.S
-+++ b/arch/arm/lib/memset.S
-@@ -19,9 +19,9 @@
- 1:    subs    r2, r2, #4              @ 1 do we have enough
-       blt     5f                      @ 1 bytes to align with?
-       cmp     r3, #2                  @ 1
--      strltb  r1, [r0], #1            @ 1
--      strleb  r1, [r0], #1            @ 1
--      strb    r1, [r0], #1            @ 1
-+      strltb  r1, [ip], #1            @ 1
-+      strleb  r1, [ip], #1            @ 1
-+      strb    r1, [ip], #1            @ 1
-       add     r2, r2, r3              @ 1 (r2 = r2 - (4 - r3))
- /*
-  * The pointer is now aligned and the length is adjusted.  Try doing the
-@@ -29,10 +29,14 @@
-  */
- ENTRY(memset)
--      ands    r3, r0, #3              @ 1 unaligned?
-+/*
-+ * Preserve the contents of r0 for the return value.
-+ */
-+      mov     ip, r0
-+      ands    r3, ip, #3              @ 1 unaligned?
-       bne     1b                      @ 1
- /*
-- * we know that the pointer in r0 is aligned to a word boundary.
-+ * we know that the pointer in ip is aligned to a word boundary.
-  */
-       orr     r1, r1, r1, lsl #8
-       orr     r1, r1, r1, lsl #16
-@@ -43,29 +47,28 @@ ENTRY(memset)
- #if ! CALGN(1)+0
- /*
-- * We need an extra register for this loop - save the return address and
-- * use the LR
-+ * We need 2 extra registers for this loop - use r8 and the LR
-  */
--      str     lr, [sp, #-4]!
--      mov     ip, r1
-+      stmfd   sp!, {r8, lr}
-+      mov     r8, r1
-       mov     lr, r1
- 2:    subs    r2, r2, #64
--      stmgeia r0!, {r1, r3, ip, lr}   @ 64 bytes at a time.
--      stmgeia r0!, {r1, r3, ip, lr}
--      stmgeia r0!, {r1, r3, ip, lr}
--      stmgeia r0!, {r1, r3, ip, lr}
-+      stmgeia ip!, {r1, r3, r8, lr}   @ 64 bytes at a time.
-+      stmgeia ip!, {r1, r3, r8, lr}
-+      stmgeia ip!, {r1, r3, r8, lr}
-+      stmgeia ip!, {r1, r3, r8, lr}
-       bgt     2b
--      ldmeqfd sp!, {pc}               @ Now <64 bytes to go.
-+      ldmeqfd sp!, {r8, pc}           @ Now <64 bytes to go.
- /*
-  * No need to correct the count; we're only testing bits from now on
-  */
-       tst     r2, #32
--      stmneia r0!, {r1, r3, ip, lr}
--      stmneia r0!, {r1, r3, ip, lr}
-+      stmneia ip!, {r1, r3, r8, lr}
-+      stmneia ip!, {r1, r3, r8, lr}
-       tst     r2, #16
--      stmneia r0!, {r1, r3, ip, lr}
--      ldr     lr, [sp], #4
-+      stmneia ip!, {r1, r3, r8, lr}
-+      ldmfd   sp!, {r8, lr}
- #else
-@@ -74,54 +77,54 @@ ENTRY(memset)
-  * whole cache lines at once.
-  */
--      stmfd   sp!, {r4-r7, lr}
-+      stmfd   sp!, {r4-r8, lr}
-       mov     r4, r1
-       mov     r5, r1
-       mov     r6, r1
-       mov     r7, r1
--      mov     ip, r1
-+      mov     r8, r1
-       mov     lr, r1
-       cmp     r2, #96
--      tstgt   r0, #31
-+      tstgt   ip, #31
-       ble     3f
--      and     ip, r0, #31
--      rsb     ip, ip, #32
--      sub     r2, r2, ip
--      movs    ip, ip, lsl #(32 - 4)
--      stmcsia r0!, {r4, r5, r6, r7}
--      stmmiia r0!, {r4, r5}
--      tst     ip, #(1 << 30)
--      mov     ip, r1
--      strne   r1, [r0], #4
-+      and     r8, ip, #31
-+      rsb     r8, r8, #32
-+      sub     r2, r2, r8
-+      movs    r8, r8, lsl #(32 - 4)
-+      stmcsia ip!, {r4, r5, r6, r7}
-+      stmmiia ip!, {r4, r5}
-+      tst     r8, #(1 << 30)
-+      mov     r8, r1
-+      strne   r1, [ip], #4
- 3:    subs    r2, r2, #64
--      stmgeia r0!, {r1, r3-r7, ip, lr}
--      stmgeia r0!, {r1, r3-r7, ip, lr}
-+      stmgeia ip!, {r1, r3-r8, lr}
-+      stmgeia ip!, {r1, r3-r8, lr}
-       bgt     3b
--      ldmeqfd sp!, {r4-r7, pc}
-+      ldmeqfd sp!, {r4-r8, pc}
-       tst     r2, #32
--      stmneia r0!, {r1, r3-r7, ip, lr}
-+      stmneia ip!, {r1, r3-r8, lr}
-       tst     r2, #16
--      stmneia r0!, {r4-r7}
--      ldmfd   sp!, {r4-r7, lr}
-+      stmneia ip!, {r4-r7}
-+      ldmfd   sp!, {r4-r8, lr}
- #endif
- 4:    tst     r2, #8
--      stmneia r0!, {r1, r3}
-+      stmneia ip!, {r1, r3}
-       tst     r2, #4
--      strne   r1, [r0], #4
-+      strne   r1, [ip], #4
- /*
-  * When we get here, we've got less than 4 bytes to zero.  We
-  * may have an unaligned pointer as well.
-  */
- 5:    tst     r2, #2
--      strneb  r1, [r0], #1
--      strneb  r1, [r0], #1
-+      strneb  r1, [ip], #1
-+      strneb  r1, [ip], #1
-       tst     r2, #1
--      strneb  r1, [r0], #1
-+      strneb  r1, [ip], #1
-       mov     pc, lr
- ENDPROC(memset)
diff --git a/target/linux/generic/patches-3.3/002-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch b/target/linux/generic/patches-3.3/002-ARM-7668-1-fix-memset-related-crashes-caused-by-rece.patch
deleted file mode 100644 (file)
index 266e507..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-From 418df63adac56841ef6b0f1fcf435bc64d4ed177 Mon Sep 17 00:00:00 2001
-From: Nicolas Pitre <nicolas.pitre@linaro.org>
-Date: Tue, 12 Mar 2013 13:00:42 +0100
-Subject: [PATCH] ARM: 7670/1: fix the memset fix
-
-Commit 455bd4c430b0 ("ARM: 7668/1: fix memset-related crashes caused by
-recent GCC (4.7.2) optimizations") attempted to fix a compliance issue
-with the memset return value.  However the memset itself became broken
-by that patch for misaligned pointers.
-
-This fixes the above by branching over the entry code from the
-misaligned fixup code to avoid reloading the original pointer.
-
-Also, because the function entry alignment is wrong in the Thumb mode
-compilation, that fixup code is moved to the end.
-
-While at it, the entry instructions are slightly reworked to help dual
-issue pipelines.
-
-Signed-off-by: Nicolas Pitre <nico@linaro.org>
-Tested-by: Alexander Holler <holler@ahsoftware.de>
-Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
----
- arch/arm/lib/memset.S | 33 +++++++++++++--------------------
- 1 file changed, 13 insertions(+), 20 deletions(-)
-
---- a/arch/arm/lib/memset.S
-+++ b/arch/arm/lib/memset.S
-@@ -14,31 +14,15 @@
-       .text
-       .align  5
--      .word   0
--
--1:    subs    r2, r2, #4              @ 1 do we have enough
--      blt     5f                      @ 1 bytes to align with?
--      cmp     r3, #2                  @ 1
--      strltb  r1, [ip], #1            @ 1
--      strleb  r1, [ip], #1            @ 1
--      strb    r1, [ip], #1            @ 1
--      add     r2, r2, r3              @ 1 (r2 = r2 - (4 - r3))
--/*
-- * The pointer is now aligned and the length is adjusted.  Try doing the
-- * memset again.
-- */
- ENTRY(memset)
--/*
-- * Preserve the contents of r0 for the return value.
-- */
--      mov     ip, r0
--      ands    r3, ip, #3              @ 1 unaligned?
--      bne     1b                      @ 1
-+      ands    r3, r0, #3              @ 1 unaligned?
-+      mov     ip, r0                  @ preserve r0 as return value
-+      bne     6f                      @ 1
- /*
-  * we know that the pointer in ip is aligned to a word boundary.
-  */
--      orr     r1, r1, r1, lsl #8
-+1:    orr     r1, r1, r1, lsl #8
-       orr     r1, r1, r1, lsl #16
-       mov     r3, r1
-       cmp     r2, #16
-@@ -127,4 +111,13 @@ ENTRY(memset)
-       tst     r2, #1
-       strneb  r1, [ip], #1
-       mov     pc, lr
-+
-+6:    subs    r2, r2, #4              @ 1 do we have enough
-+      blt     5b                      @ 1 bytes to align with?
-+      cmp     r3, #2                  @ 1
-+      strltb  r1, [ip], #1            @ 1
-+      strleb  r1, [ip], #1            @ 1
-+      strb    r1, [ip], #1            @ 1
-+      add     r2, r2, r3              @ 1 (r2 = r2 - (4 - r3))
-+      b       1b
- ENDPROC(memset)
diff --git a/target/linux/generic/patches-3.3/003-MIPS-Refactor-clear_page-and-copy_page-functions.patch b/target/linux/generic/patches-3.3/003-MIPS-Refactor-clear_page-and-copy_page-functions.patch
deleted file mode 100644 (file)
index da85701..0000000
+++ /dev/null
@@ -1,249 +0,0 @@
-From c022630633624a75b3b58f43dd3c6cc896a56cff Mon Sep 17 00:00:00 2001
-From: "Steven J. Hill" <sjhill@mips.com>
-Date: Fri, 6 Jul 2012 21:56:01 +0200
-Subject: [PATCH] MIPS: Refactor 'clear_page' and 'copy_page' functions.
-
-Remove usage of the '__attribute__((alias("...")))' hack that aliased
-to integer arrays containing micro-assembled instructions. This hack
-breaks when building a microMIPS kernel. It also makes the code much
-easier to understand.
-
-[ralf@linux-mips.org: Added back export of the clear_page and copy_page
-symbols so certain modules will work again.  Also fixed build with
-CONFIG_SIBYTE_DMA_PAGEOPS enabled.]
-
-Signed-off-by: Steven J. Hill <sjhill@mips.com>
-Cc: linux-mips@linux-mips.org
-Patchwork: https://patchwork.linux-mips.org/patch/3866/
-Acked-by: David Daney <david.daney@cavium.com>
-Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
----
- arch/mips/kernel/mips_ksyms.c |    8 ++++-
- arch/mips/mm/Makefile         |    4 +--
- arch/mips/mm/page-funcs.S     |   50 ++++++++++++++++++++++++++++++
- arch/mips/mm/page.c           |   67 +++++++++++------------------------------
- 4 files changed, 77 insertions(+), 52 deletions(-)
- create mode 100644 arch/mips/mm/page-funcs.S
-
---- a/arch/mips/kernel/mips_ksyms.c
-+++ b/arch/mips/kernel/mips_ksyms.c
-@@ -5,7 +5,7 @@
-  * License.  See the file "COPYING" in the main directory of this archive
-  * for more details.
-  *
-- * Copyright (C) 1996, 97, 98, 99, 2000, 01, 03, 04, 05 by Ralf Baechle
-+ * Copyright (C) 1996, 97, 98, 99, 2000, 01, 03, 04, 05, 12 by Ralf Baechle
-  * Copyright (C) 1999, 2000, 01 Silicon Graphics, Inc.
-  */
- #include <linux/interrupt.h>
-@@ -35,6 +35,12 @@ EXPORT_SYMBOL(memmove);
- EXPORT_SYMBOL(kernel_thread);
- /*
-+ * Functions that operate on entire pages.  Mostly used by memory management.
-+ */
-+EXPORT_SYMBOL(clear_page);
-+EXPORT_SYMBOL(copy_page);
-+
-+/*
-  * Userspace access stuff.
-  */
- EXPORT_SYMBOL(__copy_user);
---- a/arch/mips/mm/Makefile
-+++ b/arch/mips/mm/Makefile
-@@ -3,8 +3,8 @@
- #
- obj-y                         += cache.o dma-default.o extable.o fault.o \
--                                 gup.o init.o mmap.o page.o tlbex.o \
--                                 tlbex-fault.o uasm.o
-+                                 gup.o init.o mmap.o page.o page-funcs.o \
-+                                 tlbex.o tlbex-fault.o uasm.o
- obj-$(CONFIG_32BIT)           += ioremap.o pgtable-32.o
- obj-$(CONFIG_64BIT)           += pgtable-64.o
---- /dev/null
-+++ b/arch/mips/mm/page-funcs.S
-@@ -0,0 +1,50 @@
-+/*
-+ * This file is subject to the terms and conditions of the GNU General Public
-+ * License.  See the file "COPYING" in the main directory of this archive
-+ * for more details.
-+ *
-+ * Micro-assembler generated clear_page/copy_page functions.
-+ *
-+ * Copyright (C) 2012  MIPS Technologies, Inc.
-+ * Copyright (C) 2012  Ralf Baechle <ralf@linux-mips.org>
-+ */
-+#include <asm/asm.h>
-+#include <asm/regdef.h>
-+
-+#ifdef CONFIG_SIBYTE_DMA_PAGEOPS
-+#define cpu_clear_page_function_name  clear_page_cpu
-+#define cpu_copy_page_function_name   copy_page_cpu
-+#else
-+#define cpu_clear_page_function_name  clear_page
-+#define cpu_copy_page_function_name   copy_page
-+#endif
-+
-+/*
-+ * Maximum sizes:
-+ *
-+ * R4000 128 bytes S-cache:           0x058 bytes
-+ * R4600 v1.7:                                0x05c bytes
-+ * R4600 v2.0:                                0x060 bytes
-+ * With prefetching, 16 word strides  0x120 bytes
-+ */
-+EXPORT(__clear_page_start)
-+LEAF(cpu_clear_page_function_name)
-+1:    j       1b              /* Dummy, will be replaced. */
-+      .space 288
-+END(cpu_clear_page_function_name)
-+EXPORT(__clear_page_end)
-+
-+/*
-+ * Maximum sizes:
-+ *
-+ * R4000 128 bytes S-cache:           0x11c bytes
-+ * R4600 v1.7:                                0x080 bytes
-+ * R4600 v2.0:                                0x07c bytes
-+ * With prefetching, 16 word strides  0x540 bytes
-+ */
-+EXPORT(__copy_page_start)
-+LEAF(cpu_copy_page_function_name)
-+1:    j       1b              /* Dummy, will be replaced. */
-+      .space 1344
-+END(cpu_copy_page_function_name)
-+EXPORT(__copy_page_end)
---- a/arch/mips/mm/page.c
-+++ b/arch/mips/mm/page.c
-@@ -6,6 +6,7 @@
-  * Copyright (C) 2003, 04, 05 Ralf Baechle (ralf@linux-mips.org)
-  * Copyright (C) 2007  Maciej W. Rozycki
-  * Copyright (C) 2008  Thiemo Seufer
-+ * Copyright (C) 2012  MIPS Technologies, Inc.
-  */
- #include <linux/init.h>
- #include <linux/kernel.h>
-@@ -72,45 +73,6 @@ static struct uasm_reloc __cpuinitdata r
- #define cpu_is_r4600_v1_x()   ((read_c0_prid() & 0xfffffff0) == 0x00002010)
- #define cpu_is_r4600_v2_x()   ((read_c0_prid() & 0xfffffff0) == 0x00002020)
--/*
-- * Maximum sizes:
-- *
-- * R4000 128 bytes S-cache:           0x058 bytes
-- * R4600 v1.7:                                0x05c bytes
-- * R4600 v2.0:                                0x060 bytes
-- * With prefetching, 16 word strides  0x120 bytes
-- */
--
--static u32 clear_page_array[0x120 / 4];
--
--#ifdef CONFIG_SIBYTE_DMA_PAGEOPS
--void clear_page_cpu(void *page) __attribute__((alias("clear_page_array")));
--#else
--void clear_page(void *page) __attribute__((alias("clear_page_array")));
--#endif
--
--EXPORT_SYMBOL(clear_page);
--
--/*
-- * Maximum sizes:
-- *
-- * R4000 128 bytes S-cache:           0x11c bytes
-- * R4600 v1.7:                                0x080 bytes
-- * R4600 v2.0:                                0x07c bytes
-- * With prefetching, 16 word strides  0x540 bytes
-- */
--static u32 copy_page_array[0x540 / 4];
--
--#ifdef CONFIG_SIBYTE_DMA_PAGEOPS
--void
--copy_page_cpu(void *to, void *from) __attribute__((alias("copy_page_array")));
--#else
--void copy_page(void *to, void *from) __attribute__((alias("copy_page_array")));
--#endif
--
--EXPORT_SYMBOL(copy_page);
--
--
- static int pref_bias_clear_store __cpuinitdata;
- static int pref_bias_copy_load __cpuinitdata;
- static int pref_bias_copy_store __cpuinitdata;
-@@ -283,10 +245,15 @@ static inline void __cpuinit build_clear
-               }
- }
-+extern u32 __clear_page_start;
-+extern u32 __clear_page_end;
-+extern u32 __copy_page_start;
-+extern u32 __copy_page_end;
-+
- void __cpuinit build_clear_page(void)
- {
-       int off;
--      u32 *buf = (u32 *)&clear_page_array;
-+      u32 *buf = &__clear_page_start;
-       struct uasm_label *l = labels;
-       struct uasm_reloc *r = relocs;
-       int i;
-@@ -357,17 +324,17 @@ void __cpuinit build_clear_page(void)
-       uasm_i_jr(&buf, RA);
-       uasm_i_nop(&buf);
--      BUG_ON(buf > clear_page_array + ARRAY_SIZE(clear_page_array));
-+      BUG_ON(buf > &__clear_page_end);
-       uasm_resolve_relocs(relocs, labels);
-       pr_debug("Synthesized clear page handler (%u instructions).\n",
--               (u32)(buf - clear_page_array));
-+               (u32)(buf - &__clear_page_start));
-       pr_debug("\t.set push\n");
-       pr_debug("\t.set noreorder\n");
--      for (i = 0; i < (buf - clear_page_array); i++)
--              pr_debug("\t.word 0x%08x\n", clear_page_array[i]);
-+      for (i = 0; i < (buf - &__clear_page_start); i++)
-+              pr_debug("\t.word 0x%08x\n", (&__clear_page_start)[i]);
-       pr_debug("\t.set pop\n");
- }
-@@ -428,7 +395,7 @@ static inline void build_copy_store_pref
- void __cpuinit build_copy_page(void)
- {
-       int off;
--      u32 *buf = (u32 *)&copy_page_array;
-+      u32 *buf = &__copy_page_start;
-       struct uasm_label *l = labels;
-       struct uasm_reloc *r = relocs;
-       int i;
-@@ -596,21 +563,23 @@ void __cpuinit build_copy_page(void)
-       uasm_i_jr(&buf, RA);
-       uasm_i_nop(&buf);
--      BUG_ON(buf > copy_page_array + ARRAY_SIZE(copy_page_array));
-+      BUG_ON(buf > &__copy_page_end);
-       uasm_resolve_relocs(relocs, labels);
-       pr_debug("Synthesized copy page handler (%u instructions).\n",
--               (u32)(buf - copy_page_array));
-+               (u32)(buf - &__copy_page_start));
-       pr_debug("\t.set push\n");
-       pr_debug("\t.set noreorder\n");
--      for (i = 0; i < (buf - copy_page_array); i++)
--              pr_debug("\t.word 0x%08x\n", copy_page_array[i]);
-+      for (i = 0; i < (buf - &__copy_page_start); i++)
-+              pr_debug("\t.word 0x%08x\n", (&__copy_page_start)[i]);
-       pr_debug("\t.set pop\n");
- }
- #ifdef CONFIG_SIBYTE_DMA_PAGEOPS
-+extern void clear_page_cpu(void *page);
-+extern void copy_page_cpu(void *to, void *from);
- /*
-  * Pad descriptors to cacheline, since each is exclusively owned by a
diff --git a/target/linux/generic/patches-3.3/006-arm_kernel_xz_support.patch b/target/linux/generic/patches-3.3/006-arm_kernel_xz_support.patch
deleted file mode 100644 (file)
index bfb1757..0000000
+++ /dev/null
@@ -1,96 +0,0 @@
-From 2d303b4683145f7dbc918bd14d04e1396581b2ce Mon Sep 17 00:00:00 2001
-From: Imre Kaloz <kaloz@openwrt.org>
-Date: Thu, 7 Jul 2011 12:05:21 +0200
-Subject: [PATCH] ARM: support XZ compressed kernels
-
-Wire up support for the XZ decompressor
-
-Signed-off-by: Imre Kaloz <kaloz@openwrt.org>
----
- arch/arm/Kconfig                        |    1 +
- arch/arm/boot/compressed/Makefile       |   11 +++++++++--
- arch/arm/boot/compressed/decompress.c   |    4 ++++
- arch/arm/boot/compressed/piggy.xzkern.S |    6 ++++++
- lib/xz/xz_dec_stream.c                  |    1 +
- 5 files changed, 21 insertions(+), 2 deletions(-)
- create mode 100644 arch/arm/boot/compressed/piggy.xzkern.S
-
---- a/arch/arm/Kconfig
-+++ b/arch/arm/Kconfig
-@@ -21,6 +21,7 @@ config ARM
-       select HAVE_KERNEL_GZIP
-       select HAVE_KERNEL_LZO
-       select HAVE_KERNEL_LZMA
-+      select HAVE_KERNEL_XZ
-       select HAVE_IRQ_WORK
-       select HAVE_PERF_EVENTS
-       select PERF_USE_VMALLOC
---- a/arch/arm/boot/compressed/Makefile
-+++ b/arch/arm/boot/compressed/Makefile
-@@ -92,6 +92,7 @@ SEDFLAGS     = s/TEXT_START/$(ZTEXTADDR)/;s/
- suffix_$(CONFIG_KERNEL_GZIP) = gzip
- suffix_$(CONFIG_KERNEL_LZO)  = lzo
- suffix_$(CONFIG_KERNEL_LZMA) = lzma
-+suffix_$(CONFIG_KERNEL_XZ)   = xzkern
- # Borrowed libfdt files for the ATAG compatibility mode
-@@ -115,7 +116,7 @@ targets       := vmlinux vmlinux.lds \
-                lib1funcs.o lib1funcs.S font.o font.c head.o misc.o $(OBJS)
- # Make sure files are removed during clean
--extra-y       += piggy.gzip piggy.lzo piggy.lzma lib1funcs.S $(libfdt) $(libfdt_hdrs)
-+extra-y       += piggy.gzip piggy.lzo piggy.lzma piggy.xzkern lib1funcs.S ashldi3.S $(libfdt) $(libfdt_hdrs)
- ifeq ($(CONFIG_FUNCTION_TRACER),y)
- ORIG_CFLAGS := $(KBUILD_CFLAGS)
-@@ -171,8 +172,14 @@ if [ $(words $(ZRELADDR)) -gt 1 -a "$(CO
-       false; \
- fi
-+# For __aeabi_llsl
-+ashldi3 = $(obj)/ashldi3.o
-+
-+$(obj)/ashldi3.S: $(srctree)/arch/$(SRCARCH)/lib/ashldi3.S FORCE
-+      $(call cmd,shipped)
-+
- $(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/$(HEAD) $(obj)/piggy.$(suffix_y).o \
--              $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) FORCE
-+              $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) $(ashldi3) FORCE
-       @$(check_for_multiple_zreladdr)
-       $(call if_changed,ld)
-       @$(check_for_bad_syms)
---- a/arch/arm/boot/compressed/decompress.c
-+++ b/arch/arm/boot/compressed/decompress.c
-@@ -44,6 +44,12 @@ extern void error(char *);
- #include "../../../../lib/decompress_unlzma.c"
- #endif
-+#ifdef CONFIG_KERNEL_XZ
-+#define memmove memmove
-+#define memcpy memcpy
-+#include "../../../../lib/decompress_unxz.c"
-+#endif
-+
- int do_decompress(u8 *input, int len, u8 *output, void (*error)(char *x))
- {
-       return decompress(input, len, NULL, NULL, output, NULL, error);
---- /dev/null
-+++ b/arch/arm/boot/compressed/piggy.xzkern.S
-@@ -0,0 +1,6 @@
-+      .section .piggydata,#alloc
-+      .globl  input_data
-+input_data:
-+      .incbin "arch/arm/boot/compressed/piggy.xzkern"
-+      .globl  input_data_end
-+input_data_end:
---- a/lib/xz/xz_dec_stream.c
-+++ b/lib/xz/xz_dec_stream.c
-@@ -9,6 +9,7 @@
- #include "xz_private.h"
- #include "xz_stream.h"
-+#include <linux/kernel.h>
- /* Hash used to validate the Index field */
- struct xz_dec_hash {
diff --git a/target/linux/generic/patches-3.3/007-hso-Earlier-catch-of-error-condition.patch b/target/linux/generic/patches-3.3/007-hso-Earlier-catch-of-error-condition.patch
deleted file mode 100644 (file)
index bbc2b82..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-From 35e57e1b49a351aa804dab6010cd46ae6112a541 Mon Sep 17 00:00:00 2001
-From: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
-Date: Wed, 21 Aug 2013 01:43:07 -0700
-Subject: [PATCH 1/2] hso: Earlier catch of error condition
-
-There is no need to get an interface specification if we know it's the
-wrong one.
-
-Signed-off-by: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
-Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-Signed-off-by: David S. Miller <davem@davemloft.net>
----
- drivers/net/usb/hso.c |    9 +++++----
- 1 file changed, 5 insertions(+), 4 deletions(-)
-
---- a/drivers/net/usb/hso.c
-+++ b/drivers/net/usb/hso.c
-@@ -2927,6 +2927,11 @@ static int hso_probe(struct usb_interfac
-       struct hso_shared_int *shared_int;
-       struct hso_device *tmp_dev = NULL;
-+      if (interface->cur_altsetting->desc.bInterfaceClass != 0xFF) {
-+              dev_err(&interface->dev, "Not our interface\n");
-+              return -ENODEV;
-+      }
-+
-       if_num = interface->altsetting->desc.bInterfaceNumber;
-       /* Get the interface/port specification from either driver_info or from
-@@ -2936,10 +2941,6 @@ static int hso_probe(struct usb_interfac
-       else
-               port_spec = hso_get_config_data(interface);
--      if (interface->cur_altsetting->desc.bInterfaceClass != 0xFF) {
--              dev_err(&interface->dev, "Not our interface\n");
--              return -ENODEV;
--      }
-       /* Check if we need to switch to alt interfaces prior to port
-        * configuration */
-       if (interface->num_altsetting > 1)
diff --git a/target/linux/generic/patches-3.3/008-hso-Fix-stack-corruption-on-some-architectures.patch b/target/linux/generic/patches-3.3/008-hso-Fix-stack-corruption-on-some-architectures.patch
deleted file mode 100644 (file)
index e5b7e4b..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-From e75dc677ff8d06ffa61bef6fee436227ae5440c6 Mon Sep 17 00:00:00 2001
-From: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
-Date: Wed, 21 Aug 2013 01:43:19 -0700
-Subject: [PATCH 2/2] hso: Fix stack corruption on some architectures
-
-As Sergei Shtylyov explained in the #mipslinux IRC channel:
-[Mon 2013-08-19 12:28:21 PM PDT] <headless> guys, are you sure it's not "DMA off stack" case?
-[Mon 2013-08-19 12:28:35 PM PDT] <headless> it's a known stack corruptor on non-coherent arches
-[Mon 2013-08-19 12:31:48 PM PDT] <DonkeyHotei> headless: for usb/ehci?
-[Mon 2013-08-19 12:34:11 PM PDT] <DonkeyHotei> headless: explain
-[Mon 2013-08-19 12:35:38 PM PDT] <headless> usb_control_msg() (or other such func) should not use buffer on stack. DMA from/to stack is prohibited
-[Mon 2013-08-19 12:35:58 PM PDT] <headless> and EHCI uses DMA on control xfers (as well as all the others)
-
-Signed-off-by: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
-Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-Signed-off-by: David S. Miller <davem@davemloft.net>
----
- drivers/net/usb/hso.c |    6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
---- a/drivers/net/usb/hso.c
-+++ b/drivers/net/usb/hso.c
-@@ -2857,13 +2857,16 @@ exit:
- static int hso_get_config_data(struct usb_interface *interface)
- {
-       struct usb_device *usbdev = interface_to_usbdev(interface);
--      u8 config_data[17];
-+      u8 *config_data = kmalloc(17, GFP_KERNEL);
-       u32 if_num = interface->altsetting->desc.bInterfaceNumber;
-       s32 result;
-+      if (!config_data)
-+              return -ENOMEM;
-       if (usb_control_msg(usbdev, usb_rcvctrlpipe(usbdev, 0),
-                           0x86, 0xC0, 0, 0, config_data, 17,
-                           USB_CTRL_SET_TIMEOUT) != 0x11) {
-+              kfree(config_data);
-               return -EIO;
-       }
-@@ -2914,6 +2917,7 @@ static int hso_get_config_data(struct us
-       if (config_data[16] & 0x1)
-               result |= HSO_INFO_CRC_BUG;
-+      kfree(config_data);
-       return result;
- }
diff --git a/target/linux/generic/patches-3.3/020-ssb_update.patch b/target/linux/generic/patches-3.3/020-ssb_update.patch
deleted file mode 100644 (file)
index 5354cc7..0000000
+++ /dev/null
@@ -1,3206 +0,0 @@
---- a/arch/mips/bcm47xx/nvram.c
-+++ b/arch/mips/bcm47xx/nvram.c
-@@ -43,8 +43,8 @@ static void early_nvram_init(void)
- #ifdef CONFIG_BCM47XX_SSB
-       case BCM47XX_BUS_TYPE_SSB:
-               mcore_ssb = &bcm47xx_bus.ssb.mipscore;
--              base = mcore_ssb->flash_window;
--              lim = mcore_ssb->flash_window_size;
-+              base = mcore_ssb->pflash.window;
-+              lim = mcore_ssb->pflash.window_size;
-               break;
- #endif
- #ifdef CONFIG_BCM47XX_BCMA
---- a/arch/mips/bcm47xx/wgt634u.c
-+++ b/arch/mips/bcm47xx/wgt634u.c
-@@ -156,10 +156,10 @@ static int __init wgt634u_init(void)
-                                           SSB_CHIPCO_IRQ_GPIO);
-               }
--              wgt634u_flash_data.width = mcore->flash_buswidth;
--              wgt634u_flash_resource.start = mcore->flash_window;
--              wgt634u_flash_resource.end = mcore->flash_window
--                                         + mcore->flash_window_size
-+              wgt634u_flash_data.width = mcore->pflash.buswidth;
-+              wgt634u_flash_resource.start = mcore->pflash.window;
-+              wgt634u_flash_resource.end = mcore->pflash.window
-+                                         + mcore->pflash.window_size
-                                          - 1;
-               return platform_add_devices(wgt634u_devices,
-                                           ARRAY_SIZE(wgt634u_devices));
---- a/drivers/ssb/Kconfig
-+++ b/drivers/ssb/Kconfig
-@@ -136,10 +136,15 @@ config SSB_DRIVER_MIPS
-         If unsure, say N
-+config SSB_SFLASH
-+      bool "SSB serial flash support"
-+      depends on SSB_DRIVER_MIPS
-+      default y
-+
- # Assumption: We are on embedded, if we compile the MIPS core.
- config SSB_EMBEDDED
-       bool
--      depends on SSB_DRIVER_MIPS
-+      depends on SSB_DRIVER_MIPS && SSB_PCICORE_HOSTMODE
-       default y
- config SSB_DRIVER_EXTIF
-@@ -160,4 +165,12 @@ config SSB_DRIVER_GIGE
-         If unsure, say N
-+config SSB_DRIVER_GPIO
-+      bool "SSB GPIO driver"
-+      depends on SSB && GPIOLIB
-+      help
-+        Driver to provide access to the GPIO pins on the bus.
-+
-+        If unsure, say N
-+
- endmenu
---- a/drivers/ssb/Makefile
-+++ b/drivers/ssb/Makefile
-@@ -11,10 +11,12 @@ ssb-$(CONFIG_SSB_SDIOHOST)         += sdio.o
- # built-in drivers
- ssb-y                                 += driver_chipcommon.o
- ssb-y                                 += driver_chipcommon_pmu.o
-+ssb-$(CONFIG_SSB_SFLASH)              += driver_chipcommon_sflash.o
- ssb-$(CONFIG_SSB_DRIVER_MIPS)         += driver_mipscore.o
- ssb-$(CONFIG_SSB_DRIVER_EXTIF)                += driver_extif.o
- ssb-$(CONFIG_SSB_DRIVER_PCICORE)      += driver_pcicore.o
- ssb-$(CONFIG_SSB_DRIVER_GIGE)         += driver_gige.o
-+ssb-$(CONFIG_SSB_DRIVER_GPIO)         += driver_gpio.o
- # b43 pci-ssb-bridge driver
- # Not strictly a part of SSB, but kept here for convenience
---- a/drivers/ssb/b43_pci_bridge.c
-+++ b/drivers/ssb/b43_pci_bridge.c
-@@ -29,11 +29,15 @@ static const struct pci_device_id b43_pc
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4319) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4320) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4321) },
-+      { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4322) },
-+      { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43222) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4324) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4325) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4328) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4329) },
-       { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x432b) },
-+      { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x432c) },
-+      { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4350) },
-       { 0, },
- };
- MODULE_DEVICE_TABLE(pci, b43_pci_bridge_tbl);
---- a/drivers/ssb/driver_chipcommon.c
-+++ b/drivers/ssb/driver_chipcommon.c
-@@ -4,6 +4,7 @@
-  *
-  * Copyright 2005, Broadcom Corporation
-  * Copyright 2006, 2007, Michael Buesch <m@bues.ch>
-+ * Copyright 2012, Hauke Mehrtens <hauke@hauke-m.de>
-  *
-  * Licensed under the GNU/GPL. See COPYING for details.
-  */
-@@ -12,6 +13,7 @@
- #include <linux/ssb/ssb_regs.h>
- #include <linux/export.h>
- #include <linux/pci.h>
-+#include <linux/bcm47xx_wdt.h>
- #include "ssb_private.h"
-@@ -280,13 +282,79 @@ static void calc_fast_powerup_delay(stru
-       cc->fast_pwrup_delay = tmp;
- }
-+static u32 ssb_chipco_alp_clock(struct ssb_chipcommon *cc)
-+{
-+      if (cc->capabilities & SSB_CHIPCO_CAP_PMU)
-+              return ssb_pmu_get_alp_clock(cc);
-+
-+      return 20000000;
-+}
-+
-+static u32 ssb_chipco_watchdog_get_max_timer(struct ssb_chipcommon *cc)
-+{
-+      u32 nb;
-+
-+      if (cc->capabilities & SSB_CHIPCO_CAP_PMU) {
-+              if (cc->dev->id.revision < 26)
-+                      nb = 16;
-+              else
-+                      nb = (cc->dev->id.revision >= 37) ? 32 : 24;
-+      } else {
-+              nb = 28;
-+      }
-+      if (nb == 32)
-+              return 0xffffffff;
-+      else
-+              return (1 << nb) - 1;
-+}
-+
-+u32 ssb_chipco_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt, u32 ticks)
-+{
-+      struct ssb_chipcommon *cc = bcm47xx_wdt_get_drvdata(wdt);
-+
-+      if (cc->dev->bus->bustype != SSB_BUSTYPE_SSB)
-+              return 0;
-+
-+      return ssb_chipco_watchdog_timer_set(cc, ticks);
-+}
-+
-+u32 ssb_chipco_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms)
-+{
-+      struct ssb_chipcommon *cc = bcm47xx_wdt_get_drvdata(wdt);
-+      u32 ticks;
-+
-+      if (cc->dev->bus->bustype != SSB_BUSTYPE_SSB)
-+              return 0;
-+
-+      ticks = ssb_chipco_watchdog_timer_set(cc, cc->ticks_per_ms * ms);
-+      return ticks / cc->ticks_per_ms;
-+}
-+
-+static int ssb_chipco_watchdog_ticks_per_ms(struct ssb_chipcommon *cc)
-+{
-+      struct ssb_bus *bus = cc->dev->bus;
-+
-+      if (cc->capabilities & SSB_CHIPCO_CAP_PMU) {
-+                      /* based on 32KHz ILP clock */
-+                      return 32;
-+      } else {
-+              if (cc->dev->id.revision < 18)
-+                      return ssb_clockspeed(bus) / 1000;
-+              else
-+                      return ssb_chipco_alp_clock(cc) / 1000;
-+      }
-+}
-+
- void ssb_chipcommon_init(struct ssb_chipcommon *cc)
- {
-       if (!cc->dev)
-               return; /* We don't have a ChipCommon */
-+
-+      spin_lock_init(&cc->gpio_lock);
-+
-       if (cc->dev->id.revision >= 11)
-               cc->status = chipco_read32(cc, SSB_CHIPCO_CHIPSTAT);
--      ssb_dprintk(KERN_INFO PFX "chipcommon status is 0x%x\n", cc->status);
-+      ssb_dbg("chipcommon status is 0x%x\n", cc->status);
-       if (cc->dev->id.revision >= 20) {
-               chipco_write32(cc, SSB_CHIPCO_GPIOPULLUP, 0);
-@@ -297,6 +365,11 @@ void ssb_chipcommon_init(struct ssb_chip
-       chipco_powercontrol_init(cc);
-       ssb_chipco_set_clockmode(cc, SSB_CLKMODE_FAST);
-       calc_fast_powerup_delay(cc);
-+
-+      if (cc->dev->bus->bustype == SSB_BUSTYPE_SSB) {
-+              cc->ticks_per_ms = ssb_chipco_watchdog_ticks_per_ms(cc);
-+              cc->max_timer_ms = ssb_chipco_watchdog_get_max_timer(cc) / cc->ticks_per_ms;
-+      }
- }
- void ssb_chipco_suspend(struct ssb_chipcommon *cc)
-@@ -395,10 +468,27 @@ void ssb_chipco_timing_init(struct ssb_c
- }
- /* Set chip watchdog reset timer to fire in 'ticks' backplane cycles */
--void ssb_chipco_watchdog_timer_set(struct ssb_chipcommon *cc, u32 ticks)
-+u32 ssb_chipco_watchdog_timer_set(struct ssb_chipcommon *cc, u32 ticks)
- {
--      /* instant NMI */
--      chipco_write32(cc, SSB_CHIPCO_WATCHDOG, ticks);
-+      u32 maxt;
-+      enum ssb_clkmode clkmode;
-+
-+      maxt = ssb_chipco_watchdog_get_max_timer(cc);
-+      if (cc->capabilities & SSB_CHIPCO_CAP_PMU) {
-+              if (ticks == 1)
-+                      ticks = 2;
-+              else if (ticks > maxt)
-+                      ticks = maxt;
-+              chipco_write32(cc, SSB_CHIPCO_PMU_WATCHDOG, ticks);
-+      } else {
-+              clkmode = ticks ? SSB_CLKMODE_FAST : SSB_CLKMODE_DYNAMIC;
-+              ssb_chipco_set_clockmode(cc, clkmode);
-+              if (ticks > maxt)
-+                      ticks = maxt;
-+              /* instant NMI */
-+              chipco_write32(cc, SSB_CHIPCO_WATCHDOG, ticks);
-+      }
-+      return ticks;
- }
- void ssb_chipco_irq_mask(struct ssb_chipcommon *cc, u32 mask, u32 value)
-@@ -418,28 +508,93 @@ u32 ssb_chipco_gpio_in(struct ssb_chipco
- u32 ssb_chipco_gpio_out(struct ssb_chipcommon *cc, u32 mask, u32 value)
- {
--      return chipco_write32_masked(cc, SSB_CHIPCO_GPIOOUT, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOOUT, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_chipco_gpio_outen(struct ssb_chipcommon *cc, u32 mask, u32 value)
- {
--      return chipco_write32_masked(cc, SSB_CHIPCO_GPIOOUTEN, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOOUTEN, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_chipco_gpio_control(struct ssb_chipcommon *cc, u32 mask, u32 value)
- {
--      return chipco_write32_masked(cc, SSB_CHIPCO_GPIOCTL, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOCTL, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- EXPORT_SYMBOL(ssb_chipco_gpio_control);
- u32 ssb_chipco_gpio_intmask(struct ssb_chipcommon *cc, u32 mask, u32 value)
- {
--      return chipco_write32_masked(cc, SSB_CHIPCO_GPIOIRQ, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOIRQ, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_chipco_gpio_polarity(struct ssb_chipcommon *cc, u32 mask, u32 value)
- {
--      return chipco_write32_masked(cc, SSB_CHIPCO_GPIOPOL, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOPOL, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
-+}
-+
-+u32 ssb_chipco_gpio_pullup(struct ssb_chipcommon *cc, u32 mask, u32 value)
-+{
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      if (cc->dev->id.revision < 20)
-+              return 0xffffffff;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOPULLUP, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
-+}
-+
-+u32 ssb_chipco_gpio_pulldown(struct ssb_chipcommon *cc, u32 mask, u32 value)
-+{
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      if (cc->dev->id.revision < 20)
-+              return 0xffffffff;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = chipco_write32_masked(cc, SSB_CHIPCO_GPIOPULLDOWN, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- #ifdef CONFIG_SSB_SERIAL
-@@ -473,12 +628,7 @@ int ssb_chipco_serial_init(struct ssb_ch
-                                      chipco_read32(cc, SSB_CHIPCO_CORECTL)
-                                      | SSB_CHIPCO_CORECTL_UARTCLK0);
-               } else if ((ccrev >= 11) && (ccrev != 15)) {
--                      /* Fixed ALP clock */
--                      baud_base = 20000000;
--                      if (cc->capabilities & SSB_CHIPCO_CAP_PMU) {
--                              /* FIXME: baud_base is different for devices with a PMU */
--                              SSB_WARN_ON(1);
--                      }
-+                      baud_base = ssb_chipco_alp_clock(cc);
-                       div = 1;
-                       if (ccrev >= 21) {
-                               /* Turn off UART clock before switching clocksource. */
---- a/drivers/ssb/driver_chipcommon_pmu.c
-+++ b/drivers/ssb/driver_chipcommon_pmu.c
-@@ -13,6 +13,9 @@
- #include <linux/ssb/ssb_driver_chipcommon.h>
- #include <linux/delay.h>
- #include <linux/export.h>
-+#ifdef CONFIG_BCM47XX
-+#include <asm/mach-bcm47xx/nvram.h>
-+#endif
- #include "ssb_private.h"
-@@ -92,10 +95,6 @@ static void ssb_pmu0_pllinit_r0(struct s
-       u32 pmuctl, tmp, pllctl;
-       unsigned int i;
--      if ((bus->chip_id == 0x5354) && !crystalfreq) {
--              /* The 5354 crystal freq is 25MHz */
--              crystalfreq = 25000;
--      }
-       if (crystalfreq)
-               e = pmu0_plltab_find_entry(crystalfreq);
-       if (!e)
-@@ -111,8 +110,8 @@ static void ssb_pmu0_pllinit_r0(struct s
-               return;
-       }
--      ssb_printk(KERN_INFO PFX "Programming PLL to %u.%03u MHz\n",
--                 (crystalfreq / 1000), (crystalfreq % 1000));
-+      ssb_info("Programming PLL to %u.%03u MHz\n",
-+               crystalfreq / 1000, crystalfreq % 1000);
-       /* First turn the PLL off. */
-       switch (bus->chip_id) {
-@@ -139,7 +138,7 @@ static void ssb_pmu0_pllinit_r0(struct s
-       }
-       tmp = chipco_read32(cc, SSB_CHIPCO_CLKCTLST);
-       if (tmp & SSB_CHIPCO_CLKCTLST_HAVEHT)
--              ssb_printk(KERN_EMERG PFX "Failed to turn the PLL off!\n");
-+              ssb_emerg("Failed to turn the PLL off!\n");
-       /* Set PDIV in PLL control 0. */
-       pllctl = ssb_chipco_pll_read(cc, SSB_PMU0_PLLCTL0);
-@@ -250,8 +249,8 @@ static void ssb_pmu1_pllinit_r0(struct s
-               return;
-       }
--      ssb_printk(KERN_INFO PFX "Programming PLL to %u.%03u MHz\n",
--                 (crystalfreq / 1000), (crystalfreq % 1000));
-+      ssb_info("Programming PLL to %u.%03u MHz\n",
-+               crystalfreq / 1000, crystalfreq % 1000);
-       /* First turn the PLL off. */
-       switch (bus->chip_id) {
-@@ -276,7 +275,7 @@ static void ssb_pmu1_pllinit_r0(struct s
-       }
-       tmp = chipco_read32(cc, SSB_CHIPCO_CLKCTLST);
-       if (tmp & SSB_CHIPCO_CLKCTLST_HAVEHT)
--              ssb_printk(KERN_EMERG PFX "Failed to turn the PLL off!\n");
-+              ssb_emerg("Failed to turn the PLL off!\n");
-       /* Set p1div and p2div. */
-       pllctl = ssb_chipco_pll_read(cc, SSB_PMU1_PLLCTL0);
-@@ -321,7 +320,11 @@ static void ssb_pmu_pll_init(struct ssb_
-       u32 crystalfreq = 0; /* in kHz. 0 = keep default freq. */
-       if (bus->bustype == SSB_BUSTYPE_SSB) {
--              /* TODO: The user may override the crystal frequency. */
-+#ifdef CONFIG_BCM47XX
-+              char buf[20];
-+              if (nvram_getenv("xtalfreq", buf, sizeof(buf)) >= 0)
-+                      crystalfreq = simple_strtoul(buf, NULL, 0);
-+#endif
-       }
-       switch (bus->chip_id) {
-@@ -330,7 +333,11 @@ static void ssb_pmu_pll_init(struct ssb_
-               ssb_pmu1_pllinit_r0(cc, crystalfreq);
-               break;
-       case 0x4328:
-+              ssb_pmu0_pllinit_r0(cc, crystalfreq);
-+              break;
-       case 0x5354:
-+              if (crystalfreq == 0)
-+                      crystalfreq = 25000;
-               ssb_pmu0_pllinit_r0(cc, crystalfreq);
-               break;
-       case 0x4322:
-@@ -339,10 +346,11 @@ static void ssb_pmu_pll_init(struct ssb_
-                       chipco_write32(cc, SSB_CHIPCO_PLLCTL_DATA, 0x380005C0);
-               }
-               break;
-+      case 43222:
-+              break;
-       default:
--              ssb_printk(KERN_ERR PFX
--                         "ERROR: PLL init unknown for device %04X\n",
--                         bus->chip_id);
-+              ssb_err("ERROR: PLL init unknown for device %04X\n",
-+                      bus->chip_id);
-       }
- }
-@@ -427,6 +435,7 @@ static void ssb_pmu_resources_init(struc
-                min_msk = 0xCBB;
-                break;
-       case 0x4322:
-+      case 43222:
-               /* We keep the default settings:
-                * min_msk = 0xCBB
-                * max_msk = 0x7FFFF
-@@ -462,9 +471,8 @@ static void ssb_pmu_resources_init(struc
-               max_msk = 0xFFFFF;
-               break;
-       default:
--              ssb_printk(KERN_ERR PFX
--                         "ERROR: PMU resource config unknown for device %04X\n",
--                         bus->chip_id);
-+              ssb_err("ERROR: PMU resource config unknown for device %04X\n",
-+                      bus->chip_id);
-       }
-       if (updown_tab) {
-@@ -516,8 +524,8 @@ void ssb_pmu_init(struct ssb_chipcommon
-       pmucap = chipco_read32(cc, SSB_CHIPCO_PMU_CAP);
-       cc->pmu.rev = (pmucap & SSB_CHIPCO_PMU_CAP_REVISION);
--      ssb_dprintk(KERN_DEBUG PFX "Found rev %u PMU (capabilities 0x%08X)\n",
--                  cc->pmu.rev, pmucap);
-+      ssb_dbg("Found rev %u PMU (capabilities 0x%08X)\n",
-+              cc->pmu.rev, pmucap);
-       if (cc->pmu.rev == 1)
-               chipco_mask32(cc, SSB_CHIPCO_PMU_CTL,
-@@ -607,3 +615,102 @@ void ssb_pmu_set_ldo_paref(struct ssb_ch
- EXPORT_SYMBOL(ssb_pmu_set_ldo_voltage);
- EXPORT_SYMBOL(ssb_pmu_set_ldo_paref);
-+
-+static u32 ssb_pmu_get_alp_clock_clk0(struct ssb_chipcommon *cc)
-+{
-+      u32 crystalfreq;
-+      const struct pmu0_plltab_entry *e = NULL;
-+
-+      crystalfreq = chipco_read32(cc, SSB_CHIPCO_PMU_CTL) &
-+                    SSB_CHIPCO_PMU_CTL_XTALFREQ >> SSB_CHIPCO_PMU_CTL_XTALFREQ_SHIFT;
-+      e = pmu0_plltab_find_entry(crystalfreq);
-+      BUG_ON(!e);
-+      return e->freq * 1000;
-+}
-+
-+u32 ssb_pmu_get_alp_clock(struct ssb_chipcommon *cc)
-+{
-+      struct ssb_bus *bus = cc->dev->bus;
-+
-+      switch (bus->chip_id) {
-+      case 0x5354:
-+              ssb_pmu_get_alp_clock_clk0(cc);
-+      default:
-+              ssb_err("ERROR: PMU alp clock unknown for device %04X\n",
-+                      bus->chip_id);
-+              return 0;
-+      }
-+}
-+
-+u32 ssb_pmu_get_cpu_clock(struct ssb_chipcommon *cc)
-+{
-+      struct ssb_bus *bus = cc->dev->bus;
-+
-+      switch (bus->chip_id) {
-+      case 0x5354:
-+              /* 5354 chip uses a non programmable PLL of frequency 240MHz */
-+              return 240000000;
-+      default:
-+              ssb_err("ERROR: PMU cpu clock unknown for device %04X\n",
-+                      bus->chip_id);
-+              return 0;
-+      }
-+}
-+
-+u32 ssb_pmu_get_controlclock(struct ssb_chipcommon *cc)
-+{
-+      struct ssb_bus *bus = cc->dev->bus;
-+
-+      switch (bus->chip_id) {
-+      case 0x5354:
-+              return 120000000;
-+      default:
-+              ssb_err("ERROR: PMU controlclock unknown for device %04X\n",
-+                      bus->chip_id);
-+              return 0;
-+      }
-+}
-+
-+void ssb_pmu_spuravoid_pllupdate(struct ssb_chipcommon *cc, int spuravoid)
-+{
-+      u32 pmu_ctl = 0;
-+
-+      switch (cc->dev->bus->chip_id) {
-+      case 0x4322:
-+              ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL0, 0x11100070);
-+              ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL1, 0x1014140a);
-+              ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL5, 0x88888854);
-+              if (spuravoid == 1)
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL2, 0x05201828);
-+              else
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL2, 0x05001828);
-+              pmu_ctl = SSB_CHIPCO_PMU_CTL_PLL_UPD;
-+              break;
-+      case 43222:
-+              if (spuravoid == 1) {
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL0, 0x11500008);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL1, 0x0C000C06);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL2, 0x0F600a08);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL3, 0x00000000);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL4, 0x2001E920);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL5, 0x88888815);
-+              } else {
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL0, 0x11100008);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL1, 0x0c000c06);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL2, 0x03000a08);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL3, 0x00000000);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL4, 0x200005c0);
-+                      ssb_chipco_pll_write(cc, SSB_PMU1_PLLCTL5, 0x88888855);
-+              }
-+              pmu_ctl = SSB_CHIPCO_PMU_CTL_PLL_UPD;
-+              break;
-+      default:
-+              ssb_printk(KERN_ERR PFX
-+                         "Unknown spuravoidance settings for chip 0x%04X, not changing PLL\n",
-+                         cc->dev->bus->chip_id);
-+              return;
-+      }
-+
-+      chipco_set32(cc, SSB_CHIPCO_PMU_CTL, pmu_ctl);
-+}
-+EXPORT_SYMBOL_GPL(ssb_pmu_spuravoid_pllupdate);
---- /dev/null
-+++ b/drivers/ssb/driver_chipcommon_sflash.c
-@@ -0,0 +1,164 @@
-+/*
-+ * Sonics Silicon Backplane
-+ * ChipCommon serial flash interface
-+ *
-+ * Licensed under the GNU/GPL. See COPYING for details.
-+ */
-+
-+#include <linux/ssb/ssb.h>
-+
-+#include "ssb_private.h"
-+
-+static struct resource ssb_sflash_resource = {
-+      .name   = "ssb_sflash",
-+      .start  = SSB_FLASH2,
-+      .end    = 0,
-+      .flags  = IORESOURCE_MEM | IORESOURCE_READONLY,
-+};
-+
-+struct platform_device ssb_sflash_dev = {
-+      .name           = "ssb_sflash",
-+      .resource       = &ssb_sflash_resource,
-+      .num_resources  = 1,
-+};
-+
-+struct ssb_sflash_tbl_e {
-+      char *name;
-+      u32 id;
-+      u32 blocksize;
-+      u16 numblocks;
-+};
-+
-+static const struct ssb_sflash_tbl_e ssb_sflash_st_tbl[] = {
-+      { "M25P20", 0x11, 0x10000, 4, },
-+      { "M25P40", 0x12, 0x10000, 8, },
-+
-+      { "M25P16", 0x14, 0x10000, 32, },
-+      { "M25P32", 0x15, 0x10000, 64, },
-+      { "M25P64", 0x16, 0x10000, 128, },
-+      { "M25FL128", 0x17, 0x10000, 256, },
-+      { 0 },
-+};
-+
-+static const struct ssb_sflash_tbl_e ssb_sflash_sst_tbl[] = {
-+      { "SST25WF512", 1, 0x1000, 16, },
-+      { "SST25VF512", 0x48, 0x1000, 16, },
-+      { "SST25WF010", 2, 0x1000, 32, },
-+      { "SST25VF010", 0x49, 0x1000, 32, },
-+      { "SST25WF020", 3, 0x1000, 64, },
-+      { "SST25VF020", 0x43, 0x1000, 64, },
-+      { "SST25WF040", 4, 0x1000, 128, },
-+      { "SST25VF040", 0x44, 0x1000, 128, },
-+      { "SST25VF040B", 0x8d, 0x1000, 128, },
-+      { "SST25WF080", 5, 0x1000, 256, },
-+      { "SST25VF080B", 0x8e, 0x1000, 256, },
-+      { "SST25VF016", 0x41, 0x1000, 512, },
-+      { "SST25VF032", 0x4a, 0x1000, 1024, },
-+      { "SST25VF064", 0x4b, 0x1000, 2048, },
-+      { 0 },
-+};
-+
-+static const struct ssb_sflash_tbl_e ssb_sflash_at_tbl[] = {
-+      { "AT45DB011", 0xc, 256, 512, },
-+      { "AT45DB021", 0x14, 256, 1024, },
-+      { "AT45DB041", 0x1c, 256, 2048, },
-+      { "AT45DB081", 0x24, 256, 4096, },
-+      { "AT45DB161", 0x2c, 512, 4096, },
-+      { "AT45DB321", 0x34, 512, 8192, },
-+      { "AT45DB642", 0x3c, 1024, 8192, },
-+      { 0 },
-+};
-+
-+static void ssb_sflash_cmd(struct ssb_chipcommon *cc, u32 opcode)
-+{
-+      int i;
-+      chipco_write32(cc, SSB_CHIPCO_FLASHCTL,
-+                     SSB_CHIPCO_FLASHCTL_START | opcode);
-+      for (i = 0; i < 1000; i++) {
-+              if (!(chipco_read32(cc, SSB_CHIPCO_FLASHCTL) &
-+                    SSB_CHIPCO_FLASHCTL_BUSY))
-+                      return;
-+              cpu_relax();
-+      }
-+      pr_err("SFLASH control command failed (timeout)!\n");
-+}
-+
-+/* Initialize serial flash access */
-+int ssb_sflash_init(struct ssb_chipcommon *cc)
-+{
-+      struct ssb_sflash *sflash = &cc->dev->bus->mipscore.sflash;
-+      const struct ssb_sflash_tbl_e *e;
-+      u32 id, id2;
-+
-+      switch (cc->capabilities & SSB_CHIPCO_CAP_FLASHT) {
-+      case SSB_CHIPCO_FLASHT_STSER:
-+              ssb_sflash_cmd(cc, SSB_CHIPCO_FLASHCTL_ST_DP);
-+
-+              chipco_write32(cc, SSB_CHIPCO_FLASHADDR, 0);
-+              ssb_sflash_cmd(cc, SSB_CHIPCO_FLASHCTL_ST_RES);
-+              id = chipco_read32(cc, SSB_CHIPCO_FLASHDATA);
-+
-+              chipco_write32(cc, SSB_CHIPCO_FLASHADDR, 1);
-+              ssb_sflash_cmd(cc, SSB_CHIPCO_FLASHCTL_ST_RES);
-+              id2 = chipco_read32(cc, SSB_CHIPCO_FLASHDATA);
-+
-+              switch (id) {
-+              case 0xbf:
-+                      for (e = ssb_sflash_sst_tbl; e->name; e++) {
-+                              if (e->id == id2)
-+                                      break;
-+                      }
-+                      break;
-+              case 0x13:
-+                      return -ENOTSUPP;
-+              default:
-+                      for (e = ssb_sflash_st_tbl; e->name; e++) {
-+                              if (e->id == id)
-+                                      break;
-+                      }
-+                      break;
-+              }
-+              if (!e->name) {
-+                      pr_err("Unsupported ST serial flash (id: 0x%X, id2: 0x%X)\n",
-+                             id, id2);
-+                      return -ENOTSUPP;
-+              }
-+
-+              break;
-+      case SSB_CHIPCO_FLASHT_ATSER:
-+              ssb_sflash_cmd(cc, SSB_CHIPCO_FLASHCTL_AT_STATUS);
-+              id = chipco_read32(cc, SSB_CHIPCO_FLASHDATA) & 0x3c;
-+
-+              for (e = ssb_sflash_at_tbl; e->name; e++) {
-+                      if (e->id == id)
-+                              break;
-+              }
-+              if (!e->name) {
-+                      pr_err("Unsupported Atmel serial flash (id: 0x%X)\n",
-+                             id);
-+                      return -ENOTSUPP;
-+              }
-+
-+              break;
-+      default:
-+              pr_err("Unsupported flash type\n");
-+              return -ENOTSUPP;
-+      }
-+
-+      sflash->window = SSB_FLASH2;
-+      sflash->blocksize = e->blocksize;
-+      sflash->numblocks = e->numblocks;
-+      sflash->size = sflash->blocksize * sflash->numblocks;
-+      sflash->present = true;
-+
-+      pr_info("Found %s serial flash (size: %dKiB, blocksize: 0x%X, blocks: %d)\n",
-+              e->name, sflash->size / 1024, e->blocksize, e->numblocks);
-+
-+      /* Prepare platform device, but don't register it yet. It's too early,
-+       * malloc (required by device_private_init) is not available yet. */
-+      ssb_sflash_dev.resource[0].end = ssb_sflash_dev.resource[0].start +
-+                                       sflash->size;
-+      ssb_sflash_dev.dev.platform_data = sflash;
-+
-+      return 0;
-+}
---- a/drivers/ssb/driver_extif.c
-+++ b/drivers/ssb/driver_extif.c
-@@ -112,10 +112,37 @@ void ssb_extif_get_clockcontrol(struct s
-       *m = extif_read32(extif, SSB_EXTIF_CLOCK_SB);
- }
--void ssb_extif_watchdog_timer_set(struct ssb_extif *extif,
--                                u32 ticks)
-+u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt, u32 ticks)
- {
-+      struct ssb_extif *extif = bcm47xx_wdt_get_drvdata(wdt);
-+
-+      return ssb_extif_watchdog_timer_set(extif, ticks);
-+}
-+
-+u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms)
-+{
-+      struct ssb_extif *extif = bcm47xx_wdt_get_drvdata(wdt);
-+      u32 ticks = (SSB_EXTIF_WATCHDOG_CLK / 1000) * ms;
-+
-+      ticks = ssb_extif_watchdog_timer_set(extif, ticks);
-+
-+      return (ticks * 1000) / SSB_EXTIF_WATCHDOG_CLK;
-+}
-+
-+u32 ssb_extif_watchdog_timer_set(struct ssb_extif *extif, u32 ticks)
-+{
-+      if (ticks > SSB_EXTIF_WATCHDOG_MAX_TIMER)
-+              ticks = SSB_EXTIF_WATCHDOG_MAX_TIMER;
-       extif_write32(extif, SSB_EXTIF_WATCHDOG, ticks);
-+
-+      return ticks;
-+}
-+
-+void ssb_extif_init(struct ssb_extif *extif)
-+{
-+      if (!extif->dev)
-+              return; /* We don't have a Extif core */
-+      spin_lock_init(&extif->gpio_lock);
- }
- u32 ssb_extif_gpio_in(struct ssb_extif *extif, u32 mask)
-@@ -125,22 +152,50 @@ u32 ssb_extif_gpio_in(struct ssb_extif *
- u32 ssb_extif_gpio_out(struct ssb_extif *extif, u32 mask, u32 value)
- {
--      return extif_write32_masked(extif, SSB_EXTIF_GPIO_OUT(0),
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&extif->gpio_lock, flags);
-+      res = extif_write32_masked(extif, SSB_EXTIF_GPIO_OUT(0),
-                                  mask, value);
-+      spin_unlock_irqrestore(&extif->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_extif_gpio_outen(struct ssb_extif *extif, u32 mask, u32 value)
- {
--      return extif_write32_masked(extif, SSB_EXTIF_GPIO_OUTEN(0),
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&extif->gpio_lock, flags);
-+      res = extif_write32_masked(extif, SSB_EXTIF_GPIO_OUTEN(0),
-                                  mask, value);
-+      spin_unlock_irqrestore(&extif->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_extif_gpio_polarity(struct ssb_extif *extif, u32 mask, u32 value)
- {
--      return extif_write32_masked(extif, SSB_EXTIF_GPIO_INTPOL, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&extif->gpio_lock, flags);
-+      res = extif_write32_masked(extif, SSB_EXTIF_GPIO_INTPOL, mask, value);
-+      spin_unlock_irqrestore(&extif->gpio_lock, flags);
-+
-+      return res;
- }
- u32 ssb_extif_gpio_intmask(struct ssb_extif *extif, u32 mask, u32 value)
- {
--      return extif_write32_masked(extif, SSB_EXTIF_GPIO_INTMASK, mask, value);
-+      unsigned long flags;
-+      u32 res = 0;
-+
-+      spin_lock_irqsave(&extif->gpio_lock, flags);
-+      res = extif_write32_masked(extif, SSB_EXTIF_GPIO_INTMASK, mask, value);
-+      spin_unlock_irqrestore(&extif->gpio_lock, flags);
-+
-+      return res;
- }
---- /dev/null
-+++ b/drivers/ssb/driver_gpio.c
-@@ -0,0 +1,210 @@
-+/*
-+ * Sonics Silicon Backplane
-+ * GPIO driver
-+ *
-+ * Copyright 2011, Broadcom Corporation
-+ * Copyright 2012, Hauke Mehrtens <hauke@hauke-m.de>
-+ *
-+ * Licensed under the GNU/GPL. See COPYING for details.
-+ */
-+
-+#include <linux/gpio.h>
-+#include <linux/export.h>
-+#include <linux/ssb/ssb.h>
-+
-+#include "ssb_private.h"
-+
-+static struct ssb_bus *ssb_gpio_get_bus(struct gpio_chip *chip)
-+{
-+      return container_of(chip, struct ssb_bus, gpio);
-+}
-+
-+static int ssb_gpio_chipco_get_value(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      return !!ssb_chipco_gpio_in(&bus->chipco, 1 << gpio);
-+}
-+
-+static void ssb_gpio_chipco_set_value(struct gpio_chip *chip, unsigned gpio,
-+                                    int value)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_chipco_gpio_out(&bus->chipco, 1 << gpio, value ? 1 << gpio : 0);
-+}
-+
-+static int ssb_gpio_chipco_direction_input(struct gpio_chip *chip,
-+                                         unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_chipco_gpio_outen(&bus->chipco, 1 << gpio, 0);
-+      return 0;
-+}
-+
-+static int ssb_gpio_chipco_direction_output(struct gpio_chip *chip,
-+                                          unsigned gpio, int value)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_chipco_gpio_outen(&bus->chipco, 1 << gpio, 1 << gpio);
-+      ssb_chipco_gpio_out(&bus->chipco, 1 << gpio, value ? 1 << gpio : 0);
-+      return 0;
-+}
-+
-+static int ssb_gpio_chipco_request(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_chipco_gpio_control(&bus->chipco, 1 << gpio, 0);
-+      /* clear pulldown */
-+      ssb_chipco_gpio_pulldown(&bus->chipco, 1 << gpio, 0);
-+      /* Set pullup */
-+      ssb_chipco_gpio_pullup(&bus->chipco, 1 << gpio, 1 << gpio);
-+
-+      return 0;
-+}
-+
-+static void ssb_gpio_chipco_free(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      /* clear pullup */
-+      ssb_chipco_gpio_pullup(&bus->chipco, 1 << gpio, 0);
-+}
-+
-+static int ssb_gpio_chipco_to_irq(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      if (bus->bustype == SSB_BUSTYPE_SSB)
-+              return ssb_mips_irq(bus->chipco.dev) + 2;
-+      else
-+              return -EINVAL;
-+}
-+
-+static int ssb_gpio_chipco_init(struct ssb_bus *bus)
-+{
-+      struct gpio_chip *chip = &bus->gpio;
-+
-+      chip->label             = "ssb_chipco_gpio";
-+      chip->owner             = THIS_MODULE;
-+      chip->request           = ssb_gpio_chipco_request;
-+      chip->free              = ssb_gpio_chipco_free;
-+      chip->get               = ssb_gpio_chipco_get_value;
-+      chip->set               = ssb_gpio_chipco_set_value;
-+      chip->direction_input   = ssb_gpio_chipco_direction_input;
-+      chip->direction_output  = ssb_gpio_chipco_direction_output;
-+      chip->to_irq            = ssb_gpio_chipco_to_irq;
-+      chip->ngpio             = 16;
-+      /* There is just one SoC in one device and its GPIO addresses should be
-+       * deterministic to address them more easily. The other buses could get
-+       * a random base number. */
-+      if (bus->bustype == SSB_BUSTYPE_SSB)
-+              chip->base              = 0;
-+      else
-+              chip->base              = -1;
-+
-+      return gpiochip_add(chip);
-+}
-+
-+#ifdef CONFIG_SSB_DRIVER_EXTIF
-+
-+static int ssb_gpio_extif_get_value(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      return !!ssb_extif_gpio_in(&bus->extif, 1 << gpio);
-+}
-+
-+static void ssb_gpio_extif_set_value(struct gpio_chip *chip, unsigned gpio,
-+                                   int value)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_extif_gpio_out(&bus->extif, 1 << gpio, value ? 1 << gpio : 0);
-+}
-+
-+static int ssb_gpio_extif_direction_input(struct gpio_chip *chip,
-+                                        unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_extif_gpio_outen(&bus->extif, 1 << gpio, 0);
-+      return 0;
-+}
-+
-+static int ssb_gpio_extif_direction_output(struct gpio_chip *chip,
-+                                         unsigned gpio, int value)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      ssb_extif_gpio_outen(&bus->extif, 1 << gpio, 1 << gpio);
-+      ssb_extif_gpio_out(&bus->extif, 1 << gpio, value ? 1 << gpio : 0);
-+      return 0;
-+}
-+
-+static int ssb_gpio_extif_to_irq(struct gpio_chip *chip, unsigned gpio)
-+{
-+      struct ssb_bus *bus = ssb_gpio_get_bus(chip);
-+
-+      if (bus->bustype == SSB_BUSTYPE_SSB)
-+              return ssb_mips_irq(bus->extif.dev) + 2;
-+      else
-+              return -EINVAL;
-+}
-+
-+static int ssb_gpio_extif_init(struct ssb_bus *bus)
-+{
-+      struct gpio_chip *chip = &bus->gpio;
-+
-+      chip->label             = "ssb_extif_gpio";
-+      chip->owner             = THIS_MODULE;
-+      chip->get               = ssb_gpio_extif_get_value;
-+      chip->set               = ssb_gpio_extif_set_value;
-+      chip->direction_input   = ssb_gpio_extif_direction_input;
-+      chip->direction_output  = ssb_gpio_extif_direction_output;
-+      chip->to_irq            = ssb_gpio_extif_to_irq;
-+      chip->ngpio             = 5;
-+      /* There is just one SoC in one device and its GPIO addresses should be
-+       * deterministic to address them more easily. The other buses could get
-+       * a random base number. */
-+      if (bus->bustype == SSB_BUSTYPE_SSB)
-+              chip->base              = 0;
-+      else
-+              chip->base              = -1;
-+
-+      return gpiochip_add(chip);
-+}
-+
-+#else
-+static int ssb_gpio_extif_init(struct ssb_bus *bus)
-+{
-+      return -ENOTSUPP;
-+}
-+#endif
-+
-+int ssb_gpio_init(struct ssb_bus *bus)
-+{
-+      if (ssb_chipco_available(&bus->chipco))
-+              return ssb_gpio_chipco_init(bus);
-+      else if (ssb_extif_available(&bus->extif))
-+              return ssb_gpio_extif_init(bus);
-+      else
-+              SSB_WARN_ON(1);
-+
-+      return -1;
-+}
-+
-+int ssb_gpio_unregister(struct ssb_bus *bus)
-+{
-+      if (ssb_chipco_available(&bus->chipco) ||
-+          ssb_extif_available(&bus->extif)) {
-+              return gpiochip_remove(&bus->gpio);
-+      } else {
-+              SSB_WARN_ON(1);
-+      }
-+
-+      return -1;
-+}
---- a/drivers/ssb/driver_mipscore.c
-+++ b/drivers/ssb/driver_mipscore.c
-@@ -10,6 +10,7 @@
- #include <linux/ssb/ssb.h>
-+#include <linux/mtd/physmap.h>
- #include <linux/serial.h>
- #include <linux/serial_core.h>
- #include <linux/serial_reg.h>
-@@ -17,6 +18,25 @@
- #include "ssb_private.h"
-+static const char * const part_probes[] = { "bcm47xxpart", NULL };
-+
-+static struct physmap_flash_data ssb_pflash_data = {
-+      .part_probe_types       = part_probes,
-+};
-+
-+static struct resource ssb_pflash_resource = {
-+      .name   = "ssb_pflash",
-+      .flags  = IORESOURCE_MEM,
-+};
-+
-+struct platform_device ssb_pflash_dev = {
-+      .name           = "physmap-flash",
-+      .dev            = {
-+              .platform_data  = &ssb_pflash_data,
-+      },
-+      .resource       = &ssb_pflash_resource,
-+      .num_resources  = 1,
-+};
- static inline u32 mips_read32(struct ssb_mipscore *mcore,
-                             u16 offset)
-@@ -147,21 +167,22 @@ static void set_irq(struct ssb_device *d
-               irqflag |= (ipsflag & ~ipsflag_irq_mask[irq]);
-               ssb_write32(mdev, SSB_IPSFLAG, irqflag);
-       }
--      ssb_dprintk(KERN_INFO PFX
--                  "set_irq: core 0x%04x, irq %d => %d\n",
--                  dev->id.coreid, oldirq+2, irq+2);
-+      ssb_dbg("set_irq: core 0x%04x, irq %d => %d\n",
-+              dev->id.coreid, oldirq+2, irq+2);
- }
- static void print_irq(struct ssb_device *dev, unsigned int irq)
- {
--      int i;
-       static const char *irq_name[] = {"2(S)", "3", "4", "5", "6", "D", "I"};
--      ssb_dprintk(KERN_INFO PFX
--              "core 0x%04x, irq :", dev->id.coreid);
--      for (i = 0; i <= 6; i++) {
--              ssb_dprintk(" %s%s", irq_name[i], i==irq?"*":" ");
--      }
--      ssb_dprintk("\n");
-+      ssb_dbg("core 0x%04x, irq : %s%s %s%s %s%s %s%s %s%s %s%s %s%s\n",
-+              dev->id.coreid,
-+              irq_name[0], irq == 0 ? "*" : " ",
-+              irq_name[1], irq == 1 ? "*" : " ",
-+              irq_name[2], irq == 2 ? "*" : " ",
-+              irq_name[3], irq == 3 ? "*" : " ",
-+              irq_name[4], irq == 4 ? "*" : " ",
-+              irq_name[5], irq == 5 ? "*" : " ",
-+              irq_name[6], irq == 6 ? "*" : " ");
- }
- static void dump_irq(struct ssb_bus *bus)
-@@ -178,9 +199,9 @@ static void ssb_mips_serial_init(struct
- {
-       struct ssb_bus *bus = mcore->dev->bus;
--      if (bus->extif.dev)
-+      if (ssb_extif_available(&bus->extif))
-               mcore->nr_serial_ports = ssb_extif_serial_init(&bus->extif, mcore->serial_ports);
--      else if (bus->chipco.dev)
-+      else if (ssb_chipco_available(&bus->chipco))
-               mcore->nr_serial_ports = ssb_chipco_serial_init(&bus->chipco, mcore->serial_ports);
-       else
-               mcore->nr_serial_ports = 0;
-@@ -189,17 +210,42 @@ static void ssb_mips_serial_init(struct
- static void ssb_mips_flash_detect(struct ssb_mipscore *mcore)
- {
-       struct ssb_bus *bus = mcore->dev->bus;
-+      struct ssb_pflash *pflash = &mcore->pflash;
--      mcore->flash_buswidth = 2;
--      if (bus->chipco.dev) {
--              mcore->flash_window = 0x1c000000;
--              mcore->flash_window_size = 0x02000000;
-+      /* When there is no chipcommon on the bus there is 4MB flash */
-+      if (!ssb_chipco_available(&bus->chipco)) {
-+              pflash->present = true;
-+              pflash->buswidth = 2;
-+              pflash->window = SSB_FLASH1;
-+              pflash->window_size = SSB_FLASH1_SZ;
-+              goto ssb_pflash;
-+      }
-+
-+      /* There is ChipCommon, so use it to read info about flash */
-+      switch (bus->chipco.capabilities & SSB_CHIPCO_CAP_FLASHT) {
-+      case SSB_CHIPCO_FLASHT_STSER:
-+      case SSB_CHIPCO_FLASHT_ATSER:
-+              pr_debug("Found serial flash\n");
-+              ssb_sflash_init(&bus->chipco);
-+              break;
-+      case SSB_CHIPCO_FLASHT_PARA:
-+              pr_debug("Found parallel flash\n");
-+              pflash->present = true;
-+              pflash->window = SSB_FLASH2;
-+              pflash->window_size = SSB_FLASH2_SZ;
-               if ((ssb_read32(bus->chipco.dev, SSB_CHIPCO_FLASH_CFG)
-                              & SSB_CHIPCO_CFG_DS16) == 0)
--                      mcore->flash_buswidth = 1;
--      } else {
--              mcore->flash_window = 0x1fc00000;
--              mcore->flash_window_size = 0x00400000;
-+                      pflash->buswidth = 1;
-+              else
-+                      pflash->buswidth = 2;
-+              break;
-+      }
-+
-+ssb_pflash:
-+      if (pflash->present) {
-+              ssb_pflash_data.width = pflash->buswidth;
-+              ssb_pflash_resource.start = pflash->window;
-+              ssb_pflash_resource.end = pflash->window + pflash->window_size;
-       }
- }
-@@ -208,9 +254,12 @@ u32 ssb_cpu_clock(struct ssb_mipscore *m
-       struct ssb_bus *bus = mcore->dev->bus;
-       u32 pll_type, n, m, rate = 0;
--      if (bus->extif.dev) {
-+      if (bus->chipco.capabilities & SSB_CHIPCO_CAP_PMU)
-+              return ssb_pmu_get_cpu_clock(&bus->chipco);
-+
-+      if (ssb_extif_available(&bus->extif)) {
-               ssb_extif_get_clockcontrol(&bus->extif, &pll_type, &n, &m);
--      } else if (bus->chipco.dev) {
-+      } else if (ssb_chipco_available(&bus->chipco)) {
-               ssb_chipco_get_clockcpu(&bus->chipco, &pll_type, &n, &m);
-       } else
-               return 0;
-@@ -238,7 +287,7 @@ void ssb_mipscore_init(struct ssb_mipsco
-       if (!mcore->dev)
-               return; /* We don't have a MIPS core */
--      ssb_dprintk(KERN_INFO PFX "Initializing MIPS core...\n");
-+      ssb_dbg("Initializing MIPS core...\n");
-       bus = mcore->dev->bus;
-       hz = ssb_clockspeed(bus);
-@@ -246,9 +295,9 @@ void ssb_mipscore_init(struct ssb_mipsco
-               hz = 100000000;
-       ns = 1000000000 / hz;
--      if (bus->extif.dev)
-+      if (ssb_extif_available(&bus->extif))
-               ssb_extif_timing_init(&bus->extif, ns);
--      else if (bus->chipco.dev)
-+      else if (ssb_chipco_available(&bus->chipco))
-               ssb_chipco_timing_init(&bus->chipco, ns);
-       /* Assign IRQs to all cores on the bus, start with irq line 2, because serial usually takes 1 */
-@@ -286,7 +335,7 @@ void ssb_mipscore_init(struct ssb_mipsco
-                       break;
-               }
-       }
--      ssb_dprintk(KERN_INFO PFX "after irq reconfiguration\n");
-+      ssb_dbg("after irq reconfiguration\n");
-       dump_irq(bus);
-       ssb_mips_serial_init(mcore);
---- a/drivers/ssb/driver_pcicore.c
-+++ b/drivers/ssb/driver_pcicore.c
-@@ -263,8 +263,7 @@ int ssb_pcicore_plat_dev_init(struct pci
-               return -ENODEV;
-       }
--      ssb_printk(KERN_INFO "PCI: Fixing up device %s\n",
--                 pci_name(d));
-+      ssb_info("PCI: Fixing up device %s\n", pci_name(d));
-       /* Fix up interrupt lines */
-       d->irq = ssb_mips_irq(extpci_core->dev) + 2;
-@@ -285,12 +284,12 @@ static void ssb_pcicore_fixup_pcibridge(
-       if (dev->bus->number != 0 || PCI_SLOT(dev->devfn) != 0)
-               return;
--      ssb_printk(KERN_INFO "PCI: Fixing up bridge %s\n", pci_name(dev));
-+      ssb_info("PCI: Fixing up bridge %s\n", pci_name(dev));
-       /* Enable PCI bridge bus mastering and memory space */
-       pci_set_master(dev);
-       if (pcibios_enable_device(dev, ~0) < 0) {
--              ssb_printk(KERN_ERR "PCI: SSB bridge enable failed\n");
-+              ssb_err("PCI: SSB bridge enable failed\n");
-               return;
-       }
-@@ -299,8 +298,8 @@ static void ssb_pcicore_fixup_pcibridge(
-       /* Make sure our latency is high enough to handle the devices behind us */
-       lat = 168;
--      ssb_printk(KERN_INFO "PCI: Fixing latency timer of device %s to %u\n",
--                 pci_name(dev), lat);
-+      ssb_info("PCI: Fixing latency timer of device %s to %u\n",
-+               pci_name(dev), lat);
-       pci_write_config_byte(dev, PCI_LATENCY_TIMER, lat);
- }
- DECLARE_PCI_FIXUP_EARLY(PCI_ANY_ID, PCI_ANY_ID, ssb_pcicore_fixup_pcibridge);
-@@ -323,7 +322,7 @@ static void __devinit ssb_pcicore_init_h
-               return;
-       extpci_core = pc;
--      ssb_dprintk(KERN_INFO PFX "PCIcore in host mode found\n");
-+      ssb_dbg("PCIcore in host mode found\n");
-       /* Reset devices on the external PCI bus */
-       val = SSB_PCICORE_CTL_RST_OE;
-       val |= SSB_PCICORE_CTL_CLK_OE;
-@@ -338,7 +337,7 @@ static void __devinit ssb_pcicore_init_h
-       udelay(1); /* Assertion time demanded by the PCI standard */
-       if (pc->dev->bus->has_cardbus_slot) {
--              ssb_dprintk(KERN_INFO PFX "CardBus slot detected\n");
-+              ssb_dbg("CardBus slot detected\n");
-               pc->cardbusmode = 1;
-               /* GPIO 1 resets the bridge */
-               ssb_gpio_out(pc->dev->bus, 1, 1);
---- a/drivers/ssb/embedded.c
-+++ b/drivers/ssb/embedded.c
-@@ -4,11 +4,13 @@
-  *
-  * Copyright 2005-2008, Broadcom Corporation
-  * Copyright 2006-2008, Michael Buesch <m@bues.ch>
-+ * Copyright 2012, Hauke Mehrtens <hauke@hauke-m.de>
-  *
-  * Licensed under the GNU/GPL. See COPYING for details.
-  */
- #include <linux/export.h>
-+#include <linux/platform_device.h>
- #include <linux/ssb/ssb.h>
- #include <linux/ssb/ssb_embedded.h>
- #include <linux/ssb/ssb_driver_pci.h>
-@@ -32,6 +34,38 @@ int ssb_watchdog_timer_set(struct ssb_bu
- }
- EXPORT_SYMBOL(ssb_watchdog_timer_set);
-+int ssb_watchdog_register(struct ssb_bus *bus)
-+{
-+      struct bcm47xx_wdt wdt = {};
-+      struct platform_device *pdev;
-+
-+      if (ssb_chipco_available(&bus->chipco)) {
-+              wdt.driver_data = &bus->chipco;
-+              wdt.timer_set = ssb_chipco_watchdog_timer_set_wdt;
-+              wdt.timer_set_ms = ssb_chipco_watchdog_timer_set_ms;
-+              wdt.max_timer_ms = bus->chipco.max_timer_ms;
-+      } else if (ssb_extif_available(&bus->extif)) {
-+              wdt.driver_data = &bus->extif;
-+              wdt.timer_set = ssb_extif_watchdog_timer_set_wdt;
-+              wdt.timer_set_ms = ssb_extif_watchdog_timer_set_ms;
-+              wdt.max_timer_ms = SSB_EXTIF_WATCHDOG_MAX_TIMER_MS;
-+      } else {
-+              return -ENODEV;
-+      }
-+
-+      pdev = platform_device_register_data(NULL, "bcm47xx-wdt",
-+                                           bus->busnumber, &wdt,
-+                                           sizeof(wdt));
-+      if (IS_ERR(pdev)) {
-+              ssb_dbg("can not register watchdog device, err: %li\n",
-+                      PTR_ERR(pdev));
-+              return PTR_ERR(pdev);
-+      }
-+
-+      bus->watchdog = pdev;
-+      return 0;
-+}
-+
- u32 ssb_gpio_in(struct ssb_bus *bus, u32 mask)
- {
-       unsigned long flags;
---- a/drivers/ssb/main.c
-+++ b/drivers/ssb/main.c
-@@ -13,6 +13,7 @@
- #include <linux/delay.h>
- #include <linux/io.h>
- #include <linux/module.h>
-+#include <linux/platform_device.h>
- #include <linux/ssb/ssb.h>
- #include <linux/ssb/ssb_regs.h>
- #include <linux/ssb/ssb_driver_gige.h>
-@@ -289,8 +290,8 @@ int ssb_devices_thaw(struct ssb_freeze_c
-               err = sdrv->probe(sdev, &sdev->id);
-               if (err) {
--                      ssb_printk(KERN_ERR PFX "Failed to thaw device %s\n",
--                                 dev_name(sdev->dev));
-+                      ssb_err("Failed to thaw device %s\n",
-+                              dev_name(sdev->dev));
-                       result = err;
-               }
-               ssb_driver_put(sdrv);
-@@ -449,10 +450,23 @@ static void ssb_devices_unregister(struc
-               if (sdev->dev)
-                       device_unregister(sdev->dev);
-       }
-+
-+#ifdef CONFIG_SSB_EMBEDDED
-+      if (bus->bustype == SSB_BUSTYPE_SSB)
-+              platform_device_unregister(bus->watchdog);
-+#endif
- }
- void ssb_bus_unregister(struct ssb_bus *bus)
- {
-+      int err;
-+
-+      err = ssb_gpio_unregister(bus);
-+      if (err == -EBUSY)
-+              ssb_dbg("Some GPIOs are still in use\n");
-+      else if (err)
-+              ssb_dbg("Can not unregister GPIO driver: %i\n", err);
-+
-       ssb_buses_lock();
-       ssb_devices_unregister(bus);
-       list_del(&bus->list);
-@@ -498,8 +512,7 @@ static int ssb_devices_register(struct s
-               devwrap = kzalloc(sizeof(*devwrap), GFP_KERNEL);
-               if (!devwrap) {
--                      ssb_printk(KERN_ERR PFX
--                                 "Could not allocate device\n");
-+                      ssb_err("Could not allocate device\n");
-                       err = -ENOMEM;
-                       goto error;
-               }
-@@ -538,9 +551,7 @@ static int ssb_devices_register(struct s
-               sdev->dev = dev;
-               err = device_register(dev);
-               if (err) {
--                      ssb_printk(KERN_ERR PFX
--                                 "Could not register %s\n",
--                                 dev_name(dev));
-+                      ssb_err("Could not register %s\n", dev_name(dev));
-                       /* Set dev to NULL to not unregister
-                        * dev on error unwinding. */
-                       sdev->dev = NULL;
-@@ -550,6 +561,22 @@ static int ssb_devices_register(struct s
-               dev_idx++;
-       }
-+#ifdef CONFIG_SSB_DRIVER_MIPS
-+      if (bus->mipscore.pflash.present) {
-+              err = platform_device_register(&ssb_pflash_dev);
-+              if (err)
-+                      pr_err("Error registering parallel flash\n");
-+      }
-+#endif
-+
-+#ifdef CONFIG_SSB_SFLASH
-+      if (bus->mipscore.sflash.present) {
-+              err = platform_device_register(&ssb_sflash_dev);
-+              if (err)
-+                      pr_err("Error registering serial flash\n");
-+      }
-+#endif
-+
-       return 0;
- error:
-       /* Unwind the already registered devices. */
-@@ -577,6 +604,8 @@ static int __devinit ssb_attach_queued_b
-               if (err)
-                       goto error;
-               ssb_pcicore_init(&bus->pcicore);
-+              if (bus->bustype == SSB_BUSTYPE_SSB)
-+                      ssb_watchdog_register(bus);
-               ssb_bus_may_powerdown(bus);
-               err = ssb_devices_register(bus);
-@@ -812,7 +841,13 @@ static int __devinit ssb_bus_register(st
-       if (err)
-               goto err_pcmcia_exit;
-       ssb_chipcommon_init(&bus->chipco);
-+      ssb_extif_init(&bus->extif);
-       ssb_mipscore_init(&bus->mipscore);
-+      err = ssb_gpio_init(bus);
-+      if (err == -ENOTSUPP)
-+              ssb_dbg("GPIO driver not activated\n");
-+      else if (err)
-+              ssb_dbg("Error registering GPIO driver: %i\n", err);
-       err = ssb_fetch_invariants(bus, get_invariants);
-       if (err) {
-               ssb_bus_may_powerdown(bus);
-@@ -863,11 +898,11 @@ int __devinit ssb_bus_pcibus_register(st
-       err = ssb_bus_register(bus, ssb_pci_get_invariants, 0);
-       if (!err) {
--              ssb_printk(KERN_INFO PFX "Sonics Silicon Backplane found on "
--                         "PCI device %s\n", dev_name(&host_pci->dev));
-+              ssb_info("Sonics Silicon Backplane found on PCI device %s\n",
-+                       dev_name(&host_pci->dev));
-       } else {
--              ssb_printk(KERN_ERR PFX "Failed to register PCI version"
--                         " of SSB with error %d\n", err);
-+              ssb_err("Failed to register PCI version of SSB with error %d\n",
-+                      err);
-       }
-       return err;
-@@ -888,8 +923,8 @@ int __devinit ssb_bus_pcmciabus_register
-       err = ssb_bus_register(bus, ssb_pcmcia_get_invariants, baseaddr);
-       if (!err) {
--              ssb_printk(KERN_INFO PFX "Sonics Silicon Backplane found on "
--                         "PCMCIA device %s\n", pcmcia_dev->devname);
-+              ssb_info("Sonics Silicon Backplane found on PCMCIA device %s\n",
-+                       pcmcia_dev->devname);
-       }
-       return err;
-@@ -911,8 +946,8 @@ int __devinit ssb_bus_sdiobus_register(s
-       err = ssb_bus_register(bus, ssb_sdio_get_invariants, ~0);
-       if (!err) {
--              ssb_printk(KERN_INFO PFX "Sonics Silicon Backplane found on "
--                         "SDIO device %s\n", sdio_func_id(func));
-+              ssb_info("Sonics Silicon Backplane found on SDIO device %s\n",
-+                       sdio_func_id(func));
-       }
-       return err;
-@@ -931,8 +966,8 @@ int __devinit ssb_bus_ssbbus_register(st
-       err = ssb_bus_register(bus, get_invariants, baseaddr);
-       if (!err) {
--              ssb_printk(KERN_INFO PFX "Sonics Silicon Backplane found at "
--                         "address 0x%08lX\n", baseaddr);
-+              ssb_info("Sonics Silicon Backplane found at address 0x%08lX\n",
-+                       baseaddr);
-       }
-       return err;
-@@ -1094,6 +1129,9 @@ u32 ssb_clockspeed(struct ssb_bus *bus)
-       u32 plltype;
-       u32 clkctl_n, clkctl_m;
-+      if (bus->chipco.capabilities & SSB_CHIPCO_CAP_PMU)
-+              return ssb_pmu_get_controlclock(&bus->chipco);
-+
-       if (ssb_extif_available(&bus->extif))
-               ssb_extif_get_clockcontrol(&bus->extif, &plltype,
-                                          &clkctl_n, &clkctl_m);
-@@ -1131,8 +1169,7 @@ static u32 ssb_tmslow_reject_bitmask(str
-       case SSB_IDLOW_SSBREV_27:     /* same here */
-               return SSB_TMSLOW_REJECT;       /* this is a guess */
-       default:
--              printk(KERN_INFO "ssb: Backplane Revision 0x%.8X\n", rev);
--              WARN_ON(1);
-+              WARN(1, KERN_INFO "ssb: Backplane Revision 0x%.8X\n", rev);
-       }
-       return (SSB_TMSLOW_REJECT | SSB_TMSLOW_REJECT_23);
- }
-@@ -1324,7 +1361,7 @@ out:
- #endif
-       return err;
- error:
--      ssb_printk(KERN_ERR PFX "Bus powerdown failed\n");
-+      ssb_err("Bus powerdown failed\n");
-       goto out;
- }
- EXPORT_SYMBOL(ssb_bus_may_powerdown);
-@@ -1347,7 +1384,7 @@ int ssb_bus_powerup(struct ssb_bus *bus,
-       return 0;
- error:
--      ssb_printk(KERN_ERR PFX "Bus powerup failed\n");
-+      ssb_err("Bus powerup failed\n");
-       return err;
- }
- EXPORT_SYMBOL(ssb_bus_powerup);
-@@ -1455,15 +1492,13 @@ static int __init ssb_modinit(void)
-       err = b43_pci_ssb_bridge_init();
-       if (err) {
--              ssb_printk(KERN_ERR "Broadcom 43xx PCI-SSB-bridge "
--                         "initialization failed\n");
-+              ssb_err("Broadcom 43xx PCI-SSB-bridge initialization failed\n");
-               /* don't fail SSB init because of this */
-               err = 0;
-       }
-       err = ssb_gige_init();
-       if (err) {
--              ssb_printk(KERN_ERR "SSB Broadcom Gigabit Ethernet "
--                         "driver initialization failed\n");
-+              ssb_err("SSB Broadcom Gigabit Ethernet driver initialization failed\n");
-               /* don't fail SSB init because of this */
-               err = 0;
-       }
---- a/drivers/ssb/pci.c
-+++ b/drivers/ssb/pci.c
-@@ -56,7 +56,7 @@ int ssb_pci_switch_coreidx(struct ssb_bu
-       }
-       return 0;
- error:
--      ssb_printk(KERN_ERR PFX "Failed to switch to core %u\n", coreidx);
-+      ssb_err("Failed to switch to core %u\n", coreidx);
-       return -ENODEV;
- }
-@@ -67,10 +67,9 @@ int ssb_pci_switch_core(struct ssb_bus *
-       unsigned long flags;
- #if SSB_VERBOSE_PCICORESWITCH_DEBUG
--      ssb_printk(KERN_INFO PFX
--                 "Switching to %s core, index %d\n",
--                 ssb_core_name(dev->id.coreid),
--                 dev->core_index);
-+      ssb_info("Switching to %s core, index %d\n",
-+               ssb_core_name(dev->id.coreid),
-+               dev->core_index);
- #endif
-       spin_lock_irqsave(&bus->bar_lock, flags);
-@@ -178,6 +177,18 @@ err_pci:
- #define SPEX(_outvar, _offset, _mask, _shift) \
-       SPEX16(_outvar, _offset, _mask, _shift)
-+#define SPEX_ARRAY8(_field, _offset, _mask, _shift)   \
-+      do {    \
-+              SPEX(_field[0], _offset +  0, _mask, _shift);   \
-+              SPEX(_field[1], _offset +  2, _mask, _shift);   \
-+              SPEX(_field[2], _offset +  4, _mask, _shift);   \
-+              SPEX(_field[3], _offset +  6, _mask, _shift);   \
-+              SPEX(_field[4], _offset +  8, _mask, _shift);   \
-+              SPEX(_field[5], _offset + 10, _mask, _shift);   \
-+              SPEX(_field[6], _offset + 12, _mask, _shift);   \
-+              SPEX(_field[7], _offset + 14, _mask, _shift);   \
-+      } while (0)
-+
- static inline u8 ssb_crc8(u8 crc, u8 data)
- {
-@@ -219,6 +230,15 @@ static inline u8 ssb_crc8(u8 crc, u8 dat
-       return t[crc ^ data];
- }
-+static void sprom_get_mac(char *mac, const u16 *in)
-+{
-+      int i;
-+      for (i = 0; i < 3; i++) {
-+              *mac++ = in[i] >> 8;
-+              *mac++ = in[i];
-+      }
-+}
-+
- static u8 ssb_sprom_crc(const u16 *sprom, u16 size)
- {
-       int word;
-@@ -266,7 +286,7 @@ static int sprom_do_write(struct ssb_bus
-       u32 spromctl;
-       u16 size = bus->sprom_size;
--      ssb_printk(KERN_NOTICE PFX "Writing SPROM. Do NOT turn off the power! Please stand by...\n");
-+      ssb_notice("Writing SPROM. Do NOT turn off the power! Please stand by...\n");
-       err = pci_read_config_dword(pdev, SSB_SPROMCTL, &spromctl);
-       if (err)
-               goto err_ctlreg;
-@@ -274,17 +294,17 @@ static int sprom_do_write(struct ssb_bus
-       err = pci_write_config_dword(pdev, SSB_SPROMCTL, spromctl);
-       if (err)
-               goto err_ctlreg;
--      ssb_printk(KERN_NOTICE PFX "[ 0%%");
-+      ssb_notice("[ 0%%");
-       msleep(500);
-       for (i = 0; i < size; i++) {
-               if (i == size / 4)
--                      ssb_printk("25%%");
-+                      ssb_cont("25%%");
-               else if (i == size / 2)
--                      ssb_printk("50%%");
-+                      ssb_cont("50%%");
-               else if (i == (size * 3) / 4)
--                      ssb_printk("75%%");
-+                      ssb_cont("75%%");
-               else if (i % 2)
--                      ssb_printk(".");
-+                      ssb_cont(".");
-               writew(sprom[i], bus->mmio + bus->sprom_offset + (i * 2));
-               mmiowb();
-               msleep(20);
-@@ -297,12 +317,12 @@ static int sprom_do_write(struct ssb_bus
-       if (err)
-               goto err_ctlreg;
-       msleep(500);
--      ssb_printk("100%% ]\n");
--      ssb_printk(KERN_NOTICE PFX "SPROM written.\n");
-+      ssb_cont("100%% ]\n");
-+      ssb_notice("SPROM written\n");
-       return 0;
- err_ctlreg:
--      ssb_printk(KERN_ERR PFX "Could not access SPROM control register.\n");
-+      ssb_err("Could not access SPROM control register.\n");
-       return err;
- }
-@@ -327,11 +347,23 @@ static s8 r123_extract_antgain(u8 sprom_
-       return (s8)gain;
- }
-+static void sprom_extract_r23(struct ssb_sprom *out, const u16 *in)
-+{
-+      SPEX(boardflags_hi, SSB_SPROM2_BFLHI, 0xFFFF, 0);
-+      SPEX(opo, SSB_SPROM2_OPO, SSB_SPROM2_OPO_VALUE, 0);
-+      SPEX(pa1lob0, SSB_SPROM2_PA1LOB0, 0xFFFF, 0);
-+      SPEX(pa1lob1, SSB_SPROM2_PA1LOB1, 0xFFFF, 0);
-+      SPEX(pa1lob2, SSB_SPROM2_PA1LOB2, 0xFFFF, 0);
-+      SPEX(pa1hib0, SSB_SPROM2_PA1HIB0, 0xFFFF, 0);
-+      SPEX(pa1hib1, SSB_SPROM2_PA1HIB1, 0xFFFF, 0);
-+      SPEX(pa1hib2, SSB_SPROM2_PA1HIB2, 0xFFFF, 0);
-+      SPEX(maxpwr_ah, SSB_SPROM2_MAXP_A, SSB_SPROM2_MAXP_A_HI, 0);
-+      SPEX(maxpwr_al, SSB_SPROM2_MAXP_A, SSB_SPROM2_MAXP_A_LO,
-+           SSB_SPROM2_MAXP_A_LO_SHIFT);
-+}
-+
- static void sprom_extract_r123(struct ssb_sprom *out, const u16 *in)
- {
--      int i;
--      u16 v;
--      s8 gain;
-       u16 loc[3];
-       if (out->revision == 3)                 /* rev 3 moved MAC */
-@@ -341,19 +373,10 @@ static void sprom_extract_r123(struct ss
-               loc[1] = SSB_SPROM1_ET0MAC;
-               loc[2] = SSB_SPROM1_ET1MAC;
-       }
--      for (i = 0; i < 3; i++) {
--              v = in[SPOFF(loc[0]) + i];
--              *(((__be16 *)out->il0mac) + i) = cpu_to_be16(v);
--      }
-+      sprom_get_mac(out->il0mac, &in[SPOFF(loc[0])]);
-       if (out->revision < 3) {        /* only rev 1-2 have et0, et1 */
--              for (i = 0; i < 3; i++) {
--                      v = in[SPOFF(loc[1]) + i];
--                      *(((__be16 *)out->et0mac) + i) = cpu_to_be16(v);
--              }
--              for (i = 0; i < 3; i++) {
--                      v = in[SPOFF(loc[2]) + i];
--                      *(((__be16 *)out->et1mac) + i) = cpu_to_be16(v);
--              }
-+              sprom_get_mac(out->et0mac, &in[SPOFF(loc[1])]);
-+              sprom_get_mac(out->et1mac, &in[SPOFF(loc[2])]);
-       }
-       SPEX(et0phyaddr, SSB_SPROM1_ETHPHY, SSB_SPROM1_ETHPHY_ET0A, 0);
-       SPEX(et1phyaddr, SSB_SPROM1_ETHPHY, SSB_SPROM1_ETHPHY_ET1A,
-@@ -361,8 +384,10 @@ static void sprom_extract_r123(struct ss
-       SPEX(et0mdcport, SSB_SPROM1_ETHPHY, SSB_SPROM1_ETHPHY_ET0M, 14);
-       SPEX(et1mdcport, SSB_SPROM1_ETHPHY, SSB_SPROM1_ETHPHY_ET1M, 15);
-       SPEX(board_rev, SSB_SPROM1_BINF, SSB_SPROM1_BINF_BREV, 0);
--      SPEX(country_code, SSB_SPROM1_BINF, SSB_SPROM1_BINF_CCODE,
--           SSB_SPROM1_BINF_CCODE_SHIFT);
-+      SPEX(board_type, SSB_SPROM1_SPID, 0xFFFF, 0);
-+      if (out->revision == 1)
-+              SPEX(country_code, SSB_SPROM1_BINF, SSB_SPROM1_BINF_CCODE,
-+                   SSB_SPROM1_BINF_CCODE_SHIFT);
-       SPEX(ant_available_a, SSB_SPROM1_BINF, SSB_SPROM1_BINF_ANTA,
-            SSB_SPROM1_BINF_ANTA_SHIFT);
-       SPEX(ant_available_bg, SSB_SPROM1_BINF, SSB_SPROM1_BINF_ANTBG,
-@@ -386,24 +411,19 @@ static void sprom_extract_r123(struct ss
-            SSB_SPROM1_ITSSI_A_SHIFT);
-       SPEX(itssi_bg, SSB_SPROM1_ITSSI, SSB_SPROM1_ITSSI_BG, 0);
-       SPEX(boardflags_lo, SSB_SPROM1_BFLLO, 0xFFFF, 0);
--      if (out->revision >= 2)
--              SPEX(boardflags_hi, SSB_SPROM2_BFLHI, 0xFFFF, 0);
-+
-+      SPEX(alpha2[0], SSB_SPROM1_CCODE, 0xff00, 8);
-+      SPEX(alpha2[1], SSB_SPROM1_CCODE, 0x00ff, 0);
-       /* Extract the antenna gain values. */
--      gain = r123_extract_antgain(out->revision, in,
--                                  SSB_SPROM1_AGAIN_BG,
--                                  SSB_SPROM1_AGAIN_BG_SHIFT);
--      out->antenna_gain.ghz24.a0 = gain;
--      out->antenna_gain.ghz24.a1 = gain;
--      out->antenna_gain.ghz24.a2 = gain;
--      out->antenna_gain.ghz24.a3 = gain;
--      gain = r123_extract_antgain(out->revision, in,
--                                  SSB_SPROM1_AGAIN_A,
--                                  SSB_SPROM1_AGAIN_A_SHIFT);
--      out->antenna_gain.ghz5.a0 = gain;
--      out->antenna_gain.ghz5.a1 = gain;
--      out->antenna_gain.ghz5.a2 = gain;
--      out->antenna_gain.ghz5.a3 = gain;
-+      out->antenna_gain.a0 = r123_extract_antgain(out->revision, in,
-+                                                  SSB_SPROM1_AGAIN_BG,
-+                                                  SSB_SPROM1_AGAIN_BG_SHIFT);
-+      out->antenna_gain.a1 = r123_extract_antgain(out->revision, in,
-+                                                  SSB_SPROM1_AGAIN_A,
-+                                                  SSB_SPROM1_AGAIN_A_SHIFT);
-+      if (out->revision >= 2)
-+              sprom_extract_r23(out, in);
- }
- /* Revs 4 5 and 8 have partially shared layout */
-@@ -448,30 +468,30 @@ static void sprom_extract_r458(struct ss
- static void sprom_extract_r45(struct ssb_sprom *out, const u16 *in)
- {
--      int i;
--      u16 v;
-       u16 il0mac_offset;
-       if (out->revision == 4)
-               il0mac_offset = SSB_SPROM4_IL0MAC;
-       else
-               il0mac_offset = SSB_SPROM5_IL0MAC;
--      /* extract the MAC address */
--      for (i = 0; i < 3; i++) {
--              v = in[SPOFF(il0mac_offset) + i];
--              *(((__be16 *)out->il0mac) + i) = cpu_to_be16(v);
--      }
-+
-+      sprom_get_mac(out->il0mac, &in[SPOFF(il0mac_offset)]);
-+
-       SPEX(et0phyaddr, SSB_SPROM4_ETHPHY, SSB_SPROM4_ETHPHY_ET0A, 0);
-       SPEX(et1phyaddr, SSB_SPROM4_ETHPHY, SSB_SPROM4_ETHPHY_ET1A,
-            SSB_SPROM4_ETHPHY_ET1A_SHIFT);
-+      SPEX(board_rev, SSB_SPROM4_BOARDREV, 0xFFFF, 0);
-+      SPEX(board_type, SSB_SPROM1_SPID, 0xFFFF, 0);
-       if (out->revision == 4) {
--              SPEX(country_code, SSB_SPROM4_CCODE, 0xFFFF, 0);
-+              SPEX(alpha2[0], SSB_SPROM4_CCODE, 0xff00, 8);
-+              SPEX(alpha2[1], SSB_SPROM4_CCODE, 0x00ff, 0);
-               SPEX(boardflags_lo, SSB_SPROM4_BFLLO, 0xFFFF, 0);
-               SPEX(boardflags_hi, SSB_SPROM4_BFLHI, 0xFFFF, 0);
-               SPEX(boardflags2_lo, SSB_SPROM4_BFL2LO, 0xFFFF, 0);
-               SPEX(boardflags2_hi, SSB_SPROM4_BFL2HI, 0xFFFF, 0);
-       } else {
--              SPEX(country_code, SSB_SPROM5_CCODE, 0xFFFF, 0);
-+              SPEX(alpha2[0], SSB_SPROM5_CCODE, 0xff00, 8);
-+              SPEX(alpha2[1], SSB_SPROM5_CCODE, 0x00ff, 0);
-               SPEX(boardflags_lo, SSB_SPROM5_BFLLO, 0xFFFF, 0);
-               SPEX(boardflags_hi, SSB_SPROM5_BFLHI, 0xFFFF, 0);
-               SPEX(boardflags2_lo, SSB_SPROM5_BFL2LO, 0xFFFF, 0);
-@@ -504,16 +524,14 @@ static void sprom_extract_r45(struct ssb
-       }
-       /* Extract the antenna gain values. */
--      SPEX(antenna_gain.ghz24.a0, SSB_SPROM4_AGAIN01,
-+      SPEX(antenna_gain.a0, SSB_SPROM4_AGAIN01,
-            SSB_SPROM4_AGAIN0, SSB_SPROM4_AGAIN0_SHIFT);
--      SPEX(antenna_gain.ghz24.a1, SSB_SPROM4_AGAIN01,
-+      SPEX(antenna_gain.a1, SSB_SPROM4_AGAIN01,
-            SSB_SPROM4_AGAIN1, SSB_SPROM4_AGAIN1_SHIFT);
--      SPEX(antenna_gain.ghz24.a2, SSB_SPROM4_AGAIN23,
-+      SPEX(antenna_gain.a2, SSB_SPROM4_AGAIN23,
-            SSB_SPROM4_AGAIN2, SSB_SPROM4_AGAIN2_SHIFT);
--      SPEX(antenna_gain.ghz24.a3, SSB_SPROM4_AGAIN23,
-+      SPEX(antenna_gain.a3, SSB_SPROM4_AGAIN23,
-            SSB_SPROM4_AGAIN3, SSB_SPROM4_AGAIN3_SHIFT);
--      memcpy(&out->antenna_gain.ghz5, &out->antenna_gain.ghz24,
--             sizeof(out->antenna_gain.ghz5));
-       sprom_extract_r458(out, in);
-@@ -523,14 +541,21 @@ static void sprom_extract_r45(struct ssb
- static void sprom_extract_r8(struct ssb_sprom *out, const u16 *in)
- {
-       int i;
--      u16 v;
-+      u16 o;
-+      u16 pwr_info_offset[] = {
-+              SSB_SROM8_PWR_INFO_CORE0, SSB_SROM8_PWR_INFO_CORE1,
-+              SSB_SROM8_PWR_INFO_CORE2, SSB_SROM8_PWR_INFO_CORE3
-+      };
-+      BUILD_BUG_ON(ARRAY_SIZE(pwr_info_offset) !=
-+                      ARRAY_SIZE(out->core_pwr_info));
-       /* extract the MAC address */
--      for (i = 0; i < 3; i++) {
--              v = in[SPOFF(SSB_SPROM8_IL0MAC) + i];
--              *(((__be16 *)out->il0mac) + i) = cpu_to_be16(v);
--      }
--      SPEX(country_code, SSB_SPROM8_CCODE, 0xFFFF, 0);
-+      sprom_get_mac(out->il0mac, &in[SPOFF(SSB_SPROM8_IL0MAC)]);
-+
-+      SPEX(board_rev, SSB_SPROM8_BOARDREV, 0xFFFF, 0);
-+      SPEX(board_type, SSB_SPROM1_SPID, 0xFFFF, 0);
-+      SPEX(alpha2[0], SSB_SPROM8_CCODE, 0xff00, 8);
-+      SPEX(alpha2[1], SSB_SPROM8_CCODE, 0x00ff, 0);
-       SPEX(boardflags_lo, SSB_SPROM8_BFLLO, 0xFFFF, 0);
-       SPEX(boardflags_hi, SSB_SPROM8_BFLHI, 0xFFFF, 0);
-       SPEX(boardflags2_lo, SSB_SPROM8_BFL2LO, 0xFFFF, 0);
-@@ -596,16 +621,46 @@ static void sprom_extract_r8(struct ssb_
-       SPEX32(ofdm5ghpo, SSB_SPROM8_OFDM5GHPO, 0xFFFFFFFF, 0);
-       /* Extract the antenna gain values. */
--      SPEX(antenna_gain.ghz24.a0, SSB_SPROM8_AGAIN01,
-+      SPEX(antenna_gain.a0, SSB_SPROM8_AGAIN01,
-            SSB_SPROM8_AGAIN0, SSB_SPROM8_AGAIN0_SHIFT);
--      SPEX(antenna_gain.ghz24.a1, SSB_SPROM8_AGAIN01,
-+      SPEX(antenna_gain.a1, SSB_SPROM8_AGAIN01,
-            SSB_SPROM8_AGAIN1, SSB_SPROM8_AGAIN1_SHIFT);
--      SPEX(antenna_gain.ghz24.a2, SSB_SPROM8_AGAIN23,
-+      SPEX(antenna_gain.a2, SSB_SPROM8_AGAIN23,
-            SSB_SPROM8_AGAIN2, SSB_SPROM8_AGAIN2_SHIFT);
--      SPEX(antenna_gain.ghz24.a3, SSB_SPROM8_AGAIN23,
-+      SPEX(antenna_gain.a3, SSB_SPROM8_AGAIN23,
-            SSB_SPROM8_AGAIN3, SSB_SPROM8_AGAIN3_SHIFT);
--      memcpy(&out->antenna_gain.ghz5, &out->antenna_gain.ghz24,
--             sizeof(out->antenna_gain.ghz5));
-+
-+      /* Extract cores power info info */
-+      for (i = 0; i < ARRAY_SIZE(pwr_info_offset); i++) {
-+              o = pwr_info_offset[i];
-+              SPEX(core_pwr_info[i].itssi_2g, o + SSB_SROM8_2G_MAXP_ITSSI,
-+                      SSB_SPROM8_2G_ITSSI, SSB_SPROM8_2G_ITSSI_SHIFT);
-+              SPEX(core_pwr_info[i].maxpwr_2g, o + SSB_SROM8_2G_MAXP_ITSSI,
-+                      SSB_SPROM8_2G_MAXP, 0);
-+
-+              SPEX(core_pwr_info[i].pa_2g[0], o + SSB_SROM8_2G_PA_0, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_2g[1], o + SSB_SROM8_2G_PA_1, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_2g[2], o + SSB_SROM8_2G_PA_2, ~0, 0);
-+
-+              SPEX(core_pwr_info[i].itssi_5g, o + SSB_SROM8_5G_MAXP_ITSSI,
-+                      SSB_SPROM8_5G_ITSSI, SSB_SPROM8_5G_ITSSI_SHIFT);
-+              SPEX(core_pwr_info[i].maxpwr_5g, o + SSB_SROM8_5G_MAXP_ITSSI,
-+                      SSB_SPROM8_5G_MAXP, 0);
-+              SPEX(core_pwr_info[i].maxpwr_5gh, o + SSB_SPROM8_5GHL_MAXP,
-+                      SSB_SPROM8_5GH_MAXP, 0);
-+              SPEX(core_pwr_info[i].maxpwr_5gl, o + SSB_SPROM8_5GHL_MAXP,
-+                      SSB_SPROM8_5GL_MAXP, SSB_SPROM8_5GL_MAXP_SHIFT);
-+
-+              SPEX(core_pwr_info[i].pa_5gl[0], o + SSB_SROM8_5GL_PA_0, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5gl[1], o + SSB_SROM8_5GL_PA_1, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5gl[2], o + SSB_SROM8_5GL_PA_2, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5g[0], o + SSB_SROM8_5G_PA_0, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5g[1], o + SSB_SROM8_5G_PA_1, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5g[2], o + SSB_SROM8_5G_PA_2, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5gh[0], o + SSB_SROM8_5GH_PA_0, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5gh[1], o + SSB_SROM8_5GH_PA_1, ~0, 0);
-+              SPEX(core_pwr_info[i].pa_5gh[2], o + SSB_SROM8_5GH_PA_2, ~0, 0);
-+      }
-       /* Extract FEM info */
-       SPEX(fem.ghz2.tssipos, SSB_SPROM8_FEM2G,
-@@ -630,6 +685,63 @@ static void sprom_extract_r8(struct ssb_
-       SPEX(fem.ghz5.antswlut, SSB_SPROM8_FEM5G,
-               SSB_SROM8_FEM_ANTSWLUT, SSB_SROM8_FEM_ANTSWLUT_SHIFT);
-+      SPEX(leddc_on_time, SSB_SPROM8_LEDDC, SSB_SPROM8_LEDDC_ON,
-+           SSB_SPROM8_LEDDC_ON_SHIFT);
-+      SPEX(leddc_off_time, SSB_SPROM8_LEDDC, SSB_SPROM8_LEDDC_OFF,
-+           SSB_SPROM8_LEDDC_OFF_SHIFT);
-+
-+      SPEX(txchain, SSB_SPROM8_TXRXC, SSB_SPROM8_TXRXC_TXCHAIN,
-+           SSB_SPROM8_TXRXC_TXCHAIN_SHIFT);
-+      SPEX(rxchain, SSB_SPROM8_TXRXC, SSB_SPROM8_TXRXC_RXCHAIN,
-+           SSB_SPROM8_TXRXC_RXCHAIN_SHIFT);
-+      SPEX(antswitch, SSB_SPROM8_TXRXC, SSB_SPROM8_TXRXC_SWITCH,
-+           SSB_SPROM8_TXRXC_SWITCH_SHIFT);
-+
-+      SPEX(opo, SSB_SPROM8_OFDM2GPO, 0x00ff, 0);
-+
-+      SPEX_ARRAY8(mcs2gpo, SSB_SPROM8_2G_MCSPO, ~0, 0);
-+      SPEX_ARRAY8(mcs5gpo, SSB_SPROM8_5G_MCSPO, ~0, 0);
-+      SPEX_ARRAY8(mcs5glpo, SSB_SPROM8_5GL_MCSPO, ~0, 0);
-+      SPEX_ARRAY8(mcs5ghpo, SSB_SPROM8_5GH_MCSPO, ~0, 0);
-+
-+      SPEX(rawtempsense, SSB_SPROM8_RAWTS, SSB_SPROM8_RAWTS_RAWTEMP,
-+           SSB_SPROM8_RAWTS_RAWTEMP_SHIFT);
-+      SPEX(measpower, SSB_SPROM8_RAWTS, SSB_SPROM8_RAWTS_MEASPOWER,
-+           SSB_SPROM8_RAWTS_MEASPOWER_SHIFT);
-+      SPEX(tempsense_slope, SSB_SPROM8_OPT_CORRX,
-+           SSB_SPROM8_OPT_CORRX_TEMP_SLOPE,
-+           SSB_SPROM8_OPT_CORRX_TEMP_SLOPE_SHIFT);
-+      SPEX(tempcorrx, SSB_SPROM8_OPT_CORRX, SSB_SPROM8_OPT_CORRX_TEMPCORRX,
-+           SSB_SPROM8_OPT_CORRX_TEMPCORRX_SHIFT);
-+      SPEX(tempsense_option, SSB_SPROM8_OPT_CORRX,
-+           SSB_SPROM8_OPT_CORRX_TEMP_OPTION,
-+           SSB_SPROM8_OPT_CORRX_TEMP_OPTION_SHIFT);
-+      SPEX(freqoffset_corr, SSB_SPROM8_HWIQ_IQSWP,
-+           SSB_SPROM8_HWIQ_IQSWP_FREQ_CORR,
-+           SSB_SPROM8_HWIQ_IQSWP_FREQ_CORR_SHIFT);
-+      SPEX(iqcal_swp_dis, SSB_SPROM8_HWIQ_IQSWP,
-+           SSB_SPROM8_HWIQ_IQSWP_IQCAL_SWP,
-+           SSB_SPROM8_HWIQ_IQSWP_IQCAL_SWP_SHIFT);
-+      SPEX(hw_iqcal_en, SSB_SPROM8_HWIQ_IQSWP, SSB_SPROM8_HWIQ_IQSWP_HW_IQCAL,
-+           SSB_SPROM8_HWIQ_IQSWP_HW_IQCAL_SHIFT);
-+
-+      SPEX(bw40po, SSB_SPROM8_BW40PO, ~0, 0);
-+      SPEX(cddpo, SSB_SPROM8_CDDPO, ~0, 0);
-+      SPEX(stbcpo, SSB_SPROM8_STBCPO, ~0, 0);
-+      SPEX(bwduppo, SSB_SPROM8_BWDUPPO, ~0, 0);
-+
-+      SPEX(tempthresh, SSB_SPROM8_THERMAL, SSB_SPROM8_THERMAL_TRESH,
-+           SSB_SPROM8_THERMAL_TRESH_SHIFT);
-+      SPEX(tempoffset, SSB_SPROM8_THERMAL, SSB_SPROM8_THERMAL_OFFSET,
-+           SSB_SPROM8_THERMAL_OFFSET_SHIFT);
-+      SPEX(phycal_tempdelta, SSB_SPROM8_TEMPDELTA,
-+           SSB_SPROM8_TEMPDELTA_PHYCAL,
-+           SSB_SPROM8_TEMPDELTA_PHYCAL_SHIFT);
-+      SPEX(temps_period, SSB_SPROM8_TEMPDELTA, SSB_SPROM8_TEMPDELTA_PERIOD,
-+           SSB_SPROM8_TEMPDELTA_PERIOD_SHIFT);
-+      SPEX(temps_hysteresis, SSB_SPROM8_TEMPDELTA,
-+           SSB_SPROM8_TEMPDELTA_HYSTERESIS,
-+           SSB_SPROM8_TEMPDELTA_HYSTERESIS_SHIFT);
-       sprom_extract_r458(out, in);
-       /* TODO - get remaining rev 8 stuff needed */
-@@ -641,7 +753,7 @@ static int sprom_extract(struct ssb_bus
-       memset(out, 0, sizeof(*out));
-       out->revision = in[size - 1] & 0x00FF;
--      ssb_dprintk(KERN_DEBUG PFX "SPROM revision %d detected.\n", out->revision);
-+      ssb_dbg("SPROM revision %d detected\n", out->revision);
-       memset(out->et0mac, 0xFF, 6);           /* preset et0 and et1 mac */
-       memset(out->et1mac, 0xFF, 6);
-@@ -650,7 +762,7 @@ static int sprom_extract(struct ssb_bus
-                * number stored in the SPROM.
-                * Always extract r1. */
-               out->revision = 1;
--              ssb_dprintk(KERN_DEBUG PFX "SPROM treated as revision %d\n", out->revision);
-+              ssb_dbg("SPROM treated as revision %d\n", out->revision);
-       }
-       switch (out->revision) {
-@@ -667,9 +779,8 @@ static int sprom_extract(struct ssb_bus
-               sprom_extract_r8(out, in);
-               break;
-       default:
--              ssb_printk(KERN_WARNING PFX "Unsupported SPROM"
--                         " revision %d detected. Will extract"
--                         " v1\n", out->revision);
-+              ssb_warn("Unsupported SPROM revision %d detected. Will extract v1\n",
-+                       out->revision);
-               out->revision = 1;
-               sprom_extract_r123(out, in);
-       }
-@@ -689,7 +800,7 @@ static int ssb_pci_sprom_get(struct ssb_
-       u16 *buf;
-       if (!ssb_is_sprom_available(bus)) {
--              ssb_printk(KERN_ERR PFX "No SPROM available!\n");
-+              ssb_err("No SPROM available!\n");
-               return -ENODEV;
-       }
-       if (bus->chipco.dev) {  /* can be unavailable! */
-@@ -708,7 +819,7 @@ static int ssb_pci_sprom_get(struct ssb_
-       } else {
-               bus->sprom_offset = SSB_SPROM_BASE1;
-       }
--      ssb_dprintk(KERN_INFO PFX "SPROM offset is 0x%x\n", bus->sprom_offset);
-+      ssb_dbg("SPROM offset is 0x%x\n", bus->sprom_offset);
-       buf = kcalloc(SSB_SPROMSIZE_WORDS_R123, sizeof(u16), GFP_KERNEL);
-       if (!buf)
-@@ -733,18 +844,15 @@ static int ssb_pci_sprom_get(struct ssb_
-                        * available for this device in some other storage */
-                       err = ssb_fill_sprom_with_fallback(bus, sprom);
-                       if (err) {
--                              ssb_printk(KERN_WARNING PFX "WARNING: Using"
--                                         " fallback SPROM failed (err %d)\n",
--                                         err);
-+                              ssb_warn("WARNING: Using fallback SPROM failed (err %d)\n",
-+                                       err);
-                       } else {
--                              ssb_dprintk(KERN_DEBUG PFX "Using SPROM"
--                                          " revision %d provided by"
--                                          " platform.\n", sprom->revision);
-+                              ssb_dbg("Using SPROM revision %d provided by platform\n",
-+                                      sprom->revision);
-                               err = 0;
-                               goto out_free;
-                       }
--                      ssb_printk(KERN_WARNING PFX "WARNING: Invalid"
--                                 " SPROM CRC (corrupt SPROM)\n");
-+                      ssb_warn("WARNING: Invalid SPROM CRC (corrupt SPROM)\n");
-               }
-       }
-       err = sprom_extract(bus, sprom, buf, bus->sprom_size);
-@@ -759,7 +867,6 @@ static void ssb_pci_get_boardinfo(struct
- {
-       bi->vendor = bus->host_pci->subsystem_vendor;
-       bi->type = bus->host_pci->subsystem_device;
--      bi->rev = bus->host_pci->revision;
- }
- int ssb_pci_get_invariants(struct ssb_bus *bus,
---- a/drivers/ssb/pcihost_wrapper.c
-+++ b/drivers/ssb/pcihost_wrapper.c
-@@ -38,7 +38,7 @@ static int ssb_pcihost_resume(struct pci
-       struct ssb_bus *ssb = pci_get_drvdata(dev);
-       int err;
--      pci_set_power_state(dev, 0);
-+      pci_set_power_state(dev, PCI_D0);
-       err = pci_enable_device(dev);
-       if (err)
-               return err;
---- a/drivers/ssb/pcmcia.c
-+++ b/drivers/ssb/pcmcia.c
-@@ -143,7 +143,7 @@ int ssb_pcmcia_switch_coreidx(struct ssb
-       return 0;
- error:
--      ssb_printk(KERN_ERR PFX "Failed to switch to core %u\n", coreidx);
-+      ssb_err("Failed to switch to core %u\n", coreidx);
-       return err;
- }
-@@ -153,10 +153,9 @@ int ssb_pcmcia_switch_core(struct ssb_bu
-       int err;
- #if SSB_VERBOSE_PCMCIACORESWITCH_DEBUG
--      ssb_printk(KERN_INFO PFX
--                 "Switching to %s core, index %d\n",
--                 ssb_core_name(dev->id.coreid),
--                 dev->core_index);
-+      ssb_info("Switching to %s core, index %d\n",
-+               ssb_core_name(dev->id.coreid),
-+               dev->core_index);
- #endif
-       err = ssb_pcmcia_switch_coreidx(bus, dev->core_index);
-@@ -192,7 +191,7 @@ int ssb_pcmcia_switch_segment(struct ssb
-       return 0;
- error:
--      ssb_printk(KERN_ERR PFX "Failed to switch pcmcia segment\n");
-+      ssb_err("Failed to switch pcmcia segment\n");
-       return err;
- }
-@@ -549,44 +548,39 @@ static int ssb_pcmcia_sprom_write_all(st
-       bool failed = 0;
-       size_t size = SSB_PCMCIA_SPROM_SIZE;
--      ssb_printk(KERN_NOTICE PFX
--                 "Writing SPROM. Do NOT turn off the power! "
--                 "Please stand by...\n");
-+      ssb_notice("Writing SPROM. Do NOT turn off the power! Please stand by...\n");
-       err = ssb_pcmcia_sprom_command(bus, SSB_PCMCIA_SPROMCTL_WRITEEN);
-       if (err) {
--              ssb_printk(KERN_NOTICE PFX
--                         "Could not enable SPROM write access.\n");
-+              ssb_notice("Could not enable SPROM write access\n");
-               return -EBUSY;
-       }
--      ssb_printk(KERN_NOTICE PFX "[ 0%%");
-+      ssb_notice("[ 0%%");
-       msleep(500);
-       for (i = 0; i < size; i++) {
-               if (i == size / 4)
--                      ssb_printk("25%%");
-+                      ssb_cont("25%%");
-               else if (i == size / 2)
--                      ssb_printk("50%%");
-+                      ssb_cont("50%%");
-               else if (i == (size * 3) / 4)
--                      ssb_printk("75%%");
-+                      ssb_cont("75%%");
-               else if (i % 2)
--                      ssb_printk(".");
-+                      ssb_cont(".");
-               err = ssb_pcmcia_sprom_write(bus, i, sprom[i]);
-               if (err) {
--                      ssb_printk(KERN_NOTICE PFX
--                                 "Failed to write to SPROM.\n");
-+                      ssb_notice("Failed to write to SPROM\n");
-                       failed = 1;
-                       break;
-               }
-       }
-       err = ssb_pcmcia_sprom_command(bus, SSB_PCMCIA_SPROMCTL_WRITEDIS);
-       if (err) {
--              ssb_printk(KERN_NOTICE PFX
--                         "Could not disable SPROM write access.\n");
-+              ssb_notice("Could not disable SPROM write access\n");
-               failed = 1;
-       }
-       msleep(500);
-       if (!failed) {
--              ssb_printk("100%% ]\n");
--              ssb_printk(KERN_NOTICE PFX "SPROM written.\n");
-+              ssb_cont("100%% ]\n");
-+              ssb_notice("SPROM written\n");
-       }
-       return failed ? -EBUSY : 0;
-@@ -676,14 +670,10 @@ static int ssb_pcmcia_do_get_invariants(
-       case SSB_PCMCIA_CIS_ANTGAIN:
-               GOTO_ERROR_ON(tuple->TupleDataLen != 2,
-                       "antg tpl size");
--              sprom->antenna_gain.ghz24.a0 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz24.a1 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz24.a2 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz24.a3 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz5.a0 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz5.a1 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz5.a2 = tuple->TupleData[1];
--              sprom->antenna_gain.ghz5.a3 = tuple->TupleData[1];
-+              sprom->antenna_gain.a0 = tuple->TupleData[1];
-+              sprom->antenna_gain.a1 = tuple->TupleData[1];
-+              sprom->antenna_gain.a2 = tuple->TupleData[1];
-+              sprom->antenna_gain.a3 = tuple->TupleData[1];
-               break;
-       case SSB_PCMCIA_CIS_BFLAGS:
-               GOTO_ERROR_ON((tuple->TupleDataLen != 3) &&
-@@ -704,7 +694,7 @@ static int ssb_pcmcia_do_get_invariants(
-       return -ENOSPC; /* continue with next entry */
- error:
--      ssb_printk(KERN_ERR PFX
-+      ssb_err(
-                  "PCMCIA: Failed to fetch device invariants: %s\n",
-                  error_description);
-       return -ENODEV;
-@@ -726,7 +716,7 @@ int ssb_pcmcia_get_invariants(struct ssb
-       res = pcmcia_loop_tuple(bus->host_pcmcia, CISTPL_FUNCE,
-                               ssb_pcmcia_get_mac, sprom);
-       if (res != 0) {
--              ssb_printk(KERN_ERR PFX
-+              ssb_err(
-                       "PCMCIA: Failed to fetch MAC address\n");
-               return -ENODEV;
-       }
-@@ -737,7 +727,7 @@ int ssb_pcmcia_get_invariants(struct ssb
-       if ((res == 0) || (res == -ENOSPC))
-               return 0;
--      ssb_printk(KERN_ERR PFX
-+      ssb_err(
-                       "PCMCIA: Failed to fetch device invariants\n");
-       return -ENODEV;
- }
-@@ -847,6 +837,6 @@ int ssb_pcmcia_init(struct ssb_bus *bus)
-       return 0;
- error:
--      ssb_printk(KERN_ERR PFX "Failed to initialize PCMCIA host device\n");
-+      ssb_err("Failed to initialize PCMCIA host device\n");
-       return err;
- }
---- a/drivers/ssb/scan.c
-+++ b/drivers/ssb/scan.c
-@@ -90,6 +90,8 @@ const char *ssb_core_name(u16 coreid)
-               return "ARM 1176";
-       case SSB_DEV_ARM_7TDMI:
-               return "ARM 7TDMI";
-+      case SSB_DEV_ARM_CM3:
-+              return "ARM Cortex M3";
-       }
-       return "UNKNOWN";
- }
-@@ -123,8 +125,7 @@ static u16 pcidev_to_chipid(struct pci_d
-               chipid_fallback = 0x4401;
-               break;
-       default:
--              ssb_printk(KERN_ERR PFX
--                         "PCI-ID not in fallback list\n");
-+              ssb_err("PCI-ID not in fallback list\n");
-       }
-       return chipid_fallback;
-@@ -150,8 +151,7 @@ static u8 chipid_to_nrcores(u16 chipid)
-       case 0x4704:
-               return 9;
-       default:
--              ssb_printk(KERN_ERR PFX
--                         "CHIPID not in nrcores fallback list\n");
-+              ssb_err("CHIPID not in nrcores fallback list\n");
-       }
-       return 1;
-@@ -318,12 +318,13 @@ int ssb_bus_scan(struct ssb_bus *bus,
-                       bus->chip_package = 0;
-               }
-       }
-+      ssb_info("Found chip with id 0x%04X, rev 0x%02X and package 0x%02X\n",
-+               bus->chip_id, bus->chip_rev, bus->chip_package);
-       if (!bus->nr_devices)
-               bus->nr_devices = chipid_to_nrcores(bus->chip_id);
-       if (bus->nr_devices > ARRAY_SIZE(bus->devices)) {
--              ssb_printk(KERN_ERR PFX
--                         "More than %d ssb cores found (%d)\n",
--                         SSB_MAX_NR_CORES, bus->nr_devices);
-+              ssb_err("More than %d ssb cores found (%d)\n",
-+                      SSB_MAX_NR_CORES, bus->nr_devices);
-               goto err_unmap;
-       }
-       if (bus->bustype == SSB_BUSTYPE_SSB) {
-@@ -365,8 +366,7 @@ int ssb_bus_scan(struct ssb_bus *bus,
-                       nr_80211_cores++;
-                       if (nr_80211_cores > 1) {
-                               if (!we_support_multiple_80211_cores(bus)) {
--                                      ssb_dprintk(KERN_INFO PFX "Ignoring additional "
--                                                  "802.11 core\n");
-+                                      ssb_dbg("Ignoring additional 802.11 core\n");
-                                       continue;
-                               }
-                       }
-@@ -374,8 +374,7 @@ int ssb_bus_scan(struct ssb_bus *bus,
-               case SSB_DEV_EXTIF:
- #ifdef CONFIG_SSB_DRIVER_EXTIF
-                       if (bus->extif.dev) {
--                              ssb_printk(KERN_WARNING PFX
--                                         "WARNING: Multiple EXTIFs found\n");
-+                              ssb_warn("WARNING: Multiple EXTIFs found\n");
-                               break;
-                       }
-                       bus->extif.dev = dev;
-@@ -383,8 +382,7 @@ int ssb_bus_scan(struct ssb_bus *bus,
-                       break;
-               case SSB_DEV_CHIPCOMMON:
-                       if (bus->chipco.dev) {
--                              ssb_printk(KERN_WARNING PFX
--                                         "WARNING: Multiple ChipCommon found\n");
-+                              ssb_warn("WARNING: Multiple ChipCommon found\n");
-                               break;
-                       }
-                       bus->chipco.dev = dev;
-@@ -393,8 +391,7 @@ int ssb_bus_scan(struct ssb_bus *bus,
-               case SSB_DEV_MIPS_3302:
- #ifdef CONFIG_SSB_DRIVER_MIPS
-                       if (bus->mipscore.dev) {
--                              ssb_printk(KERN_WARNING PFX
--                                         "WARNING: Multiple MIPS cores found\n");
-+                              ssb_warn("WARNING: Multiple MIPS cores found\n");
-                               break;
-                       }
-                       bus->mipscore.dev = dev;
-@@ -415,8 +412,7 @@ int ssb_bus_scan(struct ssb_bus *bus,
-                               }
-                       }
-                       if (bus->pcicore.dev) {
--                              ssb_printk(KERN_WARNING PFX
--                                         "WARNING: Multiple PCI(E) cores found\n");
-+                              ssb_warn("WARNING: Multiple PCI(E) cores found\n");
-                               break;
-                       }
-                       bus->pcicore.dev = dev;
---- a/drivers/ssb/sdio.c
-+++ b/drivers/ssb/sdio.c
-@@ -551,14 +551,10 @@ int ssb_sdio_get_invariants(struct ssb_b
-                       case SSB_SDIO_CIS_ANTGAIN:
-                               GOTO_ERROR_ON(tuple->size != 2,
-                                             "antg tpl size");
--                              sprom->antenna_gain.ghz24.a0 = tuple->data[1];
--                              sprom->antenna_gain.ghz24.a1 = tuple->data[1];
--                              sprom->antenna_gain.ghz24.a2 = tuple->data[1];
--                              sprom->antenna_gain.ghz24.a3 = tuple->data[1];
--                              sprom->antenna_gain.ghz5.a0 = tuple->data[1];
--                              sprom->antenna_gain.ghz5.a1 = tuple->data[1];
--                              sprom->antenna_gain.ghz5.a2 = tuple->data[1];
--                              sprom->antenna_gain.ghz5.a3 = tuple->data[1];
-+                              sprom->antenna_gain.a0 = tuple->data[1];
-+                              sprom->antenna_gain.a1 = tuple->data[1];
-+                              sprom->antenna_gain.a2 = tuple->data[1];
-+                              sprom->antenna_gain.a3 = tuple->data[1];
-                               break;
-                       case SSB_SDIO_CIS_BFLAGS:
-                               GOTO_ERROR_ON((tuple->size != 3) &&
---- a/drivers/ssb/sprom.c
-+++ b/drivers/ssb/sprom.c
-@@ -54,7 +54,7 @@ static int hex2sprom(u16 *sprom, const c
-       while (cnt < sprom_size_words) {
-               memcpy(tmp, dump, 4);
-               dump += 4;
--              err = strict_strtoul(tmp, 16, &parsed);
-+              err = kstrtoul(tmp, 16, &parsed);
-               if (err)
-                       return err;
-               sprom[cnt++] = swab16((u16)parsed);
-@@ -127,13 +127,13 @@ ssize_t ssb_attr_sprom_store(struct ssb_
-               goto out_kfree;
-       err = ssb_devices_freeze(bus, &freeze);
-       if (err) {
--              ssb_printk(KERN_ERR PFX "SPROM write: Could not freeze all devices\n");
-+              ssb_err("SPROM write: Could not freeze all devices\n");
-               goto out_unlock;
-       }
-       res = sprom_write(bus, sprom);
-       err = ssb_devices_thaw(&freeze);
-       if (err)
--              ssb_printk(KERN_ERR PFX "SPROM write: Could not thaw all devices\n");
-+              ssb_err("SPROM write: Could not thaw all devices\n");
- out_unlock:
-       mutex_unlock(&bus->sprom_mutex);
- out_kfree:
---- a/drivers/ssb/ssb_private.h
-+++ b/drivers/ssb/ssb_private.h
-@@ -3,21 +3,33 @@
- #include <linux/ssb/ssb.h>
- #include <linux/types.h>
-+#include <linux/bcm47xx_wdt.h>
- #define PFX   "ssb: "
- #ifdef CONFIG_SSB_SILENT
--# define ssb_printk(fmt, x...)        do { /* nothing */ } while (0)
-+# define ssb_printk(fmt, ...)                                 \
-+      do { if (0) printk(fmt, ##__VA_ARGS__); } while (0)
- #else
--# define ssb_printk           printk
-+# define ssb_printk(fmt, ...)                                 \
-+      printk(fmt, ##__VA_ARGS__)
- #endif /* CONFIG_SSB_SILENT */
-+#define ssb_emerg(fmt, ...)   ssb_printk(KERN_EMERG PFX fmt, ##__VA_ARGS__)
-+#define ssb_err(fmt, ...)     ssb_printk(KERN_ERR PFX fmt, ##__VA_ARGS__)
-+#define ssb_warn(fmt, ...)    ssb_printk(KERN_WARNING PFX fmt, ##__VA_ARGS__)
-+#define ssb_notice(fmt, ...)  ssb_printk(KERN_NOTICE PFX fmt, ##__VA_ARGS__)
-+#define ssb_info(fmt, ...)    ssb_printk(KERN_INFO PFX fmt, ##__VA_ARGS__)
-+#define ssb_cont(fmt, ...)    ssb_printk(KERN_CONT fmt, ##__VA_ARGS__)
-+
- /* dprintk: Debugging printk; vanishes for non-debug compilation */
- #ifdef CONFIG_SSB_DEBUG
--# define ssb_dprintk(fmt, x...)       ssb_printk(fmt , ##x)
-+# define ssb_dbg(fmt, ...)                                    \
-+      ssb_printk(KERN_DEBUG PFX fmt, ##__VA_ARGS__)
- #else
--# define ssb_dprintk(fmt, x...)       do { /* nothing */ } while (0)
-+# define ssb_dbg(fmt, ...)                                    \
-+      do { if (0) printk(KERN_DEBUG PFX fmt, ##__VA_ARGS__); } while (0)
- #endif
- #ifdef CONFIG_SSB_DEBUG
-@@ -207,4 +219,79 @@ static inline void b43_pci_ssb_bridge_ex
- }
- #endif /* CONFIG_SSB_B43_PCI_BRIDGE */
-+/* driver_chipcommon_pmu.c */
-+extern u32 ssb_pmu_get_cpu_clock(struct ssb_chipcommon *cc);
-+extern u32 ssb_pmu_get_controlclock(struct ssb_chipcommon *cc);
-+extern u32 ssb_pmu_get_alp_clock(struct ssb_chipcommon *cc);
-+
-+extern u32 ssb_chipco_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
-+                                           u32 ticks);
-+extern u32 ssb_chipco_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
-+
-+/* driver_chipcommon_sflash.c */
-+#ifdef CONFIG_SSB_SFLASH
-+int ssb_sflash_init(struct ssb_chipcommon *cc);
-+#else
-+static inline int ssb_sflash_init(struct ssb_chipcommon *cc)
-+{
-+      pr_err("Serial flash not supported\n");
-+      return 0;
-+}
-+#endif /* CONFIG_SSB_SFLASH */
-+
-+#ifdef CONFIG_SSB_DRIVER_MIPS
-+extern struct platform_device ssb_pflash_dev;
-+#endif
-+
-+#ifdef CONFIG_SSB_SFLASH
-+extern struct platform_device ssb_sflash_dev;
-+#endif
-+
-+#ifdef CONFIG_SSB_DRIVER_EXTIF
-+extern u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt, u32 ticks);
-+extern u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt, u32 ms);
-+#else
-+static inline u32 ssb_extif_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
-+                                                 u32 ticks)
-+{
-+      return 0;
-+}
-+static inline u32 ssb_extif_watchdog_timer_set_ms(struct bcm47xx_wdt *wdt,
-+                                                u32 ms)
-+{
-+      return 0;
-+}
-+#endif
-+
-+#ifdef CONFIG_SSB_EMBEDDED
-+extern int ssb_watchdog_register(struct ssb_bus *bus);
-+#else /* CONFIG_SSB_EMBEDDED */
-+static inline int ssb_watchdog_register(struct ssb_bus *bus)
-+{
-+      return 0;
-+}
-+#endif /* CONFIG_SSB_EMBEDDED */
-+
-+#ifdef CONFIG_SSB_DRIVER_EXTIF
-+extern void ssb_extif_init(struct ssb_extif *extif);
-+#else
-+static inline void ssb_extif_init(struct ssb_extif *extif)
-+{
-+}
-+#endif
-+
-+#ifdef CONFIG_SSB_DRIVER_GPIO
-+extern int ssb_gpio_init(struct ssb_bus *bus);
-+extern int ssb_gpio_unregister(struct ssb_bus *bus);
-+#else /* CONFIG_SSB_DRIVER_GPIO */
-+static inline int ssb_gpio_init(struct ssb_bus *bus)
-+{
-+      return -ENOTSUPP;
-+}
-+static inline int ssb_gpio_unregister(struct ssb_bus *bus)
-+{
-+      return 0;
-+}
-+#endif /* CONFIG_SSB_DRIVER_GPIO */
-+
- #endif /* LINUX_SSB_PRIVATE_H_ */
---- a/include/linux/ssb/ssb.h
-+++ b/include/linux/ssb/ssb.h
-@@ -6,8 +6,10 @@
- #include <linux/types.h>
- #include <linux/spinlock.h>
- #include <linux/pci.h>
-+#include <linux/gpio.h>
- #include <linux/mod_devicetable.h>
- #include <linux/dma-mapping.h>
-+#include <linux/platform_device.h>
- #include <linux/ssb/ssb_regs.h>
-@@ -16,19 +18,29 @@ struct pcmcia_device;
- struct ssb_bus;
- struct ssb_driver;
-+struct ssb_sprom_core_pwr_info {
-+      u8 itssi_2g, itssi_5g;
-+      u8 maxpwr_2g, maxpwr_5gl, maxpwr_5g, maxpwr_5gh;
-+      u16 pa_2g[4], pa_5gl[4], pa_5g[4], pa_5gh[4];
-+};
-+
- struct ssb_sprom {
-       u8 revision;
--      u8 il0mac[6];           /* MAC address for 802.11b/g */
--      u8 et0mac[6];           /* MAC address for Ethernet */
--      u8 et1mac[6];           /* MAC address for 802.11a */
-+      u8 il0mac[6] __aligned(sizeof(u16));    /* MAC address for 802.11b/g */
-+      u8 et0mac[6] __aligned(sizeof(u16));    /* MAC address for Ethernet */
-+      u8 et1mac[6] __aligned(sizeof(u16));    /* MAC address for 802.11a */
-       u8 et0phyaddr;          /* MII address for enet0 */
-       u8 et1phyaddr;          /* MII address for enet1 */
-       u8 et0mdcport;          /* MDIO for enet0 */
-       u8 et1mdcport;          /* MDIO for enet1 */
-+      u16 dev_id;             /* Device ID overriding e.g. PCI ID */
-       u16 board_rev;          /* Board revision number from SPROM. */
-+      u16 board_num;          /* Board number from SPROM. */
-+      u16 board_type;         /* Board type from SPROM. */
-       u8 country_code;        /* Country Code */
--      u16 leddc_on_time;      /* LED Powersave Duty Cycle On Count */
--      u16 leddc_off_time;     /* LED Powersave Duty Cycle Off Count */
-+      char alpha2[2];         /* Country Code as two chars like EU or US */
-+      u8 leddc_on_time;       /* LED Powersave Duty Cycle On Count */
-+      u8 leddc_off_time;      /* LED Powersave Duty Cycle Off Count */
-       u8 ant_available_a;     /* 2GHz antenna available bits (up to 4) */
-       u8 ant_available_bg;    /* 5GHz antenna available bits (up to 4) */
-       u16 pa0b0;
-@@ -47,10 +59,10 @@ struct ssb_sprom {
-       u8 gpio1;               /* GPIO pin 1 */
-       u8 gpio2;               /* GPIO pin 2 */
-       u8 gpio3;               /* GPIO pin 3 */
--      u16 maxpwr_bg;          /* 2.4GHz Amplifier Max Power (in dBm Q5.2) */
--      u16 maxpwr_al;          /* 5.2GHz Amplifier Max Power (in dBm Q5.2) */
--      u16 maxpwr_a;           /* 5.3GHz Amplifier Max Power (in dBm Q5.2) */
--      u16 maxpwr_ah;          /* 5.8GHz Amplifier Max Power (in dBm Q5.2) */
-+      u8 maxpwr_bg;           /* 2.4GHz Amplifier Max Power (in dBm Q5.2) */
-+      u8 maxpwr_al;           /* 5.2GHz Amplifier Max Power (in dBm Q5.2) */
-+      u8 maxpwr_a;            /* 5.3GHz Amplifier Max Power (in dBm Q5.2) */
-+      u8 maxpwr_ah;           /* 5.8GHz Amplifier Max Power (in dBm Q5.2) */
-       u8 itssi_a;             /* Idle TSSI Target for A-PHY */
-       u8 itssi_bg;            /* Idle TSSI Target for B/G-PHY */
-       u8 tri2g;               /* 2.4GHz TX isolation */
-@@ -61,8 +73,8 @@ struct ssb_sprom {
-       u8 txpid5gl[4];         /* 4.9 - 5.1GHz TX power index */
-       u8 txpid5g[4];          /* 5.1 - 5.5GHz TX power index */
-       u8 txpid5gh[4];         /* 5.5 - ...GHz TX power index */
--      u8 rxpo2g;              /* 2GHz RX power offset */
--      u8 rxpo5g;              /* 5GHz RX power offset */
-+      s8 rxpo2g;              /* 2GHz RX power offset */
-+      s8 rxpo5g;              /* 5GHz RX power offset */
-       u8 rssisav2g;           /* 2GHz RSSI params */
-       u8 rssismc2g;
-       u8 rssismf2g;
-@@ -82,16 +94,13 @@ struct ssb_sprom {
-       u16 boardflags2_hi;     /* Board flags (bits 48-63) */
-       /* TODO store board flags in a single u64 */
-+      struct ssb_sprom_core_pwr_info core_pwr_info[4];
-+
-       /* Antenna gain values for up to 4 antennas
-        * on each band. Values in dBm/4 (Q5.2). Negative gain means the
-        * loss in the connectors is bigger than the gain. */
-       struct {
--              struct {
--                      s8 a0, a1, a2, a3;
--              } ghz24;        /* 2.4GHz band */
--              struct {
--                      s8 a0, a1, a2, a3;
--              } ghz5;         /* 5GHz band */
-+              s8 a0, a1, a2, a3;
-       } antenna_gain;
-       struct {
-@@ -103,14 +112,85 @@ struct ssb_sprom {
-               } ghz5;
-       } fem;
--      /* TODO - add any parameters needed from rev 2, 3, 4, 5 or 8 SPROMs */
-+      u16 mcs2gpo[8];
-+      u16 mcs5gpo[8];
-+      u16 mcs5glpo[8];
-+      u16 mcs5ghpo[8];
-+      u8 opo;
-+
-+      u8 rxgainerr2ga[3];
-+      u8 rxgainerr5gla[3];
-+      u8 rxgainerr5gma[3];
-+      u8 rxgainerr5gha[3];
-+      u8 rxgainerr5gua[3];
-+
-+      u8 noiselvl2ga[3];
-+      u8 noiselvl5gla[3];
-+      u8 noiselvl5gma[3];
-+      u8 noiselvl5gha[3];
-+      u8 noiselvl5gua[3];
-+
-+      u8 regrev;
-+      u8 txchain;
-+      u8 rxchain;
-+      u8 antswitch;
-+      u16 cddpo;
-+      u16 stbcpo;
-+      u16 bw40po;
-+      u16 bwduppo;
-+
-+      u8 tempthresh;
-+      u8 tempoffset;
-+      u16 rawtempsense;
-+      u8 measpower;
-+      u8 tempsense_slope;
-+      u8 tempcorrx;
-+      u8 tempsense_option;
-+      u8 freqoffset_corr;
-+      u8 iqcal_swp_dis;
-+      u8 hw_iqcal_en;
-+      u8 elna2g;
-+      u8 elna5g;
-+      u8 phycal_tempdelta;
-+      u8 temps_period;
-+      u8 temps_hysteresis;
-+      u8 measpower1;
-+      u8 measpower2;
-+      u8 pcieingress_war;
-+
-+      /* power per rate from sromrev 9 */
-+      u16 cckbw202gpo;
-+      u16 cckbw20ul2gpo;
-+      u32 legofdmbw202gpo;
-+      u32 legofdmbw20ul2gpo;
-+      u32 legofdmbw205glpo;
-+      u32 legofdmbw20ul5glpo;
-+      u32 legofdmbw205gmpo;
-+      u32 legofdmbw20ul5gmpo;
-+      u32 legofdmbw205ghpo;
-+      u32 legofdmbw20ul5ghpo;
-+      u32 mcsbw202gpo;
-+      u32 mcsbw20ul2gpo;
-+      u32 mcsbw402gpo;
-+      u32 mcsbw205glpo;
-+      u32 mcsbw20ul5glpo;
-+      u32 mcsbw405glpo;
-+      u32 mcsbw205gmpo;
-+      u32 mcsbw20ul5gmpo;
-+      u32 mcsbw405gmpo;
-+      u32 mcsbw205ghpo;
-+      u32 mcsbw20ul5ghpo;
-+      u32 mcsbw405ghpo;
-+      u16 mcs32po;
-+      u16 legofdm40duppo;
-+      u8 sar2g;
-+      u8 sar5g;
- };
- /* Information about the PCB the circuitry is soldered on. */
- struct ssb_boardinfo {
-       u16 vendor;
-       u16 type;
--      u8  rev;
- };
-@@ -166,6 +246,7 @@ struct ssb_bus_ops {
- #define SSB_DEV_MINI_MACPHY   0x823
- #define SSB_DEV_ARM_1176      0x824
- #define SSB_DEV_ARM_7TDMI     0x825
-+#define SSB_DEV_ARM_CM3               0x82A
- /* Vendor-ID values */
- #define SSB_VENDOR_BROADCOM   0x4243
-@@ -260,13 +341,61 @@ enum ssb_bustype {
- #define SSB_BOARDVENDOR_DELL  0x1028  /* Dell */
- #define SSB_BOARDVENDOR_HP    0x0E11  /* HP */
- /* board_type */
-+#define SSB_BOARD_BCM94301CB  0x0406
-+#define SSB_BOARD_BCM94301MP  0x0407
-+#define SSB_BOARD_BU4309      0x040A
-+#define SSB_BOARD_BCM94309CB  0x040B
-+#define SSB_BOARD_BCM4309MP   0x040C
-+#define SSB_BOARD_BU4306      0x0416
- #define SSB_BOARD_BCM94306MP  0x0418
- #define SSB_BOARD_BCM4309G    0x0421
- #define SSB_BOARD_BCM4306CB   0x0417
--#define SSB_BOARD_BCM4309MP   0x040C
-+#define SSB_BOARD_BCM94306PC  0x0425  /* pcmcia 3.3v 4306 card */
-+#define SSB_BOARD_BCM94306CBSG        0x042B  /* with SiGe PA */
-+#define SSB_BOARD_PCSG94306   0x042D  /* with SiGe PA */
-+#define SSB_BOARD_BU4704SD    0x042E  /* with sdram */
-+#define SSB_BOARD_BCM94704AGR 0x042F  /* dual 11a/11g Router */
-+#define SSB_BOARD_BCM94308MP  0x0430  /* 11a-only minipci */
-+#define SSB_BOARD_BU4318      0x0447
-+#define SSB_BOARD_CB4318      0x0448
-+#define SSB_BOARD_MPG4318     0x0449
- #define SSB_BOARD_MP4318      0x044A
--#define SSB_BOARD_BU4306      0x0416
--#define SSB_BOARD_BU4309      0x040A
-+#define SSB_BOARD_SD4318      0x044B
-+#define SSB_BOARD_BCM94306P   0x044C  /* with SiGe */
-+#define SSB_BOARD_BCM94303MP  0x044E
-+#define SSB_BOARD_BCM94306MPM 0x0450
-+#define SSB_BOARD_BCM94306MPL 0x0453
-+#define SSB_BOARD_PC4303      0x0454  /* pcmcia */
-+#define SSB_BOARD_BCM94306MPLNA       0x0457
-+#define SSB_BOARD_BCM94306MPH 0x045B
-+#define SSB_BOARD_BCM94306PCIV        0x045C
-+#define SSB_BOARD_BCM94318MPGH        0x0463
-+#define SSB_BOARD_BU4311      0x0464
-+#define SSB_BOARD_BCM94311MC  0x0465
-+#define SSB_BOARD_BCM94311MCAG        0x0466
-+/* 4321 boards */
-+#define SSB_BOARD_BU4321      0x046B
-+#define SSB_BOARD_BU4321E     0x047C
-+#define SSB_BOARD_MP4321      0x046C
-+#define SSB_BOARD_CB2_4321    0x046D
-+#define SSB_BOARD_CB2_4321_AG 0x0066
-+#define SSB_BOARD_MC4321      0x046E
-+/* 4325 boards */
-+#define SSB_BOARD_BCM94325DEVBU       0x0490
-+#define SSB_BOARD_BCM94325BGABU       0x0491
-+#define SSB_BOARD_BCM94325SDGWB       0x0492
-+#define SSB_BOARD_BCM94325SDGMDL      0x04AA
-+#define SSB_BOARD_BCM94325SDGMDL2     0x04C6
-+#define SSB_BOARD_BCM94325SDGMDL3     0x04C9
-+#define SSB_BOARD_BCM94325SDABGWBA    0x04E1
-+/* 4322 boards */
-+#define SSB_BOARD_BCM94322MC  0x04A4
-+#define SSB_BOARD_BCM94322USB 0x04A8  /* dualband */
-+#define SSB_BOARD_BCM94322HM  0x04B0
-+#define SSB_BOARD_BCM94322USB2D       0x04Bf  /* single band discrete front end */
-+/* 4312 boards */
-+#define SSB_BOARD_BU4312      0x048A
-+#define SSB_BOARD_BCM4312MCGSG        0x04B5
- /* chip_package */
- #define SSB_CHIPPACK_BCM4712S 1       /* Small 200pin 4712 */
- #define SSB_CHIPPACK_BCM4712M 2       /* Medium 225pin 4712 */
-@@ -354,7 +483,11 @@ struct ssb_bus {
- #ifdef CONFIG_SSB_EMBEDDED
-       /* Lock for GPIO register access. */
-       spinlock_t gpio_lock;
-+      struct platform_device *watchdog;
- #endif /* EMBEDDED */
-+#ifdef CONFIG_SSB_DRIVER_GPIO
-+      struct gpio_chip gpio;
-+#endif /* DRIVER_GPIO */
-       /* Internal-only stuff follows. Do not touch. */
-       struct list_head list;
---- a/include/linux/ssb/ssb_driver_chipcommon.h
-+++ b/include/linux/ssb/ssb_driver_chipcommon.h
-@@ -219,6 +219,7 @@
- #define SSB_CHIPCO_PMU_CTL                    0x0600 /* PMU control */
- #define  SSB_CHIPCO_PMU_CTL_ILP_DIV           0xFFFF0000 /* ILP div mask */
- #define  SSB_CHIPCO_PMU_CTL_ILP_DIV_SHIFT     16
-+#define  SSB_CHIPCO_PMU_CTL_PLL_UPD           0x00000400
- #define  SSB_CHIPCO_PMU_CTL_NOILPONW          0x00000200 /* No ILP on wait */
- #define  SSB_CHIPCO_PMU_CTL_HTREQEN           0x00000100 /* HT req enable */
- #define  SSB_CHIPCO_PMU_CTL_ALPREQEN          0x00000080 /* ALP req enable */
-@@ -504,7 +505,9 @@
- #define SSB_CHIPCO_FLASHCTL_ST_SE     0x02D8          /* Sector Erase */
- #define SSB_CHIPCO_FLASHCTL_ST_BE     0x00C7          /* Bulk Erase */
- #define SSB_CHIPCO_FLASHCTL_ST_DP     0x00B9          /* Deep Power-down */
--#define SSB_CHIPCO_FLASHCTL_ST_RSIG   0x03AB          /* Read Electronic Signature */
-+#define SSB_CHIPCO_FLASHCTL_ST_RES    0x03AB          /* Read Electronic Signature */
-+#define SSB_CHIPCO_FLASHCTL_ST_CSA    0x1000          /* Keep chip select asserted */
-+#define SSB_CHIPCO_FLASHCTL_ST_SSE    0x0220          /* Sub-sector Erase */
- /* Status register bits for ST flashes */
- #define SSB_CHIPCO_FLASHSTA_ST_WIP    0x01            /* Write In Progress */
-@@ -588,7 +591,10 @@ struct ssb_chipcommon {
-       u32 status;
-       /* Fast Powerup Delay constant */
-       u16 fast_pwrup_delay;
-+      spinlock_t gpio_lock;
-       struct ssb_chipcommon_pmu pmu;
-+      u32 ticks_per_ms;
-+      u32 max_timer_ms;
- };
- static inline bool ssb_chipco_available(struct ssb_chipcommon *cc)
-@@ -628,8 +634,7 @@ enum ssb_clkmode {
- extern void ssb_chipco_set_clockmode(struct ssb_chipcommon *cc,
-                                    enum ssb_clkmode mode);
--extern void ssb_chipco_watchdog_timer_set(struct ssb_chipcommon *cc,
--                                        u32 ticks);
-+extern u32 ssb_chipco_watchdog_timer_set(struct ssb_chipcommon *cc, u32 ticks);
- void ssb_chipco_irq_mask(struct ssb_chipcommon *cc, u32 mask, u32 value);
-@@ -642,6 +647,8 @@ u32 ssb_chipco_gpio_outen(struct ssb_chi
- u32 ssb_chipco_gpio_control(struct ssb_chipcommon *cc, u32 mask, u32 value);
- u32 ssb_chipco_gpio_intmask(struct ssb_chipcommon *cc, u32 mask, u32 value);
- u32 ssb_chipco_gpio_polarity(struct ssb_chipcommon *cc, u32 mask, u32 value);
-+u32 ssb_chipco_gpio_pullup(struct ssb_chipcommon *cc, u32 mask, u32 value);
-+u32 ssb_chipco_gpio_pulldown(struct ssb_chipcommon *cc, u32 mask, u32 value);
- #ifdef CONFIG_SSB_SERIAL
- extern int ssb_chipco_serial_init(struct ssb_chipcommon *cc,
-@@ -661,5 +668,6 @@ enum ssb_pmu_ldo_volt_id {
- void ssb_pmu_set_ldo_voltage(struct ssb_chipcommon *cc,
-                            enum ssb_pmu_ldo_volt_id id, u32 voltage);
- void ssb_pmu_set_ldo_paref(struct ssb_chipcommon *cc, bool on);
-+void ssb_pmu_spuravoid_pllupdate(struct ssb_chipcommon *cc, int spuravoid);
- #endif /* LINUX_SSB_CHIPCO_H_ */
---- a/include/linux/ssb/ssb_driver_extif.h
-+++ b/include/linux/ssb/ssb_driver_extif.h
-@@ -152,12 +152,16 @@
- /* watchdog */
- #define SSB_EXTIF_WATCHDOG_CLK                48000000        /* Hz */
-+#define SSB_EXTIF_WATCHDOG_MAX_TIMER  ((1 << 28) - 1)
-+#define SSB_EXTIF_WATCHDOG_MAX_TIMER_MS       (SSB_EXTIF_WATCHDOG_MAX_TIMER \
-+                                       / (SSB_EXTIF_WATCHDOG_CLK / 1000))
- #ifdef CONFIG_SSB_DRIVER_EXTIF
- struct ssb_extif {
-       struct ssb_device *dev;
-+      spinlock_t gpio_lock;
- };
- static inline bool ssb_extif_available(struct ssb_extif *extif)
-@@ -171,8 +175,7 @@ extern void ssb_extif_get_clockcontrol(s
- extern void ssb_extif_timing_init(struct ssb_extif *extif,
-                                 unsigned long ns);
--extern void ssb_extif_watchdog_timer_set(struct ssb_extif *extif,
--                                       u32 ticks);
-+extern u32 ssb_extif_watchdog_timer_set(struct ssb_extif *extif, u32 ticks);
- /* Extif GPIO pin access */
- u32 ssb_extif_gpio_in(struct ssb_extif *extif, u32 mask);
-@@ -205,10 +208,52 @@ void ssb_extif_get_clockcontrol(struct s
- }
- static inline
--void ssb_extif_watchdog_timer_set(struct ssb_extif *extif,
--                                u32 ticks)
-+void ssb_extif_timing_init(struct ssb_extif *extif, unsigned long ns)
- {
- }
-+static inline
-+u32 ssb_extif_watchdog_timer_set(struct ssb_extif *extif, u32 ticks)
-+{
-+      return 0;
-+}
-+
-+static inline u32 ssb_extif_gpio_in(struct ssb_extif *extif, u32 mask)
-+{
-+      return 0;
-+}
-+
-+static inline u32 ssb_extif_gpio_out(struct ssb_extif *extif, u32 mask,
-+                                   u32 value)
-+{
-+      return 0;
-+}
-+
-+static inline u32 ssb_extif_gpio_outen(struct ssb_extif *extif, u32 mask,
-+                                     u32 value)
-+{
-+      return 0;
-+}
-+
-+static inline u32 ssb_extif_gpio_polarity(struct ssb_extif *extif, u32 mask,
-+                                        u32 value)
-+{
-+      return 0;
-+}
-+
-+static inline u32 ssb_extif_gpio_intmask(struct ssb_extif *extif, u32 mask,
-+                                       u32 value)
-+{
-+      return 0;
-+}
-+
-+#ifdef CONFIG_SSB_SERIAL
-+static inline int ssb_extif_serial_init(struct ssb_extif *extif,
-+                                      struct ssb_serial_port *ports)
-+{
-+      return 0;
-+}
-+#endif /* CONFIG_SSB_SERIAL */
-+
- #endif /* CONFIG_SSB_DRIVER_EXTIF */
- #endif /* LINUX_SSB_EXTIFCORE_H_ */
---- a/include/linux/ssb/ssb_driver_gige.h
-+++ b/include/linux/ssb/ssb_driver_gige.h
-@@ -2,6 +2,7 @@
- #define LINUX_SSB_DRIVER_GIGE_H_
- #include <linux/ssb/ssb.h>
-+#include <linux/bug.h>
- #include <linux/pci.h>
- #include <linux/spinlock.h>
-@@ -96,21 +97,16 @@ static inline bool ssb_gige_must_flush_p
-       return 0;
- }
--#ifdef CONFIG_BCM47XX
--#include <asm/mach-bcm47xx/nvram.h>
- /* Get the device MAC address */
--static inline void ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
--{
--      char buf[20];
--      if (nvram_getenv("et0macaddr", buf, sizeof(buf)) < 0)
--              return;
--      nvram_parse_macaddr(buf, macaddr);
--}
--#else
--static inline void ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
-+static inline int ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
- {
-+      struct ssb_gige *dev = pdev_to_ssb_gige(pdev);
-+      if (!dev)
-+              return -ENODEV;
-+
-+      memcpy(macaddr, dev->dev->bus->sprom.et0mac, 6);
-+      return 0;
- }
--#endif
- extern int ssb_gige_pcibios_plat_dev_init(struct ssb_device *sdev,
-                                         struct pci_dev *pdev);
-@@ -174,6 +170,10 @@ static inline bool ssb_gige_must_flush_p
- {
-       return 0;
- }
-+static inline int ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
-+{
-+      return -ENODEV;
-+}
- #endif /* CONFIG_SSB_DRIVER_GIGE */
- #endif /* LINUX_SSB_DRIVER_GIGE_H_ */
---- a/include/linux/ssb/ssb_driver_mips.h
-+++ b/include/linux/ssb/ssb_driver_mips.h
-@@ -13,6 +13,24 @@ struct ssb_serial_port {
-       unsigned int reg_shift;
- };
-+struct ssb_pflash {
-+      bool present;
-+      u8 buswidth;
-+      u32 window;
-+      u32 window_size;
-+};
-+
-+#ifdef CONFIG_SSB_SFLASH
-+struct ssb_sflash {
-+      bool present;
-+      u32 window;
-+      u32 blocksize;
-+      u16 numblocks;
-+      u32 size;
-+
-+      void *priv;
-+};
-+#endif
- struct ssb_mipscore {
-       struct ssb_device *dev;
-@@ -20,9 +38,10 @@ struct ssb_mipscore {
-       int nr_serial_ports;
-       struct ssb_serial_port serial_ports[4];
--      u8 flash_buswidth;
--      u32 flash_window;
--      u32 flash_window_size;
-+      struct ssb_pflash pflash;
-+#ifdef CONFIG_SSB_SFLASH
-+      struct ssb_sflash sflash;
-+#endif
- };
- extern void ssb_mipscore_init(struct ssb_mipscore *mcore);
-@@ -41,6 +60,11 @@ void ssb_mipscore_init(struct ssb_mipsco
- {
- }
-+static inline unsigned int ssb_mips_irq(struct ssb_device *dev)
-+{
-+      return 0;
-+}
-+
- #endif /* CONFIG_SSB_DRIVER_MIPS */
- #endif /* LINUX_SSB_MIPSCORE_H_ */
---- a/include/linux/ssb/ssb_regs.h
-+++ b/include/linux/ssb/ssb_regs.h
-@@ -172,6 +172,7 @@
- #define SSB_SPROMSIZE_WORDS_R4                220
- #define SSB_SPROMSIZE_BYTES_R123      (SSB_SPROMSIZE_WORDS_R123 * sizeof(u16))
- #define SSB_SPROMSIZE_BYTES_R4                (SSB_SPROMSIZE_WORDS_R4 * sizeof(u16))
-+#define SSB_SPROMSIZE_WORDS_R10               230
- #define SSB_SPROM_BASE1                       0x1000
- #define SSB_SPROM_BASE31              0x0800
- #define SSB_SPROM_REVISION            0x007E
-@@ -228,6 +229,7 @@
- #define  SSB_SPROM1_AGAIN_BG_SHIFT    0
- #define  SSB_SPROM1_AGAIN_A           0xFF00  /* A-PHY */
- #define  SSB_SPROM1_AGAIN_A_SHIFT     8
-+#define SSB_SPROM1_CCODE              0x0076
- /* SPROM Revision 2 (inherits from rev 1) */
- #define SSB_SPROM2_BFLHI              0x0038  /* Boardflags (high 16 bits) */
-@@ -267,6 +269,7 @@
- #define  SSB_SPROM3_OFDMGPO           0x107A  /* G-PHY OFDM Power Offset (4 bytes, BigEndian) */
- /* SPROM Revision 4 */
-+#define SSB_SPROM4_BOARDREV           0x0042  /* Board revision */
- #define SSB_SPROM4_BFLLO              0x0044  /* Boardflags (low 16 bits) */
- #define SSB_SPROM4_BFLHI              0x0046  /* Board Flags Hi */
- #define SSB_SPROM4_BFL2LO             0x0048  /* Board flags 2 (low 16 bits) */
-@@ -287,11 +290,11 @@
- #define  SSB_SPROM4_ETHPHY_ET1A_SHIFT 5
- #define  SSB_SPROM4_ETHPHY_ET0M               (1<<14) /* MDIO for enet0 */
- #define  SSB_SPROM4_ETHPHY_ET1M               (1<<15) /* MDIO for enet1 */
--#define SSB_SPROM4_ANTAVAIL           0x005D  /* Antenna available bitfields */
--#define  SSB_SPROM4_ANTAVAIL_A                0x00FF  /* A-PHY bitfield */
--#define  SSB_SPROM4_ANTAVAIL_A_SHIFT  0
--#define  SSB_SPROM4_ANTAVAIL_BG               0xFF00  /* B-PHY and G-PHY bitfield */
--#define  SSB_SPROM4_ANTAVAIL_BG_SHIFT 8
-+#define SSB_SPROM4_ANTAVAIL           0x005C  /* Antenna available bitfields */
-+#define  SSB_SPROM4_ANTAVAIL_BG               0x00FF  /* B-PHY and G-PHY bitfield */
-+#define  SSB_SPROM4_ANTAVAIL_BG_SHIFT 0
-+#define  SSB_SPROM4_ANTAVAIL_A                0xFF00  /* A-PHY bitfield */
-+#define  SSB_SPROM4_ANTAVAIL_A_SHIFT  8
- #define SSB_SPROM4_AGAIN01            0x005E  /* Antenna Gain (in dBm Q5.2) */
- #define  SSB_SPROM4_AGAIN0            0x00FF  /* Antenna 0 */
- #define  SSB_SPROM4_AGAIN0_SHIFT      0
-@@ -389,6 +392,11 @@
- #define  SSB_SPROM8_GPIOB_P2          0x00FF  /* Pin 2 */
- #define  SSB_SPROM8_GPIOB_P3          0xFF00  /* Pin 3 */
- #define  SSB_SPROM8_GPIOB_P3_SHIFT    8
-+#define SSB_SPROM8_LEDDC              0x009A
-+#define  SSB_SPROM8_LEDDC_ON          0xFF00  /* oncount */
-+#define  SSB_SPROM8_LEDDC_ON_SHIFT    8
-+#define  SSB_SPROM8_LEDDC_OFF         0x00FF  /* offcount */
-+#define  SSB_SPROM8_LEDDC_OFF_SHIFT   0
- #define SSB_SPROM8_ANTAVAIL           0x009C  /* Antenna available bitfields*/
- #define  SSB_SPROM8_ANTAVAIL_A                0xFF00  /* A-PHY bitfield */
- #define  SSB_SPROM8_ANTAVAIL_A_SHIFT  8
-@@ -404,6 +412,13 @@
- #define  SSB_SPROM8_AGAIN2_SHIFT      0
- #define  SSB_SPROM8_AGAIN3            0xFF00  /* Antenna 3 */
- #define  SSB_SPROM8_AGAIN3_SHIFT      8
-+#define SSB_SPROM8_TXRXC              0x00A2
-+#define  SSB_SPROM8_TXRXC_TXCHAIN     0x000f
-+#define  SSB_SPROM8_TXRXC_TXCHAIN_SHIFT       0
-+#define  SSB_SPROM8_TXRXC_RXCHAIN     0x00f0
-+#define  SSB_SPROM8_TXRXC_RXCHAIN_SHIFT       4
-+#define  SSB_SPROM8_TXRXC_SWITCH      0xff00
-+#define  SSB_SPROM8_TXRXC_SWITCH_SHIFT        8
- #define SSB_SPROM8_RSSIPARM2G         0x00A4  /* RSSI params for 2GHz */
- #define  SSB_SPROM8_RSSISMF2G         0x000F
- #define  SSB_SPROM8_RSSISMC2G         0x00F0
-@@ -430,6 +445,7 @@
- #define  SSB_SPROM8_TRI5GH_SHIFT      8
- #define SSB_SPROM8_RXPO                       0x00AC  /* RX power offsets */
- #define  SSB_SPROM8_RXPO2G            0x00FF  /* 2GHz RX power offset */
-+#define  SSB_SPROM8_RXPO2G_SHIFT      0
- #define  SSB_SPROM8_RXPO5G            0xFF00  /* 5GHz RX power offset */
- #define  SSB_SPROM8_RXPO5G_SHIFT      8
- #define SSB_SPROM8_FEM2G              0x00AE
-@@ -445,10 +461,71 @@
- #define  SSB_SROM8_FEM_ANTSWLUT               0xF800
- #define  SSB_SROM8_FEM_ANTSWLUT_SHIFT 11
- #define SSB_SPROM8_THERMAL            0x00B2
--#define SSB_SPROM8_MPWR_RAWTS         0x00B4
--#define SSB_SPROM8_TS_SLP_OPT_CORRX   0x00B6
--#define SSB_SPROM8_FOC_HWIQ_IQSWP     0x00B8
--#define SSB_SPROM8_PHYCAL_TEMPDELTA   0x00BA
-+#define  SSB_SPROM8_THERMAL_OFFSET    0x00ff
-+#define  SSB_SPROM8_THERMAL_OFFSET_SHIFT      0
-+#define  SSB_SPROM8_THERMAL_TRESH     0xff00
-+#define  SSB_SPROM8_THERMAL_TRESH_SHIFT       8
-+/* Temp sense related entries */
-+#define SSB_SPROM8_RAWTS              0x00B4
-+#define  SSB_SPROM8_RAWTS_RAWTEMP     0x01ff
-+#define  SSB_SPROM8_RAWTS_RAWTEMP_SHIFT       0
-+#define  SSB_SPROM8_RAWTS_MEASPOWER   0xfe00
-+#define  SSB_SPROM8_RAWTS_MEASPOWER_SHIFT     9
-+#define SSB_SPROM8_OPT_CORRX          0x00B6
-+#define  SSB_SPROM8_OPT_CORRX_TEMP_SLOPE      0x00ff
-+#define  SSB_SPROM8_OPT_CORRX_TEMP_SLOPE_SHIFT        0
-+#define  SSB_SPROM8_OPT_CORRX_TEMPCORRX       0xfc00
-+#define  SSB_SPROM8_OPT_CORRX_TEMPCORRX_SHIFT 10
-+#define  SSB_SPROM8_OPT_CORRX_TEMP_OPTION     0x0300
-+#define  SSB_SPROM8_OPT_CORRX_TEMP_OPTION_SHIFT       8
-+/* FOC: freiquency offset correction, HWIQ: H/W IOCAL enable, IQSWP: IQ CAL swap disable */
-+#define SSB_SPROM8_HWIQ_IQSWP         0x00B8
-+#define  SSB_SPROM8_HWIQ_IQSWP_FREQ_CORR      0x000f
-+#define  SSB_SPROM8_HWIQ_IQSWP_FREQ_CORR_SHIFT        0
-+#define  SSB_SPROM8_HWIQ_IQSWP_IQCAL_SWP      0x0010
-+#define  SSB_SPROM8_HWIQ_IQSWP_IQCAL_SWP_SHIFT        4
-+#define  SSB_SPROM8_HWIQ_IQSWP_HW_IQCAL       0x0020
-+#define  SSB_SPROM8_HWIQ_IQSWP_HW_IQCAL_SHIFT 5
-+#define SSB_SPROM8_TEMPDELTA          0x00BC
-+#define  SSB_SPROM8_TEMPDELTA_PHYCAL  0x00ff
-+#define  SSB_SPROM8_TEMPDELTA_PHYCAL_SHIFT    0
-+#define  SSB_SPROM8_TEMPDELTA_PERIOD  0x0f00
-+#define  SSB_SPROM8_TEMPDELTA_PERIOD_SHIFT    8
-+#define  SSB_SPROM8_TEMPDELTA_HYSTERESIS      0xf000
-+#define  SSB_SPROM8_TEMPDELTA_HYSTERESIS_SHIFT        12
-+
-+/* There are 4 blocks with power info sharing the same layout */
-+#define SSB_SROM8_PWR_INFO_CORE0      0x00C0
-+#define SSB_SROM8_PWR_INFO_CORE1      0x00E0
-+#define SSB_SROM8_PWR_INFO_CORE2      0x0100
-+#define SSB_SROM8_PWR_INFO_CORE3      0x0120
-+
-+#define SSB_SROM8_2G_MAXP_ITSSI               0x00
-+#define  SSB_SPROM8_2G_MAXP           0x00FF
-+#define  SSB_SPROM8_2G_ITSSI          0xFF00
-+#define  SSB_SPROM8_2G_ITSSI_SHIFT    8
-+#define SSB_SROM8_2G_PA_0             0x02    /* 2GHz power amp settings */
-+#define SSB_SROM8_2G_PA_1             0x04
-+#define SSB_SROM8_2G_PA_2             0x06
-+#define SSB_SROM8_5G_MAXP_ITSSI               0x08    /* 5GHz ITSSI and 5.3GHz Max Power */
-+#define  SSB_SPROM8_5G_MAXP           0x00FF
-+#define  SSB_SPROM8_5G_ITSSI          0xFF00
-+#define  SSB_SPROM8_5G_ITSSI_SHIFT    8
-+#define SSB_SPROM8_5GHL_MAXP          0x0A    /* 5.2GHz and 5.8GHz Max Power */
-+#define  SSB_SPROM8_5GH_MAXP          0x00FF
-+#define  SSB_SPROM8_5GL_MAXP          0xFF00
-+#define  SSB_SPROM8_5GL_MAXP_SHIFT    8
-+#define SSB_SROM8_5G_PA_0             0x0C    /* 5.3GHz power amp settings */
-+#define SSB_SROM8_5G_PA_1             0x0E
-+#define SSB_SROM8_5G_PA_2             0x10
-+#define SSB_SROM8_5GL_PA_0            0x12    /* 5.2GHz power amp settings */
-+#define SSB_SROM8_5GL_PA_1            0x14
-+#define SSB_SROM8_5GL_PA_2            0x16
-+#define SSB_SROM8_5GH_PA_0            0x18    /* 5.8GHz power amp settings */
-+#define SSB_SROM8_5GH_PA_1            0x1A
-+#define SSB_SROM8_5GH_PA_2            0x1C
-+
-+/* TODO: Make it deprecated */
- #define SSB_SPROM8_MAXP_BG            0x00C0  /* Max Power 2GHz in path 1 */
- #define  SSB_SPROM8_MAXP_BG_MASK      0x00FF  /* Mask for Max Power 2GHz */
- #define  SSB_SPROM8_ITSSI_BG          0xFF00  /* Mask for path 1 itssi_bg */
-@@ -473,12 +550,23 @@
- #define SSB_SPROM8_PA1HIB0            0x00D8  /* 5.8GHz power amp settings */
- #define SSB_SPROM8_PA1HIB1            0x00DA
- #define SSB_SPROM8_PA1HIB2            0x00DC
-+
- #define SSB_SPROM8_CCK2GPO            0x0140  /* CCK power offset */
- #define SSB_SPROM8_OFDM2GPO           0x0142  /* 2.4GHz OFDM power offset */
- #define SSB_SPROM8_OFDM5GPO           0x0146  /* 5.3GHz OFDM power offset */
- #define SSB_SPROM8_OFDM5GLPO          0x014A  /* 5.2GHz OFDM power offset */
- #define SSB_SPROM8_OFDM5GHPO          0x014E  /* 5.8GHz OFDM power offset */
-+#define SSB_SPROM8_2G_MCSPO           0x0152
-+#define SSB_SPROM8_5G_MCSPO           0x0162
-+#define SSB_SPROM8_5GL_MCSPO          0x0172
-+#define SSB_SPROM8_5GH_MCSPO          0x0182
-+
-+#define SSB_SPROM8_CDDPO              0x0192
-+#define SSB_SPROM8_STBCPO             0x0194
-+#define SSB_SPROM8_BW40PO             0x0196
-+#define SSB_SPROM8_BWDUPPO            0x0198
-+
- /* Values for boardflags_lo read from SPROM */
- #define SSB_BFL_BTCOEXIST             0x0001  /* implements Bluetooth coexistance */
- #define SSB_BFL_PACTRL                        0x0002  /* GPIO 9 controlling the PA */
---- /dev/null
-+++ b/include/linux/bcm47xx_wdt.h
-@@ -0,0 +1,19 @@
-+#ifndef LINUX_BCM47XX_WDT_H_
-+#define LINUX_BCM47XX_WDT_H_
-+
-+#include <linux/types.h>
-+
-+
-+struct bcm47xx_wdt {
-+      u32 (*timer_set)(struct bcm47xx_wdt *, u32);
-+      u32 (*timer_set_ms)(struct bcm47xx_wdt *, u32);
-+      u32 max_timer_ms;
-+
-+      void *driver_data;
-+};
-+
-+static inline void *bcm47xx_wdt_get_drvdata(struct bcm47xx_wdt *wdt)
-+{
-+      return wdt->driver_data;
-+}
-+#endif /* LINUX_BCM47XX_WDT_H_ */
---- a/drivers/net/wireless/b43/phy_n.c
-+++ b/drivers/net/wireless/b43/phy_n.c
-@@ -4259,7 +4259,8 @@ static void b43_nphy_pmu_spur_avoid(stru
- #endif
- #ifdef CONFIG_B43_SSB
-       case B43_BUS_SSB:
--              /* FIXME */
-+              ssb_pmu_spuravoid_pllupdate(&dev->dev->sdev->bus->chipco,
-+                                          avoid);
-               break;
- #endif
-       }
diff --git a/target/linux/generic/patches-3.3/025-bcma_backport.patch b/target/linux/generic/patches-3.3/025-bcma_backport.patch
deleted file mode 100644 (file)
index df80ec4..0000000
+++ /dev/null
@@ -1,5794 +0,0 @@
---- a/arch/mips/bcm47xx/serial.c
-+++ b/arch/mips/bcm47xx/serial.c
-@@ -62,7 +62,7 @@ static int __init uart8250_init_bcma(voi
-               p->mapbase = (unsigned int) bcma_port->regs;
-               p->membase = (void *) bcma_port->regs;
--              p->irq = bcma_port->irq + 2;
-+              p->irq = bcma_port->irq;
-               p->uartclk = bcma_port->baud_base;
-               p->regshift = bcma_port->reg_shift;
-               p->iotype = UPIO_MEM;
---- a/drivers/bcma/Kconfig
-+++ b/drivers/bcma/Kconfig
-@@ -26,16 +26,23 @@ config BCMA_HOST_PCI_POSSIBLE
- config BCMA_HOST_PCI
-       bool "Support for BCMA on PCI-host bus"
-       depends on BCMA_HOST_PCI_POSSIBLE
-+      default y
- config BCMA_DRIVER_PCI_HOSTMODE
-       bool "Driver for PCI core working in hostmode"
--      depends on BCMA && MIPS
-+      depends on BCMA && MIPS && BCMA_HOST_PCI
-       help
-         PCI core hostmode operation (external PCI bus).
- config BCMA_HOST_SOC
--      bool
--      depends on BCMA_DRIVER_MIPS
-+      bool "Support for BCMA in a SoC"
-+      depends on BCMA
-+      help
-+        Host interface for a Broadcom AIX bus directly mapped into
-+        the memory. This only works with the Broadcom SoCs from the
-+        BCM47XX line.
-+
-+        If unsure, say N
- config BCMA_DRIVER_MIPS
-       bool "BCMA Broadcom MIPS core driver"
-@@ -46,6 +53,33 @@ config BCMA_DRIVER_MIPS
-         If unsure, say N
-+config BCMA_SFLASH
-+      bool
-+      depends on BCMA_DRIVER_MIPS
-+      default y
-+
-+config BCMA_NFLASH
-+      bool
-+      depends on BCMA_DRIVER_MIPS
-+      default y
-+
-+config BCMA_DRIVER_GMAC_CMN
-+      bool "BCMA Broadcom GBIT MAC COMMON core driver"
-+      depends on BCMA
-+      help
-+        Driver for the Broadcom GBIT MAC COMMON core attached to Broadcom
-+        specific Advanced Microcontroller Bus.
-+
-+        If unsure, say N
-+
-+config BCMA_DRIVER_GPIO
-+      bool "BCMA GPIO driver"
-+      depends on BCMA && GPIOLIB
-+      help
-+        Driver to provide access to the GPIO pins of the bcma bus.
-+
-+        If unsure, say N
-+
- config BCMA_DEBUG
-       bool "BCMA debugging"
-       depends on BCMA
---- a/drivers/bcma/Makefile
-+++ b/drivers/bcma/Makefile
-@@ -1,8 +1,12 @@
- bcma-y                                        += main.o scan.o core.o sprom.o
- bcma-y                                        += driver_chipcommon.o driver_chipcommon_pmu.o
-+bcma-$(CONFIG_BCMA_SFLASH)            += driver_chipcommon_sflash.o
-+bcma-$(CONFIG_BCMA_NFLASH)            += driver_chipcommon_nflash.o
- bcma-y                                        += driver_pci.o
- bcma-$(CONFIG_BCMA_DRIVER_PCI_HOSTMODE)       += driver_pci_host.o
- bcma-$(CONFIG_BCMA_DRIVER_MIPS)               += driver_mips.o
-+bcma-$(CONFIG_BCMA_DRIVER_GMAC_CMN)   += driver_gmac_cmn.o
-+bcma-$(CONFIG_BCMA_DRIVER_GPIO)               += driver_gpio.o
- bcma-$(CONFIG_BCMA_HOST_PCI)          += host_pci.o
- bcma-$(CONFIG_BCMA_HOST_SOC)          += host_soc.o
- obj-$(CONFIG_BCMA)                    += bcma.o
---- a/drivers/bcma/bcma_private.h
-+++ b/drivers/bcma/bcma_private.h
-@@ -10,10 +10,21 @@
- #define BCMA_CORE_SIZE                0x1000
-+#define bcma_err(bus, fmt, ...) \
-+      pr_err("bus%d: " fmt, (bus)->num, ##__VA_ARGS__)
-+#define bcma_warn(bus, fmt, ...) \
-+      pr_warn("bus%d: " fmt, (bus)->num, ##__VA_ARGS__)
-+#define bcma_info(bus, fmt, ...) \
-+      pr_info("bus%d: " fmt, (bus)->num, ##__VA_ARGS__)
-+#define bcma_debug(bus, fmt, ...) \
-+      pr_debug("bus%d: " fmt, (bus)->num, ##__VA_ARGS__)
-+
- struct bcma_bus;
- /* main.c */
--int bcma_bus_register(struct bcma_bus *bus);
-+bool bcma_wait_value(struct bcma_device *core, u16 reg, u32 mask, u32 value,
-+                   int timeout);
-+int __devinit bcma_bus_register(struct bcma_bus *bus);
- void bcma_bus_unregister(struct bcma_bus *bus);
- int __init bcma_bus_early_register(struct bcma_bus *bus,
-                                  struct bcma_device *core_cc,
-@@ -22,6 +33,8 @@ int __init bcma_bus_early_register(struc
- int bcma_bus_suspend(struct bcma_bus *bus);
- int bcma_bus_resume(struct bcma_bus *bus);
- #endif
-+struct bcma_device *bcma_find_core_unit(struct bcma_bus *bus, u16 coreid,
-+                                      u8 unit);
- /* scan.c */
- int bcma_bus_scan(struct bcma_bus *bus);
-@@ -36,11 +49,36 @@ int bcma_sprom_get(struct bcma_bus *bus)
- /* driver_chipcommon.c */
- #ifdef CONFIG_BCMA_DRIVER_MIPS
- void bcma_chipco_serial_init(struct bcma_drv_cc *cc);
-+extern struct platform_device bcma_pflash_dev;
- #endif /* CONFIG_BCMA_DRIVER_MIPS */
- /* driver_chipcommon_pmu.c */
--u32 bcma_pmu_alp_clock(struct bcma_drv_cc *cc);
--u32 bcma_pmu_get_clockcpu(struct bcma_drv_cc *cc);
-+u32 bcma_pmu_get_alp_clock(struct bcma_drv_cc *cc);
-+u32 bcma_pmu_get_cpu_clock(struct bcma_drv_cc *cc);
-+
-+#ifdef CONFIG_BCMA_SFLASH
-+/* driver_chipcommon_sflash.c */
-+int bcma_sflash_init(struct bcma_drv_cc *cc);
-+extern struct platform_device bcma_sflash_dev;
-+#else
-+static inline int bcma_sflash_init(struct bcma_drv_cc *cc)
-+{
-+      bcma_err(cc->core->bus, "Serial flash not supported\n");
-+      return 0;
-+}
-+#endif /* CONFIG_BCMA_SFLASH */
-+
-+#ifdef CONFIG_BCMA_NFLASH
-+/* driver_chipcommon_nflash.c */
-+int bcma_nflash_init(struct bcma_drv_cc *cc);
-+extern struct platform_device bcma_nflash_dev;
-+#else
-+static inline int bcma_nflash_init(struct bcma_drv_cc *cc)
-+{
-+      bcma_err(cc->core->bus, "NAND flash not supported\n");
-+      return 0;
-+}
-+#endif /* CONFIG_BCMA_NFLASH */
- #ifdef CONFIG_BCMA_HOST_PCI
- /* host_pci.c */
-@@ -48,8 +86,29 @@ extern int __init bcma_host_pci_init(voi
- extern void __exit bcma_host_pci_exit(void);
- #endif /* CONFIG_BCMA_HOST_PCI */
-+/* driver_pci.c */
-+u32 bcma_pcie_read(struct bcma_drv_pci *pc, u32 address);
-+
-+extern int bcma_chipco_watchdog_register(struct bcma_drv_cc *cc);
-+
- #ifdef CONFIG_BCMA_DRIVER_PCI_HOSTMODE
--void bcma_core_pci_hostmode_init(struct bcma_drv_pci *pc);
-+bool __devinit bcma_core_pci_is_in_hostmode(struct bcma_drv_pci *pc);
-+void __devinit bcma_core_pci_hostmode_init(struct bcma_drv_pci *pc);
- #endif /* CONFIG_BCMA_DRIVER_PCI_HOSTMODE */
-+#ifdef CONFIG_BCMA_DRIVER_GPIO
-+/* driver_gpio.c */
-+int bcma_gpio_init(struct bcma_drv_cc *cc);
-+int bcma_gpio_unregister(struct bcma_drv_cc *cc);
-+#else
-+static inline int bcma_gpio_init(struct bcma_drv_cc *cc)
-+{
-+      return -ENOTSUPP;
-+}
-+static inline int bcma_gpio_unregister(struct bcma_drv_cc *cc)
-+{
-+      return 0;
-+}
-+#endif /* CONFIG_BCMA_DRIVER_GPIO */
-+
- #endif
---- a/drivers/bcma/core.c
-+++ b/drivers/bcma/core.c
-@@ -9,6 +9,25 @@
- #include <linux/export.h>
- #include <linux/bcma/bcma.h>
-+static bool bcma_core_wait_value(struct bcma_device *core, u16 reg, u32 mask,
-+                               u32 value, int timeout)
-+{
-+      unsigned long deadline = jiffies + timeout;
-+      u32 val;
-+
-+      do {
-+              val = bcma_aread32(core, reg);
-+              if ((val & mask) == value)
-+                      return true;
-+              cpu_relax();
-+              udelay(10);
-+      } while (!time_after_eq(jiffies, deadline));
-+
-+      bcma_warn(core->bus, "Timeout waiting for register 0x%04X!\n", reg);
-+
-+      return false;
-+}
-+
- bool bcma_core_is_enabled(struct bcma_device *core)
- {
-       if ((bcma_aread32(core, BCMA_IOCTL) & (BCMA_IOCTL_CLK | BCMA_IOCTL_FGC))
-@@ -25,12 +44,15 @@ void bcma_core_disable(struct bcma_devic
-       if (bcma_aread32(core, BCMA_RESET_CTL) & BCMA_RESET_CTL_RESET)
-               return;
--      bcma_awrite32(core, BCMA_IOCTL, flags);
--      bcma_aread32(core, BCMA_IOCTL);
--      udelay(10);
-+      bcma_core_wait_value(core, BCMA_RESET_ST, ~0, 0, 300);
-       bcma_awrite32(core, BCMA_RESET_CTL, BCMA_RESET_CTL_RESET);
-+      bcma_aread32(core, BCMA_RESET_CTL);
-       udelay(1);
-+
-+      bcma_awrite32(core, BCMA_IOCTL, flags);
-+      bcma_aread32(core, BCMA_IOCTL);
-+      udelay(10);
- }
- EXPORT_SYMBOL_GPL(bcma_core_disable);
-@@ -42,6 +64,7 @@ int bcma_core_enable(struct bcma_device
-       bcma_aread32(core, BCMA_IOCTL);
-       bcma_awrite32(core, BCMA_RESET_CTL, 0);
-+      bcma_aread32(core, BCMA_RESET_CTL);
-       udelay(1);
-       bcma_awrite32(core, BCMA_IOCTL, (BCMA_IOCTL_CLK | flags));
-@@ -64,7 +87,7 @@ void bcma_core_set_clockmode(struct bcma
-       switch (clkmode) {
-       case BCMA_CLKMODE_FAST:
-               bcma_set32(core, BCMA_CLKCTLST, BCMA_CLKCTLST_FORCEHT);
--              udelay(64);
-+              usleep_range(64, 300);
-               for (i = 0; i < 1500; i++) {
-                       if (bcma_read32(core, BCMA_CLKCTLST) &
-                           BCMA_CLKCTLST_HAVEHT) {
-@@ -74,10 +97,10 @@ void bcma_core_set_clockmode(struct bcma
-                       udelay(10);
-               }
-               if (i)
--                      pr_err("HT force timeout\n");
-+                      bcma_err(core->bus, "HT force timeout\n");
-               break;
-       case BCMA_CLKMODE_DYNAMIC:
--              pr_warn("Dynamic clockmode not supported yet!\n");
-+              bcma_set32(core, BCMA_CLKCTLST, ~BCMA_CLKCTLST_FORCEHT);
-               break;
-       }
- }
-@@ -101,9 +124,15 @@ void bcma_core_pll_ctl(struct bcma_devic
-                       udelay(10);
-               }
-               if (i)
--                      pr_err("PLL enable timeout\n");
-+                      bcma_err(core->bus, "PLL enable timeout\n");
-       } else {
--              pr_warn("Disabling PLL not supported yet!\n");
-+              /*
-+               * Mask the PLL but don't wait for it to be disabled. PLL may be
-+               * shared between cores and will be still up if there is another
-+               * core using it.
-+               */
-+              bcma_mask32(core, BCMA_CLKCTLST, ~req);
-+              bcma_read32(core, BCMA_CLKCTLST);
-       }
- }
- EXPORT_SYMBOL_GPL(bcma_core_pll_ctl);
-@@ -119,8 +148,8 @@ u32 bcma_core_dma_translation(struct bcm
-               else
-                       return BCMA_DMA_TRANSLATION_DMA32_CMT;
-       default:
--              pr_err("DMA translation unknown for host %d\n",
--                     core->bus->hosttype);
-+              bcma_err(core->bus, "DMA translation unknown for host %d\n",
-+                       core->bus->hosttype);
-       }
-       return BCMA_DMA_TRANSLATION_NONE;
- }
---- a/drivers/bcma/driver_chipcommon.c
-+++ b/drivers/bcma/driver_chipcommon.c
-@@ -4,12 +4,15 @@
-  *
-  * Copyright 2005, Broadcom Corporation
-  * Copyright 2006, 2007, Michael Buesch <m@bues.ch>
-+ * Copyright 2012, Hauke Mehrtens <hauke@hauke-m.de>
-  *
-  * Licensed under the GNU/GPL. See COPYING for details.
-  */
- #include "bcma_private.h"
-+#include <linux/bcm47xx_wdt.h>
- #include <linux/export.h>
-+#include <linux/platform_device.h>
- #include <linux/bcma/bcma.h>
- static inline u32 bcma_cc_write32_masked(struct bcma_drv_cc *cc, u16 offset,
-@@ -22,29 +25,136 @@ static inline u32 bcma_cc_write32_masked
-       return value;
- }
--void bcma_core_chipcommon_init(struct bcma_drv_cc *cc)
-+u32 bcma_chipco_get_alp_clock(struct bcma_drv_cc *cc)
- {
--      u32 leddc_on = 10;
--      u32 leddc_off = 90;
-+      if (cc->capabilities & BCMA_CC_CAP_PMU)
-+              return bcma_pmu_get_alp_clock(cc);
--      if (cc->setup_done)
-+      return 20000000;
-+}
-+EXPORT_SYMBOL_GPL(bcma_chipco_get_alp_clock);
-+
-+static u32 bcma_chipco_watchdog_get_max_timer(struct bcma_drv_cc *cc)
-+{
-+      struct bcma_bus *bus = cc->core->bus;
-+      u32 nb;
-+
-+      if (cc->capabilities & BCMA_CC_CAP_PMU) {
-+              if (bus->chipinfo.id == BCMA_CHIP_ID_BCM4706)
-+                      nb = 32;
-+              else if (cc->core->id.rev < 26)
-+                      nb = 16;
-+              else
-+                      nb = (cc->core->id.rev >= 37) ? 32 : 24;
-+      } else {
-+              nb = 28;
-+      }
-+      if (nb == 32)
-+              return 0xffffffff;
-+      else
-+              return (1 << nb) - 1;
-+}
-+
-+static u32 bcma_chipco_watchdog_timer_set_wdt(struct bcm47xx_wdt *wdt,
-+                                            u32 ticks)
-+{
-+      struct bcma_drv_cc *cc = bcm47xx_wdt_get_drvdata(wdt);
-+
-+      return bcma_chipco_watchdog_timer_set(cc, ticks);
-+}
-+
-+static u32 bcma_chipco_watchdog_timer_set_ms_wdt(struct bcm47xx_wdt *wdt,
-+                                               u32 ms)
-+{
-+      struct bcma_drv_cc *cc = bcm47xx_wdt_get_drvdata(wdt);
-+      u32 ticks;
-+
-+      ticks = bcma_chipco_watchdog_timer_set(cc, cc->ticks_per_ms * ms);
-+      return ticks / cc->ticks_per_ms;
-+}
-+
-+static int bcma_chipco_watchdog_ticks_per_ms(struct bcma_drv_cc *cc)
-+{
-+      struct bcma_bus *bus = cc->core->bus;
-+
-+      if (cc->capabilities & BCMA_CC_CAP_PMU) {
-+              if (bus->chipinfo.id == BCMA_CHIP_ID_BCM4706)
-+                      /* 4706 CC and PMU watchdogs are clocked at 1/4 of ALP clock */
-+                      return bcma_chipco_get_alp_clock(cc) / 4000;
-+              else
-+                      /* based on 32KHz ILP clock */
-+                      return 32;
-+      } else {
-+              return bcma_chipco_get_alp_clock(cc) / 1000;
-+      }
-+}
-+
-+int bcma_chipco_watchdog_register(struct bcma_drv_cc *cc)
-+{
-+      struct bcm47xx_wdt wdt = {};
-+      struct platform_device *pdev;
-+
-+      wdt.driver_data = cc;
-+      wdt.timer_set = bcma_chipco_watchdog_timer_set_wdt;
-+      wdt.timer_set_ms = bcma_chipco_watchdog_timer_set_ms_wdt;
-+      wdt.max_timer_ms = bcma_chipco_watchdog_get_max_timer(cc) / cc->ticks_per_ms;
-+
-+      pdev = platform_device_register_data(NULL, "bcm47xx-wdt",
-+                                           cc->core->bus->num, &wdt,
-+                                           sizeof(wdt));
-+      if (IS_ERR(pdev))
-+              return PTR_ERR(pdev);
-+
-+      cc->watchdog = pdev;
-+
-+      return 0;
-+}
-+
-+void bcma_core_chipcommon_early_init(struct bcma_drv_cc *cc)
-+{
-+      if (cc->early_setup_done)
-               return;
-+      spin_lock_init(&cc->gpio_lock);
-+
-       if (cc->core->id.rev >= 11)
-               cc->status = bcma_cc_read32(cc, BCMA_CC_CHIPSTAT);
-       cc->capabilities = bcma_cc_read32(cc, BCMA_CC_CAP);
-       if (cc->core->id.rev >= 35)
-               cc->capabilities_ext = bcma_cc_read32(cc, BCMA_CC_CAP_EXT);
-+      if (cc->capabilities & BCMA_CC_CAP_PMU)
-+              bcma_pmu_early_init(cc);
-+
-+      cc->early_setup_done = true;
-+}
-+
-+void bcma_core_chipcommon_init(struct bcma_drv_cc *cc)
-+{
-+      u32 leddc_on = 10;
-+      u32 leddc_off = 90;
-+
-+      if (cc->setup_done)
-+              return;
-+
-+      bcma_core_chipcommon_early_init(cc);
-+
-       if (cc->core->id.rev >= 20) {
--              bcma_cc_write32(cc, BCMA_CC_GPIOPULLUP, 0);
--              bcma_cc_write32(cc, BCMA_CC_GPIOPULLDOWN, 0);
-+              u32 pullup = 0, pulldown = 0;
-+
-+              if (cc->core->bus->chipinfo.id == BCMA_CHIP_ID_BCM43142) {
-+                      pullup = 0x402e0;
-+                      pulldown = 0x20500;
-+              }
-+
-+              bcma_cc_write32(cc, BCMA_CC_GPIOPULLUP, pullup);
-+              bcma_cc_write32(cc, BCMA_CC_GPIOPULLDOWN, pulldown);
-       }
-       if (cc->capabilities & BCMA_CC_CAP_PMU)
-               bcma_pmu_init(cc);
-       if (cc->capabilities & BCMA_CC_CAP_PCTL)
--              pr_err("Power control not implemented!\n");
-+              bcma_err(cc->core->bus, "Power control not implemented!\n");
-       if (cc->core->id.rev >= 16) {
-               if (cc->core->bus->sprom.leddc_on_time &&
-@@ -56,15 +166,33 @@ void bcma_core_chipcommon_init(struct bc
-                       ((leddc_on << BCMA_CC_GPIOTIMER_ONTIME_SHIFT) |
-                        (leddc_off << BCMA_CC_GPIOTIMER_OFFTIME_SHIFT)));
-       }
-+      cc->ticks_per_ms = bcma_chipco_watchdog_ticks_per_ms(cc);
-       cc->setup_done = true;
- }
- /* Set chip watchdog reset timer to fire in 'ticks' backplane cycles */
--void bcma_chipco_watchdog_timer_set(struct bcma_drv_cc *cc, u32 ticks)
-+u32 bcma_chipco_watchdog_timer_set(struct bcma_drv_cc *cc, u32 ticks)
- {
--      /* instant NMI */
--      bcma_cc_write32(cc, BCMA_CC_WATCHDOG, ticks);
-+      u32 maxt;
-+      enum bcma_clkmode clkmode;
-+
-+      maxt = bcma_chipco_watchdog_get_max_timer(cc);
-+      if (cc->capabilities & BCMA_CC_CAP_PMU) {
-+              if (ticks == 1)
-+                      ticks = 2;
-+              else if (ticks > maxt)
-+                      ticks = maxt;
-+              bcma_cc_write32(cc, BCMA_CC_PMU_WATCHDOG, ticks);
-+      } else {
-+              clkmode = ticks ? BCMA_CLKMODE_FAST : BCMA_CLKMODE_DYNAMIC;
-+              bcma_core_set_clockmode(cc->core, clkmode);
-+              if (ticks > maxt)
-+                      ticks = maxt;
-+              /* instant NMI */
-+              bcma_cc_write32(cc, BCMA_CC_WATCHDOG, ticks);
-+      }
-+      return ticks;
- }
- void bcma_chipco_irq_mask(struct bcma_drv_cc *cc, u32 mask, u32 value)
-@@ -84,28 +212,99 @@ u32 bcma_chipco_gpio_in(struct bcma_drv_
- u32 bcma_chipco_gpio_out(struct bcma_drv_cc *cc, u32 mask, u32 value)
- {
--      return bcma_cc_write32_masked(cc, BCMA_CC_GPIOOUT, mask, value);
-+      unsigned long flags;
-+      u32 res;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOOUT, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
-+EXPORT_SYMBOL_GPL(bcma_chipco_gpio_out);
- u32 bcma_chipco_gpio_outen(struct bcma_drv_cc *cc, u32 mask, u32 value)
- {
--      return bcma_cc_write32_masked(cc, BCMA_CC_GPIOOUTEN, mask, value);
-+      unsigned long flags;
-+      u32 res;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOOUTEN, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
-+EXPORT_SYMBOL_GPL(bcma_chipco_gpio_outen);
-+/*
-+ * If the bit is set to 0, chipcommon controlls this GPIO,
-+ * if the bit is set to 1, it is used by some part of the chip and not our code.
-+ */
- u32 bcma_chipco_gpio_control(struct bcma_drv_cc *cc, u32 mask, u32 value)
- {
--      return bcma_cc_write32_masked(cc, BCMA_CC_GPIOCTL, mask, value);
-+      unsigned long flags;
-+      u32 res;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOCTL, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- EXPORT_SYMBOL_GPL(bcma_chipco_gpio_control);
- u32 bcma_chipco_gpio_intmask(struct bcma_drv_cc *cc, u32 mask, u32 value)
- {
--      return bcma_cc_write32_masked(cc, BCMA_CC_GPIOIRQ, mask, value);
-+      unsigned long flags;
-+      u32 res;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOIRQ, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- u32 bcma_chipco_gpio_polarity(struct bcma_drv_cc *cc, u32 mask, u32 value)
- {
--      return bcma_cc_write32_masked(cc, BCMA_CC_GPIOPOL, mask, value);
-+      unsigned long flags;
-+      u32 res;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOPOL, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
-+}
-+
-+u32 bcma_chipco_gpio_pullup(struct bcma_drv_cc *cc, u32 mask, u32 value)
-+{
-+      unsigned long flags;
-+      u32 res;
-+
-+      if (cc->core->id.rev < 20)
-+              return 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOPULLUP, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
-+}
-+
-+u32 bcma_chipco_gpio_pulldown(struct bcma_drv_cc *cc, u32 mask, u32 value)
-+{
-+      unsigned long flags;
-+      u32 res;
-+
-+      if (cc->core->id.rev < 20)
-+              return 0;
-+
-+      spin_lock_irqsave(&cc->gpio_lock, flags);
-+      res = bcma_cc_write32_masked(cc, BCMA_CC_GPIOPULLDOWN, mask, value);
-+      spin_unlock_irqrestore(&cc->gpio_lock, flags);
-+
-+      return res;
- }
- #ifdef CONFIG_BCMA_DRIVER_MIPS
-@@ -118,8 +317,7 @@ void bcma_chipco_serial_init(struct bcma
-       struct bcma_serial_port *ports = cc->serial_ports;
-       if (ccrev >= 11 && ccrev != 15) {
--              /* Fixed ALP clock */
--              baud_base = bcma_pmu_alp_clock(cc);
-+              baud_base = bcma_chipco_get_alp_clock(cc);
-               if (ccrev >= 21) {
-                       /* Turn off UART clock before switching clocksource. */
-                       bcma_cc_write32(cc, BCMA_CC_CORECTL,
-@@ -137,12 +335,11 @@ void bcma_chipco_serial_init(struct bcma
-                                      | BCMA_CC_CORECTL_UARTCLKEN);
-               }
-       } else {
--              pr_err("serial not supported on this device ccrev: 0x%x\n",
--                     ccrev);
-+              bcma_err(cc->core->bus, "serial not supported on this device ccrev: 0x%x\n", ccrev);
-               return;
-       }
--      irq = bcma_core_mips_irq(cc->core);
-+      irq = bcma_core_irq(cc->core);
-       /* Determine the registers of the UARTs */
-       cc->nr_serial_ports = (cc->capabilities & BCMA_CC_CAP_NRUART);
---- /dev/null
-+++ b/drivers/bcma/driver_chipcommon_nflash.c
-@@ -0,0 +1,44 @@
-+/*
-+ * Broadcom specific AMBA
-+ * ChipCommon NAND flash interface
-+ *
-+ * Licensed under the GNU/GPL. See COPYING for details.
-+ */
-+
-+#include "bcma_private.h"
-+
-+#include <linux/platform_device.h>
-+#include <linux/bcma/bcma.h>
-+
-+struct platform_device bcma_nflash_dev = {
-+      .name           = "bcma_nflash",
-+      .num_resources  = 0,
-+};
-+
-+/* Initialize NAND flash access */
-+int bcma_nflash_init(struct bcma_drv_cc *cc)
-+{
-+      struct bcma_bus *bus = cc->core->bus;
-+
-+      if (bus->chipinfo.id != BCMA_CHIP_ID_BCM4706 &&
-+          cc->core->id.rev != 38) {
-+              bcma_err(bus, "NAND flash on unsupported board!\n");
-+              return -ENOTSUPP;
-+      }
-+
-+      if (!(cc->capabilities & BCMA_CC_CAP_NFLASH)) {
-+              bcma_err(bus, "NAND flash not present according to ChipCommon\n");
-+              return -ENODEV;
-+      }
-+
-+      cc->nflash.present = true;
-+      if (cc->core->id.rev == 38 &&
-+          (cc->status & BCMA_CC_CHIPST_5357_NAND_BOOT))
-+              cc->nflash.boot = true;
-+
-+      /* Prepare platform device, but don't register it yet. It's too early,
-+       * malloc (required by device_private_init) is not available yet. */
-+      bcma_nflash_dev.dev.platform_data = &cc->nflash;
-+
-+      return 0;
-+}
---- a/drivers/bcma/driver_chipcommon_pmu.c
-+++ b/drivers/bcma/driver_chipcommon_pmu.c
-@@ -3,7 +3,8 @@
-  * ChipCommon Power Management Unit driver
-  *
-  * Copyright 2009, Michael Buesch <m@bues.ch>
-- * Copyright 2007, Broadcom Corporation
-+ * Copyright 2007, 2011, Broadcom Corporation
-+ * Copyright 2011, 2012, Hauke Mehrtens <hauke@hauke-m.de>
-  *
-  * Licensed under the GNU/GPL. See COPYING for details.
-  */
-@@ -12,12 +13,13 @@
- #include <linux/export.h>
- #include <linux/bcma/bcma.h>
--static u32 bcma_chipco_pll_read(struct bcma_drv_cc *cc, u32 offset)
-+u32 bcma_chipco_pll_read(struct bcma_drv_cc *cc, u32 offset)
- {
-       bcma_cc_write32(cc, BCMA_CC_PLLCTL_ADDR, offset);
-       bcma_cc_read32(cc, BCMA_CC_PLLCTL_ADDR);
-       return bcma_cc_read32(cc, BCMA_CC_PLLCTL_DATA);
- }
-+EXPORT_SYMBOL_GPL(bcma_chipco_pll_read);
- void bcma_chipco_pll_write(struct bcma_drv_cc *cc, u32 offset, u32 value)
- {
-@@ -54,19 +56,106 @@ void bcma_chipco_regctl_maskset(struct b
- }
- EXPORT_SYMBOL_GPL(bcma_chipco_regctl_maskset);
-+static u32 bcma_pmu_xtalfreq(struct bcma_drv_cc *cc)
-+{
-+      u32 ilp_ctl, alp_hz;
-+
-+      if (!(bcma_cc_read32(cc, BCMA_CC_PMU_STAT) &
-+            BCMA_CC_PMU_STAT_EXT_LPO_AVAIL))
-+              return 0;
-+
-+      bcma_cc_write32(cc, BCMA_CC_PMU_XTAL_FREQ,
-+                      BIT(BCMA_CC_PMU_XTAL_FREQ_MEASURE_SHIFT));
-+      usleep_range(1000, 2000);
-+
-+      ilp_ctl = bcma_cc_read32(cc, BCMA_CC_PMU_XTAL_FREQ);
-+      ilp_ctl &= BCMA_CC_PMU_XTAL_FREQ_ILPCTL_MASK;
-+
-+      bcma_cc_write32(cc, BCMA_CC_PMU_XTAL_FREQ, 0);
-+
-+      alp_hz = ilp_ctl * 32768 / 4;
-+      return (alp_hz + 50000) / 100000 * 100;
-+}
-+
-+static void bcma_pmu2_pll_init0(struct bcma_drv_cc *cc, u32 xtalfreq)
-+{
-+      struct bcma_bus *bus = cc->core->bus;
-+      u32 freq_tgt_target = 0, freq_tgt_current;
-+      u32 pll0, mask;
-+
-+      switch (bus->chipinfo.id) {
-+      case BCMA_CHIP_ID_BCM43142:
-+              /* pmu2_xtaltab0_adfll_485 */
-+              switch (xtalfreq) {
-+              case 12000:
-+                      freq_tgt_target = 0x50D52;
-+                      break;
-+              case 20000:
-+                      freq_tgt_target = 0x307FE;
-+                      break;
-+              case 26000:
-+                      freq_tgt_target = 0x254EA;
-+                      break;
-+              case 37400:
-+                      freq_tgt_target = 0x19EF8;
-+                      break;
-+              case 52000:
-+                      freq_tgt_target = 0x12A75;
-+                      break;
-+              }
-+              break;
-+      }
-+
-+      if (!freq_tgt_target) {
-+              bcma_err(bus, "Unknown TGT frequency for xtalfreq %d\n",
-+                       xtalfreq);
-+              return;
-+      }
-+
-+      pll0 = bcma_chipco_pll_read(cc, BCMA_CC_PMU15_PLL_PLLCTL0);
-+      freq_tgt_current = (pll0 & BCMA_CC_PMU15_PLL_PC0_FREQTGT_MASK) >>
-+              BCMA_CC_PMU15_PLL_PC0_FREQTGT_SHIFT;
-+
-+      if (freq_tgt_current == freq_tgt_target) {
-+              bcma_debug(bus, "Target TGT frequency already set\n");
-+              return;
-+      }
-+
-+      /* Turn off PLL */
-+      switch (bus->chipinfo.id) {
-+      case BCMA_CHIP_ID_BCM43142:
-+              mask = (u32)~(BCMA_RES_4314_HT_AVAIL |
-+                            BCMA_RES_4314_MACPHY_CLK_AVAIL);
-+
-+              bcma_cc_mask32(cc, BCMA_CC_PMU_MINRES_MSK, mask);
-+              bcma_cc_mask32(cc, BCMA_CC_PMU_MAXRES_MSK, mask);
-+              bcma_wait_value(cc->core, BCMA_CLKCTLST,
-+                              BCMA_CLKCTLST_HAVEHT, 0, 20000);
-+              break;
-+      }
-+
-+      pll0 &= ~BCMA_CC_PMU15_PLL_PC0_FREQTGT_MASK;
-+      pll0 |= freq_tgt_target << BCMA_CC_PMU15_PLL_PC0_FREQTGT_SHIFT;
-+      bcma_chipco_pll_write(cc, BCMA_CC_PMU15_PLL_PLLCTL0, pll0);
-+
-+      /* Flush */
-+      if (cc->pmu.rev >= 2)
-+              bcma_cc_set32(cc, BCMA_CC_PMU_CTL, BCMA_CC_PMU_CTL_PLL_UPD);
-+
-+      /* TODO: Do we need to update OTP? */
-+}
-+
- static void bcma_pmu_pll_init(struct bcma_drv_cc *cc)
- {
-       struct bcma_bus *bus = cc->core->bus;
-+      u32 xtalfreq = bcma_pmu_xtalfreq(cc);
-       switch (bus->chipinfo.id) {
--      case 0x4313:
--      case 0x4331:
--      case 43224:
--      case 43225:
-+      case BCMA_CHIP_ID_BCM43142:
-+              if (xtalfreq == 0)
-+                      xtalfreq = 20000;
-+              bcma_pmu2_pll_init0(cc, xtalfreq);
-               break;
--      default:
--              pr_err("PLL init unknown for device 0x%04X\n",
--                      bus->chipinfo.id);
-       }
- }
-@@ -76,16 +165,32 @@ static void bcma_pmu_resources_init(stru
-       u32 min_msk = 0, max_msk = 0;
-       switch (bus->chipinfo.id) {
--      case 0x4313:
-+      case BCMA_CHIP_ID_BCM4313:
-               min_msk = 0x200D;
-               max_msk = 0xFFFF;
-               break;
--      case 43224:
--      case 43225:
-+      case BCMA_CHIP_ID_BCM43142:
-+              min_msk = BCMA_RES_4314_LPLDO_PU |
-+                        BCMA_RES_4314_PMU_SLEEP_DIS |
-+                        BCMA_RES_4314_PMU_BG_PU |
-+                        BCMA_RES_4314_CBUCK_LPOM_PU |
-+                        BCMA_RES_4314_CBUCK_PFM_PU |
-+                        BCMA_RES_4314_CLDO_PU |
-+                        BCMA_RES_4314_LPLDO2_LVM |
-+                        BCMA_RES_4314_WL_PMU_PU |
-+                        BCMA_RES_4314_LDO3P3_PU |
-+                        BCMA_RES_4314_OTP_PU |
-+                        BCMA_RES_4314_WL_PWRSW_PU |
-+                        BCMA_RES_4314_LQ_AVAIL |
-+                        BCMA_RES_4314_LOGIC_RET |
-+                        BCMA_RES_4314_MEM_SLEEP |
-+                        BCMA_RES_4314_MACPHY_RET |
-+                        BCMA_RES_4314_WL_CORE_READY;
-+              max_msk = 0x3FFFFFFF;
-               break;
-       default:
--              pr_err("PMU resource config unknown for device 0x%04X\n",
--                      bus->chipinfo.id);
-+              bcma_debug(bus, "PMU resource config unknown or not needed for device 0x%04X\n",
-+                         bus->chipinfo.id);
-       }
-       /* Set the resource masks. */
-@@ -93,22 +198,12 @@ static void bcma_pmu_resources_init(stru
-               bcma_cc_write32(cc, BCMA_CC_PMU_MINRES_MSK, min_msk);
-       if (max_msk)
-               bcma_cc_write32(cc, BCMA_CC_PMU_MAXRES_MSK, max_msk);
--}
--void bcma_pmu_swreg_init(struct bcma_drv_cc *cc)
--{
--      struct bcma_bus *bus = cc->core->bus;
--
--      switch (bus->chipinfo.id) {
--      case 0x4313:
--      case 0x4331:
--      case 43224:
--      case 43225:
--              break;
--      default:
--              pr_err("PMU switch/regulators init unknown for device "
--                      "0x%04X\n", bus->chipinfo.id);
--      }
-+      /*
-+       * Add some delay; allow resources to come up and settle.
-+       * Delay is required for SoC (early init).
-+       */
-+      mdelay(2);
- }
- /* Disable to allow reading SPROM. Don't know the adventages of enabling it. */
-@@ -122,51 +217,69 @@ void bcma_chipco_bcm4331_ext_pa_lines_ct
-               val |= BCMA_CHIPCTL_4331_EXTPA_EN;
-               if (bus->chipinfo.pkg == 9 || bus->chipinfo.pkg == 11)
-                       val |= BCMA_CHIPCTL_4331_EXTPA_ON_GPIO2_5;
-+              else if (bus->chipinfo.rev > 0)
-+                      val |= BCMA_CHIPCTL_4331_EXTPA_EN2;
-       } else {
-               val &= ~BCMA_CHIPCTL_4331_EXTPA_EN;
-+              val &= ~BCMA_CHIPCTL_4331_EXTPA_EN2;
-               val &= ~BCMA_CHIPCTL_4331_EXTPA_ON_GPIO2_5;
-       }
-       bcma_cc_write32(cc, BCMA_CC_CHIPCTL, val);
- }
--void bcma_pmu_workarounds(struct bcma_drv_cc *cc)
-+static void bcma_pmu_workarounds(struct bcma_drv_cc *cc)
- {
-       struct bcma_bus *bus = cc->core->bus;
-       switch (bus->chipinfo.id) {
--      case 0x4313:
--              bcma_chipco_chipctl_maskset(cc, 0, ~0, 0x7);
-+      case BCMA_CHIP_ID_BCM4313:
-+              /* enable 12 mA drive strenth for 4313 and set chipControl
-+                 register bit 1 */
-+              bcma_chipco_chipctl_maskset(cc, 0,
-+                                          ~BCMA_CCTRL_4313_12MA_LED_DRIVE,
-+                                          BCMA_CCTRL_4313_12MA_LED_DRIVE);
-               break;
--      case 0x4331:
--              /* BCM4331 workaround is SPROM-related, we put it in sprom.c */
-+      case BCMA_CHIP_ID_BCM4331:
-+      case BCMA_CHIP_ID_BCM43431:
-+              /* Ext PA lines must be enabled for tx on BCM4331 */
-+              bcma_chipco_bcm4331_ext_pa_lines_ctl(cc, true);
-               break;
--      case 43224:
-+      case BCMA_CHIP_ID_BCM43224:
-+      case BCMA_CHIP_ID_BCM43421:
-+              /* enable 12 mA drive strenth for 43224 and set chipControl
-+                 register bit 15 */
-               if (bus->chipinfo.rev == 0) {
--                      pr_err("Workarounds for 43224 rev 0 not fully "
--                              "implemented\n");
--                      bcma_chipco_chipctl_maskset(cc, 0, ~0, 0x00F000F0);
-+                      bcma_cc_maskset32(cc, BCMA_CC_CHIPCTL,
-+                                        ~BCMA_CCTRL_43224_GPIO_TOGGLE,
-+                                        BCMA_CCTRL_43224_GPIO_TOGGLE);
-+                      bcma_chipco_chipctl_maskset(cc, 0,
-+                                                  ~BCMA_CCTRL_43224A0_12MA_LED_DRIVE,
-+                                                  BCMA_CCTRL_43224A0_12MA_LED_DRIVE);
-               } else {
--                      bcma_chipco_chipctl_maskset(cc, 0, ~0, 0xF0);
-+                      bcma_chipco_chipctl_maskset(cc, 0,
-+                                                  ~BCMA_CCTRL_43224B0_12MA_LED_DRIVE,
-+                                                  BCMA_CCTRL_43224B0_12MA_LED_DRIVE);
-               }
-               break;
--      case 43225:
--              break;
-       default:
--              pr_err("Workarounds unknown for device 0x%04X\n",
--                      bus->chipinfo.id);
-+              bcma_debug(bus, "Workarounds unknown or not needed for device 0x%04X\n",
-+                         bus->chipinfo.id);
-       }
- }
--void bcma_pmu_init(struct bcma_drv_cc *cc)
-+void bcma_pmu_early_init(struct bcma_drv_cc *cc)
- {
-       u32 pmucap;
-       pmucap = bcma_cc_read32(cc, BCMA_CC_PMU_CAP);
-       cc->pmu.rev = (pmucap & BCMA_CC_PMU_CAP_REVISION);
--      pr_debug("Found rev %u PMU (capabilities 0x%08X)\n", cc->pmu.rev,
--               pmucap);
-+      bcma_debug(cc->core->bus, "Found rev %u PMU (capabilities 0x%08X)\n",
-+                 cc->pmu.rev, pmucap);
-+}
-+void bcma_pmu_init(struct bcma_drv_cc *cc)
-+{
-       if (cc->pmu.rev == 1)
-               bcma_cc_mask32(cc, BCMA_CC_PMU_CTL,
-                             ~BCMA_CC_PMU_CTL_NOILPONW);
-@@ -174,37 +287,48 @@ void bcma_pmu_init(struct bcma_drv_cc *c
-               bcma_cc_set32(cc, BCMA_CC_PMU_CTL,
-                            BCMA_CC_PMU_CTL_NOILPONW);
--      if (cc->core->id.id == 0x4329 && cc->core->id.rev == 2)
--              pr_err("Fix for 4329b0 bad LPOM state not implemented!\n");
--
-       bcma_pmu_pll_init(cc);
-       bcma_pmu_resources_init(cc);
--      bcma_pmu_swreg_init(cc);
-       bcma_pmu_workarounds(cc);
- }
--u32 bcma_pmu_alp_clock(struct bcma_drv_cc *cc)
-+u32 bcma_pmu_get_alp_clock(struct bcma_drv_cc *cc)
- {
-       struct bcma_bus *bus = cc->core->bus;
-       switch (bus->chipinfo.id) {
--      case 0x4716:
--      case 0x4748:
--      case 47162:
--      case 0x4313:
--      case 0x5357:
--      case 0x4749:
--      case 53572:
-+      case BCMA_CHIP_ID_BCM4313:
-+      case BCMA_CHIP_ID_BCM43224:
-+      case BCMA_CHIP_ID_BCM43225:
-+      case BCMA_CHIP_ID_BCM43227:
-+      case BCMA_CHIP_ID_BCM43228:
-+      case BCMA_CHIP_ID_BCM4331:
-+      case BCMA_CHIP_ID_BCM43421:
-+      case BCMA_CHIP_ID_BCM43428:
-+      case BCMA_CHIP_ID_BCM43431:
-+      case BCMA_CHIP_ID_BCM4716:
-+      case BCMA_CHIP_ID_BCM47162:
-+      case BCMA_CHIP_ID_BCM4748:
-+      case BCMA_CHIP_ID_BCM4749:
-+      case BCMA_CHIP_ID_BCM5357:
-+      case BCMA_CHIP_ID_BCM53572:
-+      case BCMA_CHIP_ID_BCM6362:
-               /* always 20Mhz */
-               return 20000 * 1000;
--      case 0x5356:
--      case 0x5300:
-+      case BCMA_CHIP_ID_BCM4706:
-+      case BCMA_CHIP_ID_BCM5356:
-               /* always 25Mhz */
-               return 25000 * 1000;
-+      case BCMA_CHIP_ID_BCM43460:
-+      case BCMA_CHIP_ID_BCM4352:
-+      case BCMA_CHIP_ID_BCM4360:
-+              if (cc->status & BCMA_CC_CHIPST_4360_XTAL_40MZ)
-+                      return 40000 * 1000;
-+              else
-+                      return 20000 * 1000;
-       default:
--              pr_warn("No ALP clock specified for %04X device, "
--                      "pmu rev. %d, using default %d Hz\n",
--                      bus->chipinfo.id, cc->pmu.rev, BCMA_CC_PMU_ALP_CLOCK);
-+              bcma_warn(bus, "No ALP clock specified for %04X device, pmu rev. %d, using default %d Hz\n",
-+                        bus->chipinfo.id, cc->pmu.rev, BCMA_CC_PMU_ALP_CLOCK);
-       }
-       return BCMA_CC_PMU_ALP_CLOCK;
- }
-@@ -212,7 +336,7 @@ u32 bcma_pmu_alp_clock(struct bcma_drv_c
- /* Find the output of the "m" pll divider given pll controls that start with
-  * pllreg "pll0" i.e. 12 for main 6 for phy, 0 for misc.
-  */
--static u32 bcma_pmu_clock(struct bcma_drv_cc *cc, u32 pll0, u32 m)
-+static u32 bcma_pmu_pll_clock(struct bcma_drv_cc *cc, u32 pll0, u32 m)
- {
-       u32 tmp, div, ndiv, p1, p2, fc;
-       struct bcma_bus *bus = cc->core->bus;
-@@ -221,7 +345,8 @@ static u32 bcma_pmu_clock(struct bcma_dr
-       BUG_ON(!m || m > 4);
--      if (bus->chipinfo.id == 0x5357 || bus->chipinfo.id == 0x4749) {
-+      if (bus->chipinfo.id == BCMA_CHIP_ID_BCM5357 ||
-+          bus->chipinfo.id == BCMA_CHIP_ID_BCM4749) {
-               /* Detect failure in clock setting */
-               tmp = bcma_cc_read32(cc, BCMA_CC_CHIPSTAT);
-               if (tmp & 0x40000)
-@@ -240,60 +365,96 @@ static u32 bcma_pmu_clock(struct bcma_dr
-       ndiv = (tmp & BCMA_CC_PPL_NDIV_MASK) >> BCMA_CC_PPL_NDIV_SHIFT;
-       /* Do calculation in Mhz */
--      fc = bcma_pmu_alp_clock(cc) / 1000000;
-+      fc = bcma_pmu_get_alp_clock(cc) / 1000000;
-       fc = (p1 * ndiv * fc) / p2;
-       /* Return clock in Hertz */
-       return (fc / div) * 1000000;
- }
-+static u32 bcma_pmu_pll_clock_bcm4706(struct bcma_drv_cc *cc, u32 pll0, u32 m)
-+{
-+      u32 tmp, ndiv, p1div, p2div;
-+      u32 clock;
-+
-+      BUG_ON(!m || m > 4);
-+
-+      /* Get N, P1 and P2 dividers to determine CPU clock */
-+      tmp = bcma_chipco_pll_read(cc, pll0 + BCMA_CC_PMU6_4706_PROCPLL_OFF);
-+      ndiv = (tmp & BCMA_CC_PMU6_4706_PROC_NDIV_INT_MASK)
-+              >> BCMA_CC_PMU6_4706_PROC_NDIV_INT_SHIFT;
-+      p1div = (tmp & BCMA_CC_PMU6_4706_PROC_P1DIV_MASK)
-+              >> BCMA_CC_PMU6_4706_PROC_P1DIV_SHIFT;
-+      p2div = (tmp & BCMA_CC_PMU6_4706_PROC_P2DIV_MASK)
-+              >> BCMA_CC_PMU6_4706_PROC_P2DIV_SHIFT;
-+
-+      tmp = bcma_cc_read32(cc, BCMA_CC_CHIPSTAT);
-+      if (tmp & BCMA_CC_CHIPST_4706_PKG_OPTION)
-+              /* Low cost bonding: Fixed reference clock 25MHz and m = 4 */
-+              clock = (25000000 / 4) * ndiv * p2div / p1div;
-+      else
-+              /* Fixed reference clock 25MHz and m = 2 */
-+              clock = (25000000 / 2) * ndiv * p2div / p1div;
-+
-+      if (m == BCMA_CC_PMU5_MAINPLL