From a1ed5b4a62d3f60215dd776143f415f3ca90e26f Mon Sep 17 00:00:00 2001 From: John Crispin Date: Tue, 6 Nov 2012 07:38:18 +0000 Subject: [PATCH] [lantiq] prepare dsl driver for 3.6 and split fw into a seperate package SVN-Revision: 34096 --- package/system/ltq-dsl-fw/Makefile | 53 ++++++++++++++ package/system/ltq-dsl/Makefile | 72 +++---------------- package/system/ltq-dsl/src/Makefile | 2 + .../ltq-dsl/src/ifxmips_atm_ppe_danube.h | 1 + package/system/ltq-dsl/src/lantiq_mei.c | 8 +++ 5 files changed, 72 insertions(+), 64 deletions(-) create mode 100644 package/system/ltq-dsl-fw/Makefile diff --git a/package/system/ltq-dsl-fw/Makefile b/package/system/ltq-dsl-fw/Makefile new file mode 100644 index 0000000000..8a8b33f478 --- /dev/null +++ b/package/system/ltq-dsl-fw/Makefile @@ -0,0 +1,53 @@ +# +# Copyright (C) 2011 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# + +include $(TOPDIR)/rules.mk + +PKG_NAME:=ltq-dsl-fw +PKG_VERSION:=0.1 +PKG_RELEASE:=1 + +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2 +PKG_SOURCE_URL:=http://mirror2.openwrt.org/sources/ +PKG_MD5SUM:=4700a36b66b955b4c5544227267356f4 +PKG_MAINTAINER:=John Crispin + +include $(INCLUDE_DIR)/package.mk + +define Package/kmod-ltq-dsl-firmware-template + TITLE+=Firmware Annex-$(1) $(2) + SECTION:=sys + CATEGORY:=Kernel modules + SUBMENU:=Network Devices + VARIANT:= $(1)-$(2) + URL:=http://www.lantiq.com/ + DEPENDS:=@(TARGET_lantiq_xway|| kmod-ltq-dsl-$(2) +endef + +Package/kmod-ltq-dsl-firmware-a-danube=$(call Package/kmod-ltq-dsl-firmware-template,a,danube,xway) +Package/kmod-ltq-dsl-firmware-b-danube=$(call Package/kmod-ltq-dsl-firmware-template,b,danube,xway) +Package/kmod-ltq-dsl-firmware-a-ar9=$(call Package/kmod-ltq-dsl-firmware-template,a,ar9,xway) +Package/kmod-ltq-dsl-firmware-b-ar9=$(call Package/kmod-ltq-dsl-firmware-template,b,ar9,xway) +Package/kmod-ltq-dsl-firmware-a-ase=$(call Package/kmod-ltq-dsl-firmware-template,a,ase,ase) +Package/kmod-ltq-dsl-firmware-b-ase=$(call Package/kmod-ltq-dsl-firmware-template,b,ase,ase) + +define Build/Compile + echo +endef + +define Package/kmod-ltq-dsl-firmware-$(BUILD_VARIANT)/install + $(INSTALL_DIR) $(1)/lib/firmware/ + $(CP) $(PKG_BUILD_DIR)/$(FW_NAME)/ltq-dsl-fw-$(BUILD_VARIANT).bin $(1)/lib/firmware/ + ln -s /lib/firmware/$(FW_NAME)/ltq-dsl-fw-$(BUILD_VARIANT).bin $(1)/lib/firmware/ModemHWE.bin +endef + +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-danube)) +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-danube)) +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-ase)) +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-ase)) +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-ar9)) +$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-ar9)) diff --git a/package/system/ltq-dsl/Makefile b/package/system/ltq-dsl/Makefile index 1fb003a908..aa8106aeae 100644 --- a/package/system/ltq-dsl/Makefile +++ b/package/system/ltq-dsl/Makefile @@ -9,27 +9,16 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/kernel.mk PKG_NAME:=ltq-dsl -PKG_BASE_NAME:=drv_dsl_cpe_api_danube PKG_VERSION:=3.24.4.4 -PKG_RELEASE:=3 -PKG_SOURCE:=$(PKG_BASE_NAME)-$(PKG_VERSION).tar.gz -PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/drv_dsl_cpe_api-$(PKG_VERSION) +PKG_RELEASE:=4 +PKG_SOURCE:=drv_dsl_cpe_api_danube-$(PKG_VERSION).tar.gz +PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/ltq-dsl-$(BUILD_VARIANT)/drv_dsl_cpe_api-$(PKG_VERSION) PKG_SOURCE_URL:=http://mirror2.openwrt.org/sources/ PKG_MD5SUM:=c45bc531c1ed2ac80f68fb986b63bb87 PKG_MAINTAINER:=John Crispin -FW_NAME:=ltq-dsl-fw-0.1 -FW_MD5:=4700a36b66b955b4c5544227267356f4 - include $(INCLUDE_DIR)/package.mk -define Download/ltq-dsl-fw - FILE:=$(FW_NAME).tar.bz2 - MD5SUM:=$(FW_MD5) - URL:=http://mirror2.openwrt.org/sources/ -endef -$(eval $(call Download,ltq-dsl-fw)) - define KernelPackage/ltq-dsl-template SECTION:=sys CATEGORY:=Kernel modules @@ -37,40 +26,16 @@ define KernelPackage/ltq-dsl-template TITLE:=Lantiq dsl driver for $(1) URL:=http://www.lantiq.com/ VARIANT:=$(1) - DEPENDS:=@TARGET_lantiq_$(1) +kmod-atm + DEPENDS:=@(TARGET_lantiq_$(1)||TARGET_lantiq_$(2)) +kmod-atm FILES:=$(PKG_BUILD_DIR)/src/mei/lantiq_mei.ko \ $(PKG_BUILD_DIR)/src/drv_dsl_cpe_api.ko \ $(PKG_BUILD_DIR)/src/mei/lantiq_atm.ko AUTOLOAD:=$(call AutoLoad,50,lantiq_mei drv_dsl_cpe_api lantiq_atm) endef -KernelPackage/ltq-dsl-danube=$(call KernelPackage/ltq-dsl-template,danube) -KernelPackage/ltq-dsl-ase=$(call KernelPackage/ltq-dsl-template,ase) -KernelPackage/ltq-dsl-ar9=$(call KernelPackage/ltq-dsl-template,ar9) -KernelPackage/ltq-dsl-vr9=$(call KernelPackage/ltq-dsl-template,vr9) - -define Package/kmod-ltq-dsl-firmware-template - TITLE+=Firmware Annex-$(1) $(2) - SECTION:=sys - CATEGORY:=Kernel modules - SUBMENU:=Network Devices - VARIANT:= $(1)-$(2) - URL:=http://www.lantiq.com/ - DEPENDS:=@TARGET_lantiq_$(2) kmod-ltq-dsl-$(2) -endef - -Package/kmod-ltq-dsl-firmware-a-danube=$(call Package/kmod-ltq-dsl-firmware-template,a,danube) -Package/kmod-ltq-dsl-firmware-b-danube=$(call Package/kmod-ltq-dsl-firmware-template,b,danube) -Package/kmod-ltq-dsl-firmware-a-ase=$(call Package/kmod-ltq-dsl-firmware-template,a,ase) -Package/kmod-ltq-dsl-firmware-b-ase=$(call Package/kmod-ltq-dsl-firmware-template,b,ase) -Package/kmod-ltq-dsl-firmware-a-ar9=$(call Package/kmod-ltq-dsl-firmware-template,a,ar9) -Package/kmod-ltq-dsl-firmware-b-ar9=$(call Package/kmod-ltq-dsl-firmware-template,b,ar9) -Package/kmod-ltq-dsl-firmware-a-vr9=$(call Package/kmod-ltq-dsl-firmware-template,a,vr9) -Package/kmod-ltq-dsl-firmware-b-vr9=$(call Package/kmod-ltq-dsl-firmware-template,b,vr9) - -define KernelPackage/ltq-dsl/description - Lantiq DSL driver for AR9, Amazon SE, Danube and VR9 -endef +KernelPackage/ltq-dsl-danube=$(call KernelPackage/ltq-dsl-template,danube,xway) +KernelPackage/ltq-dsl-ar9=$(call KernelPackage/ltq-dsl-template,ar9,xway) +KernelPackage/ltq-dsl-ase=$(call KernelPackage/ltq-dsl-template,ase,ase) define KernelPackage/ltq-dsl/config source "$(SOURCE)/Config.in" @@ -105,14 +70,9 @@ CONFIGURE_ARGS += --enable-kernel-include="$(LINUX_DIR)/include" \ CONFIG_TAG_danube:=DANUBE CONFIG_TAG_ase:=AMAZON_SE CONFIG_TAG_ar9:=AR9 -CONFIG_TAG_vr9:=VR9 CONFIGURE_ARGS += --enable-add-drv-cflags="-DMODULE -DCONFIG_$(CONFIG_TAG_$(BUILD_VARIANT))" -ifeq ($(BUILD_VARIANT),vr9) -CONFIGURE_ARGS += --enable-vinax -else CONFIGURE_ARGS += --enable-danube -endif ifeq ($(CONFIG_LANTIQ_DSL_DEBUG),y) CONFIGURE_ARGS += \ @@ -125,10 +85,9 @@ EXTRA_CFLAGS = -fno-pic -mno-abicalls -mlong-calls -G 0 define Build/Prepare $(PKG_UNPACK) + $(Build/Patch) $(INSTALL_DIR) $(PKG_BUILD_DIR)/src/mei/ $(CP) ./src/* $(PKG_BUILD_DIR)/src/mei/ - $(Build/Patch) - $(TAR) -C $(PKG_BUILD_DIR) -xjf $(DL_DIR)/$(FW_NAME).tar.bz2 endef define Build/Configure @@ -157,21 +116,6 @@ define Build/InstallDev $(CP) $(PKG_BUILD_DIR)/src/include/drv_dsl_cpe_cmv_danube.h $(1)/usr/include endef -define Package/kmod-ltq-dsl-firmware-$(BUILD_VARIANT)/install - $(INSTALL_DIR) $(1)/lib/firmware/ - $(CP) $(PKG_BUILD_DIR)/$(FW_NAME)/ltq-dsl-fw-$(BUILD_VARIANT).bin $(1)/lib/firmware/dsl-fw-$(word 1, $(subst -, ,$(BUILD_VARIANT))).bin - ln -s /lib/firmware/dsl-fw-$(word 1, $(subst -, ,$(BUILD_VARIANT))).bin $(1)/lib/firmware/ModemHWE.bin -endef - -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-danube)) -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-danube)) -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-ase)) -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-ase)) -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-ar9)) -$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-ar9)) -#$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-a-vr9)) -#$(eval $(call BuildPackage,kmod-ltq-dsl-firmware-b-vr9)) $(eval $(call KernelPackage,ltq-dsl-danube)) $(eval $(call KernelPackage,ltq-dsl-ase)) $(eval $(call KernelPackage,ltq-dsl-ar9)) -#$(eval $(call KernelPackage,ltq-dsl-vr9)) diff --git a/package/system/ltq-dsl/src/Makefile b/package/system/ltq-dsl/src/Makefile index 44d2efbc05..691518a74e 100644 --- a/package/system/ltq-dsl/src/Makefile +++ b/package/system/ltq-dsl/src/Makefile @@ -1,6 +1,8 @@ obj-m = lantiq_mei.o lantiq_atm.o lantiq_atm-objs := ifxmips_atm_core.o +CFLAGS_MODULE+=-DSOC_TYPE_XWAY +EXTRA_CFLAGS+=-DSOC_TYPE_XWAY ifeq ($(BUILD_VARIANT),danube) CFLAGS_MODULE+=-DCONFIG_DANUBE EXTRA_CFLAGS+=-DCONFIG_DANUBE diff --git a/package/system/ltq-dsl/src/ifxmips_atm_ppe_danube.h b/package/system/ltq-dsl/src/ifxmips_atm_ppe_danube.h index 7e46cc1838..58db3a7460 100644 --- a/package/system/ltq-dsl/src/ifxmips_atm_ppe_danube.h +++ b/package/system/ltq-dsl/src/ifxmips_atm_ppe_danube.h @@ -122,6 +122,7 @@ /* * Mailbox IGU1 Interrupt */ +#define LTQ_PPE_MBOX_INT (INT_NUM_IM2_IRL0 + 24) #define PPE_MAILBOX_IGU1_INT LTQ_PPE_MBOX_INT diff --git a/package/system/ltq-dsl/src/lantiq_mei.c b/package/system/ltq-dsl/src/lantiq_mei.c index aadb098c6d..00ac90289b 100644 --- a/package/system/ltq-dsl/src/lantiq_mei.c +++ b/package/system/ltq-dsl/src/lantiq_mei.c @@ -81,6 +81,14 @@ #define ltq_w32_mask(clear, set, reg) ltq_w32((ltq_r32(reg) & ~clear) | set, reg) */ +#define LTQ_RCU_BASE_ADDR 0x1F203000 +#define LTQ_ICU_BASE_ADDR 0x1F880200 +#define LTQ_MEI_BASE_ADDR 0x1E116000 +#define LTQ_PMU_BASE_ADDR 0x1F102000 +#define LTQ_MEI_DYING_GASP_INT (INT_NUM_IM1_IRL0 + 21) +#define LTQ_USB_OC_INT (INT_NUM_IM4_IRL0 + 23) +#define LTQ_MEI_INT (INT_NUM_IM1_IRL0 + 23) + #define LTQ_RCU_RST_REQ_DFE (1 << 7) #define LTQ_RCU_RST_REQ_AFE (1 << 11) -- 2.30.2