Tarball MediaTek_ApSoC_SDK_4300_20140916.tar.bz2, assuming this obsoletes MTK_Ralink_ApSoC_SDK_4210_20140326.tar.bz2, yes?
Unload MTK SDK tarball, install relevant toolchains under /opt:
In config/mkconfig (line 107), change:
echo "elif [ \$CONFIG_DEFAULTS_RALINK_MT7620 = \"y\" ]; then" echo " define_bool CONFIG_DEFAULTS_KERNEL_2_6_36 y" echo " define_bool CONFIG_DEFAULTS_KERNEL_3_10_14 n"
to:
echo "elif [ \$CONFIG_DEFAULTS_RALINK_MT7620 = \"y\" ]; then" echo " define_bool CONFIG_DEFAULTS_KERNEL_2_6_36 n" echo " define_bool CONFIG_DEFAULTS_KERNEL_3_10_14 y"
Build errors of the form:
Makefile:376: *** mixed implicit and normal rules. Stop.
are explained here, so you have to adjust a number of Makefiles to work with the newest version of make. Just fix the errors as you run across them.
Start with trying to build a basic image with no WiFi support yet (and no OpenWrt support), make dep generates diagnostics:
ralink/Kconfig:206:warning: 'RT_FIRST_CARD': number is invalid ralink/Kconfig:207:warning: 'RT_FIRST_CARD': number is invalid ralink/Kconfig:208:warning: 'RT_FIRST_CARD': number is invalid ralink/Kconfig:221:warning: 'RT_SECOND_CARD': number is invalid ralink/Kconfig:222:warning: 'RT_SECOND_CARD': number is invalid ralink/Kconfig:223:warning: 'RT_SECOND_CARD': number is invalid ralink/Kconfig:224:warning: 'RT_SECOND_CARD': number is invalid
because of config entries that are defined as "int" but have some non-int values:
config RT_FIRST_CARD int depends on ! FIRST_IF_NONE default 2860 if FIRST_IF_RT2860 default 7620 if FIRST_IF_MT7620 default 7628 if FIRST_IF_MT7628 default 3090 if FIRST_IF_RT3092 default 5392 if FIRST_IF_RT5392 default 5592 if FIRST_IF_RT5592 default 3593 if FIRST_IF_RT3593 default 7610 if FIRST_IF_MT7610E default 7612e if FIRST_IF_MT7612E default 7602e if FIRST_IF_MT7602E default 7603e if FIRST_IF_MT7603E config RT_SECOND_CARD int depends on ! SECOND_IF_NONE default 3090 if SECOND_IF_RT3092 default 5392 if SECOND_IF_RT5392 default 5592 if SECOND_IF_RT5592 default 3593 if SECOND_IF_RT3593 default 7610 if SECOND_IF_MT7610E default 8592 if SECOND_IF_RT8592 default 3572 if SECOND_IF_RT3572 default 5572 if SECOND_IF_RT5572 default 7612e if SECOND_IF_MT7612E default 7612u if SECOND_IF_MT7612U default 7602e if SECOND_IF_MT7602E default 7603e if SECOND_IF_MT7603E
Obviously, those config selections shouldn't be defined as "int"; MediaTek should fix that, but it doesn't affect us -- this produces a successful build.
If you now try to add "OpenWrt Support", you get the build error:
... snip ... make -C libnvram make[2]: Entering directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib/libnvram' make[2]: *** No rule to make target '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/kernel_headers/include/linux/autoconf.h', needed by 'crc32.o'. Stop. make[2]: Leaving directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib/libnvram' Makefile:369: recipe for target '_dir_libnvram' failed make[1]: *** [_dir_libnvram] Error 2 make[1]: Leaving directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib' Makefile:493: recipe for target 'lib_only' failed make: *** [lib_only] Error 2
This seems odd since if you *don't* select "Support OpenWrt", that library appears to build just fine, so there's something in the selection of OpenWrt support that clearly changes the build environment.
Here's a snippet of the Makefile from that directory:
ifneq ($(KERNEL_HEADERS),) LINUXDIR = $(KERNEL_HEADERS) endif ... snip ... OBJS := crc32.o nvram_env.o flash_api.o HEADERS := nvram_env.h nvram.h flash_api.h $(ROOTDIR)/$(LINUXDIR)/include/linux/autoconf.h
so an early setting of KERNEL_HEADERS can certainly screw things up.
From a completely fresh checkout of the SDK, we have this:
$ find . -name autoconf.h ./linux-3.10.14.x/include/generated/autoconf.h <--- ???? ./lib/libgdbm-1.8.3/autoconf.h ./lib/vstr-1.0.15/include/autoconf.h $
Do a non-OpenWrt configure and build for MT7620A, and it all works (libnvram directory is compiled), and:
$ find . -name autoconf.h ./linux-3.10.14.x/include/linux/autoconf.h ./linux-3.10.14.x/include/uapi/linux/autoconf.h ./linux-3.10.14.x/include/generated/autoconf.h ./config/autoconf.h ./lib/libgdbm-1.8.3/autoconf.h ./lib/vstr-1.0.15/include/autoconf.h ./kernel_headers/include/linux/autoconf.h ./autoconf.h ./user/busybox/include/autoconf.h $
After make clean:
$ find . -name autoconf.h ./linux-3.10.14.x/include/linux/autoconf.h ./linux-3.10.14.x/include/uapi/linux/autoconf.h ./linux-3.10.14.x/include/generated/autoconf.h ./config/autoconf.h ./lib/libgdbm-1.8.3/autoconf.h ./lib/vstr-1.0.15/include/autoconf.h ./autoconf.h ./user/busybox/include/autoconf.h $
After doing another make (which should change nothing):
$ find . -name autoconf.h ./linux-3.10.14.x/include/linux/autoconf.h ./linux-3.10.14.x/include/uapi/linux/autoconf.h ./linux-3.10.14.x/include/generated/autoconf.h ./config/autoconf.h ./lib/libgdbm-1.8.3/autoconf.h ./lib/vstr-1.0.15/include/autoconf.h ./kernel_headers/include/linux/autoconf.h ./autoconf.h ./user/busybox/include/autoconf.h $
One last time, make clean, add OpenWrt Support, save, and here's the kernel config file difference:
$ diff .config.old .config 5c5 < # CONFIG_SUPPORT_OPENWRT is not set --- > CONFIG_SUPPORT_OPENWRT=y 31a32 > # CONFIG_RT2880_ROOTFS_IN_FLASH is not set 42c43 < # CONFIG_BOOT_RAW is not set --- > CONFIG_BOOT_RAW=y 55d55 < CONFIG_BOOT_ELF32=y 604a605 > # CONFIG_MTD_SPLIT is not set $
Nothing jumps out at me, so try to build and get earlier error:
make -C libnvram make[2]: Entering directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib/libnvram' make[2]: *** No rule to make target '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/kernel_headers/include/linux/autoconf.h', needed by 'crc32.o'. Stop. make[2]: Leaving directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib/libnvram' Makefile:369: recipe for target '_dir_libnvram' failed make[1]: *** [_dir_libnvram] Error 2 make[1]: Leaving directory '/home/rpjday/flex/MTK_SDK/SDK/RT288x_SDK/source/lib' Makefile:493: recipe for target 'lib_only' failed make: *** [lib_only] Error 2
because this:
$ find . -name autoconf.h ./linux-3.10.14.x/include/linux/autoconf.h ./linux-3.10.14.x/include/uapi/linux/autoconf.h ./linux-3.10.14.x/include/generated/autoconf.h ./config/autoconf.h ./lib/libgdbm-1.8.3/autoconf.h ./lib/vstr-1.0.15/include/autoconf.h ./autoconf.h ./user/busybox/include/autoconf.h $
In short, asking for OpenWrt support prevents autoconf.h from being placed in the kernel_headers directory. Oh, wait, here it is in the kernel source file include/uapi/linux/Kbuild:
ifndef CONFIG_SUPPORT_OPENWRT header-y += autoconf.h endif
What's the reason for that?
Under vendors/Ralink/MT7620/config/:
$ grep KERNEL_HEADERS * 2M_16M_config.uclibc0933-3.10.14.x:KERNEL_HEADERS="$(ROOTDIR)/kernel_headers/include" 2M_16M_config.uclibc-3.10.14.x:KERNEL_SOURCE="$(ROOTDIR)/$(KERNEL_HEADERS)" 4M_32M_config.uclibc0933-2.6.36.x:KERNEL_HEADERS="$(ROOTDIR)/$(LINUXDIR)/include" 4M_32M_config.uclibc0933-3.10.14.x:KERNEL_HEADERS="$(ROOTDIR)/kernel_headers/include" 4M_32M_config.uclibc-3.10.14.x:KERNEL_SOURCE="$(ROOTDIR)/$(KERNEL_HEADERS)" 8M_32M_voip_config.uclibc0933-2.6.36.x:KERNEL_HEADERS="$(ROOTDIR)/$(LINUXDIR)/include" 8M_32M_voip_config.uclibc0933-3.10.14.x:KERNEL_HEADERS="$(ROOTDIR)/kernel_headers/include" 8M_32M_voip_config.uclibc-3.10.14.x:KERNEL_SOURCE="$(ROOTDIR)/$(KERNEL_HEADERS)" 8M_64M_config.uclibc0933-3.10.14.x:KERNEL_HEADERS="$(ROOTDIR)/kernel_headers/include" 8M_64M_config.uclibc-3.10.14.x:KERNEL_SOURCE="$(ROOTDIR)/$(KERNEL_HEADERS)" $
But under a 3.10 kernel, an external kernel headers seems unnecessary since all exported headers will be under include/uapi/ and various other uapi/ directories.
For now, cheap fix for include/uapi/linux/Kbuild:
# ifndef CONFIG_SUPPORT_OPENWRT header-y += autoconf.h # endif
but why was this done in the first place? (Need to clean and rebuild to take effect.)
In MTK SDK, extra line at end of arch/mips/Kconfig:
source "ralink/Kconfig"
As for ralink/Kconfig (the only file in the top-level ralink directory), here are the source directives:
source "drivers/net/rt_rdm/Kconfig" source "drivers/net/raeth/Kconfig" #source "drivers/net/wireless/rt2860v2_ap/Kconfig" #source "drivers/net/wireless/rt2860v2_sta/Kconfig" #source "drivers/net/wireless/RTPCI_ap/Kconfig" #source "drivers/net/wireless/RT3090_ap/Kconfig" #source "drivers/net/wireless/RT5392_ap/Kconfig" #source "drivers/net/wireless/RT5592_ap/Kconfig" #source "drivers/net/wireless/RT3593_ap/Kconfig" #source "drivers/net/wireless/RT3572_ap/Kconfig" #source "drivers/net/wireless/RT5572_ap/Kconfig" #source "drivers/net/wireless/iNIC/Kconfig" #source "drivers/net/wireless/iNIC_RT305x/Kconfig" #source "drivers/net/wireless/RT3680_ap/Kconfig" #source "drivers/net/wireless/MT7610_ap/Kconfig" #source "drivers/net/wireless/rlt_wifi/Kconfig" source "drivers/usb/dwc_otg/Kconfig" source "net/nat/hw_nat/Kconfig"
Here's the first mystery -- which selection for onboard 2.4G?
############# # Wireless ############# menuconfig WIFI_DRIVER bool "WiFi Driver Support" if WIFI_DRIVER choice prompt "Choose First WiFi Interface" config FIRST_IF_NONE bool "None" config FIRST_IF_RT2860 bool "RT2860 for rt2860v2 wifi driver" select RTMP_MAC select RALINK_RT2860 config FIRST_IF_MT7620 bool "MT7620 for rlt_wifi wifi driver" <--- typo, "rtl_wifi", no? select RTMP_MAC select RALINK_RT6352
It looks like we want the second one -- "RT6352" is apparently the CPU type. But that config symbol doesn't appear to be tested anywhere in the newer kernels:
grep -r RT6352 * linux-2.6.21.x/include/asm-mips/rt2880/eureka_ep430.h:#elif defined(CONFIG_RALINK_RT6855) || defined (CONFIG_RALINK_RT6352) linux-2.6.21.x/include/asm-mips/rt2880/surfboardint.h:#elif defined (CONFIG_RALINK_RT3052) || defined (CONFIG_RALINK_RT3352) || defined (CONFIG_RALINK_RT2883) || defined (CONFIG_RALINK_RT5350) || defined (CONFIG_RALINK_RT6855) || defined (CONFIG_RALINK_RT6352) linux-2.6.21.x/include/asm-mips/rt2880/rt_mmap.h:#elif defined (CONFIG_RALINK_RT6855) || defined (CONFIG_RALINK_RT6352) linux-2.6.36.x/ralink/Kconfig: select RALINK_RT6352 linux-2.6.36.x/ralink/Kconfig: select RALINK_RT6352 linux-3.10.14.x/ralink/Kconfig: select RALINK_RT6352 linux-3.10.14.x/ralink/Kconfig: select RALINK_RT6352 vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.MT7612-efuse-txbf:# CONFIG_RALINK_RT6352 is not set vendors/Ralink/MT7621/config/8M_64M_config.linux-2.6.36.x:# CONFIG_RALINK_RT6352 is not set vendors/Ralink/MT7621/config/128M_128M_config.linux-2.6.36.x:# CONFIG_RALINK_RT6352 is not set vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.MT7612-efuse:# CONFIG_RALINK_RT6352 is not set vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.txbf:# CONFIG_RALINK_RT6352 is not set vendors/Ralink/MT7620/config/2M_16M_config.linux-2.6.36.x:CONFIG_RALINK_RT6352=y vendors/Ralink/MT7620/config/8M_64M_config.linux-2.6.36.x:CONFIG_RALINK_RT6352=y vendors/Ralink/MT7620/config/4M_32M_config.linux-2.6.36.x:CONFIG_RALINK_RT6352=y vendors/Ralink/MT7620/config/8M_64M_config.linux-2.6.36.x.MT7530:CONFIG_RALINK_RT6352=y $
Looking for RALINK_RT2860 is even worse:
$ grep -r RALINK_RT2860 * linux-2.6.36.x/ralink/Kconfig: select RALINK_RT2860 linux-3.10.14.x/ralink/Kconfig: select RALINK_RT2860 $
And this, too:
linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC linux-3.10.14.x/ralink/Kconfig: select RTMP_MAC vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.MT7612-efuse-txbf:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7621/config/8M_64M_config.linux-2.6.36.x:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7621/config/128M_128M_config.linux-2.6.36.x:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.MT7612-efuse:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7621/config/8M_16M_config.linux-2.6.36.x.txbf:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7628/config/8M_64M_config.linux-2.6.36.x:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7628/config/4M_32M_config.linux-2.6.36.x:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7628/config/2M_8M_config.linux-2.6.36.x:# CONFIG_RTMP_MAC is not set vendors/Ralink/MT7620/config/2M_16M_config.linux-2.6.36.x:CONFIG_RTMP_MAC=y vendors/Ralink/MT7620/config/8M_64M_config.linux-2.6.36.x:CONFIG_RTMP_MAC=y vendors/Ralink/MT7620/config/4M_32M_config.linux-2.6.36.x:CONFIG_RTMP_MAC=y vendors/Ralink/MT7620/config/8M_64M_config.linux-2.6.36.x.MT7530:CONFIG_RTMP_MAC=y
but lots of checking under 2.6.36 kernel under drivers/staging/rt2860.
from http://www.crashcourse.ca/wiki/index.php/OpenWrt_MTK_SDK