From 9fd0b05b294a0b247a9ec3b2001b074297c7b16c Mon Sep 17 00:00:00 2001 From: Florian Fainelli Date: Mon, 26 Jun 2006 11:45:23 +0000 Subject: [PATCH] Merge premilinary Broadcom 63xx support (Livebox, Siemens SE515...) Kernel compiles fine, does not include linux-2.6.8.1 linux-mips specific fixes and neither includes broadcom changes to netfiler Needs testing of course :) SVN-Revision: 4084 --- openwrt/target/Config.in | 10 + openwrt/target/image/brcm63xx/Makefile | 27 + openwrt/target/linux/au1000-2.6/config | 105 +- openwrt/target/linux/brcm63xx-2.6/Makefile | 18 + openwrt/target/linux/brcm63xx-2.6/config | 988 + .../linux/brcm63xx-2.6/files/built-in.o | Bin 0 -> 279454 bytes .../brcm63xx-2.6/patches/001-bcm963xx.patch | 48189 ++++++++++++++++ 7 files changed, 49318 insertions(+), 19 deletions(-) create mode 100644 openwrt/target/image/brcm63xx/Makefile create mode 100644 openwrt/target/linux/brcm63xx-2.6/Makefile create mode 100644 openwrt/target/linux/brcm63xx-2.6/config create mode 100644 openwrt/target/linux/brcm63xx-2.6/files/built-in.o create mode 100644 openwrt/target/linux/brcm63xx-2.6/patches/001-bcm963xx.patch diff --git a/openwrt/target/Config.in b/openwrt/target/Config.in index 47e62d41e6..8037a88c0b 100644 --- a/openwrt/target/Config.in +++ b/openwrt/target/Config.in @@ -43,6 +43,16 @@ config LINUX_2_6_BRCM Build firmware images for Broadcom based routers (e.g. Netgear WGT634u) +config LINUX_2_6_BRCM63XX + bool "Broadcom BCM63xx [2.6]" + select mips + select LINUX_2_6 + select PCI_SUPPORT + select PCMCIA_SUPPORT + help + Build firmware images for Broadcom based xDSL/routers + (e.g. Inventel Livebox, Siemens SE515) + config LINUX_2_6_RB532 bool "Mikrotik RB532 [2.6]" select mipsel diff --git a/openwrt/target/image/brcm63xx/Makefile b/openwrt/target/image/brcm63xx/Makefile new file mode 100644 index 0000000000..19799e88af --- /dev/null +++ b/openwrt/target/image/brcm63xx/Makefile @@ -0,0 +1,27 @@ +include $(TOPDIR)/rules.mk +include $(INCLUDE_DIR)/image.mk + +LOADADDR = 0x8108c8f4 # RAM start + 16M +KERNEL_ENTRY = 0x80100000 # Default kernel entry in arch/mips/Makefile +RAMSIZE = 0x01000000 # 64MB + +LOADER_MAKEOPTS= \ + KDIR=$(KDIR) \ + LOADADDR=$(LOADADDR) \ + KERNEL_ENTRY=$(KERNEL_ENTRY) \ + RAMSIZE=$(RAMSIZE) + +define Build/Clean + $(MAKE) -C ../generic/lzma-loader $(LOADER_MAKEOPTS) clean +endef + +define Image/Prepare + cat $(KDIR)/vmlinux | $(STAGING_DIR)/bin/lzma e -si -so -eos -lc1 -lp2 -pb2 > $(KDIR)/vmlinux.lzma + $(MAKE) -C ../generic/lzma-loader $(LOADER_MAKEOPTS) compile +endef + +define Image/Build + cp $(KDIR)/vmlinux $(BIN_DIR)/openwrt-$(BOARD)-$(KERNEL)-$(1).img +endef + +$(eval $(call BuildImage)) diff --git a/openwrt/target/linux/au1000-2.6/config b/openwrt/target/linux/au1000-2.6/config index 8a24bd557e..fbb0d7e96d 100644 --- a/openwrt/target/linux/au1000-2.6/config +++ b/openwrt/target/linux/au1000-2.6/config @@ -1,7 +1,7 @@ # # Automatically generated make config: don't edit # Linux kernel version: 2.6.17 -# Tue Jun 20 11:35:00 2006 +# Mon Jun 26 09:27:40 2006 # CONFIG_MIPS=y @@ -255,32 +255,39 @@ CONFIG_IP_FIB_HASH=y CONFIG_IP_MULTIPLE_TABLES=y CONFIG_IP_ROUTE_FWMARK=y CONFIG_IP_ROUTE_MULTIPATH=y -# CONFIG_IP_ROUTE_MULTIPATH_CACHED is not set +CONFIG_IP_ROUTE_MULTIPATH_CACHED=y +CONFIG_IP_ROUTE_MULTIPATH_RR=m +CONFIG_IP_ROUTE_MULTIPATH_RANDOM=m +CONFIG_IP_ROUTE_MULTIPATH_WRANDOM=m +CONFIG_IP_ROUTE_MULTIPATH_DRR=m CONFIG_IP_ROUTE_VERBOSE=y CONFIG_IP_PNP=y CONFIG_IP_PNP_DHCP=y -# CONFIG_IP_PNP_BOOTP is not set -# CONFIG_IP_PNP_RARP is not set +CONFIG_IP_PNP_BOOTP=y +CONFIG_IP_PNP_RARP=y CONFIG_NET_IPIP=m CONFIG_NET_IPGRE=m CONFIG_NET_IPGRE_BROADCAST=y -# CONFIG_IPSEC_NAT_TRAVERSAL is not set -# CONFIG_IP_MROUTE is not set -# CONFIG_ARPD is not set +CONFIG_IPSEC_NAT_TRAVERSAL=y +CONFIG_IP_MROUTE=y +CONFIG_IP_PIMSM_V1=y +CONFIG_IP_PIMSM_V2=y +CONFIG_ARPD=y CONFIG_SYN_COOKIES=y CONFIG_INET_AH=m CONFIG_INET_ESP=m CONFIG_INET_IPCOMP=m CONFIG_INET_XFRM_TUNNEL=m CONFIG_INET_TUNNEL=m -# CONFIG_INET_DIAG is not set +CONFIG_INET_DIAG=m +CONFIG_INET_TCP_DIAG=m CONFIG_TCP_CONG_ADVANCED=y # # TCP congestion control # CONFIG_TCP_CONG_BIC=y -# CONFIG_TCP_CONG_CUBIC is not set +CONFIG_TCP_CONG_CUBIC=m CONFIG_TCP_CONG_WESTWOOD=m CONFIG_TCP_CONG_HTCP=m CONFIG_TCP_CONG_HSTCP=m @@ -291,7 +298,36 @@ CONFIG_TCP_CONG_SCALABLE=m # # IP: Virtual Server Configuration # -# CONFIG_IP_VS is not set +CONFIG_IP_VS=m +# CONFIG_IP_VS_DEBUG is not set +CONFIG_IP_VS_TAB_BITS=12 + +# +# IPVS transport protocol load balancing support +# +CONFIG_IP_VS_PROTO_TCP=y +CONFIG_IP_VS_PROTO_UDP=y +CONFIG_IP_VS_PROTO_ESP=y +CONFIG_IP_VS_PROTO_AH=y + +# +# IPVS scheduler +# +CONFIG_IP_VS_RR=m +CONFIG_IP_VS_WRR=m +CONFIG_IP_VS_LC=m +CONFIG_IP_VS_WLC=m +CONFIG_IP_VS_LBLC=m +CONFIG_IP_VS_LBLCR=m +CONFIG_IP_VS_DH=m +CONFIG_IP_VS_SH=m +CONFIG_IP_VS_SED=m +CONFIG_IP_VS_NQ=m + +# +# IPVS application helper +# +CONFIG_IP_VS_FTP=m CONFIG_IPV6=m CONFIG_IPV6_PRIVACY=y CONFIG_IPV6_ROUTER_PREF=y @@ -314,10 +350,10 @@ CONFIG_NETFILTER_NETLINK_QUEUE=m CONFIG_NETFILTER_NETLINK_LOG=m CONFIG_NETFILTER_XTABLES=m CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m -# CONFIG_NETFILTER_XT_TARGET_CONNMARK is not set +CONFIG_NETFILTER_XT_TARGET_CONNMARK=m CONFIG_NETFILTER_XT_TARGET_MARK=m CONFIG_NETFILTER_XT_TARGET_NFQUEUE=m -# CONFIG_NETFILTER_XT_TARGET_NOTRACK is not set +CONFIG_NETFILTER_XT_TARGET_NOTRACK=m CONFIG_NETFILTER_XT_MATCH_COMMENT=m CONFIG_NETFILTER_XT_MATCH_CONNBYTES=m CONFIG_NETFILTER_XT_MATCH_CONNMARK=m @@ -418,7 +454,22 @@ CONFIG_IP_NF_TARGET_SET=m # IPv6: Netfilter Configuration (EXPERIMENTAL) # CONFIG_IP6_NF_QUEUE=m -# CONFIG_IP6_NF_IPTABLES is not set +CONFIG_IP6_NF_IPTABLES=m +CONFIG_IP6_NF_MATCH_RT=m +CONFIG_IP6_NF_MATCH_OPTS=m +CONFIG_IP6_NF_MATCH_FRAG=m +CONFIG_IP6_NF_MATCH_HL=m +CONFIG_IP6_NF_MATCH_OWNER=m +CONFIG_IP6_NF_MATCH_IPV6HEADER=m +CONFIG_IP6_NF_MATCH_AH=m +CONFIG_IP6_NF_MATCH_EUI64=m +CONFIG_IP6_NF_FILTER=m +CONFIG_IP6_NF_TARGET_IMQ=m +CONFIG_IP6_NF_TARGET_LOG=m +CONFIG_IP6_NF_TARGET_REJECT=m +CONFIG_IP6_NF_MANGLE=m +CONFIG_IP6_NF_TARGET_HL=m +CONFIG_IP6_NF_RAW=m # # Bridge: Netfilter Configuration @@ -447,17 +498,33 @@ CONFIG_BRIDGE_EBT_ULOG=m # # DCCP Configuration (EXPERIMENTAL) # -# CONFIG_IP_DCCP is not set +CONFIG_IP_DCCP=m +CONFIG_INET_DCCP_DIAG=m +CONFIG_IP_DCCP_ACKVEC=y + +# +# DCCP CCIDs Configuration (EXPERIMENTAL) +# +CONFIG_IP_DCCP_CCID2=m +CONFIG_IP_DCCP_CCID3=m +CONFIG_IP_DCCP_TFRC_LIB=m # # SCTP Configuration (EXPERIMENTAL) # -# CONFIG_IP_SCTP is not set +CONFIG_IP_SCTP=m +# CONFIG_SCTP_DBG_MSG is not set +# CONFIG_SCTP_DBG_OBJCNT is not set +# CONFIG_SCTP_HMAC_NONE is not set +# CONFIG_SCTP_HMAC_SHA1 is not set +CONFIG_SCTP_HMAC_MD5=y # # TIPC Configuration (EXPERIMENTAL) # -# CONFIG_TIPC is not set +CONFIG_TIPC=m +# CONFIG_TIPC_ADVANCED is not set +# CONFIG_TIPC_DEBUG is not set # CONFIG_ATM is not set CONFIG_BRIDGE=m CONFIG_VLAN_8021Q=m @@ -489,7 +556,7 @@ CONFIG_NET_SCH_HFSC=m CONFIG_NET_SCH_PRIO=m CONFIG_NET_SCH_RED=m CONFIG_NET_SCH_SFQ=m -# CONFIG_NET_SCH_ESFQ is not set +CONFIG_NET_SCH_ESFQ=m CONFIG_NET_SCH_TEQL=m CONFIG_NET_SCH_TBF=m CONFIG_NET_SCH_GRED=m @@ -523,10 +590,10 @@ CONFIG_NET_ACT_POLICE=m CONFIG_NET_ACT_GACT=m CONFIG_GACT_PROB=y CONFIG_NET_ACT_MIRRED=m -# CONFIG_NET_ACT_IPT is not set +CONFIG_NET_ACT_IPT=m CONFIG_NET_ACT_PEDIT=m CONFIG_NET_ACT_SIMP=m -# CONFIG_NET_CLS_IND is not set +CONFIG_NET_CLS_IND=y CONFIG_NET_ESTIMATOR=y # diff --git a/openwrt/target/linux/brcm63xx-2.6/Makefile b/openwrt/target/linux/brcm63xx-2.6/Makefile new file mode 100644 index 0000000000..a48442a69f --- /dev/null +++ b/openwrt/target/linux/brcm63xx-2.6/Makefile @@ -0,0 +1,18 @@ +include $(TOPDIR)/rules.mk + +LINUX_VERSION:=2.6.8.1 +LINUX_RELEASE:=1 +LINUX_KERNEL_MD5SUM:=9517ca999e822b898fbdc7e72796b1aa + +include ./config +include $(INCLUDE_DIR)/kernel.mk +include $(INCLUDE_DIR)/kernel-build.mk + + +$(LINUX_DIR)/.patched: $(LINUX_DIR)/.unpacked + #[ -d ../generic-$(KERNEL)/patches ] && $(PATCH) $(LINUX_DIR) ../generic-$(KERNEL)/patches $(MAKE_TRACE) + [ -d ./patches ] && $(PATCH) $(LINUX_DIR) ./patches $(MAKE_TRACE) + @$(CP) config $(LINUX_DIR)/.config + @$(CP) ./files/built-in.o $(LINUX_DIR)/bcmdrivers/broadcom/ + touch $@ + diff --git a/openwrt/target/linux/brcm63xx-2.6/config b/openwrt/target/linux/brcm63xx-2.6/config new file mode 100644 index 0000000000..f774cfc276 --- /dev/null +++ b/openwrt/target/linux/brcm63xx-2.6/config @@ -0,0 +1,988 @@ +# +# Automatically generated make config: don't edit +# +CONFIG_MIPS=y +# CONFIG_MIPS64 is not set +# CONFIG_64BIT is not set +CONFIG_MIPS32=y + +# +# Code maturity level options +# +CONFIG_EXPERIMENTAL=y +CONFIG_CLEAN_COMPILE=y +CONFIG_BROKEN_ON_SMP=y + +# +# General setup +# +# CONFIG_SWAP is not set +CONFIG_SYSVIPC=y +# CONFIG_POSIX_MQUEUE is not set +# CONFIG_BSD_PROCESS_ACCT is not set +CONFIG_SYSCTL=y +# CONFIG_AUDIT is not set +CONFIG_LOG_BUF_SHIFT=14 +CONFIG_HOTPLUG=y +# CONFIG_IKCONFIG is not set +CONFIG_EMBEDDED=y +CONFIG_KALLSYMS=y +# CONFIG_KALLSYMS_ALL is not set +# CONFIG_KALLSYMS_EXTRA_PASS is not set +# CONFIG_FUTEX is not set +# CONFIG_EPOLL is not set +CONFIG_IOSCHED_NOOP=y +CONFIG_IOSCHED_AS=y +CONFIG_IOSCHED_DEADLINE=y +CONFIG_IOSCHED_CFQ=y +CONFIG_CC_OPTIMIZE_FOR_SIZE=y + +# +# Loadable module support +# +CONFIG_MODULES=y +CONFIG_MODULE_UNLOAD=y +CONFIG_MODULE_FORCE_UNLOAD=y +CONFIG_OBSOLETE_MODPARM=y +# CONFIG_MODVERSIONS is not set +CONFIG_KMOD=y + +# +# Machine selection +# +CONFIG_MIPS_BRCM=y +# CONFIG_BCM96338 is not set +# CONFIG_BCM96345 is not set +CONFIG_BCM96348=y +CONFIG_BCM_BOARD=y +CONFIG_BCM_SERIAL=y +CONFIG_BCM_ENET=y +CONFIG_BCM_USB=m +CONFIG_BCM_WLAN=m +CONFIG_BCM_PCI=y +CONFIG_BCM_ATMAPI=y +CONFIG_BCM_ATMTEST=m +CONFIG_BCM_ADSL=y +CONFIG_BCM_ENDPOINT=m +CONFIG_BCM_PROCFS=m +CONFIG_BCM_VDSL=m +CONFIG_BCM_SECURITY=m +CONFIG_BCM_HPNA=m +CONFIG_BCM_BOARD_IMPL=1 +CONFIG_BCM_SERIAL_IMPL=1 +CONFIG_BCM_ENET_IMPL=2 +CONFIG_BCM_USB_IMPL=2 +CONFIG_BCM_WLAN_IMPL=1 +CONFIG_BCM_ATMAPI_IMPL=1 +CONFIG_BCM_ATMTEST_IMPL=1 +CONFIG_BCM_BLAA_IMPL=1 +CONFIG_BCM_ADSL_IMPL=1 +CONFIG_BCM_ENDPOINT_IMPL=1 +CONFIG_BCM_PROCFS_IMPL=1 +CONFIG_BCM_VDSL_IMPL=1 +CONFIG_BCM_SECURITY_IMPL=1 +CONFIG_BCM_HPNA_IMPL=0 +# CONFIG_ROOTFS_SQUASHFS is not set +CONFIG_ROOTFS_CRAMFS=y +# CONFIG_ROOTFS_JFFS2 is not set +# CONFIG_ROOTFS_NFS is not set +CONFIG_ROOT_FLASHFS="root=31:0 ro noinitrd" +# CONFIG_MACH_JAZZ is not set +# CONFIG_BAGET_MIPS is not set +# CONFIG_MACH_VR41XX is not set +# CONFIG_TOSHIBA_JMR3927 is not set +# CONFIG_MIPS_COBALT is not set +# CONFIG_MACH_DECSTATION is not set +# CONFIG_MIPS_EV64120 is not set +# CONFIG_MIPS_EV96100 is not set +# CONFIG_MIPS_IVR is not set +# CONFIG_LASAT is not set +# CONFIG_MIPS_ITE8172 is not set +# CONFIG_MIPS_ATLAS is not set +# CONFIG_MIPS_MALTA is not set +# CONFIG_MIPS_SEAD is not set +# CONFIG_MOMENCO_OCELOT is not set +# CONFIG_MOMENCO_OCELOT_G is not set +# CONFIG_MOMENCO_OCELOT_C is not set +# CONFIG_MOMENCO_JAGUAR_ATX is not set +# CONFIG_PMC_YOSEMITE is not set +# CONFIG_DDB5074 is not set +# CONFIG_DDB5476 is not set +# CONFIG_DDB5477 is not set +# CONFIG_NEC_OSPREY is not set +# CONFIG_SGI_IP22 is not set +# CONFIG_SGI_IP32 is not set +# CONFIG_SOC_AU1X00 is not set +# CONFIG_SIBYTE_SB1xxx_SOC is not set +# CONFIG_SNI_RM200_PCI is not set +# CONFIG_TOSHIBA_RBTX4927 is not set +CONFIG_RWSEM_GENERIC_SPINLOCK=y +CONFIG_HAVE_DEC_LOCK=y +CONFIG_DMA_NONCOHERENT=y +# CONFIG_CPU_LITTLE_ENDIAN is not set +CONFIG_MIPS_L1_CACHE_SHIFT=5 +# CONFIG_FB is not set + +# +# CPU selection +# +CONFIG_CPU_MIPS32=y +# CONFIG_CPU_MIPS64 is not set +# CONFIG_CPU_R3000 is not set +# CONFIG_CPU_TX39XX is not set +# CONFIG_CPU_VR41XX is not set +# CONFIG_CPU_R4300 is not set +# CONFIG_CPU_R4X00 is not set +# CONFIG_CPU_TX49XX is not set +# CONFIG_CPU_R5000 is not set +# CONFIG_CPU_R5432 is not set +# CONFIG_CPU_R6000 is not set +# CONFIG_CPU_NEVADA is not set +# CONFIG_CPU_R8000 is not set +# CONFIG_CPU_R10000 is not set +# CONFIG_CPU_RM7000 is not set +# CONFIG_CPU_RM9000 is not set +# CONFIG_CPU_SB1 is not set +CONFIG_PAGE_SIZE_4KB=y +# CONFIG_PAGE_SIZE_8KB is not set +# CONFIG_PAGE_SIZE_16KB is not set +# CONFIG_PAGE_SIZE_64KB is not set +CONFIG_CPU_HAS_PREFETCH=y +# CONFIG_VTAG_ICACHE is not set +# CONFIG_64BIT_PHYS_ADDR is not set +# CONFIG_CPU_ADVANCED is not set +CONFIG_CPU_HAS_LLSC=y +CONFIG_CPU_HAS_SYNC=y +# CONFIG_PREEMPT is not set +# CONFIG_DEBUG_SPINLOCK is not set +# CONFIG_DEBUG_SPINLOCK_SLEEP is not set + +# +# Bus options (PCI, PCMCIA, EISA, ISA, TC) +# +CONFIG_PCI=y +CONFIG_PCI_LEGACY_PROC=y +CONFIG_PCI_NAMES=y +CONFIG_MMU=y + +# +# PCMCIA/CardBus support +# +# CONFIG_PCMCIA is not set + +# +# PCI Hotplug Support +# +# CONFIG_HOTPLUG_PCI is not set + +# +# Executable file formats +# +CONFIG_BINFMT_ELF=y +CONFIG_BINFMT_MISC=m +CONFIG_TRAD_SIGNALS=y +# CONFIG_BINFMT_IRIX is not set + +# +# Device Drivers +# + +# +# Generic Driver Options +# +# CONFIG_STANDALONE is not set +CONFIG_PREVENT_FIRMWARE_BUILD=y +CONFIG_FW_LOADER=m +# CONFIG_DEBUG_DRIVER is not set + +# +# Memory Technology Devices (MTD) +# +CONFIG_MTD=y +# CONFIG_MTD_DEBUG is not set +CONFIG_MTD_PARTITIONS=y +# CONFIG_MTD_CONCAT is not set +CONFIG_MTD_REDBOOT_PARTS=y +CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED=y +CONFIG_MTD_REDBOOT_PARTS_READONLY=y +# CONFIG_MTD_CMDLINE_PARTS is not set + +# +# User Modules And Translation Layers +# +# CONFIG_MTD_CHAR is not set +CONFIG_MTD_BLOCK=y +# CONFIG_FTL is not set +# CONFIG_NFTL is not set +# CONFIG_INFTL is not set + +# +# RAM/ROM/Flash chip drivers +# +CONFIG_MTD_CFI=y +# CONFIG_MTD_JEDECPROBE is not set +CONFIG_MTD_GEN_PROBE=y +# CONFIG_MTD_CFI_ADV_OPTIONS is not set +CONFIG_MTD_MAP_BANK_WIDTH_1=y +CONFIG_MTD_MAP_BANK_WIDTH_2=y +CONFIG_MTD_MAP_BANK_WIDTH_4=y +# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set +# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set +# CONFIG_MTD_MAP_BANK_WIDTH_32 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 is not set +CONFIG_MTD_CFI_AMDSTD=y +CONFIG_MTD_CFI_AMDSTD_RETRY=0 +# CONFIG_MTD_CFI_STAA is not set +CONFIG_MTD_CFI_UTIL=y +# CONFIG_MTD_RAM is not set +# CONFIG_MTD_ROM is not set +# CONFIG_MTD_ABSENT is not set + +# +# Mapping drivers for chip access +# +CONFIG_MTD_COMPLEX_MAPPINGS=y +# CONFIG_MTD_PHYSMAP is not set +CONFIG_MTD_BCM963XX=y +# CONFIG_MTD_PCI is not set + +# +# Self-contained MTD device drivers +# +# CONFIG_MTD_PMC551 is not set +# CONFIG_MTD_SLRAM is not set +# CONFIG_MTD_PHRAM is not set +# CONFIG_MTD_MTDRAM is not set +# CONFIG_MTD_BLKMTD is not set + +# +# Disk-On-Chip Device Drivers +# +# CONFIG_MTD_DOC2000 is not set +# CONFIG_MTD_DOC2001 is not set +# CONFIG_MTD_DOC2001PLUS is not set + +# +# NAND Flash Device Drivers +# +# CONFIG_MTD_NAND is not set + +# +# Parallel port support +# +# CONFIG_PARPORT is not set + +# +# Plug and Play support +# + +# +# Block devices +# +# CONFIG_BLK_DEV_FD is not set +# CONFIG_BLK_CPQ_DA is not set +# CONFIG_BLK_CPQ_CISS_DA is not set +# CONFIG_BLK_DEV_DAC960 is not set +# CONFIG_BLK_DEV_UMEM is not set +# CONFIG_BLK_DEV_LOOP is not set +# CONFIG_BLK_DEV_NBD is not set +# CONFIG_BLK_DEV_SX8 is not set +# CONFIG_BLK_DEV_RAM is not set +# CONFIG_LBD is not set + +# +# ATA/ATAPI/MFM/RLL support +# +# CONFIG_IDE is not set + +# +# SCSI device support +# +# CONFIG_SCSI is not set + +# +# Multi-device support (RAID and LVM) +# +# CONFIG_MD is not set + +# +# Fusion MPT device support +# + +# +# IEEE 1394 (FireWire) support +# +# CONFIG_IEEE1394 is not set + +# +# I2O device support +# +# CONFIG_I2O is not set + +# +# Networking support +# +CONFIG_NET=y + +# +# Networking options +# +CONFIG_PACKET=y +# CONFIG_PACKET_MMAP is not set +# CONFIG_NETLINK_DEV is not set +CONFIG_UNIX=y +# CONFIG_NET_KEY is not set +CONFIG_INET=y +CONFIG_IP_MULTICAST=y +# CONFIG_IP_ADVANCED_ROUTER is not set +# CONFIG_IP_PNP is not set +# CONFIG_NET_IPIP is not set +# CONFIG_NET_IPGRE is not set +CONFIG_IP_MROUTE=y +# CONFIG_IP_PIMSM_V1 is not set +# CONFIG_IP_PIMSM_V2 is not set +# CONFIG_ARPD is not set +# CONFIG_SYN_COOKIES is not set +# CONFIG_INET_AH is not set +# CONFIG_INET_ESP is not set +# CONFIG_INET_IPCOMP is not set + +# +# IP: Virtual Server Configuration +# +# CONFIG_IP_VS is not set +# CONFIG_IPV6 is not set +CONFIG_NETFILTER=y +# CONFIG_NETFILTER_DEBUG is not set +# CONFIG_BRIDGE_NETFILTER is not set + +# +# IP: Netfilter Configuration +# +CONFIG_IP_NF_CONNTRACK=y +CONFIG_IP_NF_FTP=y +CONFIG_IP_NF_H323=y +CONFIG_IP_NF_IRC=y +CONFIG_IP_NF_TFTP=y +# CONFIG_IP_NF_AMANDA is not set +# CONFIG_IP_NF_DTX8 is not set +CONFIG_IP_NF_WM=m +CONFIG_IP_NF_PT=m +CONFIG_IP_NF_IPSEC=m +# CONFIG_IP_NF_RTSP is not set +# CONFIG_IP_NF_QUEUE is not set +CONFIG_IP_NF_IPTABLES=y +CONFIG_IP_NF_MATCH_LIMIT=y +CONFIG_IP_NF_MATCH_IPRANGE=y +CONFIG_IP_NF_MATCH_MAC=y +# CONFIG_IP_NF_MATCH_PKTTYPE is not set +CONFIG_IP_NF_MATCH_MARK=y +# CONFIG_IP_NF_MATCH_MULTIPORT is not set +# CONFIG_IP_NF_MATCH_TOS is not set +# CONFIG_IP_NF_MATCH_RECENT is not set +# CONFIG_IP_NF_MATCH_ECN is not set +# CONFIG_IP_NF_MATCH_DSCP is not set +# CONFIG_IP_NF_MATCH_AH_ESP is not set +# CONFIG_IP_NF_MATCH_LENGTH is not set +# CONFIG_IP_NF_MATCH_TTL is not set +# CONFIG_IP_NF_MATCH_TCPMSS is not set +# CONFIG_IP_NF_MATCH_HELPER is not set +CONFIG_IP_NF_MATCH_STATE=y +# CONFIG_IP_NF_MATCH_CONNTRACK is not set +# CONFIG_IP_NF_MATCH_OWNER is not set +CONFIG_IP_NF_FILTER=y +CONFIG_IP_NF_TARGET_REJECT=m +CONFIG_IP_NF_NAT=y +CONFIG_IP_NF_NAT_NEEDED=y +CONFIG_IP_NF_TARGET_MASQUERADE=y +CONFIG_IP_NF_TARGET_REDIRECT=y +# CONFIG_IP_NF_TARGET_NETMAP is not set +# CONFIG_IP_NF_TARGET_SAME is not set +CONFIG_IP_NF_NAT_LOCAL=y +# CONFIG_IP_NF_NAT_SNMP_BASIC is not set +CONFIG_IP_NF_NAT_IRC=y +CONFIG_IP_NF_NAT_FTP=y +CONFIG_IP_NF_NAT_H323=y +CONFIG_IP_NF_NAT_TFTP=y +CONFIG_IP_NF_NAT_IPSEC=m +CONFIG_IP_NF_MANGLE=y +# CONFIG_IP_NF_TARGET_TOS is not set +# CONFIG_IP_NF_TARGET_FTOS is not set +# CONFIG_IP_NF_TARGET_ECN is not set +# CONFIG_IP_NF_TARGET_DSCP is not set +CONFIG_IP_NF_TARGET_MARK=y +# CONFIG_IP_NF_TARGET_CLASSIFY is not set +CONFIG_IP_NF_TARGET_LOG=y +# CONFIG_IP_NF_TARGET_ULOG is not set +CONFIG_IP_NF_TARGET_TCPMSS=y +# CONFIG_IP_NF_ARPTABLES is not set +# CONFIG_IP_NF_RAW is not set +# CONFIG_IP_NF_MATCH_ADDRTYPE is not set +# CONFIG_IP_NF_MATCH_REALM is not set +# CONFIG_IP_NF_PPTP is not set + +# +# Bridge: Netfilter Configuration +# +# CONFIG_BRIDGE_NF_EBTABLES is not set + +# +# SCTP Configuration (EXPERIMENTAL) +# +# CONFIG_IP_SCTP is not set +CONFIG_ATM=y +CONFIG_ATM_CLIP=y +# CONFIG_ATM_CLIP_NO_ICMP is not set +# CONFIG_ATM_LANE is not set +CONFIG_ATM_BR2684=y +# CONFIG_ATM_BR2684_IPFILTER is not set +CONFIG_ATM_RT2684=y +CONFIG_BRIDGE=y +# CONFIG_VLAN_8021Q is not set +# CONFIG_DECNET is not set +# CONFIG_LLC2 is not set +# CONFIG_IPX is not set +# CONFIG_ATALK is not set +# CONFIG_X25 is not set +# CONFIG_LAPB is not set +# CONFIG_NET_DIVERT is not set +# CONFIG_ECONET is not set +# CONFIG_WAN_ROUTER is not set +# CONFIG_NET_HW_FLOWCONTROL is not set + +# +# QoS and/or fair queueing +# +# CONFIG_NET_SCHED is not set +# CONFIG_NET_CLS_ROUTE is not set + +# +# Network testing +# +# CONFIG_NET_PKTGEN is not set +# CONFIG_NETPOLL is not set +# CONFIG_NET_POLL_CONTROLLER is not set +# CONFIG_HAMRADIO is not set +# CONFIG_IRDA is not set +CONFIG_BT=m +CONFIG_BT_L2CAP=m +CONFIG_BT_SCO=m +CONFIG_BT_RFCOMM=m +CONFIG_BT_RFCOMM_TTY=y +CONFIG_BT_BNEP=m +CONFIG_BT_BNEP_MC_FILTER=y +CONFIG_BT_BNEP_PROTO_FILTER=y +CONFIG_BT_HIDP=m + +# +# Bluetooth device drivers +# +CONFIG_BT_HCIUSB=m +CONFIG_BT_HCIUSB_SCO=y +CONFIG_BT_HCIUART=m +CONFIG_BT_HCIUART_H4=y +CONFIG_BT_HCIUART_BCSP=y +CONFIG_BT_HCIUART_BCSP_TXCRC=y +CONFIG_BT_HCIBCM203X=m +CONFIG_BT_HCIBFUSB=m +CONFIG_BT_HCIVHCI=m +CONFIG_NETDEVICES=y +CONFIG_DUMMY=m +CONFIG_BONDING=m +CONFIG_EQUALIZER=m +CONFIG_TUN=m + +# +# ARCnet devices +# +# CONFIG_ARCNET is not set + +# +# Ethernet (10 or 100Mbit) +# +CONFIG_NET_ETHERNET=y +CONFIG_MII=m +# CONFIG_HAPPYMEAL is not set +# CONFIG_SUNGEM is not set +# CONFIG_NET_VENDOR_3COM is not set + +# +# Tulip family network device support +# +# CONFIG_NET_TULIP is not set +# CONFIG_HP100 is not set +# CONFIG_NET_PCI is not set + +# +# Ethernet (1000 Mbit) +# +# CONFIG_ACENIC is not set +# CONFIG_DL2K is not set +# CONFIG_E1000 is not set +# CONFIG_NS83820 is not set +# CONFIG_HAMACHI is not set +# CONFIG_YELLOWFIN is not set +# CONFIG_R8169 is not set +# CONFIG_SK98LIN is not set +# CONFIG_TIGON3 is not set + +# +# Ethernet (10000 Mbit) +# +# CONFIG_IXGB is not set +# CONFIG_S2IO is not set + +# +# Token Ring devices +# +# CONFIG_TR is not set + +# +# Wireless LAN (non-hamradio) +# +CONFIG_NET_RADIO=y + +# +# Obsolete Wireless cards support (pre-802.11) +# +# CONFIG_STRIP is not set + +# +# Wireless 802.11b ISA/PCI cards support +# +# CONFIG_HERMES is not set +# CONFIG_ATMEL is not set + +# +# Prism GT/Duette 802.11(a/b/g) PCI/Cardbus support +# +# CONFIG_PRISM54 is not set +CONFIG_NET_WIRELESS=y + +# +# Wan interfaces +# +# CONFIG_WAN is not set + +# +# ATM drivers +# +# CONFIG_ATM_TCP is not set +# CONFIG_ATM_LANAI is not set +# CONFIG_ATM_ENI is not set +# CONFIG_ATM_FIRESTREAM is not set +# CONFIG_ATM_ZATM is not set +# CONFIG_ATM_NICSTAR is not set +# CONFIG_ATM_IDT77252 is not set +# CONFIG_ATM_AMBASSADOR is not set +# CONFIG_ATM_HORIZON is not set +# CONFIG_ATM_IA is not set +# CONFIG_ATM_FORE200E_MAYBE is not set +# CONFIG_ATM_HE is not set +# CONFIG_FDDI is not set +# CONFIG_HIPPI is not set +CONFIG_PPP=y +CONFIG_PPP_MULTILINK=y +CONFIG_PPP_FILTER=y +CONFIG_PPP_ASYNC=m +CONFIG_PPP_SYNC_TTY=m +CONFIG_PPP_DEFLATE=m +CONFIG_PPP_BSDCOMP=m +CONFIG_PPPOE=y +CONFIG_PPPOATM=y +# CONFIG_SLIP is not set +# CONFIG_SHAPER is not set +# CONFIG_NETCONSOLE is not set + +# +# ISDN subsystem +# +# CONFIG_ISDN is not set + +# +# Telephony Support +# +# CONFIG_PHONE is not set + +# +# Input device support +# +CONFIG_INPUT=y + +# +# Userland interfaces +# +CONFIG_INPUT_MOUSEDEV=y +CONFIG_INPUT_MOUSEDEV_PSAUX=y +CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 +CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 +# CONFIG_INPUT_JOYDEV is not set +# CONFIG_INPUT_TSDEV is not set +# CONFIG_INPUT_EVDEV is not set +# CONFIG_INPUT_EVBUG is not set + +# +# Input I/O drivers +# +# CONFIG_GAMEPORT is not set +CONFIG_SOUND_GAMEPORT=y +CONFIG_SERIO=y +# CONFIG_SERIO_I8042 is not set +CONFIG_SERIO_SERPORT=y +# CONFIG_SERIO_CT82C710 is not set +# CONFIG_SERIO_PCIPS2 is not set + +# +# Input Device Drivers +# +CONFIG_INPUT_KEYBOARD=y +CONFIG_KEYBOARD_ATKBD=y +# CONFIG_KEYBOARD_SUNKBD is not set +# CONFIG_KEYBOARD_LKKBD is not set +# CONFIG_KEYBOARD_XTKBD is not set +# CONFIG_KEYBOARD_NEWTON is not set +CONFIG_INPUT_MOUSE=y +CONFIG_MOUSE_PS2=y +# CONFIG_MOUSE_SERIAL is not set +# CONFIG_MOUSE_VSXXXAA is not set +# CONFIG_INPUT_JOYSTICK is not set +# CONFIG_INPUT_TOUCHSCREEN is not set +# CONFIG_INPUT_MISC is not set + +# +# Character devices +# +CONFIG_VT=y +CONFIG_VT_CONSOLE=y +CONFIG_HW_CONSOLE=y +# CONFIG_SERIAL_NONSTANDARD is not set + +# +# Serial drivers +# +CONFIG_SERIAL_8250=y +CONFIG_SERIAL_8250_CONSOLE=y +CONFIG_SERIAL_8250_NR_UARTS=4 +# CONFIG_SERIAL_8250_EXTENDED is not set + +# +# Non-8250 serial port support +# +CONFIG_SERIAL_CORE=y +CONFIG_SERIAL_CORE_CONSOLE=y +CONFIG_UNIX98_PTYS=y +CONFIG_LEGACY_PTYS=y +CONFIG_LEGACY_PTY_COUNT=2 +# CONFIG_QIC02_TAPE is not set + +# +# IPMI +# +# CONFIG_IPMI_HANDLER is not set + +# +# Watchdog Cards +# +# CONFIG_WATCHDOG is not set +# CONFIG_RTC is not set +# CONFIG_GEN_RTC is not set +# CONFIG_DTLK is not set +# CONFIG_R3964 is not set +# CONFIG_APPLICOM is not set + +# +# Ftape, the floppy tape device driver +# +# CONFIG_AGP is not set +# CONFIG_DRM is not set +# CONFIG_RAW_DRIVER is not set + +# +# I2C support +# +# CONFIG_I2C is not set + +# +# Dallas's 1-wire bus +# +# CONFIG_W1 is not set + +# +# Misc devices +# + +# +# Multimedia devices +# +# CONFIG_VIDEO_DEV is not set + +# +# Digital Video Broadcasting Devices +# +# CONFIG_DVB is not set + +# +# Graphics support +# + +# +# Console display driver support +# +CONFIG_VGA_CONSOLE=y +# CONFIG_MDA_CONSOLE is not set +CONFIG_DUMMY_CONSOLE=y + +# +# Sound +# +# CONFIG_SOUND is not set + +# +# USB support +# +CONFIG_USB=m +# CONFIG_USB_DEBUG is not set + +# +# Miscellaneous USB options +# +CONFIG_USB_DEVICEFS=y +CONFIG_USB_BANDWIDTH=y +CONFIG_USB_DYNAMIC_MINORS=y + +# +# USB Host Controller Drivers +# +CONFIG_USB_EHCI_HCD=m +CONFIG_USB_EHCI_SPLIT_ISO=y +CONFIG_USB_EHCI_ROOT_HUB_TT=y +CONFIG_USB_OHCI_HCD=m +CONFIG_USB_UHCI_HCD=m + +# +# USB Device Class drivers +# + +# +# USB Bluetooth TTY can only be used with disabled Bluetooth subsystem +# +# CONFIG_USB_ACM is not set +# CONFIG_USB_PRINTER is not set +# CONFIG_USB_STORAGE is not set + +# +# USB Human Interface Devices (HID) +# +# CONFIG_USB_HID is not set + +# +# USB HID Boot Protocol drivers +# +# CONFIG_USB_KBD is not set +# CONFIG_USB_MOUSE is not set +# CONFIG_USB_AIPTEK is not set +# CONFIG_USB_WACOM is not set +# CONFIG_USB_KBTAB is not set +# CONFIG_USB_POWERMATE is not set +# CONFIG_USB_MTOUCH is not set +# CONFIG_USB_EGALAX is not set +# CONFIG_USB_XPAD is not set +# CONFIG_USB_ATI_REMOTE is not set + +# +# USB Imaging devices +# +# CONFIG_USB_MDC800 is not set + +# +# USB Multimedia devices +# +# CONFIG_USB_DABUSB is not set + +# +# Video4Linux support is needed for USB Multimedia device support +# + +# +# USB Network adaptors +# +# CONFIG_USB_CATC is not set +# CONFIG_USB_KAWETH is not set +# CONFIG_USB_PEGASUS is not set +# CONFIG_USB_RTL8150 is not set +# CONFIG_USB_USBNET is not set + +# +# USB port drivers +# + +# +# USB Serial Converter support +# +# CONFIG_USB_SERIAL is not set + +# +# USB Miscellaneous drivers +# +# CONFIG_USB_EMI62 is not set +# CONFIG_USB_EMI26 is not set +# CONFIG_USB_TIGL is not set +# CONFIG_USB_AUERSWALD is not set +# CONFIG_USB_RIO500 is not set +# CONFIG_USB_LEGOTOWER is not set +# CONFIG_USB_LCD is not set +# CONFIG_USB_LED is not set +# CONFIG_USB_CYTHERM is not set +# CONFIG_USB_SPEEDTOUCH is not set +# CONFIG_USB_PHIDGETSERVO is not set +# CONFIG_USB_TEST is not set + +# +# USB Gadget Support +# +# CONFIG_USB_GADGET is not set + +# +# File systems +# +# CONFIG_EXT2_FS is not set +# CONFIG_EXT3_FS is not set +# CONFIG_JBD is not set +# CONFIG_REISERFS_FS is not set +# CONFIG_JFS_FS is not set +# CONFIG_XFS_FS is not set +# CONFIG_MINIX_FS is not set +# CONFIG_ROMFS_FS is not set +# CONFIG_QUOTA is not set +# CONFIG_AUTOFS_FS is not set +# CONFIG_AUTOFS4_FS is not set + +# +# CD-ROM/DVD Filesystems +# +# CONFIG_ISO9660_FS is not set +# CONFIG_UDF_FS is not set + +# +# DOS/FAT/NT Filesystems +# +# CONFIG_MSDOS_FS is not set +# CONFIG_VFAT_FS is not set +# CONFIG_NTFS_FS is not set + +# +# Pseudo filesystems +# +CONFIG_PROC_FS=y +CONFIG_PROC_KCORE=y +CONFIG_SYSFS=y +CONFIG_DEVFS_FS=y +CONFIG_DEVFS_MOUNT=y +# CONFIG_DEVFS_DEBUG is not set +# CONFIG_DEVPTS_FS_XATTR is not set +CONFIG_TMPFS=y +# CONFIG_HUGETLB_PAGE is not set +CONFIG_RAMFS=y + +# +# Miscellaneous filesystems +# +# CONFIG_ADFS_FS is not set +# CONFIG_AFFS_FS is not set +# CONFIG_HFS_FS is not set +# CONFIG_HFSPLUS_FS is not set +# CONFIG_BEFS_FS is not set +# CONFIG_BFS_FS is not set +# CONFIG_EFS_FS is not set +# CONFIG_JFFS_FS is not set +# CONFIG_JFFS2_FS is not set +# CONFIG_SQUASHFS is not set +CONFIG_CRAMFS=y +# CONFIG_LZMA_FS_INFLATE is not set +CONFIG_ZLIB_FS_INFLATE=y +# CONFIG_VXFS_FS is not set +# CONFIG_HPFS_FS is not set +# CONFIG_QNX4FS_FS is not set +# CONFIG_SYSV_FS is not set +# CONFIG_UFS_FS is not set + +# +# Network File Systems +# +# CONFIG_NFS_FS is not set +# CONFIG_NFSD is not set +# CONFIG_EXPORTFS is not set +# CONFIG_SMB_FS is not set +# CONFIG_CIFS is not set +# CONFIG_NCP_FS is not set +# CONFIG_CODA_FS is not set +# CONFIG_AFS_FS is not set + +# +# Partition Types +# +# CONFIG_PARTITION_ADVANCED is not set +# CONFIG_MSDOS_PARTITION is not set + +# +# Native Language Support +# +# CONFIG_NLS is not set + +# +# Kernel hacking +# +CONFIG_CROSSCOMPILE=y +CONFIG_CMDLINE="" +CONFIG_DEBUG_KERNEL=y +# CONFIG_DEBUG_STACK_USAGE is not set +# CONFIG_DEBUG_SLAB is not set +# CONFIG_KGDB is not set +# CONFIG_DEBUG_INFO is not set +# CONFIG_RUNTIME_DEBUG is not set +# CONFIG_MAGIC_SYSRQ is not set +# CONFIG_MIPS_UNCACHED is not set + +# +# Security options +# +# CONFIG_SECURITY is not set + +# +# Cryptographic options +# +CONFIG_CRYPTO=y +CONFIG_CRYPTO_HMAC=y +CONFIG_CRYPTO_NULL=m +CONFIG_CRYPTO_MD4=m +CONFIG_CRYPTO_MD5=m +CONFIG_CRYPTO_SHA1=m +CONFIG_CRYPTO_SHA256=m +CONFIG_CRYPTO_SHA512=m +CONFIG_CRYPTO_DES=m +CONFIG_CRYPTO_BLOWFISH=m +CONFIG_CRYPTO_TWOFISH=m +CONFIG_CRYPTO_SERPENT=m +CONFIG_CRYPTO_AES=y +CONFIG_CRYPTO_CAST5=m +CONFIG_CRYPTO_CAST6=m +CONFIG_CRYPTO_TEA=m +CONFIG_CRYPTO_ARC4=m +CONFIG_CRYPTO_KHAZAD=m +CONFIG_CRYPTO_DEFLATE=m +CONFIG_CRYPTO_MICHAEL_MIC=m +CONFIG_CRYPTO_CRC32C=m +# CONFIG_CRYPTO_TEST is not set + +# +# Library routines +# +CONFIG_CRC_CCITT=y +CONFIG_CRC32=m +CONFIG_LIBCRC32C=m +CONFIG_ZLIB_INFLATE=y +CONFIG_ZLIB_DEFLATE=m diff --git a/openwrt/target/linux/brcm63xx-2.6/files/built-in.o b/openwrt/target/linux/brcm63xx-2.6/files/built-in.o new file mode 100644 index 0000000000000000000000000000000000000000..721d8f9174fc4684d94196823337b037175505c9 GIT binary patch literal 279454 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 Kjim)%5@Q*CG1#Qp0BTsxW6Os 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ðhoZt~;br$0aA=kxQR@}BXxh4>l2phx~}mLIuK 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
UNc1b~pS#)G%RON+uT)X}owvv8=N(i$ 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 literal 0 HcmV?d00001 diff --git a/openwrt/target/linux/brcm63xx-2.6/patches/001-bcm963xx.patch b/openwrt/target/linux/brcm63xx-2.6/patches/001-bcm963xx.patch new file mode 100644 index 0000000000..185575f670 --- /dev/null +++ b/openwrt/target/linux/brcm63xx-2.6/patches/001-bcm963xx.patch @@ -0,0 +1,48189 @@ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/Kconfig linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/Kconfig +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/Kconfig 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/Kconfig 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,169 @@ ++# Kernel and Driver configuration for Broadcom Commengine ADSL board ++choice ++ prompt "Broadcom Commengine ADSL board" ++ depends on MIPS_BRCM ++ default BCM96345 ++ help ++ Select different Broadcom ADSL board ++ ++config BCM96338 ++ bool "96338 ADSL board" ++ select DMA_NONCOHERENT ++ ++config BCM96345 ++ bool "96345 ADSL board" ++ select DMA_NONCOHERENT ++ ++config BCM96348 ++ bool "96348 ADSL board" ++ select DMA_NONCOHERENT ++ ++endchoice ++ ++config BCM_BOARD ++ bool "Support for Broadcom Board" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_SERIAL ++ bool "Support for Serial Port" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ENET ++ tristate "Support for Ethernet" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_USB ++ tristate "Support for USB" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_WLAN ++ tristate "Support for Wireless" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_PCI ++ bool "Support for PCI" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ select PCI ++ ++config BCM_ATMAPI ++ tristate "Support for ATM" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ATMTEST ++ tristate "Support for ATM Diagnostic" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ADSL ++ tristate "Support for ADSL" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ENDPOINT ++ tristate "Support for VOICE" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_PROCFS ++ tristate "Support for PROCFS" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_VDSL ++ tristate "Support for VDSL" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_SECURITY ++ tristate "Support for SECURITY" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_HPNA ++ tristate "Support for HPNA" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_BOARD_IMPL ++ int "Implementation index for ADSL Board" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_SERIAL_IMPL ++ int "Implementation index for Serial" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ENET_IMPL ++ int "Implementation index for Ethernet" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_USB_IMPL ++ int "Implementation index for USB" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_WLAN_IMPL ++ int "Implementation index for WIRELESS" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ATMAPI_IMPL ++ int "Implementation index for ATM" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ATMTEST_IMPL ++ int "Implementation index for ATM Diagnostic" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_BLAA_IMPL ++ int "Implementation index for BLAA" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ADSL_IMPL ++ int "Implementation index for ADSL" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_ENDPOINT_IMPL ++ int "Implementation index for VOICE" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_PROCFS_IMPL ++ int "Implementation index for PROCFS" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_VDSL_IMPL ++ int "Implementation index for VDSL" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_SECURITY_IMPL ++ int "Implementation index for SECURITY" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++config BCM_HPNA_IMPL ++ int "Implementation index for HPNA" ++ depends on BCM96338 || BCM96345 || BCM96348 ++ ++choice ++ prompt "Root File System" ++ depends on MIPS_BRCM ++ default ROOTFS_SQUASHFS ++ help ++ Select root file system on the board flash. ++ ++config ROOTFS_SQUASHFS ++ bool "SQUASHFS" ++config ROOTFS_CRAMFS ++ bool "CRAMFS" ++config ROOTFS_JFFS2 ++ bool "JFFS2" ++config ROOTFS_NFS ++ bool "NFS" ++ ++endchoice ++ ++config ROOT_FLASHFS ++ string "flash partition" ++ depends on ROOTFS_SQUASHFS || ROOTFS_CRAMFS || ROOTFS_JFFS2 ++ default "root=31:0 ro noinitrd" if ROOTFS_SQUASHFS = y || ROOTFS_CRAMFS = y ++ default "root=31:2 ro noinitrd" if ROOTFS_JFFS2 = y ++ help ++ This is the root file system partition on flash memory ++ ++config ROOT_NFS_DIR ++ string "NFS server path" ++ depends on ROOTFS_NFS ++ default "/opt/bcm96338/targets/96338R/fs" if BCM96338 = y ++ default "/opt/bcm96345/targets/96345R/fs" if BCM96345 = y ++ default "/opt/bcm96348/targets/96348R/fs" if BCM96348 = y ++ help ++ This is the path of NFS server (host system) +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/Makefile linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/Makefile +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/Makefile 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,23 @@ ++# ++# Makefile for generic Broadcom MIPS boards ++# ++# Copyright (C) 2004 Broadcom Corporation ++# ++obj-y := irq.o prom.o setup.o time.o ser_init.o ++ ++SRCBASE := $(TOPDIR) ++EXTRA_CFLAGS += -I$(INC_BRCMBOARDPARMS_PATH)/$(BRCM_BOARD) -I$(SRCBASE)/include -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++#EXTRA_CFLAGS += -I$(INC_ADSLDRV_PATH) -DDBG ++EXTRA_CFLAGS += -I$(INC_ADSLDRV_PATH) ++ ++ ++ifeq "$(ADSL)" "ANNEX_B" ++EXTRA_CFLAGS += -DADSL_ANNEXB ++endif ++ifeq "$(ADSL)" "SADSL" ++EXTRA_CFLAGS += -DADSL_SADSL ++endif ++ifeq "$(ADSL)" "ANNEX_C" ++EXTRA_CFLAGS += -DADSL_ANNEXC ++endif ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/irq.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/irq.c +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/irq.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/irq.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,276 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * Interrupt control functions for Broadcom 963xx MIPS boards ++ */ ++ ++#include ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++extern asmlinkage unsigned int do_IRQ(int irq, struct pt_regs *regs); ++ ++static void irq_dispatch_int(struct pt_regs *regs) ++{ ++ unsigned int pendingIrqs; ++ static unsigned int irqBit; ++ static unsigned int isrNumber = 31; ++ ++ pendingIrqs = PERF->IrqStatus & PERF->IrqMask; ++ if (!pendingIrqs) { ++ return; ++ } ++ ++ while (1) { ++ irqBit <<= 1; ++ isrNumber++; ++ if (isrNumber == 32) { ++ isrNumber = 0; ++ irqBit = 0x1; ++ } ++ if (pendingIrqs & irqBit) { ++ PERF->IrqMask &= ~irqBit; // mask ++ do_IRQ(isrNumber + INTERNAL_ISR_TABLE_OFFSET, regs); ++ break; ++ } ++ } ++} ++ ++static void irq_dispatch_ext(uint32 irq, struct pt_regs *regs) ++{ ++ if (!(PERF->ExtIrqCfg & (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_MASK_SHFT)))) { ++ printk("**** Ext IRQ mask. Should not dispatch ****\n"); ++ } ++ /* disable and clear interrupt in the controller */ ++ PERF->ExtIrqCfg |= (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_CLEAR_SHFT)); ++ PERF->ExtIrqCfg &= ~(1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_MASK_SHFT)); ++ do_IRQ(irq, regs); ++} ++ ++void brcm_irq_dispatch(struct pt_regs *regs) ++{ ++ u32 cause; ++ while((cause = (read_c0_cause()& CAUSEF_IP))) { ++ if (cause & CAUSEF_IP7) ++ do_IRQ(MIPS_TIMER_INT, regs); ++ else if (cause & CAUSEF_IP2) ++ irq_dispatch_int(regs); ++ else if (cause & CAUSEF_IP3) ++ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_0, regs); ++ else if (cause & CAUSEF_IP4) ++ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_1, regs); ++ else if (cause & CAUSEF_IP5) ++ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_2, regs); ++ else if (cause & CAUSEF_IP6) ++ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_3, regs); ++ cli(); ++ } ++} ++ ++ ++void enable_brcm_irq(unsigned int irq) ++{ ++ unsigned long flags; ++ ++ local_irq_save(flags); ++ if( irq >= INTERNAL_ISR_TABLE_OFFSET ) { ++ PERF->IrqMask |= (1 << (irq - INTERNAL_ISR_TABLE_OFFSET)); ++ } ++ else if (irq >= INTERRUPT_ID_EXTERNAL_0 && irq <= INTERRUPT_ID_EXTERNAL_3) { ++ /* enable and clear interrupt in the controller */ ++ PERF->ExtIrqCfg |= (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_CLEAR_SHFT)); ++ PERF->ExtIrqCfg |= (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_MASK_SHFT)); ++ } ++ local_irq_restore(flags); ++} ++ ++void disable_brcm_irq(unsigned int irq) ++{ ++ unsigned long flags; ++ ++ local_irq_save(flags); ++ if( irq >= INTERNAL_ISR_TABLE_OFFSET ) { ++ PERF->IrqMask &= ~(1 << (irq - INTERNAL_ISR_TABLE_OFFSET)); ++ } ++ else if (irq >= INTERRUPT_ID_EXTERNAL_0 && irq <= INTERRUPT_ID_EXTERNAL_3) { ++ /* disable interrupt in the controller */ ++ PERF->ExtIrqCfg &= ~(1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_MASK_SHFT)); ++ } ++ local_irq_restore(flags); ++} ++ ++void ack_brcm_irq(unsigned int irq) ++{ ++ /* Already done in brcm_irq_dispatch */ ++} ++ ++unsigned int startup_brcm_irq(unsigned int irq) ++{ ++ enable_brcm_irq(irq); ++ ++ return 0; /* never anything pending */ ++} ++ ++unsigned int startup_brcm_none(unsigned int irq) ++{ ++ return 0; ++} ++ ++void end_brcm_irq(unsigned int irq) ++{ ++ if (!(irq_desc[irq].status & (IRQ_DISABLED|IRQ_INPROGRESS))) ++ enable_brcm_irq(irq); ++} ++ ++void end_brcm_none(unsigned int irq) ++{ ++} ++ ++#define ALLINTS_NOTIMER (IE_IRQ0 | IE_IRQ1 | IE_IRQ2 | IE_IRQ3 | IE_IRQ4) ++ ++static void __init brcm_irq_setup(void) ++{ ++ extern asmlinkage void brcmIRQ(void); ++ ++ clear_c0_status(ST0_BEV); ++ set_except_vector(0, brcmIRQ); ++ change_c0_status(ST0_IM, ALLINTS_NOTIMER); ++ ++#ifdef CONFIG_REMOTE_DEBUG ++ rs_kgdb_hook(0); ++#endif ++} ++ ++static struct hw_interrupt_type brcm_irq_type = { ++ .typename = "MIPS", ++ .startup = startup_brcm_irq, ++ .shutdown = disable_brcm_irq, ++ .enable = enable_brcm_irq, ++ .disable = disable_brcm_irq, ++ .ack = ack_brcm_irq, ++ .end = end_brcm_irq, ++ .set_affinity = NULL ++}; ++ ++static struct hw_interrupt_type brcm_irq_no_end_type = { ++ .typename = "MIPS", ++ .startup = startup_brcm_none, ++ .shutdown = disable_brcm_irq, ++ .enable = enable_brcm_irq, ++ .disable = disable_brcm_irq, ++ .ack = ack_brcm_irq, ++ .end = end_brcm_none, ++ .set_affinity = NULL ++}; ++ ++void __init arch_init_irq(void) ++{ ++ int i; ++ ++ for (i = 0; i < NR_IRQS; i++) { ++ irq_desc[i].status = IRQ_DISABLED; ++ irq_desc[i].action = 0; ++ irq_desc[i].depth = 1; ++ irq_desc[i].handler = &brcm_irq_type; ++ } ++ ++ brcm_irq_setup(); ++} ++ ++int request_external_irq(unsigned int irq, ++ FN_HANDLER handler, ++ unsigned long irqflags, ++ const char * devname, ++ void *dev_id) ++{ ++ unsigned long flags; ++ ++ local_irq_save(flags); ++ ++ PERF->ExtIrqCfg |= (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_CLEAR_SHFT)); // Clear ++ PERF->ExtIrqCfg &= ~(1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_MASK_SHFT)); // Mask ++ PERF->ExtIrqCfg &= ~(1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_INSENS_SHFT)); // Edge insesnsitive ++ PERF->ExtIrqCfg |= (1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_LEVEL_SHFT)); // Level triggered ++ PERF->ExtIrqCfg &= ~(1 << (irq - INTERRUPT_ID_EXTERNAL_0 + EI_SENSE_SHFT)); // Low level ++ ++ local_irq_restore(flags); ++ ++ return( request_irq(irq, handler, irqflags, devname, dev_id) ); ++} ++ ++/* VxWorks compatibility function(s). */ ++ ++unsigned int BcmHalMapInterrupt(FN_HANDLER pfunc, unsigned int param, ++ unsigned int interruptId) ++{ ++ int nRet = -1; ++ char *devname; ++ ++ devname = kmalloc(16, GFP_KERNEL); ++ if (devname) ++ sprintf( devname, "brcm_%d", interruptId ); ++ ++ /* Set the IRQ description to not automatically enable the interrupt at ++ * the end of an ISR. The driver that handles the interrupt must ++ * explicitly call BcmHalInterruptEnable or enable_brcm_irq. This behavior ++ * is consistent with interrupt handling on VxWorks. ++ */ ++ irq_desc[interruptId].handler = &brcm_irq_no_end_type; ++ ++ if( interruptId >= INTERNAL_ISR_TABLE_OFFSET ) ++ { ++ nRet = request_irq( interruptId, pfunc, SA_SAMPLE_RANDOM | SA_INTERRUPT, ++ devname, (void *) param ); ++ } ++ else if (interruptId >= INTERRUPT_ID_EXTERNAL_0 && interruptId <= INTERRUPT_ID_EXTERNAL_3) ++ { ++ nRet = request_external_irq( interruptId, pfunc, SA_SAMPLE_RANDOM | SA_INTERRUPT, ++ devname, (void *) param ); ++ } ++ ++ return( nRet ); ++} ++ ++ ++/* Debug function. */ ++ ++void dump_intr_regs(void) ++{ ++ printk("PERF->ExtIrqCfg [%08x]\n", *(&(PERF->ExtIrqCfg))); ++} ++ ++EXPORT_SYMBOL(enable_brcm_irq); ++EXPORT_SYMBOL(disable_brcm_irq); ++EXPORT_SYMBOL(request_external_irq); ++EXPORT_SYMBOL(BcmHalMapInterrupt); ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/prom.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/prom.c +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/prom.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/prom.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,233 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * prom.c: PROM library initialization code. ++ * ++ */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include "boardparms.h" ++#include "softdsl/AdslCoreDefs.h" ++ ++ ++extern int do_syslog(int, char *, int); ++extern void serial_init(void); ++extern void __init InitNvramInfo( void ); ++extern void kerSysFlashInit( void ); ++extern unsigned long get_nvram_start_addr(void); ++void __init create_root_nfs_cmdline( char *cmdline ); ++ ++#if defined(CONFIG_BCM96338) ++#define CPU_CLOCK 240000000 ++#define MACH_BCM MACH_BCM96338 ++#endif ++#if defined(CONFIG_BCM96345) ++#define CPU_CLOCK 140000000 ++#define MACH_BCM MACH_BCM96345 ++#endif ++#if defined(CONFIG_BCM96348) ++void __init calculateCpuSpeed(void); ++static unsigned long cpu_speed; ++#define CPU_CLOCK cpu_speed ++#define MACH_BCM MACH_BCM96348 ++#endif ++ ++const char *get_system_type(void) ++{ ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ ++ return( pNvramData->szBoardId ); ++} ++ ++unsigned long getMemorySize(void) ++{ ++ unsigned long ulSdramType = BOARD_SDRAM_TYPE; ++ ++ unsigned long ulSdramSize; ++ ++ switch( ulSdramType ) ++ { ++ case BP_MEMORY_16MB_1_CHIP: ++ case BP_MEMORY_16MB_2_CHIP: ++ ulSdramSize = 16 * 1024 * 1024; ++ break; ++ case BP_MEMORY_32MB_1_CHIP: ++ case BP_MEMORY_32MB_2_CHIP: ++ ulSdramSize = 32 * 1024 * 1024; ++ break; ++ case BP_MEMORY_64MB_2_CHIP: ++ ulSdramSize = 64 * 1024 * 1024; ++ break; ++ default: ++ ulSdramSize = 8 * 1024 * 1024; ++ break; ++ } ++ ++ return ulSdramSize; ++} ++ ++/* -------------------------------------------------------------------------- ++ Name: prom_init ++ -------------------------------------------------------------------------- */ ++void __init prom_init(void) ++{ ++ extern ulong r4k_interval; ++ ++ serial_init(); ++ ++ kerSysFlashInit(); ++ ++ do_syslog(8, NULL, 8); ++ ++ printk( "%s prom init\n", get_system_type() ); ++ ++ PERF->IrqMask = 0; ++ ++ arcs_cmdline[0] = '\0'; ++ ++#if defined(CONFIG_ROOT_NFS) ++ create_root_nfs_cmdline( arcs_cmdline ); ++#elif defined(CONFIG_ROOT_FLASHFS) ++ strcpy(arcs_cmdline, CONFIG_ROOT_FLASHFS); ++#endif ++ ++ add_memory_region(0, (getMemorySize() - ADSL_SDRAM_IMAGE_SIZE), BOOT_MEM_RAM); ++ ++#if defined(CONFIG_BCM96348) ++ calculateCpuSpeed(); ++#endif ++ /* Count register increments every other clock */ ++ r4k_interval = CPU_CLOCK / HZ / 2; ++ mips_hpt_frequency = CPU_CLOCK / 2; ++ ++ mips_machgroup = MACH_GROUP_BRCM; ++ mips_machtype = MACH_BCM; ++} ++ ++/* -------------------------------------------------------------------------- ++ Name: prom_free_prom_memory ++Abstract: ++ -------------------------------------------------------------------------- */ ++void __init prom_free_prom_memory(void) ++{ ++ ++} ++ ++ ++#if defined(CONFIG_ROOT_NFS) ++/* This function reads in a line that looks something like this: ++ * ++ * ++ * CFE bootline=bcmEnet(0,0)host:vmlinux e=192.169.0.100:ffffff00 h=192.169.0.1 ++ * ++ * ++ * and retuns in the cmdline parameter some that looks like this: ++ * ++ * CONFIG_CMDLINE="root=/dev/nfs nfsroot=192.168.0.1:/opt/targets/96345R/fs ++ * ip=192.168.0.100:192.168.0.1::255.255.255.0::eth0:off rw" ++ */ ++#define BOOT_LINE_ADDR 0x0 ++#define HEXDIGIT(d) ((d >= '0' && d <= '9') ? (d - '0') : ((d | 0x20) - 'W')) ++#define HEXBYTE(b) (HEXDIGIT((b)[0]) << 4) + HEXDIGIT((b)[1]) ++extern unsigned long get_nvram_start_addr(void); ++ ++void __init create_root_nfs_cmdline( char *cmdline ) ++{ ++ char root_nfs_cl[] = "root=/dev/nfs nfsroot=%s:" CONFIG_ROOT_NFS_DIR ++ " ip=%s:%s::%s::eth0:off rw"; ++ ++ char *localip = NULL; ++ char *hostip = NULL; ++ char mask[16] = ""; ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ char bootline[128] = ""; ++ char *p = bootline; ++ ++ memcpy(bootline, pNvramData->szBootline, sizeof(bootline)); ++ while( *p ) ++ { ++ if( p[0] == 'e' && p[1] == '=' ) ++ { ++ /* Found local ip address */ ++ p += 2; ++ localip = p; ++ while( *p && *p != ' ' && *p != ':' ) ++ p++; ++ if( *p == ':' ) ++ { ++ /* Found network mask (eg FFFFFF00 */ ++ *p++ = '\0'; ++ sprintf( mask, "%u.%u.%u.%u", HEXBYTE(p), HEXBYTE(p + 2), ++ HEXBYTE(p + 4), HEXBYTE(p + 6) ); ++ p += 4; ++ } ++ else if( *p == ' ' ) ++ *p++ = '\0'; ++ } ++ else if( p[0] == 'h' && p[1] == '=' ) ++ { ++ /* Found host ip address */ ++ p += 2; ++ hostip = p; ++ while( *p && *p != ' ' ) ++ p++; ++ if( *p == ' ' ) ++ *p++ = '\0'; ++ } ++ else ++ p++; ++ } ++ ++ if( localip && hostip ) ++ sprintf( cmdline, root_nfs_cl, hostip, localip, hostip, mask ); ++} ++#endif ++ ++#if defined(CONFIG_BCM96348) ++/* ********************************************************************* ++ * calculateCpuSpeed() ++ * Calculate the BCM6348 CPU speed by reading the PLL strap register ++ * and applying the following formula: ++ * cpu_clk = (.25 * 64MHz freq) * (N1 + 1) * (N2 + 2) / (M1_CPU + 1) ++ * Input parameters: ++ * none ++ * Return value: ++ * none ++ ********************************************************************* */ ++void __init calculateCpuSpeed(void) ++{ ++ UINT32 pllStrap = PERF->PllStrap; ++ int n1 = (pllStrap & PLL_N1_MASK) >> PLL_N1_SHFT; ++ int n2 = (pllStrap & PLL_N2_MASK) >> PLL_N2_SHFT; ++ int m1cpu = (pllStrap & PLL_M1_CPU_MASK) >> PLL_M1_CPU_SHFT; ++ ++ cpu_speed = (16 * (n1 + 1) * (n2 + 2) / (m1cpu + 1)) * 1000000; ++} ++#endif ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/ser_init.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/ser_init.c +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/ser_init.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/ser_init.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,180 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * Broadcom bcm63xx serial port initialization, also prepare for printk ++ * by registering with console_init ++ * ++ */ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++ ++#define SER63XX_DEFAULT_BAUD 115200 ++#define BD_BCM63XX_TIMER_CLOCK_INPUT (FPERIPH) ++#define stUart ((volatile Uart * const) UART_BASE) ++ ++// Transmit interrupts ++#define TXINT (TXFIFOEMT | TXUNDERR | TXOVFERR) ++// Receive interrupts ++#define RXINT (RXFIFONE | RXOVFERR) ++ ++/* -------------------------------------------------------------------------- ++ Name: serial_init ++ Purpose: Initalize the UART ++-------------------------------------------------------------------------- */ ++void __init serial_init(void) ++{ ++ UINT32 tmpVal = SER63XX_DEFAULT_BAUD; ++ ULONG clockFreqHz; ++ ++#if defined(CONFIG_BCM96345) ++ // Make sure clock is ticking ++ PERF->blkEnables |= UART_CLK_EN; ++#endif ++ ++ /* Dissable channel's receiver and transmitter. */ ++ stUart->control &= ~(BRGEN|TXEN|RXEN); ++ ++ /*--------------------------------------------------------------------*/ ++ /* Write the table value to the clock select register. */ ++ /* DPullen - this is the equation to use: */ ++ /* value = clockFreqHz / baud / 32-1; */ ++ /* (snmod) Actually you should also take into account any necessary */ ++ /* rounding. Divide by 16, look at lsb, if 0, divide by 2 */ ++ /* and subtract 1. If 1, just divide by 2 */ ++ /*--------------------------------------------------------------------*/ ++ clockFreqHz = BD_BCM63XX_TIMER_CLOCK_INPUT; ++ tmpVal = (clockFreqHz / tmpVal) / 16; ++ if( tmpVal & 0x01 ) ++ tmpVal /= 2; //Rounding up, so sub is already accounted for ++ else ++ tmpVal = (tmpVal / 2) - 1; // Rounding down so we must sub 1 ++ stUart->baudword = tmpVal; ++ ++ /* Finally, re-enable the transmitter and receiver. */ ++ stUart->control |= (BRGEN|TXEN|RXEN); ++ ++ stUart->config = (BITS8SYM | ONESTOP); ++ // Set the FIFO interrupt depth ... stUart->fifocfg = 0xAA; ++ stUart->fifoctl = RSTTXFIFOS | RSTRXFIFOS; ++ stUart->intMask = 0; ++ stUart->intMask = RXINT | TXINT; ++} ++ ++ ++/* prom_putc() ++ * Output a character to the UART ++ */ ++void prom_putc(char c) ++{ ++ /* Wait for Tx uffer to empty */ ++ while (! (READ16(stUart->intStatus) & TXFIFOEMT)); ++ /* Send character */ ++ stUart->Data = c; ++} ++ ++/* prom_puts() ++ * Write a string to the UART ++ */ ++void prom_puts(const char *s) ++{ ++ while (*s) { ++ if (*s == '\n') { ++ prom_putc('\r'); ++ } ++ prom_putc(*s++); ++ } ++} ++ ++ ++/* prom_getc_nowait() ++ * Returns a character from the UART ++ * Returns -1 if no characters available or corrupted ++ */ ++int prom_getc_nowait(void) ++{ ++ uint16 uStatus; ++ int cData = -1; ++ ++ uStatus = READ16(stUart->intStatus); ++ ++ if (uStatus & RXFIFONE) { /* Do we have a character? */ ++ cData = READ16(stUart->Data) & 0xff; /* Read character */ ++ if (uStatus & (RXFRAMERR | RXPARERR)) { /* If we got an error, throw it away */ ++ cData = -1; ++ } ++ } ++ ++ return cData; ++} ++ ++/* prom_getc() ++ * Returns a charcter from the serial port ++ * Will block until it receives a valid character ++*/ ++char prom_getc(void) ++{ ++ int cData = -1; ++ ++ /* Loop until we get a valid character */ ++ while(cData == -1) { ++ cData = prom_getc_nowait(); ++ } ++ return (char) cData; ++} ++ ++/* prom_testc() ++ * Returns 0 if no characters available ++ */ ++int prom_testc(void) ++{ ++ uint16 uStatus; ++ ++ uStatus = READ16(stUart->intStatus); ++ ++ return (uStatus & RXFIFONE); ++} ++ ++#if CONFIG_REMOTE_DEBUG ++/* Prevent other code from writing to the serial port */ ++void _putc(char c) { } ++void _puts(const char *ptr) { } ++#else ++/* Low level outputs call prom routines */ ++void _putc(char c) { ++ prom_putc(c); ++} ++void _puts(const char *ptr) { ++ prom_puts(ptr); ++} ++#endif +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/setup.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/setup.c +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/setup.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/setup.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,519 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * Generic setup routines for Broadcom 963xx MIPS boards ++ */ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++extern void brcm_timer_setup(struct irqaction *irq); ++extern unsigned long getMemorySize(void); ++ ++#if defined(CONFIG_BCM96348) && defined(CONFIG_PCI) ++#include ++#include ++#include ++#include ++ ++static volatile MpiRegisters * mpi = (MpiRegisters *)(MPI_BASE); ++#endif ++ ++/* This function should be in a board specific directory. For now, ++ * assume that all boards that include this file use a Broadcom chip ++ * with a soft reset bit in the PLL control register. ++ */ ++static void brcm_machine_restart(char *command) ++{ ++ const unsigned long ulSoftReset = 0x00000001; ++ unsigned long *pulPllCtrl = (unsigned long *) 0xfffe0008; ++ *pulPllCtrl |= ulSoftReset; ++} ++ ++static void brcm_machine_halt(void) ++{ ++ printk("System halted\n"); ++ while (1); ++} ++ ++#if defined(CONFIG_BCM96348) && defined(CONFIG_PCI) ++ ++static void mpi_SetLocalPciConfigReg(uint32 reg, uint32 value) ++{ ++ /* write index then value */ ++ mpi->pcicfgcntrl = PCI_CFG_REG_WRITE_EN + reg;; ++ mpi->pcicfgdata = value; ++} ++ ++static uint32 mpi_GetLocalPciConfigReg(uint32 reg) ++{ ++ /* write index then get value */ ++ mpi->pcicfgcntrl = PCI_CFG_REG_WRITE_EN + reg;; ++ return mpi->pcicfgdata; ++} ++ ++/* ++ * mpi_ResetPcCard: Set/Reset the PcCard ++ */ ++static void mpi_ResetPcCard(int cardtype, BOOL bReset) ++{ ++ if (cardtype == MPI_CARDTYPE_NONE) { ++ return; ++ } ++ ++ if (cardtype == MPI_CARDTYPE_CARDBUS) { ++ bReset = ! bReset; ++ } ++ ++ if (bReset) { ++ mpi->pcmcia_cntl1 = (mpi->pcmcia_cntl1 & ~PCCARD_CARD_RESET); ++ } else { ++ mpi->pcmcia_cntl1 = (mpi->pcmcia_cntl1 | PCCARD_CARD_RESET); ++ } ++} ++ ++/* ++ * mpi_ConfigCs: Configure an MPI/EBI chip select ++ */ ++static void mpi_ConfigCs(uint32 cs, uint32 base, uint32 size, uint32 flags) ++{ ++ mpi->cs[cs].base = ((base & 0x1FFFFFFF) | size); ++ mpi->cs[cs].config = flags; ++} ++ ++/* ++ * mpi_InitPcmciaSpace ++ */ ++static void mpi_InitPcmciaSpace(void) ++{ ++ // ChipSelect 4 controls PCMCIA Memory accesses ++ mpi_ConfigCs(PCMCIA_COMMON_BASE, pcmciaMem, EBI_SIZE_1M, (EBI_WORD_WIDE|EBI_ENABLE)); ++ // ChipSelect 5 controls PCMCIA Attribute accesses ++ mpi_ConfigCs(PCMCIA_ATTRIBUTE_BASE, pcmciaAttr, EBI_SIZE_1M, (EBI_WORD_WIDE|EBI_ENABLE)); ++ // ChipSelect 6 controls PCMCIA I/O accesses ++ mpi_ConfigCs(PCMCIA_IO_BASE, pcmciaIo, EBI_SIZE_64K, (EBI_WORD_WIDE|EBI_ENABLE)); ++ ++ mpi->pcmcia_cntl2 = ((PCMCIA_ATTR_ACTIVE << RW_ACTIVE_CNT_BIT) | ++ (PCMCIA_ATTR_INACTIVE << INACTIVE_CNT_BIT) | ++ (PCMCIA_ATTR_CE_SETUP << CE_SETUP_CNT_BIT) | ++ (PCMCIA_ATTR_CE_HOLD << CE_HOLD_CNT_BIT)); ++ ++ mpi->pcmcia_cntl2 |= (PCMCIA_HALFWORD_EN | PCMCIA_BYTESWAP_DIS); ++} ++ ++/* ++ * cardtype_vcc_detect: PC Card's card detect and voltage sense connection ++ * ++ * CD1#/ CD2#/ VS1#/ VS2#/ Card Initial Vcc ++ * CCD1# CCD2# CVS1 CVS2 Type ++ * ++ * GND GND open open 16-bit 5 vdc ++ * ++ * GND GND GND open 16-bit 3.3 vdc ++ * ++ * GND GND open GND 16-bit x.x vdc ++ * ++ * GND GND GND GND 16-bit 3.3 & x.x vdc ++ * ++ *==================================================================== ++ * ++ * CVS1 GND CCD1# open CardBus 3.3 vdc ++ * ++ * GND CVS2 open CCD2# CardBus x.x vdc ++ * ++ * GND CVS1 CCD2# open CardBus y.y vdc ++ * ++ * GND CVS2 GND CCD2# CardBus 3.3 & x.x vdc ++ * ++ * CVS2 GND open CCD1# CardBus x.x & y.y vdc ++ * ++ * GND CVS1 CCD2# open CardBus 3.3, x.x & y.y vdc ++ * ++ */ ++static int cardtype_vcc_detect(void) ++{ ++ uint32 data32; ++ int cardtype; ++ ++ cardtype = MPI_CARDTYPE_NONE; ++ mpi->pcmcia_cntl1 = 0x0000A000; // Turn on the output enables and drive ++ // the CVS pins to 0. ++ data32 = mpi->pcmcia_cntl1; ++ switch (data32 & 0x00000003) // Test CD1# and CD2#, see if card is plugged in. ++ { ++ case 0x00000003: // No Card is in the slot. ++ printk("mpi: No Card is in the PCMCIA slot\n"); ++ break; ++ ++ case 0x00000002: // Partial insertion, No CD2#. ++ printk("mpi: Card in the PCMCIA slot partial insertion, no CD2 signal\n"); ++ break; ++ ++ case 0x00000001: // Partial insertion, No CD1#. ++ printk("mpi: Card in the PCMCIA slot partial insertion, no CD1 signal\n"); ++ break; ++ ++ case 0x00000000: ++ mpi->pcmcia_cntl1 = 0x0000A0C0; // Turn off the CVS output enables and ++ // float the CVS pins. ++ mdelay(1); ++ data32 = mpi->pcmcia_cntl1; ++ // Read the Register. ++ switch (data32 & 0x0000000C) // See what is on the CVS pins. ++ { ++ case 0x00000000: // CVS1 and CVS2 are tied to ground, only 1 option. ++ printk("mpi: Detected 3.3 & x.x 16-bit PCMCIA card\n"); ++ cardtype = MPI_CARDTYPE_PCMCIA; ++ break; ++ ++ case 0x00000004: // CVS1 is open or tied to CCD1/CCD2 and CVS2 is tied to ground. ++ // 2 valid voltage options. ++ switch (data32 & 0x00000003) // Test the values of CCD1 and CCD2. ++ { ++ case 0x00000003: // CCD1 and CCD2 are tied to 1 of the CVS pins. ++ // This is not a valid combination. ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ case 0x00000002: // CCD2 is tied to either CVS1 or CVS2. ++ mpi->pcmcia_cntl1 = 0x0000A080; // Drive CVS1 to a 0. ++ mdelay(1); ++ data32 = mpi->pcmcia_cntl1; ++ if (data32 & 0x00000002) { // CCD2 is tied to CVS2, not valid. ++ printk("mpi: Unknown card plugged into slot\n"); ++ } else { // CCD2 is tied to CVS1. ++ printk("mpi: Detected 3.3, x.x and y.y Cardbus card\n"); ++ cardtype = MPI_CARDTYPE_CARDBUS; ++ } ++ break; ++ ++ case 0x00000001: // CCD1 is tied to either CVS1 or CVS2. ++ // This is not a valid combination. ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ case 0x00000000: // CCD1 and CCD2 are tied to ground. ++ printk("mpi: Detected x.x vdc 16-bit PCMCIA card\n"); ++ cardtype = MPI_CARDTYPE_PCMCIA; ++ break; ++ } ++ break; ++ ++ case 0x00000008: // CVS2 is open or tied to CCD1/CCD2 and CVS1 is tied to ground. ++ // 2 valid voltage options. ++ switch (data32 & 0x00000003) // Test the values of CCD1 and CCD2. ++ { ++ case 0x00000003: // CCD1 and CCD2 are tied to 1 of the CVS pins. ++ // This is not a valid combination. ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ case 0x00000002: // CCD2 is tied to either CVS1 or CVS2. ++ mpi->pcmcia_cntl1 = 0x0000A040; // Drive CVS2 to a 0. ++ mdelay(1); ++ data32 = mpi->pcmcia_cntl1; ++ if (data32 & 0x00000002) { // CCD2 is tied to CVS1, not valid. ++ printk("mpi: Unknown card plugged into slot\n"); ++ } else {// CCD2 is tied to CVS2. ++ printk("mpi: Detected 3.3 and x.x Cardbus card\n"); ++ cardtype = MPI_CARDTYPE_CARDBUS; ++ } ++ break; ++ ++ case 0x00000001: // CCD1 is tied to either CVS1 or CVS2. ++ // This is not a valid combination. ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ case 0x00000000: // CCD1 and CCD2 are tied to ground. ++ cardtype = MPI_CARDTYPE_PCMCIA; ++ printk("mpi: Detected 3.3 vdc 16-bit PCMCIA card\n"); ++ break; ++ } ++ break; ++ ++ case 0x0000000C: // CVS1 and CVS2 are open or tied to CCD1/CCD2. ++ // 5 valid voltage options. ++ ++ switch (data32 & 0x00000003) // Test the values of CCD1 and CCD2. ++ { ++ case 0x00000003: // CCD1 and CCD2 are tied to 1 of the CVS pins. ++ // This is not a valid combination. ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ case 0x00000002: // CCD2 is tied to either CVS1 or CVS2. ++ // CCD1 is tied to ground. ++ mpi->pcmcia_cntl1 = 0x0000A040; // Drive CVS2 to a 0. ++ mdelay(1); ++ data32 = mpi->pcmcia_cntl1; ++ if (data32 & 0x00000002) { // CCD2 is tied to CVS1. ++ printk("mpi: Detected y.y vdc Cardbus card\n"); ++ } else { // CCD2 is tied to CVS2. ++ printk("mpi: Detected x.x vdc Cardbus card\n"); ++ } ++ cardtype = MPI_CARDTYPE_CARDBUS; ++ break; ++ ++ case 0x00000001: // CCD1 is tied to either CVS1 or CVS2. ++ // CCD2 is tied to ground. ++ ++ mpi->pcmcia_cntl1 = 0x0000A040; // Drive CVS2 to a 0. ++ mdelay(1); ++ data32 = mpi->pcmcia_cntl1; ++ if (data32 & 0x00000001) {// CCD1 is tied to CVS1. ++ printk("mpi: Detected 3.3 vdc Cardbus card\n"); ++ } else { // CCD1 is tied to CVS2. ++ printk("mpi: Detected x.x and y.y Cardbus card\n"); ++ } ++ cardtype = MPI_CARDTYPE_CARDBUS; ++ break; ++ ++ case 0x00000000: // CCD1 and CCD2 are tied to ground. ++ cardtype = MPI_CARDTYPE_PCMCIA; ++ printk("mpi: Detected 5 vdc 16-bit PCMCIA card\n"); ++ break; ++ } ++ break; ++ ++ default: ++ printk("mpi: Unknown card plugged into slot\n"); ++ break; ++ ++ } ++ } ++ return cardtype; ++} ++ ++/* ++ * mpi_DetectPcCard: Detect the plugged in PC-Card ++ * Return: < 0 => Unknown card detected ++ * 0 => No card detected ++ * 1 => 16-bit card detected ++ * 2 => 32-bit CardBus card detected ++ */ ++static int mpi_DetectPcCard(void) ++{ ++ int cardtype; ++ ++ cardtype = cardtype_vcc_detect(); ++ switch(cardtype) { ++ case MPI_CARDTYPE_PCMCIA: ++ mpi->pcmcia_cntl1 &= ~0x0000e000; // disable enable bits ++ //mpi->pcmcia_cntl1 = (mpi->pcmcia_cntl1 & ~PCCARD_CARD_RESET); ++ mpi->pcmcia_cntl1 |= (PCMCIA_ENABLE | PCMCIA_GPIO_ENABLE); ++ mpi_InitPcmciaSpace(); ++ mpi_ResetPcCard(cardtype, FALSE); ++ // Hold card in reset for 10ms ++ mdelay(10); ++ mpi_ResetPcCard(cardtype, TRUE); ++ // Let card come out of reset ++ mdelay(100); ++ break; ++ case MPI_CARDTYPE_CARDBUS: ++ // 8 => CardBus Enable ++ // 1 => PCI Slot Number ++ // C => Float VS1 & VS2 ++ mpi->pcmcia_cntl1 = (mpi->pcmcia_cntl1 & 0xFFFF0000) | ++ CARDBUS_ENABLE | ++ (CARDBUS_SLOT << 8)| ++ VS2_OEN | ++ VS1_OEN; ++ /* access to this memory window will be to/from CardBus */ ++ mpi->l2pmremap1 |= CARDBUS_MEM; ++ ++ // Need to reset the Cardbus Card. There's no CardManager to do this, ++ // and we need to be ready for PCI configuration. ++ mpi_ResetPcCard(cardtype, FALSE); ++ // Hold card in reset for 10ms ++ mdelay(10); ++ mpi_ResetPcCard(cardtype, TRUE); ++ // Let card come out of reset ++ mdelay(100); ++ break; ++ default: ++ break; ++ } ++ return cardtype; ++} ++ ++static int mpi_init(void) ++{ ++ unsigned long data; ++ unsigned int chipid; ++ unsigned int chiprev; ++ unsigned int sdramsize; ++ ++ chipid = (PERF->RevID & 0xFFFF0000) >> 16; ++ chiprev = (PERF->RevID & 0xFF); ++ sdramsize = getMemorySize(); ++ /* ++ * Init the pci interface ++ */ ++ data = GPIO->GPIOMode; // GPIO mode register ++ data |= GROUP2_PCI | GROUP1_MII_PCCARD; // PCI internal arbiter + Cardbus ++ GPIO->GPIOMode = data; // PCI internal arbiter ++ ++ /* ++ * In the BCM6348 CardBus support is defaulted to Slot 0 ++ * because there is no external IDSEL for CardBus. To disable ++ * the CardBus and allow a standard PCI card in Slot 0 ++ * set the cbus_idsel field to 0x1f. ++ */ ++ /* ++ uData = mpi->pcmcia_cntl1; ++ uData |= CARDBUS_IDSEL; ++ mpi->pcmcia_cntl1 = uData; ++ */ ++ // Setup PCI I/O Window range. Give 64K to PCI I/O ++ mpi->l2piorange = ~(BCM_PCI_IO_SIZE_64KB-1); ++ // UBUS to PCI I/O base address ++ mpi->l2piobase = BCM_PCI_IO_BASE & BCM_PCI_ADDR_MASK; ++ // UBUS to PCI I/O Window remap ++ mpi->l2pioremap = (BCM_PCI_IO_BASE | MEM_WINDOW_EN); ++ ++ // enable PCI related GPIO pins and data swap between system and PCI bus ++ mpi->locbuscntrl = (EN_PCI_GPIO | DIR_U2P_NOSWAP); ++ ++ /* Enable 6348 BusMaster and Memory access mode */ ++ data = mpi_GetLocalPciConfigReg(PCI_COMMAND); ++ data |= (PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER); ++ mpi_SetLocalPciConfigReg(PCI_COMMAND, data); ++ ++ /* Configure two 16 MByte PCI to System memory regions. */ ++ /* These memory regions are used when PCI device is a bus master */ ++ /* Accesses to the SDRAM from PCI bus will be "byte swapped" for this region */ ++ mpi_SetLocalPciConfigReg(PCI_BASE_ADDRESS_3, BCM_HOST_MEM_SPACE1); ++ mpi->sp0remap = 0x0; ++ ++ /* Accesses to the SDRAM from PCI bus will not be "byte swapped" for this region */ ++ mpi_SetLocalPciConfigReg(PCI_BASE_ADDRESS_4, BCM_HOST_MEM_SPACE2); ++ mpi->sp1remap = 0x0; ++ mpi->pcimodesel |= (PCI_BAR2_NOSWAP | 0x40); ++ ++ if ((chipid == 0x6348) && (chiprev == 0xb0)) { ++ mpi->sp0range = ~(sdramsize-1); ++ mpi->sp1range = ~(sdramsize-1); ++ } ++ /* ++ * Change 6348 PCI Cfg Reg. offset 0x40 to PCI memory read retry count infinity ++ * by set 0 in bit 8~15. This resolve read Bcm4306 srom return 0xffff in ++ * first read. ++ */ ++ data = mpi_GetLocalPciConfigReg(BRCM_PCI_CONFIG_TIMER); ++ data &= ~BRCM_PCI_CONFIG_TIMER_RETRY_MASK; ++ data |= 0x00000080; ++ mpi_SetLocalPciConfigReg(BRCM_PCI_CONFIG_TIMER, data); ++ ++ /* enable pci interrupt */ ++ mpi->locintstat |= (EXT_PCI_INT << 16); ++ ++ mpi_DetectPcCard(); ++ ++ ioport_resource.start = BCM_PCI_IO_BASE; ++ ioport_resource.end = BCM_PCI_IO_BASE + BCM_PCI_IO_SIZE_64KB; ++ ++#if defined(CONFIG_USB) ++ PERF->blkEnables |= USBH_CLK_EN; ++ mdelay(100); ++ *USBH_NON_OHCI = NON_OHCI_BYTE_SWAP; ++#endif ++ ++ return 0; ++} ++#endif ++ ++static int __init brcm63xx_setup(void) ++{ ++ extern int panic_timeout; ++ ++ _machine_restart = brcm_machine_restart; ++ _machine_halt = brcm_machine_halt; ++ _machine_power_off = brcm_machine_halt; ++ ++ board_timer_setup = brcm_timer_setup; ++ ++ panic_timeout = 180; ++ ++#if defined(CONFIG_BCM96348) && defined(CONFIG_PCI) ++ /* mpi initialization */ ++ mpi_init(); ++#endif ++ return 0; ++} ++ ++early_initcall(brcm63xx_setup); ++ ++/*************************************************************************** ++ * C++ New and delete operator functions ++ ***************************************************************************/ ++ ++/* void *operator new(unsigned int sz) */ ++void *_Znwj(unsigned int sz) ++{ ++ return( kmalloc(sz, GFP_KERNEL) ); ++} ++ ++/* void *operator new[](unsigned int sz)*/ ++void *_Znaj(unsigned int sz) ++{ ++ return( kmalloc(sz, GFP_KERNEL) ); ++} ++ ++/* placement new operator */ ++/* void *operator new (unsigned int size, void *ptr) */ ++void *ZnwjPv(unsigned int size, void *ptr) ++{ ++ return ptr; ++} ++ ++/* void operator delete(void *m) */ ++void _ZdlPv(void *m) ++{ ++ kfree(m); ++} ++ ++/* void operator delete[](void *m) */ ++void _ZdaPv(void *m) ++{ ++ kfree(m); ++} ++ ++EXPORT_SYMBOL(_Znwj); ++EXPORT_SYMBOL(_Znaj); ++EXPORT_SYMBOL(ZnwjPv); ++EXPORT_SYMBOL(_ZdlPv); ++EXPORT_SYMBOL(_ZdaPv); ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/time.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/time.c +--- linux-2.6.8.1/arch/mips/brcm-boards/bcm963xx/time.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/bcm963xx/time.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,277 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * Setup time for Broadcom 963xx MIPS boards ++ */ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++ ++#include ++#include ++ ++unsigned long r4k_interval; /* Amount to increment compare reg each time */ ++static unsigned long r4k_cur; /* What counter should be at next timer irq */ ++ ++/* Cycle counter value at the previous timer interrupt.. */ ++static unsigned int timerhi = 0, timerlo = 0; ++ ++extern volatile unsigned long wall_jiffies; ++ ++/* Optional board-specific timer routine */ ++void (*board_timer_interrupt)(int irq, void *dev_id, struct pt_regs * regs); ++ ++static inline void ack_r4ktimer(unsigned long newval) ++{ ++ write_c0_compare(newval); ++} ++ ++/* ++ * There are a lot of conceptually broken versions of the MIPS timer interrupt ++ * handler floating around. This one is rather different, but the algorithm ++ * is provably more robust. ++ */ ++static irqreturn_t brcm_timer_interrupt(int irq, void *dev_id, struct pt_regs *regs) ++{ ++ unsigned int count; ++ ++ if (r4k_interval == 0) ++ goto null; ++ ++ do { ++ do_timer(regs); ++ ++ if (board_timer_interrupt) ++ board_timer_interrupt(irq, dev_id, regs); ++ ++ r4k_cur += r4k_interval; ++ ack_r4ktimer(r4k_cur); ++ ++ } while (((count = (unsigned long)read_c0_count()) ++ - r4k_cur) < 0x7fffffff); ++ ++ if (!jiffies) { ++ /* ++ * If jiffies has overflowed in this timer_interrupt we must ++ * update the timer[hi]/[lo] to make do_fast_gettimeoffset() ++ * quotient calc still valid. -arca ++ */ ++ timerhi = timerlo = 0; ++ } else { ++ /* ++ * The cycle counter is only 32 bit which is good for about ++ * a minute at current count rates of upto 150MHz or so. ++ */ ++ timerhi += (count < timerlo); /* Wrap around */ ++ timerlo = count; ++ } ++ ++ return IRQ_HANDLED; ++ ++null: ++ ack_r4ktimer(0); ++ return IRQ_NONE; ++} ++ ++static struct irqaction brcm_timer_action = { ++ .handler = brcm_timer_interrupt, ++ .flags = SA_INTERRUPT, ++ .mask = CPU_MASK_NONE, ++ .name = "timer", ++ .next = NULL, ++ .dev_id = brcm_timer_interrupt, ++}; ++ ++ ++void __init brcm_timer_setup(struct irqaction *irq) ++{ ++ r4k_cur = (read_c0_count() + r4k_interval); ++ write_c0_compare(r4k_cur); ++ ++ /* we are using the cpu counter for timer interrupts */ ++ irq->handler = no_action; /* we use our own handler */ ++ setup_irq(MIPS_TIMER_INT, &brcm_timer_action); ++ set_c0_status(IE_IRQ5); ++} ++ ++#if 0 ++/* This is for machines which generate the exact clock. */ ++#define USECS_PER_JIFFY (1000000/HZ) ++#define USECS_PER_JIFFY_FRAC (0x100000000*1000000/HZ&0xffffffff) ++ ++static void call_do_div64_32( unsigned long *res, unsigned int high, ++ unsigned int low, unsigned long base ) ++{ ++ do_div64_32(*res, high, low, base); ++} ++ ++/* ++ * FIXME: Does playing with the RP bit in c0_status interfere with this code? ++ */ ++static unsigned long do_fast_gettimeoffset(void) ++{ ++ u32 count; ++ unsigned long res, tmp; ++ ++ /* Last jiffy when do_fast_gettimeoffset() was called. */ ++ static unsigned long last_jiffies=0; ++ unsigned long quotient; ++ ++ /* ++ * Cached "1/(clocks per usec)*2^32" value. ++ * It has to be recalculated once each jiffy. ++ */ ++ static unsigned long cached_quotient=0; ++ ++ tmp = jiffies; ++ ++ quotient = cached_quotient; ++ ++ if (tmp && last_jiffies != tmp) { ++ last_jiffies = tmp; ++#ifdef CONFIG_CPU_MIPS32 ++ if (last_jiffies != 0) { ++ ++ unsigned long r0; ++ /* gcc 3.0.1 gets an internal compiler error if there are two ++ * do_div64_32 inline macros. To work around this problem, ++ * do_div64_32 is called as a function. ++ */ ++ call_do_div64_32(&r0, timerhi, timerlo, tmp); ++ call_do_div64_32("ient, USECS_PER_JIFFY, ++ USECS_PER_JIFFY_FRAC, r0); ++ ++ cached_quotient = quotient; ++ ++ } ++#else ++ __asm__(".set\tnoreorder\n\t" ++ ".set\tnoat\n\t" ++ ".set\tmips3\n\t" ++ "lwu\t%0,%2\n\t" ++ "dsll32\t$1,%1,0\n\t" ++ "or\t$1,$1,%0\n\t" ++ "ddivu\t$0,$1,%3\n\t" ++ "mflo\t$1\n\t" ++ "dsll32\t%0,%4,0\n\t" ++ "nop\n\t" ++ "ddivu\t$0,%0,$1\n\t" ++ "mflo\t%0\n\t" ++ ".set\tmips0\n\t" ++ ".set\tat\n\t" ++ ".set\treorder" ++ :"=&r" (quotient) ++ :"r" (timerhi), ++ "m" (timerlo), ++ "r" (tmp), ++ "r" (USECS_PER_JIFFY) ++ :"$1"); ++ cached_quotient = quotient; ++#endif ++ } ++ ++ /* Get last timer tick in absolute kernel time */ ++ count = read_c0_count(); ++ ++ /* .. relative to previous jiffy (32 bits is enough) */ ++ count -= timerlo; ++ ++ __asm__("multu\t%1,%2\n\t" ++ "mfhi\t%0" ++ :"=r" (res) ++ :"r" (count), ++ "r" (quotient)); ++ ++ /* ++ * Due to possible jiffies inconsistencies, we need to check ++ * the result so that we'll get a timer that is monotonic. ++ */ ++ if (res >= USECS_PER_JIFFY) ++ res = USECS_PER_JIFFY-1; ++ ++ return res; ++} ++ ++void do_gettimeofday(struct timeval *tv) ++{ ++ unsigned int flags; ++ ++ read_lock_irqsave (&xtime_lock, flags); ++ tv->tv_sec = xtime.tv_sec; ++ tv->tv_usec = xtime.tv_nsec/1000; ++ tv->tv_usec += do_fast_gettimeoffset(); ++ ++ /* ++ * xtime is atomically updated in timer_bh. jiffies - wall_jiffies ++ * is nonzero if the timer bottom half hasnt executed yet. ++ */ ++ if (jiffies - wall_jiffies) ++ tv->tv_usec += USECS_PER_JIFFY; ++ ++ read_unlock_irqrestore (&xtime_lock, flags); ++ ++ if (tv->tv_usec >= 1000000) { ++ tv->tv_usec -= 1000000; ++ tv->tv_sec++; ++ } ++} ++ ++EXPORT_SYMBOL(do_gettimeofday); ++ ++int do_settimeofday(struct timespec *tv) ++{ ++ write_lock_irq (&xtime_lock); ++ ++ /* This is revolting. We need to set the xtime.tv_usec correctly. ++ * However, the value in this location is is value at the last tick. ++ * Discover what correction gettimeofday would have done, and then ++ * undo it! ++ */ ++ tv->tv_nsec -= do_fast_gettimeoffset()*NSEC_PER_USEC; ++ ++ if (tv->tv_nsec < 0) { ++ tv->tv_nsec += 1000000*NSEC_PER_USEC; ++ tv->tv_sec--; ++ } ++ ++ xtime.tv_sec = tv->tv_sec; ++ xtime.tv_nsec = tv->tv_nsec; ++ time_adjust = 0; /* stop active adjtime() */ ++ time_status |= STA_UNSYNC; ++ time_maxerror = NTP_PHASE_LIMIT; ++ time_esterror = NTP_PHASE_LIMIT; ++ ++ write_unlock_irq (&xtime_lock); ++} ++ ++EXPORT_SYMBOL(do_settimeofday); ++ ++#endif +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/generic/Makefile linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/Makefile +--- linux-2.6.8.1/arch/mips/brcm-boards/generic/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/Makefile 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,11 @@ ++# ++# Makefile for generic Broadcom MIPS boards ++# ++# Copyright (C) 2001 Broadcom Corporation ++# ++obj-y := int-handler.o ++ ++ifdef CONFIG_REMOTE_DEBUG ++obj-y += dbg_io.o ++endif ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/generic/dbg_io.c linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/dbg_io.c +--- linux-2.6.8.1/arch/mips/brcm-boards/generic/dbg_io.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/dbg_io.c 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,260 @@ ++/* ++<:copyright-gpl ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++ ++#undef PRNT /* define for debug printing */ ++ ++#define UART16550_BAUD_2400 2400 ++#define UART16550_BAUD_4800 4800 ++#define UART16550_BAUD_9600 9600 ++#define UART16550_BAUD_19200 19200 ++#define UART16550_BAUD_38400 38400 ++#define UART16550_BAUD_57600 57600 ++#define UART16550_BAUD_115200 115200 ++ ++#define UART16550_PARITY_NONE 0 ++#define UART16550_PARITY_ODD 0x08 ++#define UART16550_PARITY_EVEN 0x18 ++#define UART16550_PARITY_MARK 0x28 ++#define UART16550_PARITY_SPACE 0x38 ++ ++#define UART16550_DATA_5BIT 0x0 ++#define UART16550_DATA_6BIT 0x1 ++#define UART16550_DATA_7BIT 0x2 ++#define UART16550_DATA_8BIT 0x3 ++ ++#define UART16550_STOP_1BIT 0x0 ++#define UART16550_STOP_2BIT 0x4 ++ ++volatile Uart * stUart = UART_BASE; ++ ++#define WRITE16(addr, value) ((*(volatile UINT16 *)((ULONG)&addr)) = value) ++ ++/* Low level UART routines from promcon.c */ ++extern void prom_putc(char c); ++extern char prom_getc(void); ++extern int prom_getc_nowait(void); ++extern int prom_testc(void); ++ ++extern void set_debug_traps(void); ++extern void breakpoint(void); ++extern void enable_brcm_irq(unsigned int); ++extern void set_async_breakpoint(unsigned int epc); ++ ++#ifdef CONFIG_GDB_CONSOLE ++extern void register_gdb_console(void); ++#endif ++ ++int gdb_initialized = 0; ++ ++#define GDB_BUF_SIZE 512 /* power of 2, please */ ++ ++static char gdb_buf[GDB_BUF_SIZE] ; ++static int gdb_buf_in_inx ; ++static atomic_t gdb_buf_in_cnt ; ++static int gdb_buf_out_inx ; ++ ++void debugInit(uint32 baud, uint8 data, uint8 parity, uint8 stop) ++{ ++ /* Do nothing, assume boot loader has already set up serial port */ ++ printk("debugInit called\n"); ++} ++ ++/* ++ * Get a char if available, return -1 if nothing available. ++ * Empty the receive buffer first, then look at the interface hardware. ++ */ ++static int read_char(void) ++{ ++ if (atomic_read(&gdb_buf_in_cnt) != 0) /* intr routine has q'd chars */ ++ { ++ int chr ; ++ ++ chr = gdb_buf[gdb_buf_out_inx++] ; ++ gdb_buf_out_inx &= (GDB_BUF_SIZE - 1) ; ++ atomic_dec(&gdb_buf_in_cnt) ; ++ return(chr) ; ++ } ++ return(prom_getc_nowait()) ; /* read from hardware */ ++} /* read_char */ ++ ++/* ++ * This is the receiver interrupt routine for the GDB stub. ++ * It will receive a limited number of characters of input ++ * from the gdb host machine and save them up in a buffer. ++ * ++ * When the gdb stub routine getDebugChar() is called it ++ * draws characters out of the buffer until it is empty and ++ * then reads directly from the serial port. ++ * ++ * We do not attempt to write chars from the interrupt routine ++ * since the stubs do all of that via putDebugChar() which ++ * writes one byte after waiting for the interface to become ++ * ready. ++ * ++ * The debug stubs like to run with interrupts disabled since, ++ * after all, they run as a consequence of a breakpoint in ++ * the kernel. ++ * ++ * Perhaps someone who knows more about the tty driver than I ++ * care to learn can make this work for any low level serial ++ * driver. ++ */ ++static void gdb_interrupt(int irq, void *dev_id, struct pt_regs * regs) ++{ ++ int chr ; ++ int more; ++ do ++ { ++ chr = prom_getc_nowait() ; ++ more = prom_testc(); ++ if (chr < 0) continue ; ++ ++ /* If we receive a Ctrl-C then this is GDB trying to break in */ ++ if (chr == 3) ++ { ++ /* Replace current instruction with breakpoint */ ++ set_async_breakpoint(regs->cp0_epc); ++ //breakpoint(); ++ } ++ ++#ifdef PRNT ++ printk("gdb_interrupt: chr=%02x '%c', more = %x\n", ++ chr, chr > ' ' && chr < 0x7F ? chr : ' ', more) ; ++#endif ++ ++ if (atomic_read(&gdb_buf_in_cnt) >= GDB_BUF_SIZE) ++ { /* buffer overflow, clear it */ ++ gdb_buf_in_inx = 0 ; ++ atomic_set(&gdb_buf_in_cnt, 0) ; ++ gdb_buf_out_inx = 0 ; ++ break ; ++ } ++ ++ gdb_buf[gdb_buf_in_inx++] = chr ; ++ gdb_buf_in_inx &= (GDB_BUF_SIZE - 1) ; ++ atomic_inc(&gdb_buf_in_cnt) ; ++ } ++ while (more !=0); ++ ++} /* gdb_interrupt */ ++ ++/* ++ * getDebugChar ++ * ++ * This is a GDB stub routine. It waits for a character from the ++ * serial interface and then returns it. If there is no serial ++ * interface connection then it returns a bogus value which will ++ * almost certainly cause the system to hang. ++ */ ++int getDebugChar(void) ++{ ++ volatile int chr ; ++ ++#ifdef PRNT ++ printk("getDebugChar: ") ; ++#endif ++ ++ while ( (chr = read_char()) < 0 ) ; ++ ++#ifdef PRNT ++ printk("%c\n", chr > ' ' && chr < 0x7F ? chr : ' ') ; ++#endif ++ return(chr) ; ++ ++} /* getDebugChar */ ++ ++/* ++ * putDebugChar ++ * ++ * This is a GDB stub routine. It waits until the interface is ready ++ * to transmit a char and then sends it. If there is no serial ++ * interface connection then it simply returns to its caller, having ++ * pretended to send the char. ++ */ ++int putDebugChar(unsigned char chr) ++{ ++#ifdef PRNT ++ printk("putDebugChar: chr=%02x '%c'\n", chr, ++ chr > ' ' && chr < 0x7F ? chr : ' ') ; ++#endif ++ ++ prom_putc(chr) ; /* this routine will wait */ ++ return 1; ++ ++} /* putDebugChar */ ++ ++/* Just a NULL routine for testing. */ ++void gdb_null(void) ++{ ++} ++ ++void rs_kgdb_hook(int tty_no) ++{ ++ printk("rs_kgdb_hook: tty %d\n", tty_no); ++ ++ /* Call GDB routine to setup the exception vectors for the debugger */ ++ set_debug_traps(); ++ ++ printk("Breaking into debugger...\n"); ++ breakpoint(); ++ gdb_null() ; ++ printk("Connected.\n"); ++ ++ gdb_initialized = 1; ++ ++#ifdef CONFIG_GDB_CONSOLE ++ register_gdb_console(); ++#endif ++} ++ ++void kgdb_hook_irq() ++{ ++ int retval ; ++ uint16 uMask; ++ ++ printk("GDB: Hooking UART interrupt\n"); ++ ++ retval = request_irq(INTERRUPT_ID_UART, ++ gdb_interrupt, ++ SA_INTERRUPT, ++ "GDB-stub", NULL); ++ ++ if (retval != 0) ++ printk("gdb_hook: request_irq(irq=%d) failed: %d\n", INTERRUPT_ID_UART, retval); ++ ++ // Enable UART config Rx not empty IRQ ++ uMask = READ16(stUart->intMask) ; ++ // printk("intMask: 0x%x\n", uMask); ++ WRITE16(stUart->intMask, uMask | RXFIFONE); ++} ++ ++ +diff -urN linux-2.6.8.1/arch/mips/brcm-boards/generic/int-handler.S linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/int-handler.S +--- linux-2.6.8.1/arch/mips/brcm-boards/generic/int-handler.S 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/brcm-boards/generic/int-handler.S 2006-06-26 09:07:08.000000000 +0200 +@@ -0,0 +1,59 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ * Generic interrupt handler for Broadcom MIPS boards ++ */ ++ ++#include ++ ++#include ++#include ++#include ++#include ++ ++/* ++ * MIPS IRQ Source ++ * -------- ------ ++ * 0 Software (ignored) ++ * 1 Software (ignored) ++ * 2 Combined hardware interrupt (hw0) ++ * 3 Hardware ++ * 4 Hardware ++ * 5 Hardware ++ * 6 Hardware ++ * 7 R4k timer ++ */ ++ ++ .text ++ .set noreorder ++ .set noat ++ .align 5 ++ NESTED(brcmIRQ, PT_SIZE, sp) ++ SAVE_ALL ++ CLI ++ .set noreorder ++ .set at ++ ++ jal brcm_irq_dispatch ++ move a0, sp ++ ++ j ret_from_irq ++ nop ++ ++ END(brcmIRQ) +--- linux-2.6.8.1/arch/mips/Kconfig 2004-08-14 12:55:32.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/Kconfig 2006-06-26 09:07:08.000000000 +0200 +@@ -27,6 +27,17 @@ + + menu "Machine selection" + ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++ ++config MIPS_BRCM ++ bool "Support for the Broadcom boards" ++ help ++ This is a family of boards based on the Broadcom MIPS32 ++ ++source "arch/mips/brcm-boards/bcm963xx/Kconfig" ++ ++# CONFIG_MIPS_BRCM End Broadcom changed code. ++ + config MACH_JAZZ + bool "Support for the Jazz family of machines" + select ISA +@@ -146,6 +157,7 @@ + depends on MIPS32 + select DMA_NONCOHERENT + select HW_HAS_PCI ++ select SWAP_IO_SPACE + + config MIPS_COBALT + bool "Support for Cobalt Server (EXPERIMENTAL)" +@@ -198,6 +210,7 @@ + select IRQ_CPU + select MIPS_GT96100 + select RM7000_CPU_SCACHE ++ select SWAP_IO_SPACE + help + This is an evaluation board based on the Galileo GT-96100 LAN/WAN + communications controllers containing a MIPS R5000 compatible core +@@ -268,6 +281,7 @@ + bool "Support for MIPS Atlas board" + select DMA_NONCOHERENT + select HW_HAS_PCI ++ select SWAP_IO_SPACE + help + This enables support for the QED R5231-based MIPS Atlas evaluation + board. +@@ -277,6 +291,7 @@ + select HAVE_STD_PC_SERIAL_PORT + select DMA_NONCOHERENT + select HW_HAS_PCI ++ select SWAP_IO_SPACE + help + This enables support for the VR5000-based MIPS Malta evaluation + board. +@@ -294,6 +309,7 @@ + select IRQ_CPU + select IRQ_CPU_RM7K + select RM7000_CPU_SCACHE ++ select SWAP_IO_SPACE + help + The Ocelot is a MIPS-based Single Board Computer (SBC) made by + Momentum Computer . +@@ -306,6 +322,7 @@ + select IRQ_CPU_RM7K + select PCI_MARVELL + select RM7000_CPU_SCACHE ++ select SWAP_IO_SPACE + help + The Ocelot is a MIPS-based Single Board Computer (SBC) made by + Momentum Computer . +@@ -318,6 +335,7 @@ + select IRQ_MV64340 + select PCI_MARVELL + select RM7000_CPU_SCACHE ++ select SWAP_IO_SPACE + help + The Ocelot is a MIPS-based Single Board Computer (SBC) made by + Momentum Computer . +@@ -332,6 +350,7 @@ + select LIMITED_DMA + select PCI_MARVELL + select RM7000_CPU_SCACHE ++ select SWAP_IO_SPACE + help + The Jaguar ATX is a MIPS-based Single Board Computer (SBC) made by + Momentum Computer . +@@ -349,6 +368,7 @@ + select HW_HAS_PCI + select IRQ_CPU + select IRQ_CPU_RM7K ++ select SWAP_IO_SPACE + help + Yosemite is an evaluation board for the RM9000x2 processor + manufactured by PMC-Sierra +@@ -411,6 +431,7 @@ + select DMA_NONCOHERENT + select IP22_CPU_SCACHE + select IRQ_CPU ++ select SWAP_IO_SPACE + help + This are the SGI Indy, Challenge S and Indigo2, as well as certain + OEM variants like the Tandem CMN B006S. To compile a Linux kernel +@@ -529,12 +550,14 @@ + depends on SOC_AU1000 + select DMA_NONCOHERENT + select HW_HAS_PCI ++ select SWAP_IO_SPACE + + config MIPS_PB1100 + bool "PB1100 board" + depends on SOC_AU1100 + select DMA_NONCOHERENT + select HW_HAS_PCI ++ select SWAP_IO_SPACE + + config MIPS_PB1500 + bool "PB1500 board" +@@ -596,6 +619,7 @@ + bool "Support for Broadcom BCM1xxx SOCs (EXPERIMENTAL)" + depends on EXPERIMENTAL + select DMA_COHERENT ++ select SWAP_IO_SPACE + + choice + prompt "BCM1xxx SOC-based board" +@@ -818,6 +842,7 @@ + select DMA_NONCOHERENT + select HW_HAS_PCI + select ISA ++ select SWAP_IO_SPACE + + config RWSEM_GENERIC_SPINLOCK + bool +@@ -934,8 +959,6 @@ + + config SWAP_IO_SPACE + bool +- depends on TOSHIBA_JMR3927 || TOSHIBA_RBTX4927 || SIBYTE_SB1xxx_SOC || SGI_IP22 || MOMENCO_OCELOT_C || MOMENCO_OCELOT_G || MOMENCO_OCELOT || MOMENCO_JAGUAR_ATX || MIPS_MALTA || MIPS_ATLAS || MIPS_EV96100 || MIPS_PB1100 || MIPS_PB1000 +- default y + + # + # Unfortunately not all GT64120 systems run the chip at the same clock. +--- linux-2.6.8.1/arch/mips/kernel/cpu-probe.c 2004-08-14 12:55:10.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/cpu-probe.c 2006-06-26 09:07:09.000000000 +0200 +@@ -538,6 +538,27 @@ + } + } + ++#if defined(CONFIG_MIPS_BRCM) ++static inline void cpu_probe_broadcom(struct cpuinfo_mips *c) ++{ ++ decode_config1(c); ++ switch (c->processor_id & 0xff00) { ++ case PRID_IMP_BCM6338: ++ c->cputype = CPU_BCM6338; ++ break; ++ case PRID_IMP_BCM6345: ++ c->cputype = CPU_BCM6345; ++ break; ++ case PRID_IMP_BCM6348: ++ c->cputype = CPU_BCM6348; ++ break; ++ default: ++ c->cputype = CPU_UNKNOWN; ++ break; ++ } ++} ++#endif ++ + static inline void cpu_probe_sandcraft(struct cpuinfo_mips *c) + { + decode_config1(c); +@@ -576,6 +597,11 @@ + case PRID_COMP_SIBYTE: + cpu_probe_sibyte(c); + break; ++#if defined(CONFIG_MIPS_BRCM) ++ case PRID_COMP_BROADCOM: ++ cpu_probe_broadcom(c); ++ break; ++#endif + + case PRID_COMP_SANDCRAFT: + cpu_probe_sandcraft(c); +--- linux-2.6.8.1/arch/mips/kernel/gdb-stub.c 2004-08-14 12:56:23.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/gdb-stub.c 2006-06-26 09:07:09.000000000 +0200 +@@ -171,6 +171,8 @@ + static unsigned char *mem2hex(char *mem, char *buf, int count, int may_fault); + void handle_exception(struct gdb_regs *regs); + ++int kgdb_enabled; ++ + /* + * spin locks for smp case + */ +--- linux-2.6.8.1/arch/mips/kernel/irq.c 2004-08-14 12:54:50.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/irq.c 2006-06-26 09:07:09.000000000 +0200 +@@ -30,12 +30,7 @@ + /* + * Controller mappings for all interrupt sources: + */ +-irq_desc_t irq_desc[NR_IRQS] __cacheline_aligned = { +- [0 ... NR_IRQS-1] = { +- .handler = &no_irq_type, +- .lock = SPIN_LOCK_UNLOCKED +- } +-}; ++irq_desc_t irq_desc[NR_IRQS] __cacheline_aligned; + + static void register_irq_proc (unsigned int irq); + +@@ -809,7 +804,20 @@ + return 0; + } + +-void __init init_generic_irq(void) ++#ifdef CONFIG_KGDB ++extern void breakpoint(void); ++extern void set_debug_traps(void); ++ ++static int kgdb_flag = 1; ++static int __init nokgdb(char *str) ++{ ++ kgdb_flag = 0; ++ return 1; ++} ++__setup("nokgdb", nokgdb); ++#endif ++ ++void __init init_IRQ(void) + { + int i; + +@@ -818,7 +826,18 @@ + irq_desc[i].action = NULL; + irq_desc[i].depth = 1; + irq_desc[i].handler = &no_irq_type; ++ irq_desc[i].lock = SPIN_LOCK_UNLOCKED; ++ } ++ ++ arch_init_irq(); ++ ++#ifdef CONFIG_KGDB ++ if (kgdb_flag) { ++ printk("Wait for gdb client connection ...\n"); ++ set_debug_traps(); ++ breakpoint(); + } ++#endif + } + + EXPORT_SYMBOL(disable_irq_nosync); +@@ -833,7 +852,7 @@ + + static struct proc_dir_entry * smp_affinity_entry [NR_IRQS]; + +-static cpumask_t irq_affinity [NR_IRQS] = { [0 ... NR_IRQS-1] = ~0UL }; ++static cpumask_t irq_affinity [NR_IRQS] = { [0 ... NR_IRQS-1] = CPU_MASK_ALL }; + static int irq_affinity_read_proc (char *page, char **start, off_t off, + int count, int *eof, void *data) + { +--- linux-2.6.8.1/arch/mips/kernel/Makefile 2004-08-14 12:55:19.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/Makefile 2006-06-26 09:07:09.000000000 +0200 +@@ -8,6 +8,13 @@ + ptrace.o reset.o semaphore.o setup.o signal.o syscall.o \ + time.o traps.o unaligned.o + ++# CONFIG_MIPS_BRCM Begin Broadcom added code. ++# gcc 3.4.x reorders code with -Os and -O2, breaking the save_static stuff. ++CFLAGS_syscall.o := -O1 ++CFLAGS_signal.o := -O1 ++CFLAGS_signal32.o := -O1 ++# CONFIG_MIPS_BRCM End Broadcom added code. ++ + ifdef CONFIG_MODULES + obj-y += mips_ksyms.o module.o + obj-$(CONFIG_MIPS32) += module-elf32.o +--- linux-2.6.8.1/arch/mips/kernel/proc.c 2004-08-14 12:55:09.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/proc.c 2006-06-26 09:07:09.000000000 +0200 +@@ -75,6 +75,11 @@ + [CPU_VR4133] "NEC VR4133", + [CPU_VR4181] "NEC VR4181", + [CPU_VR4181A] "NEC VR4181A", ++#if defined(CONFIG_MIPS_BRCM) ++ [CPU_BCM6338] "BCM6338", ++ [CPU_BCM6345] "BCM6345", ++ [CPU_BCM6348] "BCM6348", ++#endif + [CPU_SR71000] "Sandcraft SR71000" + }; + +--- linux-2.6.8.1/arch/mips/kernel/scall32-o32.S 2004-08-14 12:54:49.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/scall32-o32.S 2006-06-26 12:42:05.000000000 +0200 +@@ -640,9 +640,9 @@ + syscalltable + .size sys_call_table, . - sys_call_table + +- .macro sys function, nargs ++ /*.macro sys function, nargs + .byte \nargs +- .endm ++ .endm*/ + + sys_narg_table: + syscalltable +--- linux-2.6.8.1/arch/mips/kernel/time.c 2004-08-14 12:55:20.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/time.c 2006-06-26 09:07:09.000000000 +0200 +@@ -274,11 +274,15 @@ + + /* .. relative to previous jiffy (32 bits is enough) */ + count -= timerlo; +- ++ + __asm__("multu %1,%2" + : "=h" (res) + : "r" (count), "r" (sll32_usecs_per_cycle) ++#if defined(CONFIG_MIPS_BRCM) ++ : "lo"); ++#else + : "lo", "accum"); ++#endif + + /* + * Due to possible jiffies inconsistencies, we need to check +@@ -333,7 +337,11 @@ + __asm__("multu %1,%2" + : "=h" (res) + : "r" (count), "r" (quotient) ++#if defined(CONFIG_MIPS_BRCM) ++ : "lo"); ++#else + : "lo", "accum"); ++#endif + + /* + * Due to possible jiffies inconsistencies, we need to check +@@ -375,7 +383,11 @@ + : "r" (timerhi), "m" (timerlo), + "r" (tmp), "r" (USECS_PER_JIFFY), + "r" (USECS_PER_JIFFY_FRAC) ++#if defined(CONFIG_MIPS_BRCM) ++ : "hi", "lo"); ++#else + : "hi", "lo", "accum"); ++#endif + cached_quotient = quotient; + } + } +@@ -389,7 +401,11 @@ + __asm__("multu %1,%2" + : "=h" (res) + : "r" (count), "r" (quotient) ++#if defined(CONFIG_MIPS_BRCM) ++ : "lo"); ++#else + : "lo", "accum"); ++#endif + + /* + * Due to possible jiffies inconsistencies, we need to check +@@ -738,6 +754,7 @@ + board_timer_setup(&timer_irqaction); + } + ++ + #define FEBRUARY 2 + #define STARTOFTIME 1970 + #define SECDAY 86400L +--- linux-2.6.8.1/arch/mips/kernel/traps.c 2004-08-14 12:55:20.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/kernel/traps.c 2006-06-26 09:07:09.000000000 +0200 +@@ -246,6 +246,13 @@ + + static spinlock_t die_lock = SPIN_LOCK_UNLOCKED; + ++#if defined(CONFIG_MIPS_BRCM) ++#ifdef CONFIG_REMOTE_DEBUG ++#include ++extern void handle_exception(struct gdb_regs *regs); ++#endif ++#endif ++ + NORET_TYPE void __die(const char * str, struct pt_regs * regs, + const char * file, const char * func, unsigned long line) + { +@@ -258,7 +265,33 @@ + printk(" in %s:%s, line %ld", file, func, line); + printk("[#%d]:\n", ++die_counter); + show_registers(regs); ++#if defined(CONFIG_MIPS_BRCM) ++#ifdef CONFIG_REMOTE_DEBUG ++ { ++ struct gdb_regs regs2; ++ int i; ++ long *ptr; ++ ++ ptr = ®s2.reg0; ++ /* Copy registers to GDB structure */ ++ for(i=0; i<32;i++) ++ *ptr++ = regs->regs[i]; ++ ++ regs2.lo = regs->lo; ++ regs2.hi = regs->hi; ++ regs2.cp0_epc = regs->cp0_epc; ++ regs2.cp0_badvaddr = regs->cp0_badvaddr; ++ regs2.cp0_status = regs->cp0_status; ++ regs2.cp0_cause = regs->cp0_cause; ++ ++ handle_exception(®s2); /* Break to GDB */ ++ } ++#endif ++#endif + spin_unlock_irq(&die_lock); ++ /* Ron add for kernel crash */ ++ (*(volatile unsigned int *)(0xfffe040c)) &= ~(1<<5); ++ machine_restart(NULL); + do_exit(SIGSEGV); + } + +--- linux-2.6.8.1/arch/mips/Makefile 2004-08-14 12:54:47.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/Makefile 2006-06-26 09:07:09.000000000 +0200 +@@ -41,8 +41,14 @@ + endif + + ifdef CONFIG_CROSSCOMPILE ++# CONFIG_MIPS_BRCM Begin Broadcom added code. ++ifdef CONFIG_MIPS_BRCM ++CROSS_COMPILE := mips-linux-uclibc-#$(tool-prefix) ++else + CROSS_COMPILE := $(tool-prefix) + endif ++# CONFIG_MIPS_BRCM End Broadcom added code. ++endif + + # + # GCC uses -G 0 -mabicalls -fpic as default. We don't want PIC in the kernel +@@ -57,6 +63,9 @@ + cflags-y := -I $(TOPDIR)/include/asm/gcc + cflags-y += -G 0 -mno-abicalls -fno-pic -pipe + cflags-y += $(call check_gcc, -finline-limit=100000,) ++ifeq ($(strip $(JTAG_KERNEL_DEBUG)),y) ++cflags-y += -g ++endif + LDFLAGS_vmlinux += -G 0 -static -n + MODFLAGS += -mlong-calls + +@@ -64,6 +73,12 @@ + + check_warning = $(shell if $(CC) $(1) -c -o /dev/null -xc /dev/null > /dev/null 2>&1; then echo "$(1)"; else echo "$(2)"; fi) + ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++ifdef CONFIG_MIPS_BRCM ++cflags-$(CONFIG_REMOTE_DEBUG) += -ggdb ++endif ++# CONFIG_MIPS_BRCM End Broadcom changed code. ++ + # + # Use: $(call set_gccflags,,,,,) + # +@@ -302,6 +317,20 @@ + libs-$(CONFIG_BAGET_MIPS) += arch/mips/baget/ arch/mips/baget/prom/ + load-$(CONFIG_BAGET_MIPS) += 0x80001000 + ++# CONFIG_MIPS_BRCM Begin Broadcom added code. ++ifdef CONFIG_MIPS_BRCM ++# ++# Broadcom board ++core-$(CONFIG_BCM96338) += arch/mips/brcm-boards/generic/ arch/mips/brcm-boards/bcm963xx/ ++cflags-$(CONFIG_BCM96338) += -Iinclude/asm-mips/mach-bcm963xx ++core-$(CONFIG_BCM96345) += arch/mips/brcm-boards/generic/ arch/mips/brcm-boards/bcm963xx/ ++cflags-$(CONFIG_BCM96345) += -Iinclude/asm-mips/mach-bcm963xx ++core-$(CONFIG_BCM96348) += arch/mips/brcm-boards/generic/ arch/mips/brcm-boards/bcm963xx/ ++cflags-$(CONFIG_BCM96348) += -Iinclude/asm-mips/mach-bcm963xx ++load-$(CONFIG_MIPS_BRCM) += 0x80010000 ++endif ++# CONFIG_MIPS_BRCM End Broadcom added code. ++ + # + # Cobalt Server + # +--- linux-2.6.8.1/arch/mips/mm/c-r4k.c 2004-08-14 12:56:22.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/mm/c-r4k.c 2006-06-26 09:07:09.000000000 +0200 +@@ -86,7 +86,7 @@ + + static void (* r4k_blast_dcache)(void); + +-static void r4k_blast_dcache_setup(void) ++static inline void r4k_blast_dcache_setup(void) + { + unsigned long dc_lsize = cpu_dcache_line_size(); + +@@ -385,6 +385,7 @@ + static void r4k_flush_icache_range(unsigned long start, unsigned long end) + { + unsigned long dc_lsize = current_cpu_data.dcache.linesz; ++ unsigned long ic_lsize = current_cpu_data.icache.linesz; + unsigned long addr, aend; + + if (!cpu_has_ic_fills_f_dc) { +@@ -407,14 +408,14 @@ + if (end - start > icache_size) + r4k_blast_icache(); + else { +- addr = start & ~(dc_lsize - 1); +- aend = (end - 1) & ~(dc_lsize - 1); ++ addr = start & ~(ic_lsize - 1); ++ aend = (end - 1) & ~(ic_lsize - 1); + while (1) { + /* Hit_Invalidate_I */ + protected_flush_icache_line(addr); + if (addr == aend) + break; +- addr += dc_lsize; ++ addr += ic_lsize; + } + } + } +@@ -802,6 +803,13 @@ + if (!(config & MIPS_CONF_M)) + panic("Don't know how to probe P-caches on this cpu."); + ++#if defined(CONFIG_MIPS_BRCM) ++ if (c->cputype == CPU_BCM6338 || c->cputype == CPU_BCM6345 || c->cputype == CPU_BCM6348){ ++ printk("brcm mips: enabling icache and dcache...\n"); ++ /* Enable caches */ ++ write_c0_diag(read_c0_diag() | 0xC0000000); ++ } ++#endif + /* + * So we seem to be a MIPS32 or MIPS64 CPU + * So let's probe the I-cache ... +--- linux-2.6.8.1/arch/mips/pci/fixup-bcm96348.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/pci/fixup-bcm96348.c 2006-06-26 09:07:09.000000000 +0200 +@@ -0,0 +1,85 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++#include ++#include ++#include ++ ++#include ++#include ++#include ++ ++static volatile MpiRegisters * mpi = (MpiRegisters *)(MPI_BASE); ++ ++static char irq_tab_bcm96348[] __initdata = { ++ [0] = INTERRUPT_ID_MPI, ++ [1] = INTERRUPT_ID_MPI, ++#if defined(CONFIG_USB) ++ [USB_HOST_SLOT] = INTERRUPT_ID_USBH ++#endif ++}; ++ ++int __init pcibios_map_irq(struct pci_dev *dev, u8 slot, u8 pin) ++{ ++ return irq_tab_bcm96348[slot]; ++} ++ ++static void bcm96348_fixup(struct pci_dev *dev) ++{ ++ uint32 memaddr; ++ uint32 size; ++ ++ memaddr = pci_resource_start(dev, 0); ++ size = pci_resource_len(dev, 0); ++ ++ switch (PCI_SLOT(dev->devfn)) { ++ case 0: ++ // UBUS to PCI address range ++ // Memory Window 1. Mask determines which bits are decoded. ++ mpi->l2pmrange1 = ~(size-1); ++ // UBUS to PCI Memory base address. This is akin to the ChipSelect base ++ // register. ++ mpi->l2pmbase1 = memaddr & BCM_PCI_ADDR_MASK; ++ // UBUS to PCI Remap Address. Replaces the masked address bits in the ++ // range register with this setting. ++ // Also, enable direct I/O and direct Memory accesses ++ mpi->l2pmremap1 = (memaddr | MEM_WINDOW_EN); ++ break; ++ ++ case 1: ++ // Memory Window 2 ++ mpi->l2pmrange2 = ~(size-1); ++ // UBUS to PCI Memory base address. ++ mpi->l2pmbase2 = memaddr & BCM_PCI_ADDR_MASK; ++ // UBUS to PCI Remap Address ++ mpi->l2pmremap2 = (memaddr | MEM_WINDOW_EN); ++ break; ++ ++#if defined(CONFIG_USB) ++ case USB_HOST_SLOT: ++ dev->resource[0].start = USB_HOST_BASE; ++ dev->resource[0].end = USB_HOST_BASE+USB_BAR0_MEM_SIZE-1; ++ break; ++#endif ++ } ++} ++ ++struct pci_fixup pcibios_fixups[] = { ++ { PCI_FIXUP_FINAL, PCI_ANY_ID, PCI_ANY_ID, bcm96348_fixup }, ++ {0} ++}; +--- linux-2.6.8.1/arch/mips/pci/ops-bcm96348.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/pci/ops-bcm96348.c 2006-06-26 09:07:09.000000000 +0200 +@@ -0,0 +1,276 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++ ++#include ++ ++#if defined(CONFIG_USB) ++#if 0 ++#define DPRINT(x...) printk(x) ++#else ++#define DPRINT(x...) ++#endif ++ ++static int ++pci63xx_int_read(unsigned int devfn, int where, u32 * value, int size); ++static int ++pci63xx_int_write(unsigned int devfn, int where, u32 * value, int size); ++ ++static bool usb_mem_size_rd = FALSE; ++static uint32 usb_mem_base = 0; ++static uint32 usb_cfg_space_cmd_reg = 0; ++#endif ++static bool pci_mem_size_rd = FALSE; ++ ++static volatile MpiRegisters * mpi = (MpiRegisters *)(MPI_BASE); ++ ++static void mpi_SetupPciConfigAccess(uint32 addr) ++{ ++ mpi->l2pcfgctl = (DIR_CFG_SEL | DIR_CFG_USEREG | addr) & ~CONFIG_TYPE; ++} ++ ++static void mpi_ClearPciConfigAccess(void) ++{ ++ mpi->l2pcfgctl = 0x00000000; ++} ++ ++#if defined(CONFIG_USB) ++/* -------------------------------------------------------------------------- ++ Name: pci63xx_int_write ++Abstract: PCI Config write on internal device(s) ++ -------------------------------------------------------------------------- */ ++static int ++pci63xx_int_write(unsigned int devfn, int where, u32 * value, int size) ++{ ++ if (PCI_SLOT(devfn) != USB_HOST_SLOT) { ++ return PCIBIOS_SUCCESSFUL; ++ } ++ ++ switch (size) { ++ case 1: ++ DPRINT("W => Slot: %d Where: %2X Len: %d Data: %02X\n", ++ PCI_SLOT(devfn), where, size, *value); ++ break; ++ case 2: ++ DPRINT("W => Slot: %d Where: %2X Len: %d Data: %04X\n", ++ PCI_SLOT(devfn), where, size, *value); ++ switch (where) { ++ case PCI_COMMAND: ++ usb_cfg_space_cmd_reg = *value; ++ break; ++ default: ++ break; ++ } ++ break; ++ case 4: ++ DPRINT("W => Slot: %d Where: %2X Len: %d Data: %08lX\n", ++ PCI_SLOT(devfn), where, size, *value); ++ switch (where) { ++ case PCI_BASE_ADDRESS_0: ++ if (*value == 0xffffffff) { ++ usb_mem_size_rd = TRUE; ++ } else { ++ usb_mem_base = *value; ++ } ++ break; ++ default: ++ break; ++ } ++ break; ++ default: ++ break; ++ } ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++ ++/* -------------------------------------------------------------------------- ++ Name: pci63xx_int_read ++Abstract: PCI Config read on internal device(s) ++ -------------------------------------------------------------------------- */ ++static int ++pci63xx_int_read(unsigned int devfn, int where, u32 * value, int size) ++{ ++ uint32 retValue = 0xFFFFFFFF; ++ ++ if (PCI_SLOT(devfn) != USB_HOST_SLOT) { ++ return PCIBIOS_SUCCESSFUL; ++ } ++ ++ // For now, this is specific to the USB Host controller. We can ++ // make it more general if we have to... ++ // Emulate PCI Config accesses ++ switch (where) { ++ case PCI_VENDOR_ID: ++ case PCI_DEVICE_ID: ++ retValue = PCI_VENDOR_ID_BROADCOM | 0x63000000; ++ break; ++ case PCI_COMMAND: ++ case PCI_STATUS: ++ retValue = (0x0006 << 16) | usb_cfg_space_cmd_reg; ++ break; ++ case PCI_CLASS_REVISION: ++ case PCI_CLASS_DEVICE: ++ retValue = (PCI_CLASS_SERIAL_USB << 16) | (0x10 << 8) | 0x01; ++ break; ++ case PCI_BASE_ADDRESS_0: ++ if (usb_mem_size_rd) { ++ retValue = USB_BAR0_MEM_SIZE; ++ } else { ++ if (usb_mem_base != 0) ++ retValue = usb_mem_base; ++ else ++ retValue = USB_HOST_BASE; ++ } ++ usb_mem_size_rd = FALSE; ++ break; ++ case PCI_CACHE_LINE_SIZE: ++ case PCI_LATENCY_TIMER: ++ retValue = 0; ++ break; ++ case PCI_HEADER_TYPE: ++ retValue = PCI_HEADER_TYPE_NORMAL; ++ break; ++ case PCI_SUBSYSTEM_VENDOR_ID: ++ retValue = PCI_VENDOR_ID_BROADCOM; ++ break; ++ case PCI_SUBSYSTEM_ID: ++ retValue = 0x6300; ++ break; ++ case PCI_INTERRUPT_LINE: ++ retValue = INTERRUPT_ID_USBH; ++ break; ++ default: ++ break; ++ } ++ ++ switch (size) { ++ case 1: ++ *value = (retValue >> ((where & 3) << 3)) & 0xff; ++ DPRINT("R <= Slot: %d Where: %2X Len: %d Data: %02X\n", ++ PCI_SLOT(devfn), where, size, *value); ++ break; ++ case 2: ++ *value = (retValue >> ((where & 3) << 3)) & 0xffff; ++ DPRINT("R <= Slot: %d Where: %2X Len: %d Data: %04X\n", ++ PCI_SLOT(devfn), where, size, *value); ++ break; ++ case 4: ++ *value = retValue; ++ DPRINT("R <= Slot: %d Where: %2X Len: %d Data: %08lX\n", ++ PCI_SLOT(devfn), where, size, *value); ++ break; ++ default: ++ break; ++ } ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++#endif ++ ++static int bcm96348_pcibios_read(struct pci_bus *bus, unsigned int devfn, ++ int where, int size, u32 * val) ++{ ++ volatile unsigned char *ioBase = (unsigned char *)(mpi->l2piobase | KSEG1); ++ uint32 data; ++ ++#if defined(CONFIG_USB) ++ if (PCI_SLOT(devfn) == USB_HOST_SLOT) ++ return pci63xx_int_read(devfn, where, val, size); ++#endif ++ ++ mpi_SetupPciConfigAccess(BCM_PCI_CFG(PCI_SLOT(devfn), PCI_FUNC(devfn), where)); ++ data = *(uint32 *)ioBase; ++ switch(size) { ++ case 1: ++ *val = (data >> ((where & 3) << 3)) & 0xff; ++ break; ++ case 2: ++ *val = (data >> ((where & 3) << 3)) & 0xffff; ++ break; ++ case 4: ++ *val = data; ++ /* Special case for reading PCI device range */ ++ if ((where >= PCI_BASE_ADDRESS_0) && (where <= PCI_BASE_ADDRESS_5)) { ++ if (pci_mem_size_rd) { ++ /* bcm6348 PCI memory window minimum size is 64K */ ++ *val &= PCI_SIZE_64K; ++ } ++ } ++ break; ++ default: ++ break; ++ } ++ pci_mem_size_rd = FALSE; ++ mpi_ClearPciConfigAccess(); ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++ ++static int bcm96348_pcibios_write(struct pci_bus *bus, unsigned int devfn, ++ int where, int size, u32 val) ++{ ++ volatile unsigned char *ioBase = (unsigned char *)(mpi->l2piobase | KSEG1); ++ uint32 data; ++ ++#if defined(CONFIG_USB) ++ if (PCI_SLOT(devfn) == USB_HOST_SLOT) ++ return pci63xx_int_write(devfn, where, &val, size); ++#endif ++ mpi_SetupPciConfigAccess(BCM_PCI_CFG(PCI_SLOT(devfn), PCI_FUNC(devfn), where)); ++ data = *(uint32 *)ioBase; ++ switch(size) { ++ case 1: ++ data = (data & ~(0xff << ((where & 3) << 3))) | ++ (val << ((where & 3) << 3)); ++ break; ++ case 2: ++ data = (data & ~(0xffff << ((where & 3) << 3))) | ++ (val << ((where & 3) << 3)); ++ break; ++ case 4: ++ data = val; ++ /* Special case for reading PCI device range */ ++ if ((where >= PCI_BASE_ADDRESS_0) && (where <= PCI_BASE_ADDRESS_5)) { ++ if (val == 0xffffffff) ++ pci_mem_size_rd = TRUE; ++ } ++ break; ++ default: ++ break; ++ } ++ *(uint32 *)ioBase = data; ++ udelay(500); ++ mpi_ClearPciConfigAccess(); ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++ ++struct pci_ops bcm96348_pci_ops = { ++ .read = bcm96348_pcibios_read, ++ .write = bcm96348_pcibios_write ++}; +--- linux-2.6.8.1/arch/mips/pci/Makefile 2004-08-14 12:54:47.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/arch/mips/pci/Makefile 2006-06-26 09:07:09.000000000 +0200 +@@ -17,6 +17,8 @@ + obj-$(CONFIG_MIPS_NILE4) += ops-nile4.o + obj-$(CONFIG_MIPS_TX3927) += ops-jmr3927.o + obj-$(CONFIG_PCI_VR41XX) += ops-vr41xx.o pci-vr41xx.o ++obj-$(CONFIG_PCI_VR41XX) += ops-vr41xx.o pci-vr41xx.o ++obj-$(CONFIG_BCM_PCI) += fixup-bcm96348.o pci-bcm96348.o ops-bcm96348.o + + # + # These are still pretty much in the old state, watch, go blind. +@@ -51,3 +53,7 @@ + obj-$(CONFIG_TOSHIBA_RBTX4927) += fixup-rbtx4927.o ops-tx4927.o + obj-$(CONFIG_VICTOR_MPC30X) += fixup-mpc30x.o + obj-$(CONFIG_ZAO_CAPCELLA) += fixup-capcella.o ++ ++ifeq "$(CONFIG_BCM_PCI)" "y" ++EXTRA_CFLAGS += -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++endif +--- linux-2.6.8.1/arch/mips/pci/pci-bcm96348.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/arch/mips/pci/pci-bcm96348.c 2006-06-26 09:07:09.000000000 +0200 +@@ -0,0 +1,54 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++#include ++#include ++#include ++#include ++ ++#include ++#include ++ ++static struct resource bcm_pci_io_resource = { ++ .name = "bcm96348 pci IO space", ++ .start = BCM_PCI_IO_BASE, ++ .end = BCM_PCI_IO_BASE + BCM_PCI_IO_SIZE_64KB - 1, ++ .flags = IORESOURCE_IO ++}; ++ ++static struct resource bcm_pci_mem_resource = { ++ .name = "bcm96348 pci memory space", ++ .start = BCM_PCI_MEM_BASE, ++ .end = BCM_PCI_MEM_BASE + BCM_PCI_MEM_SIZE_16MB - 1, ++ .flags = IORESOURCE_MEM ++}; ++ ++extern struct pci_ops bcm96348_pci_ops; ++ ++struct pci_controller bcm96348_controller = { ++ .pci_ops = &bcm96348_pci_ops, ++ .io_resource = &bcm_pci_io_resource, ++ .mem_resource = &bcm_pci_mem_resource, ++}; ++ ++static void bcm96348_pci_init(void) ++{ ++ register_pci_controller(&bcm96348_controller); ++} ++ ++arch_initcall(bcm96348_pci_init); +--- linux-2.6.8.1/drivers/mtd/maps/bcm963xx.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/drivers/mtd/maps/bcm963xx.c 2006-06-26 09:07:13.000000000 +0200 +@@ -0,0 +1,162 @@ ++/* ++ * A simple flash mapping code for BCM963xx board flash memory ++ * It is simple because it only treats all the flash memory as ROM ++ * It is used with chips/map_rom.c ++ * ++ * Song Wang (songw@broadcom.com) ++ */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#define VERSION "1.0" ++ ++ ++extern PFILE_TAG kerSysImageTagGet(void); ++ ++static struct mtd_info *mymtd; ++static struct mtd_partition brcm_partition_info[4]; ++ ++#define CFE_ADDR 0xbfc00000 ++#define CFE_SIZE 64 << 10 ++#define FLASH_2M_SIZE 2048 << 10 ++#define FLASH_4M_SIZE 4096 << 10 ++#define NVRAM_SIZE 64 << 10 ++#define TAG_SIZE 0x100 ++#define FS_KERNEL_SIZE_4M 0x3E0000 ++#define NVRAM_ADDR_4M 0x3F0000 ++ ++static map_word brcm_physmap_read16(struct map_info *map, unsigned long ofs) ++{ ++ map_word val; ++ ++ val.x[0] = __raw_readw(map->map_priv_1 + ofs); ++ ++ return val; ++} ++ ++void brcm_physmap_copy_from(struct map_info *map, void *to, unsigned long from, ssize_t len) ++{ ++ memcpy_fromio(to, map->map_priv_1 + from, len); ++} ++ ++static void brcm_physmap_write16(struct map_info *map, __u16 d, unsigned long adr) ++{ ++ __raw_writew(d, map->map_priv_1 + adr); ++ mb(); ++} ++ ++void brcm_physmap_copy_to(struct map_info *map, unsigned long to, const void *from, ssize_t len) ++{ ++ memcpy_toio(map->map_priv_1 + to, from, len); ++} ++ ++struct map_info brcm_physmap_map = { ++ .name = "Physically mapped flash", ++ .bankwidth = 2, ++ .read = brcm_physmap_read16, ++ .copy_from = brcm_physmap_copy_from, ++ .write = brcm_physmap_write16, ++ .copy_to = brcm_physmap_copy_to ++ ++}; ++ ++ ++ ++int __init init_brcm_physmap(void) ++{ ++ PFILE_TAG pTag = NULL; ++ u_int32_t rootfs_addr, kernel_addr,fs_len,cfe_len; ++ FLASH_ADDR_INFO info; ++ ++ kerSysFlashAddrInfoGet( &info ); ++ ++ /* Read the flash memory map from flash memory. */ ++ if (!(pTag = kerSysImageTagGet())) { ++ printk("Failed to read image tag from flash\n"); ++ return -EIO; ++ } ++ ++ rootfs_addr = (u_int32_t) simple_strtoul(pTag->rootfsAddress, NULL, 10); ++ kernel_addr = (u_int32_t) simple_strtoul(pTag->kernelAddress, NULL, 10); ++ ++ ++ brcm_physmap_map.size = FLASH_4M_SIZE; ++ ++ fs_len = kernel_addr - rootfs_addr; ++ cfe_len=CFE_SIZE; ++ /* Ron mapping from fs */ ++ brcm_physmap_map.map_priv_1 = (unsigned long)CFE_ADDR; ++ ++ if (!brcm_physmap_map.map_priv_1) { ++ printk("Wrong flash starting address\n"); ++ return -EIO; ++ } ++ ++ if (brcm_physmap_map.size <= 0) { ++ printk("Wrong flash size\n"); ++ return -EIO; ++ } ++ ++ mymtd = do_map_probe("cfi_probe", &brcm_physmap_map); ++ if (!mymtd) ++ return -EIO; ++ ++ mymtd->owner = THIS_MODULE; ++ /* Ron file system */ ++ brcm_partition_info[0].name = "fs"; ++ brcm_partition_info[0].offset = (cfe_len + TAG_SIZE); ++ brcm_partition_info[0].size = fs_len; ++ brcm_partition_info[0].mask_flags = 0; ++ ++ /* Ron tag + file system + kernel */ ++ brcm_partition_info[1].name = "tag+fs+kernel"; ++ brcm_partition_info[1].offset = cfe_len; ++ brcm_partition_info[1].size = FS_KERNEL_SIZE_4M; ++ brcm_partition_info[1].mask_flags = 0; ++ ++ /* Ron bootloader */ ++ brcm_partition_info[2].name = "bootloader"; ++ brcm_partition_info[2].offset = 0x00; ++ brcm_partition_info[2].size = cfe_len; ++ brcm_partition_info[2].mask_flags = 0; ++ ++ /* Ron nvram */ ++ brcm_partition_info[3].name = "nvram"; ++ brcm_partition_info[3].offset = NVRAM_ADDR_4M; ++ brcm_partition_info[3].size = NVRAM_SIZE; ++ brcm_partition_info[3].mask_flags = 0; ++ ++ add_mtd_partitions(mymtd, brcm_partition_info, 4); ++ ++ return 0; ++ ++} ++ ++static void __exit cleanup_brcm_physmap(void) ++{ ++if (mymtd) { ++ del_mtd_partitions(mymtd); ++ del_mtd_device(mymtd); ++ map_destroy(mymtd); ++} ++if (brcm_physmap_map.map_priv_1) { ++ brcm_physmap_map.map_priv_1 = 0; ++} ++} ++ ++module_init(init_brcm_physmap); ++module_exit(cleanup_brcm_physmap); ++ ++ ++MODULE_LICENSE("GPL"); ++MODULE_AUTHOR("Song Wang songw@broadcom.com"); ++MODULE_DESCRIPTION("Configurable MTD map driver for read-only root file system"); +--- linux-2.6.8.1/drivers/mtd/maps/Makefile 2004-08-14 12:54:46.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/drivers/mtd/maps/Makefile 2006-06-26 09:07:13.000000000 +0200 +@@ -39,13 +39,13 @@ + obj-$(CONFIG_MTD_SCx200_DOCFLASH)+= scx200_docflash.o + obj-$(CONFIG_MTD_DBOX2) += dbox2-flash.o + obj-$(CONFIG_MTD_OCELOT) += ocelot.o ++obj-$(CONFIG_MTD_LASAT) += lasat.o + obj-$(CONFIG_MTD_SOLUTIONENGINE)+= solutionengine.o + obj-$(CONFIG_MTD_PCI) += pci.o +-obj-$(CONFIG_MTD_PB1XXX) += pb1xxx-flash.o +-obj-$(CONFIG_MTD_DB1X00) += db1x00-flash.o +-obj-$(CONFIG_MTD_PB1550) += pb1550-flash.o +-obj-$(CONFIG_MTD_DB1550) += db1550-flash.o + obj-$(CONFIG_MTD_LASAT) += lasat.o ++obj-$(CONFIG_MTD_DB1X00) += db1x00-flash.o ++obj-$(CONFIG_MTD_PB1550) += pb1550-flash.o ++obj-$(CONFIG_MTD_DB1550) += db1550-flash.o + obj-$(CONFIG_MTD_AUTCPU12) += autcpu12-nvram.o + obj-$(CONFIG_MTD_EDB7312) += edb7312.o + obj-$(CONFIG_MTD_IMPA7) += impa7.o +@@ -64,3 +64,11 @@ + obj-$(CONFIG_MTD_IXP4XX) += ixp4xx.o + obj-$(CONFIG_MTD_WRSBC8260) += wr_sbc82xx_flash.o + obj-$(CONFIG_MTD_DMV182) += dmv182.o ++obj-$(CONFIG_MTD_PB1000) += pb1xxx-flash.o ++obj-$(CONFIG_MTD_PB1100) += pb1xxx-flash.o ++obj-$(CONFIG_MTD_PB1500) += pb1xxx-flash.o ++obj-$(CONFIG_MTD_DB1X00) += db1x00-flash.o ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++obj-$(CONFIG_MTD_BCM963XX) += bcm963xx.o ++EXTRA_CFLAGS += -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++# CONFIG_MIPS_BRCM End Broadcom changed code. +--- linux-2.6.8.1/drivers/mtd/maps/Kconfig 2004-08-14 12:56:23.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/drivers/mtd/maps/Kconfig 2006-06-26 09:07:13.000000000 +0200 +@@ -60,6 +60,12 @@ + Ignore this option if you use run-time physmap configuration + (i.e., run-time calling physmap_configure()). + ++config MTD_BCM963XX ++ tristate "Broadcom 963xx ADSL board flash memory support" ++ depends on MIPS_BRCM ++ help ++ Broadcom 963xx ADSL board flash memory ++ + config MTD_SUN_UFLASH + tristate "Sun Microsystems userflash support" + depends on (SPARC32 || SPARC64) && MTD_CFI +@@ -182,41 +188,12 @@ + help + Support for the flash chip on Tsunami TIG bus. + +-config MTD_LASAT +- tristate "Flash chips on LASAT board" +- depends on LASAT +- help +- Support for the flash chips on the Lasat 100 and 200 boards. +- + config MTD_NETtel + tristate "CFI flash device on SnapGear/SecureEdge" + depends on X86 && MTD_PARTITIONS && MTD_JEDECPROBE + help + Support for flash chips on NETtel/SecureEdge/SnapGear boards. + +-config MTD_PB1XXX +- tristate "Flash devices on Alchemy PB1xxx boards" +- depends on MIPS && ( MIPS_PB1000 || MIPS_PB1100 || MIPS_PB1500 ) +- help +- Flash memory access on Alchemy Pb1000/Pb1100/Pb1500 boards +- +-config MTD_PB1XXX_BOOT +- bool "PB1x00 boot flash device" +- depends on MTD_PB1XXX && ( MIPS_PB1100 || MIPS_PB1500 ) +- help +- Use the first of the two 32MiB flash banks on Pb1100/Pb1500 board. +- You can say 'Y' to both this and 'MTD_PB1XXX_USER' below, to use +- both banks. +- +-config MTD_PB1XXX_USER +- bool "PB1x00 user flash device" +- depends on MTD_PB1XXX && ( MIPS_PB1100 || MIPS_PB1500 ) +- default y if MTD_PB1XX_BOOT = n +- help +- Use the second of the two 32MiB flash banks on Pb1100/Pb1500 board. +- You can say 'Y' to both this and 'MTD_PB1XXX_BOOT' above, to use +- both banks. +- + config MTD_PB1550 + tristate "Flash devices on Alchemy PB1550 board" + depends on MIPS && MIPS_PB1550 +@@ -338,6 +315,80 @@ + Mapping for the Flaga digital module. If you don´t have one, ignore + this setting. + ++config MTD_PB1000 ++ tristate "Pb1000 Boot Flash device" ++ depends on MIPS && MIPS_PB1000 ++ help ++ Flash memory access on Alchemy Pb1000 ++ ++config MTD_PB1100 ++ tristate "Pb1100 Flash device" ++ depends on MIPS && MIPS_PB1100 ++ help ++ Flash memory access on Alchemy Pb1100 ++ ++config MTD_PB1500 ++ tristate "Pb1500 Flash device" ++ depends on MIPS && MIPS_PB1500 ++ help ++ Flash memory access on Alchemy Pb1500 ++ ++config MTD_PB1500_BOOT ++ bool "Pb1100/Pb1500 Boot Flash device" ++ depends on MIPS && (MTD_PB1500 || MTD_PB1100) ++ help ++ Use the first of the two 32MB flash banks on Pb1100/Pb1500 board. ++ You can say 'Y' to both this and the USER flash option, to use ++ both banks. ++ ++config MTD_PB1500_USER ++ bool "Pb1100/Pb1500 User Flash device (2nd 32MB bank)" ++ depends on MIPS && (MTD_PB1500 || MTD_PB1100) ++ help ++ Use the second of the two 32MB flash banks on Pb1100/Pb1500 board. ++ You can say 'Y' to both this and the BOOT flash option, to use ++ both banks. ++ ++config MTD_DB1X00 ++ tristate "Db1X00 Flash device" ++ depends on MIPS && (MIPS_DB1000 || MIPS_DB1100 || MIPS_DB1500) ++ help ++ Flash memory access on Alchemy Db1X00 Boards ++ ++config MTD_DB1X00_BOOT ++ bool "Db1X00 Boot Flash device" ++ depends on MIPS && MTD_DB1X00 ++ help ++ Use the first of the two 32MB flash banks on Db1X00 board. ++ You can say 'Y' to both this and the USER flash option, to use ++ both banks. ++ ++config MTD_DB1X00_USER ++ bool "Db1X00 User Flash device (2nd 32MB bank)" ++ depends on MIPS && MTD_DB1X00 ++ help ++ Use the second of the two 32MB flash banks on Db1X00 boards. ++ You can say 'Y' to both this and the BOOT flash option, to use ++ both banks. ++ ++config MTD_BOSPORUS ++ tristate "Bosporus Flash device" ++ depends on MIPS && MIPS_BOSPORUS ++ help ++ Flash memory access on Alchemy Bosporus Board ++ ++config MTD_XXS1500 ++ tristate "MyCable XXS1500 Flash device" ++ depends on MIPS && MIPS_XXS1500 ++ help ++ Flash memory access on MyCable XXS1500 Board ++ ++config MTD_MTX1 ++ tristate "4-G Systems MTX-1 Flash device" ++ depends on MIPS && MIPS_MTX1 ++ help ++ Flash memory access on 4-G Systems MTX-1 Board ++ + config MTD_BEECH + tristate "CFI Flash device mapped on IBM 405LP Beech" + depends on MTD_CFI && PPC32 && 40x && BEECH +@@ -422,6 +473,12 @@ + NVRAM on the Momenco Ocelot board. If you have one of these boards + and would like access to either of these, say 'Y'. + ++config MTD_LASAT ++ tristate "LASAT flash device" ++ depends on LASAT && MTD_CFI ++ help ++ Support for the flash chips on the Lasat 100 and 200 boards. ++ + config MTD_SOLUTIONENGINE + tristate "CFI Flash device mapped on Hitachi SolutionEngine" + depends on SUPERH && MTD_CFI && MTD_REDBOOT_PARTS +--- linux-2.6.8.1/drivers/usb/host/Makefile 2004-08-14 12:56:23.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/drivers/usb/host/Makefile 2006-06-26 09:07:14.000000000 +0200 +@@ -8,3 +8,7 @@ + obj-$(CONFIG_USB_UHCI_HCD) += uhci-hcd.o + + obj-$(CONFIG_USB_SL811HS) += hc_sl811.o ++ ++ifeq ($(CONFIG_MIPS_BRCM),y) ++EXTRA_CFLAGS += -DCONFIG_SWAP_IO_SPACE -D__MIPSEB__ ++endif +\ No newline at end of file +--- linux-2.6.8.1/include/asm-mips/addrspace.h 2004-08-14 12:54:47.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/addrspace.h 2006-06-26 09:07:15.000000000 +0200 +@@ -11,7 +11,13 @@ + #define _ASM_ADDRSPACE_H + + #include ++#ifdef __KERNEL__ ++#if defined(CONFIG_BCM_ENDPOINT_MODULE) ++#include ++#else + #include ++#endif ++#endif + + /* + * Configure language +--- linux-2.6.8.1/include/asm-mips/bootinfo.h 2004-08-14 12:54:51.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/bootinfo.h 2006-06-26 09:07:15.000000000 +0200 +@@ -210,6 +210,16 @@ + #define MACH_GROUP_TITAN 22 /* PMC-Sierra Titan */ + #define MACH_TITAN_YOSEMITE 1 /* PMC-Sierra Yosemite */ + ++#if defined(CONFIG_MIPS_BRCM) ++/* ++ * Valid machtype for group BRCM ++ */ ++#define MACH_GROUP_BRCM 23 /* Broadcom boards */ ++#define MACH_BCM96338 0 ++#define MACH_BCM96345 1 ++#define MACH_BCM96348 2 ++#endif ++ + #define CL_SIZE COMMAND_LINE_SIZE + + const char *get_system_type(void); +--- linux-2.6.8.1/include/asm-mips/cpu.h 2004-08-14 12:54:50.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/cpu.h 2006-06-26 09:07:15.000000000 +0200 +@@ -71,6 +71,11 @@ + #define PRID_IMP_4KEMPR2 0x9100 + #define PRID_IMP_4KSD 0x9200 + #define PRID_IMP_24K 0x9300 ++#if defined(CONFIG_MIPS_BRCM) ++#define PRID_IMP_BCM6338 0x9000 ++#define PRID_IMP_BCM6345 0x8000 ++#define PRID_IMP_BCM6348 0x9100 ++#endif + + #define PRID_IMP_UNKNOWN 0xff00 + +@@ -177,7 +182,14 @@ + #define CPU_VR4133 56 + #define CPU_AU1550 57 + #define CPU_24K 58 ++#if defined(CONFIG_MIPS_BRCM) ++#define CPU_BCM6338 59 ++#define CPU_BCM6345 60 ++#define CPU_BCM6348 61 ++#define CPU_LAST 61 ++#else + #define CPU_LAST 58 ++#endif + + /* + * ISA Level encodings +diff -urN linux-2.6.8.1/include/asm-mips/mach-bcm963xx/cpu-feature-overrides.h linux-2.6.8.1-brcm63xx/include/asm-mips/mach-bcm963xx/cpu-feature-overrides.h +--- linux-2.6.8.1/include/asm-mips/mach-bcm963xx/cpu-feature-overrides.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/mach-bcm963xx/cpu-feature-overrides.h 2006-06-26 09:07:15.000000000 +0200 +@@ -0,0 +1,36 @@ ++#ifndef __ASM_MACH_BCM963XX_CPU_FEATURE_OVERRIDES_H ++#define __ASM_MACH_BCM963XX_CPU_FEATURE_OVERRIDES_H ++ ++#define cpu_has_tlb 1 ++#define cpu_has_4kex 4 ++#define cpu_has_4ktlb 8 ++#define cpu_has_fpu 0 ++#define cpu_has_32fpr 0 ++#define cpu_has_counter 0x40 ++#define cpu_has_watch 0 ++#define cpu_has_mips16 0 ++#define cpu_has_divec 0x200 ++#define cpu_has_vce 0 ++#define cpu_has_cache_cdex_p 0 ++#define cpu_has_cache_cdex_s 0 ++#define cpu_has_prefetch 0x40000 ++#define cpu_has_mcheck 0x2000 ++#define cpu_has_ejtag 0x4000 ++#define cpu_has_llsc 0x10000 ++#define cpu_has_vtag_icache 0 ++#define cpu_has_dc_aliases 0 ++#define cpu_has_ic_fills_f_dc 0 ++ ++#define cpu_has_nofpuex 0 ++#define cpu_has_64bits 0 ++#define cpu_has_64bit_zero_reg 0 ++#define cpu_has_64bit_gp_regs 0 ++#define cpu_has_64bit_addresses 0 ++ ++#define cpu_has_subset_pcaches 0 ++ ++#define cpu_dcache_line_size() 16 ++#define cpu_icache_line_size() 16 ++#define cpu_scache_line_size() 0 ++ ++#endif /* __ASM_MACH_BCM963XX_CPU_FEATURE_OVERRIDES_H */ +--- linux-2.6.8.1/include/asm-mips/mach-generic/param.h 2004-08-14 12:55:10.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/mach-generic/param.h 2006-06-26 09:07:15.000000000 +0200 +@@ -8,6 +8,10 @@ + #ifndef __ASM_MACH_GENERIC_PARAM_H + #define __ASM_MACH_GENERIC_PARAM_H + ++#if defined(CONFIG_MIPS_BRCM) ++#define HZ 200 /* Internal kernel timer frequency */ ++#else + #define HZ 1000 /* Internal kernel timer frequency */ ++#endif + + #endif /* __ASM_MACH_GENERIC_PARAM_H */ +--- linux-2.6.8.1/include/asm-mips/page.h 2004-08-14 12:55:10.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/page.h 2006-06-26 09:07:15.000000000 +0200 +@@ -13,7 +13,13 @@ + + #ifdef __KERNEL__ + ++#if defined(CONFIG_BCM_ENDPOINT_MODULE) ++#include ++#else + #include ++#endif ++ ++#endif + + /* + * PAGE_SHIFT determines the page size +@@ -33,6 +39,7 @@ + #define PAGE_SIZE (1UL << PAGE_SHIFT) + #define PAGE_MASK (~(PAGE_SIZE-1)) + ++#ifdef __KERNEL__ + #ifndef __ASSEMBLY__ + + extern void clear_page(void * page); +--- linux-2.6.8.1/include/asm-mips/param.h 2004-08-14 12:54:51.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/param.h 2006-06-26 09:07:15.000000000 +0200 +@@ -12,7 +12,11 @@ + #ifdef __KERNEL__ + + # include /* Internal kernel timer frequency */ ++#if defined(CONFIG_BCM_ENDPOINT_MODULE) ++# define USER_HZ HZ /* .. some user interfaces are in "ticks" */ ++#else + # define USER_HZ 100 /* .. some user interfaces are in "ticks" */ ++#endif + # define CLOCKS_PER_SEC (USER_HZ) /* like times() */ + #endif + +--- linux-2.6.8.1/include/asm-mips/timex.h 2004-08-14 12:56:15.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/include/asm-mips/timex.h 2006-06-26 09:07:15.000000000 +0200 +@@ -31,7 +31,11 @@ + * no reason to make this a separate architecture. + */ + ++#if defined(CONFIG_BCM_ENDPOINT_MODULE) ++#include ++#else + #include ++#endif + + /* + * Standard way to access the cycle counter. +diff -urN linux-2.6.8.1/bcmdrivers/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/Makefile +--- linux-2.6.8.1/bcmdrivers/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,17 @@ ++# File: bcmdrivers/Makefile ++# ++# Makefile for the Linux kernel modules. ++# ++-include $(KERNEL_DIR)/.config ++ ++obj-y += opensource/ ++ ++# If rootfs is nfs, we have to build Ethernet ++# driver as built-n ++ifeq ($(CONFIG_ROOTFS_NFS),y) ++obj-y += broadcom/ ++endif ++ ++obj-y += broadcom/ ++obj-m += broadcom/ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/Makefile +--- linux-2.6.8.1/bcmdrivers/broadcom/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/Makefile 2006-06-26 10:29:23.000000000 +0200 +@@ -0,0 +1,3 @@ ++ ++symlinks: ++ #cp ../../../tools/built-in.o built-in.o +Files linux-2.6.8.1/bcmdrivers/broadcom/built-in.o and linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/built-in.o differ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_defs.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_defs.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_defs.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_defs.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,133 @@ ++/* TARGET=bcm6348-dmt-T1-dmtbis-adsl2plus-L2-SRA-firmware-Qproc-HW-RTL-pipeline-IncOneBit-Readsl2-doubleUS */ ++ ++#define SOURCE_FILE_ ++#define BCM6348_SRC ++#define G994_T1P413_1024_FFT ++#define ENABLE_DIG_USPWR_CUTBACK ++#define ADSLCORE_ONLY ++#define TEQ_DF ++#define LOOP_TIMING_PLL ++#define RCV_PHASE_TWEAK_ONLY ++#define ADSL_MAX_POSSIBLE_RCV_RATE ++#define HARDWARE_CHANNEL ++#define ADSL_HARDWARE_AGC ++#define HW_CHANNEL_ADC ++#define HW_CHANNEL_DAC ++#define HW_PGA ++#define DIGITALEC_SINGLE_TAP_UPDATE ++#define ANALOGEC_SINGLE_TAP_UPDATE ++#define HWLOG ++#define G992_TRELLIS_CODE_CLAMPING ++#define G992DECODERTRELLISBOUNDARY ++#define MEMORYLIMIT64K ++#define bcm47xx ++#define DSL_BIG_ENDIAN ++#define MIPS_SRC ++#define VP_INLINE -Winline ++#define USE_ASM_API ++#define RTL_SRC ++#define RSENC_INLINE ++#define BITENC_INLINE ++#define USE_SLOW_DATA ++#define USE_FAST_TEXT ++#define PROFILE_INLINE ++#define CHIP_SRC ++#define G992_RESYNC_PILOT_PHASE_IN_SHOWTIME ++#define G992_APPLY_SSVI ++#define SHARE_TEQ_VARS ++#define ANNEX_M ++#define DOUBLE_UP_STREAM ++#define G994P1_SUPPORT_A43C ++#define USE_ASM_API ++#define MIPS_ASM ++#define MEMORYLIMIT64K ++#define ADSL_FIRMWARE ++#define G992DATA_XMT_COMPACT_WORD ++#define ADSL_MAX_POSSIBLE_RCV_RATE ++#define DSP_FRONTEND_ONLY ++#define G992P3_ONE_BIT_CONSTELLATION ++#define ADSL_MODEM ++#define ATM ++#define ADSL_ATUR ++#define ADSL_SOFTWARE_TIME_ERROR_CALCULATION ++#define DSL_REPORT_ALL_COUNTERS ++#define ADSL_MONITOR_LCD ++#define G994P1 ++#define G994P1_ATUR ++#define G992 ++#define G992_ATUR ++#define ADSL_FRAMER ++#define G997_1 ++#define ATM_I432 ++#define TEQ_DF ++#define G992_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ ++#define G994P1_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ ++#define G992_TRELLISCODE ++#define ADSL_HARDWARE_ECHO_CANCELLOR ++#define G992P1 ++#define G992P1_ATUR ++#define G992P1_ANNEX_A ++#define ADSL_HARDWARE_TIME_ERROR_TRACKING ++#define G992P1_NEWFRAME ++#define G992P1_NEWFRAME_ATUR ++#define G992P1_ANNEX_A_USED_FOR_G992P2 ++#define T1P413 ++#define G992_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ ++#define G992_CALC_DEBUG_SNR_BEFORE_TEQ ++#define G992P3 ++#define RATE_SELECT_E14 ++#define G992P3_ATUR ++#define G992P3AMENDMENT ++#define GLOBESPAN_DM ++#define G992P3_COMB_MSG_THREE_COPIES ++#define G992P3_POWER_MANAGEMENT ++#define G992P3_SRA ++#define G992P5 ++#define G992P5_ATUR ++#define ADSL_PIPELINE_CODE ++#define ADSL_HARDWARE_TIME_ERROR_TRACKING ++#define G994P1RCV_QPROC ++#define G994P1XMT_QPROC ++#define G992RCV_QPROC ++#define G992XMT_QPROC ++#define G992RCV_RS ++#define VP_SIMULATOR ++#define T1P413RCV_QPROC ++#define T1P413XMT_QPROC ++#define G992ENC_HW_DATAMODE ++#define G992DATA_XMT_HW_RS ++#define G992DATA_XMT_COMPACT_WORD ++#define G992RCV_QPROC_FAST ++#define G992_BIT_SWAP ++#define ADSL_IDENTIFY_VENDOR_FIRMWARE ++#define ADSL_ATUR_FORCE_BIGGER_UPSTREAM_MARGIN ++#define G992_MORE_FRAME_MODE ++#define XMT_RACT2_FOR_ADI_COMPATIBILITY ++#define XMT_FFT_SIZE_2X ++#define SYNCH_SYMBOL_DETECTION ++#define ANSI_CACT12_PING_PONG ++#define ADSL_SPECIAL_FIX_FOR_FRENCH_TELECOM ++#define G994P1_CHECK_SECURITY ++#define G994P1_NON_STD_INFO ++#define I432_HEADER_COMPRESSION ++#define TDC_IOP_FIX_ERICSSON_TI_4000C_350 ++#define TDC_IOP_FIX_SEIMENS_TI ++#define FT_ADI_US_RATE_FIX ++#define ANSI_CACT12_PING_PONG ++#define G992_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ ++#define G994P1_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ ++#define READSL2 ++#define G992_APPLY_SSVI ++#define READSL2_FILTERS ++ ++ ++#define ADSL_PHY_XFACE_OFFSET 0x21F90 ++ ++ ++#define ADSL_PHY_SDRAM_BIAS 0x1A0000 ++ ++ ++#define ADSL_PHY_SDRAM_LINK_OFFSET 0x1A0000 ++ ++ ++#define ADSL_PHY_SDRAM_PAGE_SIZE 0x200000 +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_lmem.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_lmem.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_lmem.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_lmem.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,6 @@ ++/* ++** Don't change! ++** This file has been generated automatically by bin2c program ++*/ ++ ++extern const unsigned char adsl_lmem[51036]; +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_sdram.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_sdram.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_sdram.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/adslcore6348/adsl_sdram.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,6 @@ ++/* ++** Don't change! ++** This file has been generated automatically by bin2c program ++*/ ++ ++extern const unsigned char adsl_sdram[364348]; +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslCoreDefs.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslCoreDefs.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslCoreDefs.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslCoreDefs.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,245 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslCore.c -- Bcm ADSL core driver ++ * ++ * Description: ++ * This file contains BCM ADSL core driver ++ * ++ * ++ * Copyright (c) 2000-2001 Broadcom Corporation ++ * All Rights Reserved ++ * No portions of this material may be reproduced in any form without the ++ * written permission of: ++ * Broadcom Corporation ++ * 16215 Alton Parkway ++ * Irvine, California 92619 ++ * All information contained in this document is Broadcom Corporation ++ * company private, proprietary, and trade secret. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.4 $ ++ * ++ * $Id: AdslCoreDefs.h,v 1.4 2004/07/20 23:45:48 ilyas Exp $ ++ * ++ * $Log: AdslCoreDefs.h,v $ ++ * Revision 1.4 2004/07/20 23:45:48 ilyas ++ * Added driver version info, SoftDslPrintf support. Fixed G.997 related issues ++ * ++ * Revision 1.3 2004/06/10 00:20:33 ilyas ++ * Added L2/L3 and SRA ++ * ++ * Revision 1.2 2004/04/12 23:24:38 ilyas ++ * Added default G992P5 PHY definition ++ * ++ * Revision 1.1 2004/04/08 23:59:15 ilyas ++ * Initial CVS checkin ++ * ++ ****************************************************************************/ ++ ++#ifndef _ADSL_CORE_DEFS_H ++#define _ADSL_CORE_DEFS_H ++ ++#if defined(__KERNEL__) ++#include ++#endif ++ ++#if defined(CONFIG_BCM96348) || defined(BOARD_bcm96348) || defined(_BCM96348_) || defined(CONFIG_BCM96338) || defined(BOARD_bcm96338) || defined(_BCM96338_) ++#ifdef ADSL_ANNEXC ++#include "../adslcore6348C/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcore6348B/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcore6348SA/adsl_defs.h" ++#else ++#include "../adslcore6348/adsl_defs.h" ++#endif ++#endif ++ ++#if defined(__KERNEL__) || defined(TARG_OS_RTEMS) || defined(_CFE_) ++#if defined(CONFIG_BCM96345) || defined(BOARD_bcm96345) || defined(_BCM96345_) ++#ifdef ADSL_ANNEXC ++#include "../adslcore6345C/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcore6345B/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcore6345SA/adsl_defs.h" ++#else ++#include "../adslcore6345/adsl_defs.h" ++#endif ++#endif /* of CONFIG_BCM96345 */ ++#else ++#if defined(CONFIG_BCM96345) ++#ifdef ADSL_ANNEXC ++#include "../adslcoreC/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcoreB/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcoreSA/adsl_defs.h" ++#else ++#include "../adslcore/adsl_defs.h" ++#endif ++#endif /* of CONFIG_BCM96345 */ ++#endif /* __KERNEL__ */ ++ ++#ifdef _WIN32_WCE ++#define ASSERT(a) ++#endif ++ ++#include "AdslXfaceData.h" ++ ++/* adjust some definitions for the HOST */ ++ ++#undef GLOBAL_PTR_BIAS ++#undef ADSLCORE_ONLY ++#undef USE_SLOW_DATA ++#undef USE_FAST_TEXT ++#undef VP_SIMULATOR ++#undef bcm47xx ++#undef ADSL_FRAMER ++#undef ATM ++#undef ATM_I432 ++#undef DSL_OS ++ ++#define HOST_ONLY ++#define G997_1_FRAMER ++#define ADSL_MIB ++ ++#ifndef FLATTEN_ADDR_ADJUST ++#define FLATTEN_ADDR_ADJUST 0xFFF00000 ++#endif ++ ++/* definitions for combo PHY (AnnexA(ADSL2) and AnnexB) */ ++ ++#if !(defined(ADSL_SINGLE_PHY) || defined(G992_ANNEXC)) ++ ++#undef G992P1_ANNEX_A ++#define G992P1_ANNEX_A ++#undef G992P3 ++#define G992P3 ++#undef G992P5 ++#define G992P5 ++#define G992P1_ANNEX_A ++#undef READSL2 ++#define READSL2 ++#undef G992P1_ANNEX_A_USED_FOR_G992P2 ++#define G992P1_ANNEX_A_USED_FOR_G992P2 ++#undef T1P413 ++#define T1P413 ++ ++#undef G992P1_ANNEX_B ++#define G992P1_ANNEX_B ++ ++#endif ++ ++/* ADSL PHY definition */ ++ ++typedef struct { ++ unsigned long sdramPageAddr; ++ unsigned long sdramImageAddr; ++ unsigned long sdramImageSize; ++ unsigned long sdramPhyImageAddr; ++ unsigned short fwType; ++ unsigned short chipType; ++ unsigned short mjVerNum; ++ unsigned short mnVerNum; ++ char *pVerStr; ++ unsigned long features[4]; ++} adslPhyInfo; ++extern adslPhyInfo adslCorePhyDesc; ++ ++/* chip list */ ++ ++#define kAdslPhyChipMjMask 0xFF00 ++#define kAdslPhyChipMnMask 0x00FF ++#define kAdslPhyChipUnknown 0 ++#define kAdslPhyChip6345 0x100 ++#define kAdslPhyChip6348 0x200 ++#define kAdslPhyChipRev0 0 ++#define kAdslPhyChipRev1 1 ++#define kAdslPhyChipRev2 2 ++#define kAdslPhyChipRev3 3 ++#define kAdslPhyChipRev4 4 ++#define kAdslPhyChipRev5 5 ++ ++#define ADSL_PHY_SUPPORT(f) AdslFeatureSupported(adslCorePhyDesc.features,f) ++#define ADSL_PHY_SET_SUPPORT(p,f) AdslFeatureSet((p)->features,f) ++ ++/* ADSL Driver to/from PHY address and data conversion macros */ ++ ++#ifdef ADSLDRV_LITTLE_ENDIAN ++#define ADSL_ENDIAN_CONV_LONG(x) ( ((x) << 24) | (((x) << 8) & 0x00FF0000) | (((x) >> 8) & 0x0000FF00) | ((unsigned long)(x) >> 24) ) ++#define ADSL_ENDIAN_CONV_SHORT(x) ( ((x) << 8) | ((unsigned short)(x) >> 8) ) ++#define ADSL_ENDIAN_CONV_2SHORTS(x) ( ((x) << 16) | ((unsigned long)(x) >> 16) ) ++#else ++#define ADSL_ENDIAN_CONV_LONG(x) x ++#define ADSL_ENDIAN_CONV_SHORT(x) x ++#define ADSL_ENDIAN_CONV_2SHORTS(x) x ++#endif ++ ++#ifndef ADSL_PHY_XFACE_OFFSET ++#define ADSL_PHY_XFACE_OFFSET 0x00017F90 ++#endif ++#define ADSL_LMEM_XFACE_DATA (0xFFF00000 | ADSL_PHY_XFACE_OFFSET) ++ ++#ifndef ADSL_PHY_SDRAM_START ++#define ADSL_PHY_SDRAM_START 0x10000000 ++#endif ++#ifndef ADSL_PHY_SDRAM_BIAS ++#define ADSL_PHY_SDRAM_BIAS 0x00040000 ++#endif ++#define ADSL_PHY_SDRAM_START_4 (ADSL_PHY_SDRAM_START + ADSL_PHY_SDRAM_BIAS) ++ ++#ifndef ADSL_PHY_SDRAM_PAGE_SIZE ++#define ADSL_PHY_SDRAM_PAGE_SIZE 0x00080000 ++#endif ++ ++#ifdef ADSL_PHY_SDRAM_BIAS ++#define ADSL_SDRAM_IMAGE_SIZE (ADSL_PHY_SDRAM_PAGE_SIZE - ADSL_PHY_SDRAM_BIAS) ++#else ++#define ADSL_SDRAM_IMAGE_SIZE (256*1024) ++#endif ++ ++ ++#ifndef ADSL_PHY_SDRAM_LINK_OFFSET ++#define ADSL_PHY_SDRAM_LINK_OFFSET 0x00040000 ++#endif ++ ++#define ADSL_SDRAM_TOTAL_SIZE 0x00800000 ++#define ADSL_SDRAM_HOST_MIPS_DEFAULT (0xA0000000 | (ADSL_SDRAM_TOTAL_SIZE - ADSL_PHY_SDRAM_PAGE_SIZE + ADSL_PHY_SDRAM_BIAS)) ++ ++#define ADSLXF ((AdslXfaceData *) ADSL_LMEM_XFACE_DATA) ++ ++#define ADSL_MIPS_LMEM_ADDR(a) (((ulong)(a) & 0x19000000) == 0x19000000) ++#define SDRAM_ADDR_TO_HOST(a) ((void *) ((ulong)(a) - adslCorePhyDesc.sdramPhyImageAddr + \ ++ (ADSLXF->sdramBaseAddr ? (unsigned long) ADSLXF->sdramBaseAddr : ADSL_SDRAM_HOST_MIPS_DEFAULT))) ++#define SDRAM_ADDR_TO_ADSL(a) ((void *) (adslCorePhyDesc.sdramPhyImageAddr + ((ulong)(a) - \ ++ (ADSLXF->sdramBaseAddr ? (unsigned long) ADSLXF->sdramBaseAddr : ADSL_SDRAM_HOST_MIPS_DEFAULT)))) ++ ++#define ADSL_ADDR_TO_HOST(addr) ADSL_MIPS_LMEM_ADDR(addr) ? (void *) ((ulong) (addr) | FLATTEN_ADDR_ADJUST) : SDRAM_ADDR_TO_HOST(addr) ++ ++ ++#ifndef DEBUG ++#define DEBUG ++#endif ++ ++#ifndef __SoftDslPrintf ++void __SoftDslPrintf(void *gDslVars, char *fmt, int argNum, ...); ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,94 @@ ++/**************************************************************************** ++ * ++ * AdslMib.gh ++ * ++ * Description: ++ * This is a header file which defines the type for AdslMib ++ * global variable structure. ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.8 $ ++ * ++ * $Id: AdslMib.gh,v 1.8 2004/06/04 18:56:01 ilyas Exp $ ++ * ++ * $Log: AdslMib.gh,v $ ++ * Revision 1.8 2004/06/04 18:56:01 ilyas ++ * Added counter for ADSL2 framing and performance ++ * ++ * Revision 1.7 2003/10/17 21:02:12 ilyas ++ * Added more data for ADSL2 ++ * ++ * Revision 1.6 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.5 2003/07/18 19:07:15 ilyas ++ * Merged with ADSL driver ++ * ++ * Revision 1.4 2002/11/13 21:32:49 ilyas ++ * Added adjustK support for Centillium non-standard framing mode ++ * ++ * Revision 1.3 2002/10/31 20:27:13 ilyas ++ * Merged with the latest changes for VxWorks/Linux driver ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibGlobals ++#define AdslMibGlobals ++ ++#include "AdslMib.h" ++ ++typedef struct ++ { ++ /* MIB data */ ++ ++ adslMibInfo adslMib; ++ ++ /* ADSL state data */ ++ ++ adslMibNotifyHandlerType notifyHandlerPtr; ++ ulong timeSec; ++ ulong timeMs; ++ Boolean currSecondErrored; ++ Boolean currSecondLOS; ++ Boolean currSecondSES; ++ Boolean currSecondFEC; ++ ulong rcvPower; ++ ulong rcvRateBps; ++ ulong xmtRateBps; ++ ulong linkStatus; ++ G992CodingParams rcvParams; ++ G992CodingParams xmtParams; ++ ulong shtCounters[kG992ShowtimeNumOfMonitorCounters]; ++ ulong scratchData; ++ long showtimeMarginThld; ++ ++ /* ADSL diag data */ ++ ++ short snr[kAdslMibMaxToneNum]; ++ short showtimeMargin[kAdslMibMaxToneNum]; ++ uchar bitAlloc[kAdslMibMaxToneNum]; ++ short gain[kAdslMibMaxToneNum]; ++ ComplexShort chanCharLin[kAdslMibMaxToneNum]; ++ short chanCharLog[kAdslMibMaxToneNum]; ++ short quietLineNoise[kAdslMibMaxToneNum]; ++ ++ ushort nTones; ++ uchar nMsgCnt; ++ ulong g992MsgType; ++ uchar rsOption[1+4]; ++ Boolean rsOptionValid; ++ } ++ adslMibVarsStruct; ++ ++#endif /* AdslMibGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMib.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,114 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslMib.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for AdslMib ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: AdslMib.h,v 1.9 2004/04/12 23:34:52 ilyas Exp $ ++ * ++ * $Log: AdslMib.h,v $ ++ * Revision 1.9 2004/04/12 23:34:52 ilyas ++ * Merged the latest ADSL driver chnages for ADSL2+ ++ * ++ * Revision 1.8 2004/03/03 20:14:05 ilyas ++ * Merged changes for ADSL2+ from ADSL driver ++ * ++ * Revision 1.7 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.6 2003/07/18 19:07:15 ilyas ++ * Merged with ADSL driver ++ * ++ * Revision 1.5 2002/10/31 20:27:13 ilyas ++ * Merged with the latest changes for VxWorks/Linux driver ++ * ++ * Revision 1.4 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.3 2002/01/13 22:25:40 ilyas ++ * Added functions to get channels rate ++ * ++ * Revision 1.2 2002/01/03 06:03:36 ilyas ++ * Handle byte moves tha are not multiple of 2 ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibHeader ++#define AdslMibHeader ++ ++#if defined(_CFE_) ++#include "lib_types.h" ++#include "lib_string.h" ++#endif ++ ++#include "AdslMibDef.h" ++ ++/* Interface functions */ ++ ++typedef int (SM_DECL *adslMibNotifyHandlerType) (void *gDslVars, ulong event); ++ ++extern Boolean AdslMibInit(void *gDslVars); ++extern void AdslMibTimer(void *gDslVars, long timeMs); ++extern void AdslMibStatusSnooper (void *gDslVars, dslStatusStruct *status); ++extern void AdslMibSetNotifyHandler(void *gDslVars, adslMibNotifyHandlerType notifyHandlerPtr); ++extern int AdslMibGetModulationType(void *gDslVars); ++extern Boolean AdslMibIsAdsl2Mod(void *gDslVars); ++extern int AdslMibGetActiveChannel(void *gDslVars); ++extern int AdslMibGetGetChannelRate(void *gDslVars, int dir, int channel); ++extern Boolean AdslMibIsLinkActive(void *gDslVars); ++extern int AdslMibPowerState(void *gDslVars); ++extern int AdslMibTrainingState (void *gDslVars); ++extern void AdslMibClearData(void *gDslVars); ++extern void AdslMibClearBertResults(void *gDslVars); ++extern void AdslMibBertStartEx(void *gDslVars, ulong bertSec); ++extern void AdslMibBertStopEx(void *gDslVars); ++extern ulong AdslMibBertContinueEx(void *gDslVars, ulong totalBits, ulong errBits); ++extern void AdslMibSetLPR(void *gDslVars); ++extern void AdslMibSetShowtimeMargin(void *gDslVars, long showtimeMargin); ++extern void AdslMibResetConectionStatCounters(void *gDslVars); ++ ++extern void AdslMibByteMove (int size, void* srcPtr, void* dstPtr); ++extern void AdslMibByteClear(int size, void* dstPtr); ++extern int AdslMibStrCopy(char *srcPtr, char *dstPtr); ++ ++/* AdslMibGetData dataId codes */ ++ ++#define kAdslMibDataAll 0 ++ ++extern void *AdslMibGetData (void *gDslVars, int dataId, void *pAdslMibData); ++ ++extern int AdslMibGetObjectValue ( ++ void *gDslVars, ++ uchar *objId, ++ int objIdLen, ++ uchar *dataBuf, ++ ulong *dataBufLen); ++ ++#endif /* AdslMibHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMibOid.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMibOid.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMibOid.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslMibOid.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,177 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslMibOid.h ++ * ++ * Description: ++ * SNMP object identifiers for ADSL MIB and other related MIBs ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: AdslMibOid.h,v 1.5 2004/06/04 18:56:01 ilyas Exp $ ++ * ++ * $Log: AdslMibOid.h,v $ ++ * Revision 1.5 2004/06/04 18:56:01 ilyas ++ * Added counter for ADSL2 framing and performance ++ * ++ * Revision 1.4 2003/10/17 21:02:12 ilyas ++ * Added more data for ADSL2 ++ * ++ * Revision 1.3 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibOidHeader ++#define AdslMibOidHeader ++ ++#define kOidAdsl 94 ++#define kOidAdslInterleave 124 ++#define kOidAdslFast 125 ++#define kOidAtm 37 ++ ++#define kOidAdslLine 1 ++#define kOidAdslMibObjects 1 ++ ++#define kOidAdslLineTable 1 ++#define kOidAdslLineEntry 1 ++#define kOidAdslLineCoding 1 ++#define kOidAdslLineType 2 ++#define kOidAdslLineSpecific 3 ++#define kOidAdslLineConfProfile 4 ++#define kOidAdslLineAlarmConfProfile 5 ++ ++#define kOidAdslAtucPhysTable 2 ++#define kOidAdslAturPhysTable 3 ++#define kOidAdslPhysEntry 1 ++#define kOidAdslPhysInvSerialNumber 1 ++#define kOidAdslPhysInvVendorID 2 ++#define kOidAdslPhysInvVersionNumber 3 ++#define kOidAdslPhysCurrSnrMgn 4 ++#define kOidAdslPhysCurrAtn 5 ++#define kOidAdslPhysCurrStatus 6 ++#define kOidAdslPhysCurrOutputPwr 7 ++#define kOidAdslPhysCurrAttainableRate 8 ++ ++#define kOidAdslAtucChanTable 4 ++#define kOidAdslAturChanTable 5 ++#define kOidAdslChanEntry 1 ++#define kOidAdslChanInterleaveDelay 1 ++#define kOidAdslChanCurrTxRate 2 ++#define kOidAdslChanPrevTxRate 3 ++#define kOidAdslChanCrcBlockLength 4 ++ ++#define kOidAdslAtucPerfDataTable 6 ++#define kOidAdslAturPerfDataTable 7 ++#define kOidAdslPerfDataEntry 1 ++#define kOidAdslPerfLofs 1 ++#define kOidAdslPerfLoss 2 ++#define kOidAdslPerfLprs 3 ++#define kOidAdslPerfESs 4 ++#define kOidAdslPerfValidIntervals 5 ++#define kOidAdslPerfInvalidIntervals 6 ++#define kOidAdslPerfCurr15MinTimeElapsed 7 ++#define kOidAdslPerfCurr15MinLofs 8 ++#define kOidAdslPerfCurr15MinLoss 9 ++#define kOidAdslPerfCurr15MinLprs 10 ++#define kOidAdslPerfCurr15MinESs 11 ++#define kOidAdslPerfCurr1DayTimeElapsed 12 ++#define kOidAdslPerfCurr1DayLofs 13 ++#define kOidAdslPerfCurr1DayLoss 14 ++#define kOidAdslPerfCurr1DayLprs 15 ++#define kOidAdslPerfCurr1DayESs 16 ++#define kOidAdslPerfPrev1DayMoniSecs 17 ++#define kOidAdslPerfPrev1DayLofs 18 ++#define kOidAdslPerfPrev1DayLoss 19 ++#define kOidAdslPerfPrev1DayLprs 20 ++#define kOidAdslPerfPrev1DayESs 21 ++ ++#define kOidAdslAtucPerfIntervalTable 8 ++#define kOidAdslAturPerfIntervalTable 9 ++#define kOidAdslPerfIntervalEntry 1 ++#define kOidAdslIntervalNumber 1 ++#define kOidAdslIntervalLofs 2 ++#define kOidAdslIntervalLoss 3 ++#define kOidAdslIntervalLprs 4 ++#define kOidAdslIntervalESs 5 ++#define kOidAdslIntervalValidData 6 ++ ++#define kOidAdslAtucChanPerfTable 10 ++#define kOidAdslAturChanPerfTable 11 ++#define kOidAdslChanPerfEntry 1 ++#define kOidAdslChanReceivedBlks 1 ++#define kOidAdslChanTransmittedBlks 2 ++#define kOidAdslChanCorrectedBlks 3 ++#define kOidAdslChanUncorrectBlks 4 ++#define kOidAdslChanPerfValidIntervals 5 ++#define kOidAdslChanPerfInvalidIntervals 6 ++#define kOidAdslChanPerfCurr15MinTimeElapsed 7 ++#define kOidAdslChanPerfCurr15MinReceivedBlks 8 ++#define kOidAdslChanPerfCurr15MinTransmittedBlks 9 ++#define kOidAdslChanPerfCurr15MinCorrectedBlks 10 ++#define kOidAdslChanPerfCurr15MinUncorrectBlks 11 ++#define kOidAdslChanPerfCurr1DayTimeElapsed 12 ++#define kOidAdslChanPerfCurr1DayReceivedBlks 13 ++#define kOidAdslChanPerfCurr1DayTransmittedBlks 14 ++#define kOidAdslChanPerfCurr1DayCorrectedBlks 15 ++#define kOidAdslChanPerfCurr1DayUncorrectBlks 16 ++#define kOidAdslChanPerfPrev1DayMoniSecs 17 ++#define kOidAdslChanPerfPrev1DayReceivedBlks 18 ++#define kOidAdslChanPerfPrev1DayTransmittedBlks 19 ++#define kOidAdslChanPerfPrev1DayCorrectedBlks 20 ++#define kOidAdslChanPerfPrev1DayUncorrectBlks 21 ++ ++#define kOidAdslAtucChanIntervalTable 12 ++#define kOidAdslAturChanIntervalTable 13 ++#define kOidAdslChanIntervalEntry 1 ++#define kOidAdslChanIntervalNumber 1 ++#define kOidAdslChanIntervalReceivedBlks 2 ++#define kOidAdslChanIntervalTransmittedBlks 3 ++#define kOidAdslChanIntervalCorrectedBlks 4 ++#define kOidAdslChanIntervalUncorrectBlks 5 ++#define kOidAdslChanIntervalValidData 6 ++ ++/* AdslExtra OIDs for kOidAdslPrivate, kOidAdslPrivExtraInfo (defined in AdslMibDef.h) */ ++ ++#define kOidAdslExtraConnectionInfo 1 ++#define kOidAdslExtraConnectionStat 2 ++#define kOidAdslExtraFramingMode 3 ++#define kOidAdslExtraTrainingState 4 ++#define kOidAdslExtraNonStdFramingAdjustK 5 ++#define kOidAdslExtraAtmStat 6 ++#define kOidAdslExtraDiagModeData 7 ++#define kOidAdslExtraAdsl2Info 8 ++#define kOidAdslExtraTxPerfCounterInfo 9 ++ ++#define kOidAtmMibObjects 1 ++#define kOidAtmTcTable 4 ++#define kOidAtmTcEntry 1 ++#define kOidAtmOcdEvents 1 ++#define kOidAtmAlarmState 2 ++ ++#endif /* AdslMibOidHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslXfaceData.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslXfaceData.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslXfaceData.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/AdslXfaceData.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,129 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslXfaceData.h -- ADSL Core interface data structure ++ * ++ * Description: ++ * To be included both in SoftDsl and BcmAdslCore driver ++ * ++ * ++ * Copyright (c) 2000-2001 Broadcom Corporation ++ * All Rights Reserved ++ * No portions of this material may be reproduced in any form without the ++ * written permission of: ++ * Broadcom Corporation ++ * 16215 Alton Parkway ++ * Irvine, California 92619 ++ * All information contained in this document is Broadcom Corporation ++ * company private, proprietary, and trade secret. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: AdslXfaceData.h,v 1.9 2004/02/03 02:57:22 ilyas Exp $ ++ * ++ * $Log: AdslXfaceData.h,v $ ++ * Revision 1.9 2004/02/03 02:57:22 ilyas ++ * Added PHY feature settings ++ * ++ * Revision 1.8 2003/07/18 04:50:21 ilyas ++ * Added shared buffer for clEoc messages to avoid copying thru command buffer ++ * ++ * Revision 1.7 2003/02/25 00:46:32 ilyas ++ * Added T1.413 EOC vendor ID ++ * ++ * Revision 1.6 2003/02/21 23:29:13 ilyas ++ * Added OEM vendor ID parameter for T1.413 mode ++ * ++ * Revision 1.5 2002/09/13 21:17:12 ilyas ++ * Added pointers to version and build string to OEM interface structure ++ * ++ * Revision 1.4 2002/09/07 04:16:29 ilyas ++ * Fixed HOST to ADSL MIPS SDRAM address translation for relocatable images ++ * ++ * Revision 1.3 2002/09/07 01:43:59 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.2 2002/01/22 19:03:10 khp ++ * -put sdramBaseAddr at end of Xface struct ++ * ++ * Revision 1.1 2002/01/15 06:25:08 ilyas ++ * Initial implementation of ADSL core firmware ++ * ++ ****************************************************************************/ ++ ++#ifndef AdslXfaceDataHeader ++#define AdslXfaceDataHeader ++ ++#include "CircBuf.h" ++ ++typedef struct _AdslXfaceData { ++ stretchBufferStruct sbSta; ++ stretchBufferStruct sbCmd; ++ unsigned long gfcTable[15]; ++ void *sdramBaseAddr; ++} AdslXfaceData; ++ ++/* Shared SDRAM configuration data */ ++ ++#define kAdslOemVendorIdMaxSize 8 ++#define kAdslOemVersionMaxSize 32 ++#define kAdslOemSerNumMaxSize 32 ++#define kAdslOemNonStdInfoMaxSize 64 ++ ++typedef struct _AdslOemSharedData { ++ unsigned long g994VendorIdLen; ++ unsigned long g994XmtNonStdInfoLen; ++ unsigned long g994RcvNonStdInfoLen; ++ unsigned long eocVendorIdLen; ++ unsigned long eocVersionLen; ++ unsigned long eocSerNumLen; ++ unsigned char g994VendorId[kAdslOemVendorIdMaxSize]; ++ unsigned char eocVendorId[kAdslOemVendorIdMaxSize]; ++ unsigned char eocVersion[kAdslOemVersionMaxSize]; ++ unsigned char eocSerNum[kAdslOemSerNumMaxSize]; ++ unsigned char g994XmtNonStdInfo[kAdslOemNonStdInfoMaxSize]; ++ unsigned char g994RcvNonStdInfo[kAdslOemNonStdInfoMaxSize]; ++ char *gDslVerionStringPtr; ++ char *gDslBuildDataStringPtr; ++ unsigned long t1413VendorIdLen; ++ unsigned char t1413VendorId[kAdslOemVendorIdMaxSize]; ++ unsigned long t1413EocVendorIdLen; ++ unsigned char t1413EocVendorId[kAdslOemVendorIdMaxSize]; ++ unsigned long clEocBufLen; ++ unsigned char *clEocBufPtr; ++} AdslOemSharedData; ++ ++/* feature list */ ++ ++#define kAdslPhyAnnexA 0 ++#define kAdslPhyAnnexB 1 ++#define kAdslPhyAnnexC 2 ++#define kAdslPhySADSL 3 ++#define kAdslPhyAdsl2 4 ++#define kAdslPhyAdslG992p3 4 ++#define kAdslPhyAdsl2p 5 ++#define kAdslPhyAdslG992p5 5 ++#define kAdslPhyAnnexI 6 ++#define kAdslPhyAdslReAdsl2 7 ++#define kAdslPhyG992p2Init 8 ++#define kAdslPhyT1P413 9 ++ ++#define AdslFeatureSupported(fa,f) ((fa)[(f) >> 5] & (1 << ((f) & 0x1F))) ++#define AdslFeatureSet(fa,f) (fa)[(f) >> 5] |= (1 << ((f) & 0x1F)) ++ ++#endif /* AdslXfaceDataHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlankList.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlankList.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlankList.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlankList.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,87 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * BlankList.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of blank list - list of unused items of any size (not less than ++ * sizeof(void *) ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef BlankListHeader ++#define BlankListHeader ++ ++#define BlankListPeek(head) ((void *) (head)) ++#define BlankListNext(p) (*(void **) (p)) ++ ++#define BlankListAdd(pHead,p) do { \ ++ BlankListNext(p) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = (void *) (p); \ ++} while (0) ++ ++#define BlankListAddList(pHead,pFirst,pLast) do { \ ++ if (NULL != (pLast)) { \ ++ BlankListNext(pLast) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = (void *) (pFirst); \ ++ } \ ++} while (0) ++ ++#define BlankListGet(pHead) \ ++ BlankListNext(pHead); \ ++ { \ ++ void **__p; \ ++ __p = (void **) BlankListNext(pHead); \ ++ if (NULL != __p) \ ++ BlankListNext(pHead) = *__p; \ ++ } ++ ++ ++#define BlankListForEach(pHead,f,ref) do { \ ++ void *p = BlankListNext(pHead); \ ++ \ ++ while (NULL != p) { \ ++ if ( (f)((p), ref) ) break; \ ++ p = BlankListNext(p); \ ++ } \ ++} while (0) ++ ++ ++#include "Que.h" ++ ++#define BlankListAddQue(pHead,pqHdr) do { \ ++ if (NULL != ((QueHeader *)(pqHdr))->tail) { \ ++ BlankListNext(((QueHeader *)(pqHdr))->tail) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = ((QueHeader *)(pqHdr))->head; \ ++ } \ ++} while (0) ++ ++#include "DList.h" ++ ++#define BlankListAddDList(pHead,pDListHead) do { \ ++ if (!DListEmpty(pDListHead)) { \ ++ BlankListNext(DListLast(pDListHead)) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = DListFirst(pDListHead); \ ++ } \ ++} while (0) ++ ++#endif /* BlankListHeader */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlockUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlockUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlockUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/BlockUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,235 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/* BlockUtil.h ++ * ++ * Description: ++ * This file contains the interfaces for the fixed point block ++ * processing utilities. ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.23 $ ++ * ++ * $Id: BlockUtil.h,v 1.23 2004/04/13 00:31:10 ilyas Exp $ ++ * ++ * $Log: BlockUtil.h,v $ ++ * Revision 1.23 2004/04/13 00:31:10 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.22 2003/07/11 01:49:01 gsyu ++ * Added BlockShortClearByLong to speed up performance ++ * ++ * Revision 1.21 2003/07/10 22:35:23 gsyu ++ * Speed up BlockByteXXX performance ++ * ++ * Revision 1.20 2003/07/10 22:15:51 gsyu ++ * Added BlockByteMoveByWord to speed up performance ++ * ++ * Revision 1.19 2002/03/12 00:03:03 yongbing ++ * Modify cplxScaleCplxSymbols to accept a shift value instead of an array of shifts ++ * ++ * Revision 1.18 2001/03/14 00:50:25 georgep ++ * All targets use FEQ_PASS_FFTSHIFT, remove code for case where its not defined ++ * ++ * Revision 1.17 2000/11/30 03:54:09 khp ++ * -BlockRealScaleCplxSymbols instead of BlockScaleComplexSymbols ++ * ++ * Revision 1.16 2000/11/29 20:42:12 liang ++ * Add function for ADSL xmt gains with fixed shift. ++ * ++ * Revision 1.15 2000/10/02 19:24:08 georgep ++ * Modify FEQ for new fft, fft outputs a shift for each block ++ * ++ * Revision 1.14 2000/09/09 00:23:48 liang ++ * Add corresponding functions for the ComplexLong FEQ coef. ++ * ++ * Revision 1.13 2000/05/17 01:36:52 yongbing ++ * Add Pentium MMX assembly codes for more block related functions ++ * ++ * Revision 1.12 2000/04/19 19:22:22 yongbing ++ * Add BlockShortScaleby2 function used in G994p1 ++ * ++ * Revision 1.11 2000/04/04 02:28:01 liang ++ * Merged with SoftDsl_0_2 from old tree. ++ * ++ * Revision 1.11 2000/03/14 23:29:01 yongbing ++ * Add Pentim MMX codes for BlockCplxSymbolUpdateCplxScale function ++ * ++ * Revision 1.10 2000/02/16 01:53:00 yongbing ++ * Add Pentium MMX module for FEQ ++ * ++ * Revision 1.9 1999/11/02 02:49:55 liang ++ * Add BlockComplexPower function. ++ * ++ * Revision 1.8 1999/08/05 19:42:34 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.7 1999/06/16 00:54:39 liang ++ * BlockRealScaleComplexSymbols takes a scale shift buffer now. ++ * ++ * Revision 1.6 1999/05/22 02:18:29 liang ++ * Add one more parameter to BlockCplxSymbolUpdateCplxScale function. ++ * ++ * Revision 1.5 1999/05/14 22:49:39 liang ++ * Added two more functions. ++ * ++ * Revision 1.4 1999/03/26 03:29:57 liang ++ * Add function BlockComplexMultLongAcc. ++ * ++ * Revision 1.3 1999/02/22 22:40:59 liang ++ * BlockByteSum takes uchar inputs instead of schar. ++ * ++ * Revision 1.2 1999/02/10 01:56:44 liang ++ * Added BlockByteSum, BlockRealScaleComplexSymbols and BlockCplxScaleComplexSymbols. ++ * ++ * Revision 1.1 1998/10/28 01:35:38 liang ++ * *** empty log message *** ++ * ++ * Revision 1.12 1998/07/08 17:09:25 scott ++ * Removed unnecessary undefs ++ * ++ * Revision 1.11 1998/04/02 06:19:44 mwg ++ * Added two new utilities. ++ * ++ * Revision 1.10 1998/03/26 23:20:55 liang ++ * Added function BlockShortMultiply. ++ * ++ * Revision 1.9 1998/02/16 18:41:00 scott ++ * Added MMX autodetect support ++ * ++ * Revision 1.8 1997/12/13 06:11:35 mwg ++ * Added new functions: ++ * BlockLongSubtract() ++ * BlockLongAdd() ++ * BlockLong2ShortSubtract() ++ * BlockShort2LongMove() ++ * BlockShortInterpolate() ++ * BlockLongCorrelate() ++ * BlockMapShort2Short() ++ * ++ * Revision 1.7 1997/03/19 18:35:10 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.6 1997/02/11 00:08:18 mwg ++ * Added BlockByteMove function ++ * ++ * Revision 1.5 1997/02/04 08:40:08 mwg ++ * Changed interface forBlockReal2ComplexMacc() ++ * ++ * Revision 1.4 1997/01/23 02:04:28 mwg ++ * Added return value to BlockShortMove ++ * ++ * Revision 1.3 1996/12/19 22:34:55 mwg ++ * Added new function BlockFullPower(). ++ * ++ * Revision 1.2 1996/02/21 03:59:15 mwg ++ * Added new function BlockReal2ComplexMacc ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1995/04/04 06:09:32 mwg ++ * Changed the SoftModem status reporting: now the status is a structure/union ++ * where different fields used for different status code. This will enable ++ * efficient status snooping for high level protocols on top of the softmodem. ++ * ++ */ ++ ++#ifndef BlockUtilPh ++#define BlockUtilPh ++ ++extern void BlockLongAdd (int, long*, long*, long*); ++extern void BlockLong2ShortSubtract (int, long*, long*, short*); ++extern void BlockShort2LongMove (int, short*, long*); ++extern void BlockShortMultiply (int, int, short*, short*, short*); ++extern void BlockByteMoveUnaligned (int size, uchar *srcPtr, uchar *dstPtr); ++extern void BlockShortOffset (int, short, short*, short*); ++extern long BlockShortInterpolateWithIncrement (int size, long scaleFactor, long increment, int shift, short* src1Ptr, short* src2Ptr, short* dstPtr); ++extern void BlockReal2ComplexMult (int, short*, ComplexShort*, ComplexShort*); ++extern void BlockComplexConjigateMult (int, ComplexShort*, ComplexShort*, ComplexShort*); ++ ++extern long BlockSum (int, short*); ++extern long BlockByteSum (int, uchar*); ++extern void BlockComplexSum (int, ComplexShort*, ComplexLong*); ++extern void BlockComplexPower (int, int, ComplexShort*, long*); ++extern long BlockFullPower (int, short*); ++extern long BlockLongCorrelate (int, long*, long*); ++ ++extern int BlockSymbol2Byte (int, int, ushort*, uchar*); ++extern int BlockByte2Symbol (int, int, uchar*, ushort*); ++ ++extern void BlockMapShort2Complex (int, ushort*, ComplexByte*, ComplexShort*); ++extern void BlockMapShort2Short (int size, ushort *srcPtr, short *mapPtr, short *dstPtr); ++extern void BlockMapByte2Byte (int size, uchar *srcPtr, uchar *mapPtr, uchar *dstPtr); ++extern void BlockMapByte2Short (int size, uchar *srcPtr, short *mapPtr, short *dstPtr); ++extern void BlockShortMult (int size, int shift, short* src1Ptr, short* src2Ptr, short* dstPtr); ++ ++extern int SM_DECL Idle(void); ++ ++extern void BlockGenerateAngles(int size, ComplexShort *anglePtr, ComplexShort *incPtr, ComplexShort *dstPtr); ++extern void BlockExtractRealPart(int size, ComplexShort *srcPtr, short *dstPtr); ++extern void BlockShortScaleByShift (int size, int shift, short* srcPtr, short* dstPtr); ++ ++#ifndef PENTIUM_REDEFS /* only if these have not been redefined to function pointers */ ++extern long BlockPower (int, short*); ++extern void BlockReal2ComplexMacc (int, int, short*, ComplexShort*, ComplexLong*); ++extern void BlockComplexMult (int, ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockShortScale (int, short, int, short*, short*); ++extern int SM_DECL BlockShortMove (int, short*, short*); ++extern long BlockCorrelate (int, short*, short*); ++ ++extern void BlockRealScaleComplexSymbols(int, int, uchar*, short*, ComplexShort*, ComplexShort*); ++/* FIXME -- the following 3 functions can be removed */ ++extern void BlockCplxScaleComplexSymbols(int, int, int, ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockCplxSymbolUpdateCplxScale(int, int, int, uchar*, ComplexShort*, ++ ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockComplexShortFill (int, short, short, ComplexShort*); ++ ++ ++extern void BlockRealScaleCplxSymbols(int, int, int, short*, ComplexShort*, ComplexShort*); ++extern void BlockCplxLongConjigateMultCplxShort(int, ComplexLong*, ComplexShort*, ComplexLong*); ++ ++extern void BlockCplxLongScaleCplxSymbols(int, int, int, ComplexLong*, ComplexShort*, short*, ComplexShort*); ++extern void BlockCplxSymbolUpdateCplxLongScale(int, int, int, int, ++ ComplexShort*, short *, ComplexLong*, ComplexShort*); ++ ++extern void BlockComplexLongFill (int, long, long, ComplexLong*); ++ ++extern void BlockShortSubtract (int, short*, short*, short*); ++extern void BlockLongSubtract (int, long*, long*, long*); ++extern void BlockShortAdd (int, short*, short*, short*); ++extern void BlockByteMove (int, uchar*, uchar*); ++extern void BlockByteMoveByLong (int, uchar*, uchar*); ++extern void SM_DECL BlockByteFill (int, uchar, uchar*); ++extern void BlockByteFillByLong (int, uchar, uchar*); ++extern void BlockByteClear (int, uchar*); ++extern void BlockByteClearByLong (int, uchar*); ++extern void BlockShortFill (int, short, short*); ++extern void BlockShortClear (int, short*); ++extern void BlockShortClearByLong (int, short*); ++extern void BlockLongFill (int, long, long*); ++extern void BlockLongClear (int, long*); ++extern void BlockComplexShortClear (int, ComplexShort*); ++extern void BlockShortInvert (int, short*, short*); ++extern void BlockShortScaleDown (int, short*); ++extern void BlockLongMove (int, long*, long*); ++extern void BlockShortInterpolate (int, short, int, short*, short*, short*); ++extern void BlockComplexMultLongAcc (int, int, ComplexShort*, ComplexShort*, ComplexLong*); ++ ++#endif ++ ++#endif /* BlockUtilPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/CircBuf.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/CircBuf.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/CircBuf.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/CircBuf.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,217 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * CircBuf -- Generic Circular Buffer ++ * ++ * Description: ++ * Implementation of generic circular buffer algorithms ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.14 $ ++ * ++ * $Id: CircBuf.h,v 1.14 2004/06/24 03:10:37 ilyas Exp $ ++ * ++ * $Log: CircBuf.h,v $ ++ * Revision 1.14 2004/06/24 03:10:37 ilyas ++ * Added extra macro to be able to use un-cached variable (for status write) ++ * ++ * Revision 1.13 2004/02/09 23:47:02 ilyas ++ * Fixed last change ++ * ++ * Revision 1.12 2004/02/06 22:52:58 ilyas ++ * Improved stretch buffer write ++ * ++ * Revision 1.11 2002/12/30 23:27:55 ilyas ++ * Added macro for HostDma optimizations ++ * ++ * Revision 1.10 2002/10/26 02:15:02 ilyas ++ * Optimized and added new macros for HostDma ++ * ++ * Revision 1.9 2002/01/22 23:59:29 ilyas ++ * Added paraenthesis around macro argument ++ * ++ * Revision 1.8 2002/01/15 22:28:38 ilyas ++ * Extended macro to support readPtr from uncached address ++ * ++ * Revision 1.7 2001/09/21 19:47:05 ilyas ++ * Fixed compiler warnings for VxWorks build ++ * ++ * Revision 1.6 2001/06/07 18:47:56 ilyas ++ * Added more macros for circular buffer arithmetics ++ * ++ * Revision 1.5 2001/04/18 03:58:34 ilyas ++ * Added LOG file write granularity ++ * ++ * Revision 1.4 2001/01/19 04:34:12 ilyas ++ * Added more macros to circular buffer implementation ++ * ++ * Revision 1.3 2001/01/06 04:01:41 ilyas ++ * Changed the way we write status messages ++ * ++ * Revision 1.2 2001/01/04 05:52:21 ilyas ++ * Added implementation of stretchable circular buffer used in LOG and Status ++ * handlers ++ * ++ * Revision 1.1 2000/05/03 03:45:55 ilyas ++ * Original implementation ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef CircBufHeader_H_ ++#define CircBufHeader_H_ ++ ++ ++typedef struct { ++ char *pStart; ++ char *pEnd; ++ char *pRead; ++ char *pWrite; ++} circBufferStruct; ++ ++/* Initialize circular buffer */ ++ ++#define CircBufferInit(pCB,buf,size) do { \ ++ (pCB)->pStart = (char *) (buf); \ ++ (pCB)->pRead = (pCB)->pWrite = (pCB)->pStart; \ ++ (pCB)->pEnd = (pCB)->pStart + size; \ ++} while (0) ++ ++#define CircBufferGetSize(pCB) ((pCB)->pEnd - (pCB)->pStart) ++#define CircBufferGetStartPtr(pCB) ((void *) (pCB)->pStart) ++#define CircBufferGetEndPtr(pCB) ((void *) (pCB)->pEnd) ++ ++#define CircBufferReset(pCB) (pCB)->pRead = (pCB)->pWrite = (pCB)->pStart ++ ++ ++#define CircBufferGetReadPtr(pCB) ((void *) (pCB)->pRead) ++#define CircBufferGetWritePtr(pCB) ((void *) (pCB)->pWrite) ++ ++ ++#ifndef bcm47xx ++#define CircBufferDistance(pCB,p1,p2,d) ((char*)(p2) - (char*)(p1) - d >= 0 ? \ ++ (char*)(p2) - (char*)(p1) - d : \ ++ ((char*)(p2)- (char*)(p1) - d + ((pCB)->pEnd - (pCB)->pStart))) ++ ++#define CircBufferAddContig(pCB,p,n) ((char*)(p) + (n) == (pCB)->pEnd ? (pCB)->pStart : (char*)(p) + (n)) ++#else ++static __inline int CircBufferDistance(circBufferStruct *pCB, char *p1, char *p2, int d) ++{ ++ int tmp = p2 - p1 - d; ++ ++ return (tmp >= 0 ? tmp : tmp + (pCB->pEnd - pCB->pStart)); ++} ++ ++static __inline char * CircBufferAddContig(circBufferStruct *pCB, char *p, int n) ++{ ++ p += n; ++ return (p == pCB->pEnd ? pCB->pStart : p); ++} ++#endif ++ ++#define CircBufferAdd(pCB,p,n) ((char*)(p) + (n) >= (pCB)->pEnd ? \ ++ (pCB)->pStart + ((char*)(p) + (n) - (pCB)->pEnd) : \ ++ (char*)(p) + (n)) ++ ++#define CircBufferReadUpdate(pCB,n) (pCB)->pRead = CircBufferAdd(pCB,(pCB)->pRead,n) ++#define CircBufferWriteUpdate(pCB,n) (pCB)->pWrite= CircBufferAdd(pCB,(pCB)->pWrite,n) ++ ++#define CircBufferReadUpdateContig(pCB,n) (pCB)->pRead = CircBufferAddContig(pCB,(pCB)->pRead,n) ++#define CircBufferWriteUpdateContig(pCB,n) (pCB)->pWrite= CircBufferAddContig(pCB,(pCB)->pWrite,n) ++ ++#define CircBufferGetReadAvail(pCB) CircBufferDistance(pCB,(pCB)->pRead,(pCB)->pWrite,0) ++#define CircBufferIsReadEmpty(pCB) ((pCB)->pRead == (pCB)->pWrite) ++#define CircBufferGetWriteAvail(pCB) CircBufferDistance(pCB,(pCB)->pWrite,(pCB)->pRead,1) ++#define CircBufferGetWriteAvailN(pCB,n) CircBufferDistance(pCB,(pCB)->pWrite,(pCB)->pRead,n) ++ ++#define CircBufferGetReadContig(pCB) ((unsigned long)(pCB)->pWrite >= (unsigned long) (pCB)->pRead ? \ ++ (pCB)->pWrite - (pCB)->pRead : \ ++ (pCB)->pEnd - (pCB)->pRead) ++ ++#define CircBufferGetWriteContig(pCB) ((pCB)->pEnd - (pCB)->pWrite > CircBufferGetWriteAvail(pCB) ? \ ++ CircBufferGetWriteAvail(pCB) : \ ++ (pCB)->pEnd - (pCB)->pWrite) ++ ++/* ++** ++** structure and macros for "strectch" buffer ++** ++*/ ++ ++typedef struct { ++ char *pStart; ++ char *pEnd; ++ char *pExtraEnd; ++ char *pStretchEnd; ++ char *pRead; ++ char *pWrite; ++} stretchBufferStruct; ++ ++#define StretchBufferInit(pSB,buf,size,extra) do { \ ++ (pSB)->pStart = (char *) (buf); \ ++ (pSB)->pRead = (pSB)->pWrite = (pSB)->pStart; \ ++ (pSB)->pEnd = (pSB)->pStart + (size); \ ++ (pSB)->pStretchEnd = (pSB)->pEnd; \ ++ (pSB)->pExtraEnd = (pSB)->pEnd+(extra); \ ++} while (0) ++ ++#define StretchBufferGetSize(pSB) ((pSB)->pEnd - (pSB)->pStart) ++#define StretchBufferGetStartPtr(pSB) ((void *) (pSB)->pStart) ++#define StretchBufferGetReadPtr(pSB) ((void *) (pSB)->pRead) ++#define StretchBufferGetWritePtr(pSB) ((void *) (pSB)->pWrite) ++#define StretchBufferReset(pSB) ((pSB)->pRead = (pSB)->pWrite = (pSB)->pStart) ++ ++#define StretchBufferGetReadToEnd(pSB) ((pSB)->pStretchEnd - (pSB)->pRead) ++ ++#define StretchBufferGetReadAvail(pSB) ((pSB)->pWrite - (pSB)->pRead >= 0 ? \ ++ (pSB)->pWrite - (pSB)->pRead : \ ++ (pSB)->pStretchEnd - (pSB)->pRead) ++#define _StretchBufferGetWriteAvail(pSB,rd) ((rd) - (pSB)->pWrite > 0 ? \ ++ (rd) - (pSB)->pWrite - 1 : \ ++ ((pSB)->pExtraEnd - (pSB)->pWrite)) ++#define StretchBufferGetWriteAvail(pSB) _StretchBufferGetWriteAvail(pSB, (pSB)->pRead) ++ ++#define StretchBufferReadUpdate(pSB,n) do { \ ++ char *p; \ ++ \ ++ p = (pSB)->pRead + (n); \ ++ (pSB)->pRead = (p >= (pSB)->pStretchEnd ? (pSB)->pStart : p); \ ++} while (0) ++ ++#define _StretchBufferWriteUpdate(pSB,rd,n) do { \ ++ char *p; \ ++ \ ++ p = (pSB)->pWrite + (n); \ ++ if (p >= (pSB)->pEnd) { \ ++ if ((rd) != (pSB)->pStart) { \ ++ (pSB)->pStretchEnd = p; \ ++ (pSB)->pWrite = (pSB)->pStart; \ ++ } \ ++ } \ ++ else \ ++ (pSB)->pWrite = p; \ ++} while (0) ++ ++#define StretchBufferWriteUpdate(pSB,n) _StretchBufferWriteUpdate(pSB,(pSB)->pRead,n) ++ ++#endif /* CircBufHeader_H_ */ ++ ++ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DList.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DList.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DList.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DList.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,131 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * DList.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of double-linked list ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef DListHeader_H_ ++#define DListHeader_H_ ++ ++typedef struct _DListHeader ++ { ++ struct _DListHeader *next; /* next item in the list */ ++ struct _DListHeader *prev; /* prev item in the list */ ++ } DListHeader; ++ ++typedef struct _DListUpHeader ++ { ++ struct _DListUpHeader *next; /* next item in the list */ ++ struct _DListUpHeader *prev; /* prev item in the list */ ++ struct _DListUpHeader *head; /* head of the list */ ++ } DListUpHeader; ++ ++/* Double linked list DList management macros */ ++ ++#define DListInit(pDListHead) do { \ ++ ((DListHeader *)(pDListHead))->next = pDListHead; \ ++ ((DListHeader *)(pDListHead))->prev = pDListHead; \ ++} while (0) ++ ++#define DListNext(pDListEntry) (((DListHeader *)(pDListEntry))->next) ++#define DListPrev(pDListEntry) (((DListHeader *)(pDListEntry))->prev) ++ ++#define DListEntryLinked(pDListEntry) (NULL != DListNext(pDListEntry)) ++#define DListUnlinkEntry(pDListEntry) (DListNext(pDListEntry) = DListPrev(pDListEntry) = NULL) ++ ++#define DListFirst(pDListHead) DListNext(pDListHead) ++#define DListLast(pDListHead) DListPrev(pDListHead) ++#define DListValid(pDListHead,pEntry) ((void *)(pDListHead) != (pEntry)) ++#define DListEmpty(pDListHead) ((void *)pDListHead == ((DListHeader *)pDListHead)->next) ++ ++#define DListInsertAfter(pDListEntry,pEntry) do { \ ++ ((DListHeader *)(pEntry))->next = ((DListHeader *)(pDListEntry))->next; \ ++ ((DListHeader *)(pEntry))->prev = (DListHeader *)(pDListEntry); \ ++ ((DListHeader *)(pDListEntry))->next->prev = (DListHeader *) (pEntry); \ ++ ((DListHeader *)(pDListEntry))->next = (DListHeader *) (pEntry); \ ++} while (0) ++ ++#define DListInsertBefore(pDListEntry,pEntry) do { \ ++ ((DListHeader *)(pEntry))->next = (DListHeader *)(pDListEntry); \ ++ ((DListHeader *)(pEntry))->prev = ((DListHeader *)(pDListEntry))->prev; \ ++ ((DListHeader *)(pDListEntry))->prev->next = (DListHeader *) (pEntry); \ ++ ((DListHeader *)(pDListEntry))->prev = (DListHeader *) (pEntry); \ ++} while (0) ++ ++#define DListInsertTail(pDListHead,pEntry) DListInsertBefore(pDListHead,pEntry) ++#define DListInsertHead(pDListHead,pEntry) DListInsertAfter(pDListHead,pEntry) ++ ++#define DListRemove(pDListEntry) do { \ ++ ((DListHeader *)(pDListEntry))->prev->next = ((DListHeader *)(pDListEntry))->next; \ ++ ((DListHeader *)(pDListEntry))->next->prev = ((DListHeader *)(pDListEntry))->prev; \ ++} while (0) ++ ++ ++#define DListForEach(pDListHead,f,ref) do { \ ++ DListHeader *p = ((DListHeader *)(pDListHead))->next; \ ++ \ ++ while (DListValid(pDListHead,p)) { \ ++ DListHeader *p0 = p; \ ++ p = DListNext(p); \ ++ if ( (f)((void *)p0, ref) ) break; \ ++ } \ ++} while (0) ++ ++ ++/* Double linked list with up link DListUp management macros */ ++ ++#define DListUpInit(pDListHead) do { \ ++ ((DListUpHeader *)(pDListHead))->next = (DListUpHeader *) (pDListHead); \ ++ ((DListUpHeader *)(pDListHead))->prev = (DListUpHeader *) (pDListHead); \ ++ ((DListUpHeader *)(pDListHead))->head = (DListUpHeader *) (pDListHead); \ ++} while (0) ++ ++#define DListUpNext(pDListEntry) ((DListUpHeader *) DListNext(pDListEntry)) ++#define DListUpPrev(pDListEntry) ((DListUpHeader *) DListPrev(pDListEntry)) ++#define DListUpHead(pDListEntry) (((DListUpHeader *)(pDListEntry))->head) ++ ++#define DListUpFirst(pDListHead) DListUpNext(pDListHead) ++#define DListUpLast(pDListHead) DListUpPrev(pDListHead) ++#define DListUpValid(pEntry) (((DListUpHeader *)(pEntry))->head != (void *) pEntry) ++#define DListUpEmpty(pDListHead) DListEmpty(pDListHead) ++ ++#define DListUpInsertAfter(pDListEntry,pEntry) do { \ ++ DListInsertAfter(pDListEntry,pEntry); \ ++ ((DListUpHeader *)(pEntry))->head = ((DListUpHeader *)(pDListEntry))->head; \ ++} while (0) ++ ++#define DListUpInsertBefore(pDListEntry,pEntry) do { \ ++ DListInsertBefore(pDListEntry,pEntry); \ ++ ((DListUpHeader *)(pEntry))->head = ((DListUpHeader *)(pDListEntry))->head; \ ++} while (0) ++ ++#define DListUpInsertTail(pDListHead,pEntry) DListUpInsertBefore(pDListHead,pEntry) ++#define DListUpInsertHead(pDListHead,pEntry) DListUpInsertAfter(pDListHead,pEntry) ++ ++#define DListUpRemove(pDListEntry) DListRemove(pDListEntry) ++#define DListUpForEach(pDListHead,f,ref) DListForEach((DListHeader *)(pDListHead),f,ref) ++ ++#endif /* DListHeader_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DslFramer.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DslFramer.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DslFramer.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/DslFramer.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,159 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * DslFramer.h ++ * ++ * Description: ++ * This file contains common DSL framer definitions ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: DslFramer.h,v 1.3 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: DslFramer.h,v $ ++ * Revision 1.3 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.2 2004/04/12 23:41:10 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef DslFramerHeader ++#define DslFramerHeader ++ ++#include "DList.h" ++ ++#define kDslFramerInitialized 0x80000000 ++ ++/* status codes */ ++ ++#define kDslFramerRxFrame 1 ++#define kDslFramerRxFrameErr 2 ++#define kDslFramerTxFrame 3 ++#define kDslFramerTxFrameErr 4 ++ ++#define kDslFramerRxFrameErrFlushed 1 ++#define kDslFramerRxFrameErrAbort 2 ++#define kDslFramerRxFrameErrPhy 3 ++ ++#define kDslFramerTxFrameErrFlushed 1 ++ ++ ++typedef struct _dslFramerBufDesc { ++ long pkId; ++ long bufFlags; ++ void *bufPtr; ++ long bufLen; ++} dslFramerBufDesc; ++ ++/* data bufDesc flags */ ++ ++#define kDslFramerStartNewFrame 1 ++#define kDslFramerEndOfFrame 2 ++#define kDslFramerAbortFrame 4 ++ ++#define kDslFramerExtraByteShift 3 ++#define kDslFramerExtraByteMask (0x7 << kDslFramerExtraByteShift) ++ ++typedef struct _dslFramerControl { ++ bitMap setup; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ ulong statusCode; ++ ulong statusOffset; ++ ++ int nRxBuffers; ++ int nRxBufSize; ++ int nRxPackets; ++ ++ dslFrame *freeBufListPtr; ++ void *freeBufPool; ++ void *pBufMemory; ++ ++ dslFrame *freePacketListPtr; ++ void *freePacketPool; ++ ++ /* RX working data set */ ++ ++ dslFrame *pRxFrame; ++ dslFrameBuffer *pRxBuf; ++ uchar *pRxBufData; ++ uchar *pRxBufDataEnd; ++ int rxFrameLen; ++ ++ /* TX working data set */ ++ ++ DListHeader dlistTxWaiting; ++ dslFrame *pTxFrame; ++ dslFrameBuffer *pTxBuf; ++ uchar *pTxBufData; ++ uchar *pTxBufDataEnd; ++ ++ /* stats data */ ++ ++ ulong dslByteCntRxTotal; ++ ulong dslByteCntTxTotal; ++ ++ ulong dslFrameCntRxTotal; ++ ulong dslFrameCntRxErr; ++ ulong dslFrameCntTxTotal; ++ ++} dslFramerControl; ++ ++ ++extern Boolean DslFramerInit( ++ void *gDslVars, ++ dslFramerControl *dfCtrl, ++ bitMap setup, ++ ulong statusCode, ++ ulong statusOffset, ++ dslFrameHandlerType rxIndicateHandlerPtr, ++ dslFrameHandlerType txCompleteHandlerPtr, ++ dslStatusHandlerType statusHandlerPtr, ++ ulong rxBufNum, ++ ulong rxBufSize, ++ ulong rxPacketNum); ++extern void DslFramerClose(void *gDslVars, dslFramerControl *dfCtrl); ++extern void DslFramerSendFrame(void *gDslVars, dslFramerControl *dfCtrl, dslFrame *pFrame); ++extern void DslFramerReturnFrame(void *gDslVars, dslFramerControl *dfCtrl, dslFrame *pFrame); ++ ++ ++extern Boolean DslFramerRxGetPtr(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern void DslFramerRxDone (void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern Boolean DslFramerTxGetPtr(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern void DslFramerTxDone(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern Boolean DslFramerTxIdle (void *gDslVars, dslFramerControl *dfCtrl); ++extern void DslFramerTxFlush(void *gDslVars, dslFramerControl *dfCtrl); ++ ++extern void * DslFramerGetFramePoolHandler(dslFramerControl *dfCtrl); ++extern void DslFramerClearStat(dslFramerControl *dfCtrl); ++ ++extern void DslFramerRxFlushFrame (void *gDslVars, dslFramerControl *dfCtrl, int errCode); ++extern void DslFramerRxFlush(void *gDslVars, dslFramerControl *dfCtrl); ++ ++#endif /* DslFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Flatten.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Flatten.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Flatten.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Flatten.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,115 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * Flatten.h -- Header for Flatten/Unflatten command/status ++ * ++ * Copyright (c) 1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.14 $ ++ * ++ * $Id: Flatten.h,v 1.14 2004/03/04 19:48:52 linyin Exp $ ++ * ++ * $Log: Flatten.h,v $ ++ * Revision 1.14 2004/03/04 19:48:52 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.13 2003/10/17 22:45:14 yongbing ++ * Increase buffer size for large B&G table of G992P3 ++ * ++ * Revision 1.12 2003/08/12 23:16:26 khp ++ * - for Haixiang: added support for ADSL_MARGIN_TWEAK_TEST ++ * ++ * Revision 1.11 2003/02/27 06:33:03 ilyas ++ * Improved free space checking in command buffer (became a problem with ++ * 2 commands SetXmtgain and StartPhy) ++ * ++ * Revision 1.10 2003/01/11 01:27:07 ilyas ++ * Improved checking for available space in status buffer ++ * ++ * Revision 1.9 2002/09/07 01:43:59 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.8 2002/05/16 00:01:52 khp ++ * -added missing #endif ++ * ++ * Revision 1.7 2002/05/15 00:04:48 mprahlad ++ * increase the status buffer size - prevent memory overflow for annexC cases ++ * ++ * Revision 1.6 2002/04/05 04:10:33 linyin ++ * -hack to fit in Annex C firmware in LMEM ++ * ++ * Revision 1.5 2002/04/05 02:45:25 linyin ++ * Make the buffer side larger for annexC ++ * ++ * Revision 1.4 2002/01/30 07:19:06 ilyas ++ * Moved showtime code to LMEM ++ * ++ * Revision 1.3 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.2 2001/04/25 00:30:54 ilyas ++ * Adjusted MaxFrameLen ++ * ++ * Revision 1.1 2001/04/24 21:41:21 ilyas ++ * Implemented status flattening/unflattaning to transfer statuses between ++ * modules asynchronously through the circular buffer ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef _Flatten_H_ ++#define _Flatten_H_ ++ ++#include "CircBuf.h" ++ ++#ifdef ADSL_MARGIN_TWEAK_TEST ++#define kMaxFlattenedCommandSize 272 /* maximum no. of bytes in flattened cmd */ ++#else ++#define kMaxFlattenedCommandSize 128 /* maximum no. of bytes in flattened cmd */ ++#endif ++#if defined(G992_ANNEXC) || defined(G992P3) ++#if defined(G992P5) ++#define kMaxFlattenedStatusSize 2200 /* maximum no. of bytes in flattened status */ ++#else ++#define kMaxFlattenedStatusSize 1100 /* maximum no. of bytes in flattened status */ ++#endif ++#else ++#define kMaxFlattenedStatusSize 550 /* maximum no. of bytes in flattened status */ ++#endif ++ ++#define kMaxFlattenFramelength (kMaxFlattenedStatusSize - (4*sizeof(long)) - 20) ++ ++extern int SM_DECL FlattenCommand (dslCommandStruct *cmd, ulong *dstPtr, ulong nAvail); ++extern int SM_DECL UnflattenCommand(ulong *srcPtr, dslCommandStruct *cmd); ++extern int SM_DECL FlattenStatus (dslStatusStruct *status, ulong *dstPtr, ulong nAvail); ++extern int SM_DECL UnflattenStatus (ulong *srcPtr, dslStatusStruct *status); ++ ++#define FlattenBufferInit(fb,fbData,bufSize,itemSize) \ ++ StretchBufferInit(fb, fbData, bufSize, itemSize) ++ ++extern int SM_DECL FlattenBufferStatusWrite(stretchBufferStruct *fBuf, dslStatusStruct *status); ++extern int SM_DECL FlattenBufferStatusRead(stretchBufferStruct *fBuf, dslStatusStruct *status); ++ ++extern int SM_DECL FlattenBufferCommandWrite(stretchBufferStruct *fBuf, dslCommandStruct *cmd); ++extern int SM_DECL FlattenBufferCommandRead(stretchBufferStruct *fBuf, dslCommandStruct *cmd); ++ ++#define FlattenBufferReadComplete(fb,nBytes) \ ++ StretchBufferReadUpdate (fb, nBytes) ++ ++#endif /* _Flatten_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,110 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G992p3OvhMsg.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the G992p3 overhead ++ * channel messages global variable structure. ++ * ++ * ++ * Copyright (c) 1999-2003 BroadCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: G992p3OvhMsg.gh,v 1.5 2004/09/11 03:52:25 ilyas Exp $ ++ * ++ * $Log: G992p3OvhMsg.gh,v $ ++ * Revision 1.5 2004/09/11 03:52:25 ilyas ++ * Added support for overhead message segmentation ++ * ++ * Revision 1.4 2004/07/07 01:27:20 ilyas ++ * Fixed OHC message stuck problem on L2 entry/exit ++ * ++ * Revision 1.3 2004/06/10 00:13:31 ilyas ++ * Added L2/L3 and SRA ++ * ++ * Revision 1.2 2004/04/12 23:34:52 ilyas ++ * Merged the latest ADSL driver chnages for ADSL2+ ++ * ++ * Revision 1.1 2003/07/18 19:39:18 ilyas ++ * Initial G.992.3 overhead channel message implementation (from ADSL driver) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G992p3OvhMsgFramerGlobals ++#define G992p3OvhMsgFramerGlobals ++ ++#define kG992p3OvhMsgMaxCmdSize (16 + 16) ++#define kG992p3OvhMsgMaxRspSize (16 + 2*512) ++ ++typedef struct ++ { ++ dslFrame *segFrame; ++ dslFrameBuffer *segFrBufCur; ++ dslFrameBuffer segFrBuf; ++ ulong timeSegOut; ++ uchar tryCnt; ++ uchar segTotal; ++ uchar segId; ++ } ++ g992p3SegFrameCtlStruct; ++ ++typedef struct ++ { ++ bitMap setup; ++ dslFrameHandlerType rxReturnFramePtr; ++ dslFrameHandlerType txSendFramePtr; ++ dslCommandHandlerType cmdHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ ++ dslFrame txRspFrame; ++ dslFrameBuffer txRspFrBuf; ++ dslFrameBuffer txRspFrBuf1; ++ uchar txRspBuf[kG992p3OvhMsgMaxRspSize]; ++ dslFrame txPwrRspFrame; ++ dslFrameBuffer txPwrRspFrBuf0; ++ dslFrameBuffer txPwrRspFrBuf0a; ++ dslFrameBuffer txPwrRspFrBuf1; ++ uchar txPwrRspBuf0[8]; ++ dslFrame txCmdFrame; ++ dslFrameBuffer txCmdFrBuf0; ++ dslFrameBuffer txCmdFrBuf0a; ++ dslFrameBuffer txCmdFrBuf1; ++ uchar txCmdBuf[kG992p3OvhMsgMaxCmdSize]; ++ g992p3SegFrameCtlStruct txSegFrameCtl; ++ ulong txFlags; ++ uchar txL0Rq; ++ uchar txL3Rq; ++ ++ ulong timeMs; ++ ulong timeCmdOut; ++ ulong cmdTryCnt; ++ ulong cmdNum; ++ ulong timeRspOut; ++ uchar *txPmdCmd; ++ ++ uchar rxCmdMsgNum; ++ uchar rxRspMsgNum; ++ uchar txCmdMsgNum; ++ uchar txRspMsgNum; ++ } ++ g992p3OvhMsgVarsStruct; ++ ++#endif /* G992p3OvhMsgFramerGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G992p3OvhMsg.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,64 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G992p3OvhMsg.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for G992p3 ++ * overhead channel messages ++ * ++ * ++ * Copyright (c) 1999-2003 BroadCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.1 $ ++ * ++ * $Id: G992p3OvhMsg.h,v 1.1 2003/07/18 19:39:18 ilyas Exp $ ++ * ++ * $Log: G992p3OvhMsg.h,v $ ++ * Revision 1.1 2003/07/18 19:39:18 ilyas ++ * Initial G.992.3 overhead channel message implementation (from ADSL driver) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G992p3OvhMsgFramerHeader ++#define G992p3OvhMsgFramerHeader ++ ++#define kG992p3OvhMsgFrameBufCnt -1 ++ ++extern Boolean G992p3OvhMsgInit( ++ void *gDslVars, ++ bitMap setup, ++ dslFrameHandlerType rxReturnFramePtr, ++ dslFrameHandlerType txSendFramePtr, ++ dslCommandHandlerType commandHandler, ++ dslStatusHandlerType statusHandler); ++ ++extern void G992p3OvhMsgReset(void *gDslVars); ++extern void G992p3OvhMsgClose(void *gDslVars); ++extern void G992p3OvhMsgTimer(void *gDslVars, long timeQ24ms); ++extern Boolean G992p3OvhMsgCommandHandler (void *gDslVars, dslCommandStruct *cmd); ++extern void G992p3OvhMsgStatusSnooper (void *gDslVars, dslStatusStruct *status); ++ ++extern int G992p3OvhMsgSendCompleteFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++extern int G992p3OvhMsgIndicateRcvFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++ ++extern void G992p3OvhMsgSetL3(void *gDslVars); ++extern void G992p3OvhMsgSetL0(void *gDslVars); ++ ++#endif /* G992p3OvhMsgFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,66 @@ ++/**************************************************************************** ++ * ++ * G997.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the G997 Framer ++ * global variable structure. ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: G997.gh,v 1.5 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: G997.gh,v $ ++ * Revision 1.5 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.4 2004/04/27 00:27:16 ilyas ++ * Implemented double buffering to ensure G.997 HDLC frame is continuous ++ * ++ * Revision 1.3 2003/07/18 18:56:59 ilyas ++ * Added support for shared TX buffer (for ADSL driver) ++ * ++ * Revision 1.2 2002/01/11 06:48:27 ilyas ++ * Added command handler pointer ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G997FramerGlobals ++#define G997FramerGlobals ++ ++#include "DslFramer.h" ++#include "HdlcFramer.h" ++ ++#define kG997MsgBufSize 64 ++ ++typedef struct ++ { ++ bitMap setup; ++ dslFramerControl dslFramer; ++ hdlcByteControl hdlcByte; ++ dslCommandHandlerType commandHandler; ++ ++ ulong timeMs; ++ ulong timeCmdOut; ++ ++ uchar rxMsgNum; ++ uchar txMsgNum; ++ Boolean txIdle; ++ uchar txMsgBuf[kG997MsgBufSize]; ++ ulong txMsgBufLen; ++ uchar *txMsgBufPtr; ++ ulong txMsgLen; ++ ulong txMsgBufs; ++ ulong txMsgBufNum; ++ } ++ g997VarsStruct; ++ ++#endif /* G997FramerGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/G997.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,68 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G997.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for G97Framer ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: G997.h,v 1.3 2003/07/18 18:56:59 ilyas Exp $ ++ * ++ * $Log: G997.h,v $ ++ * Revision 1.3 2003/07/18 18:56:59 ilyas ++ * Added support for shared TX buffer (for ADSL driver) ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G997FramerHeader ++#define G997FramerHeader ++ ++extern Boolean G997Init( ++ void *gDslVars, ++ bitMap setup, ++ ulong rxBufNum, ++ ulong rxBufSize, ++ ulong rxPacketNum, ++ upperLayerFunctions *pUpperLayerFunctions, ++ dslCommandHandlerType g997PhyCommandHandler); ++ ++extern void G997Close(void *gDslVars); ++extern void G997Timer(void *gDslVars, long timeQ24ms); ++extern Boolean G997CommandHandler (void *gDslVars, dslCommandStruct *cmd); ++extern void G997StatusSnooper (void *gDslVars, dslStatusStruct *status); ++ ++extern int G997SendFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++extern int G997ReturnFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++ ++extern Boolean G997SetTxBuffer(void *gDslVars, ulong len, void *bufPtr); ++extern void * G997GetFramePoolHandler(void *gDslVars); ++ ++#endif /* G997FramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/HdlcFramer.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/HdlcFramer.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/HdlcFramer.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/HdlcFramer.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,237 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * HdlcFramer.h ++ * ++ * Description: ++ * This file contains common HDLC definitions for bit/byte stuffing ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: HdlcFramer.h,v 1.3 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: HdlcFramer.h,v $ ++ * Revision 1.3 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.2 2003/07/18 18:51:05 ilyas ++ * Added mode (default) to pass address and control field ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef HdlcFramerHeader ++#define HdlcFramerHeader ++ ++/* setup bitmap definitions */ ++ ++#define kHdlcSetupShift 16 ++#define kHdlcSetupMask ((long)0xFFFF << kHdlcSetupShift) ++ ++#define kHdlcCrcMask 0x00030000 ++#define kHdlcCrcNone 0x00000000 ++#define kHdlcCrc16 0x00010000 ++#define kHdlcCrc32 0x00020000 ++ ++#define kHdlcTxIdleStop 0x00040000 ++#define kHdlcSpecialAddrCtrl 0x00080000 ++ ++extern ushort HdlcCrc16Table[]; ++ ++#define HDLC16_CRC_INIT 0xFFFF ++#define HDLC16_CRC_FINAL(crc) ((crc) ^ 0xFFFF) ++#define HDLC16_GOOD_CRC 0xF0B8 ++#define Hdlc16UpdateCrc(crc,b) ((crc) >> 8) ^ HdlcCrc16Table[((crc) ^ (b)) & 0xFF] ++ ++extern ulong HdlcCrc32Table[]; ++ ++#define HDLC32_CRC_INIT 0xFFFFFFFF ++#define HDLC32_CRC_FINAL(crc) ((crc) ^ 0xFFFFFFFF) ++#define HDLC32_GOOD_CRC 0xDEBB20E3 ++#define Hdlc32UpdateCrc(crc,b) ((crc) >> 8) ^ HdlcCrc32Table[((crc) ^ (b)) & 0xFF] ++ ++extern ulong HdlcCrc32Table[]; ++ ++/* HDLC common fields */ ++ ++#define HDLC_ADDR 0xFF ++#define HDLC_CTRL 0x3 ++ ++#define HDLC_BYTE_FLAG 0x7E ++#define HDLC_BYTE_ESC 0x7D ++ ++/* HDLC frame assembly states */ ++ ++#define HDLC_STATE_START_FLAG 0 ++#define HDLC_STATE_ADDRESS (HDLC_STATE_START_FLAG + 1) ++#define HDLC_STATE_CONTROL (HDLC_STATE_START_FLAG + 2) ++#define HDLC_STATE_DATA (HDLC_STATE_START_FLAG + 3) ++#define HDLC_STATE_FCS1 (HDLC_STATE_START_FLAG + 4) ++#define HDLC_STATE_FCS2 (HDLC_STATE_START_FLAG + 5) ++#define HDLC_STATE_END_FLAG (HDLC_STATE_START_FLAG + 6) ++ ++ ++/* HDLC common types */ ++ ++typedef struct _hdlcByteControl { ++ bitMap setup; ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ ++ /* RX working data set */ ++ ++ uchar rxFrameState; ++ int rxFrameLen; ++ ulong rxCrc; ++ Boolean rxEscChar; ++ ++ uchar *pRxData; ++ uchar *pRxDataEnd; ++ long rxDataLen; ++ ++ /* TX working data set */ ++ ++ uchar txFrameState; ++ int txFrameLen; ++ ulong txCrc; ++ int txCharPending; ++ ++ uchar *pTxData; ++ uchar *pTxDataEnd; ++ long txDataLen; ++} hdlcByteControl; ++ ++typedef struct _hdlcBitControl { ++ bitMap setup; ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ ++ /* RX working data set */ ++ ++ uchar rxFrameState; ++ int rxFrameLen; ++ ulong rxCrc; ++ int rxNibblePending; ++ int rxOutVal; ++ uchar rxOutBits; ++ uchar rxRem1Bits; ++ Boolean rxEscChar; /* ???? */ ++ ++ uchar *pRxData; ++ uchar *pRxDataEnd; ++ long rxDataLen; ++ ++ /* TX working data set */ ++ ++ uchar txFrameState; ++ int txFrameLen; ++ ulong txCrc; ++ int txOutVal; ++ uchar txOutBits; ++ uchar txLast1Bits; ++ int txCharPending; /* ???? */ ++ ++ uchar *pTxData; ++ uchar *pTxDataEnd; ++ long txDataLen; ++} hdlcBitControl; ++ ++/* HDLC common functions */ ++ ++#define HdlcFramerTxFrameInit(ctrl) do { \ ++ ctrl->txFrameState = HDLC_STATE_START_FLAG; \ ++ ctrl->txFrameLen = 0; \ ++ ctrl->txCrc = HDLC16_CRC_INIT; \ ++ ctrl->txCharPending= -1; \ ++} while (0) ++ ++#define HdlcFramerRxFrameInit(ctrl) do { \ ++ ctrl->rxFrameState = HDLC_STATE_START_FLAG; \ ++ ctrl->rxFrameLen = 0; \ ++ ctrl->rxCrc = HDLC16_CRC_INIT; \ ++ ctrl->rxEscChar = false; \ ++} while (0) ++ ++#define HdlcFramerTxGetData(ctrl) do { \ ++ dslFramerBufDesc bufDesc; \ ++ \ ++ if ((ctrl->txDataGetPtrHandler) (gDslVars, &bufDesc)) { \ ++ ctrl->pTxData = bufDesc.bufPtr; \ ++ ctrl->pTxDataEnd = (uchar*)bufDesc.bufPtr + bufDesc.bufLen; \ ++ ctrl->txDataLen = bufDesc.bufLen; \ ++ if (bufDesc.bufFlags & kDslFramerStartNewFrame) \ ++ HdlcFramerTxFrameInit(ctrl); \ ++ } \ ++ else { \ ++ HdlcFramerTxFrameInit(ctrl); \ ++ } \ ++} while (0); ++ ++#define HdlcFramerRxGetData(ctrl, frFlag) do { \ ++ dslFramerBufDesc bufDesc; \ ++ \ ++ bufDesc.bufFlags = frFlag; \ ++ if ((ctrl->rxDataGetPtrHandler) (gDslVars, &bufDesc)) { \ ++ ctrl->pRxData = bufDesc.bufPtr; \ ++ ctrl->pRxDataEnd = (uchar*)bufDesc.bufPtr + bufDesc.bufLen; \ ++ ctrl->rxDataLen = bufDesc.bufLen; \ ++ } \ ++} while (0); ++ ++/* HDLC functions headers */ ++ ++extern Boolean HdlcByteInit( ++ void *gDslVars, ++ hdlcByteControl *hbyCtrl, ++ bitMap setup, ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler, ++ dslFramerDataDoneHandlerType rxDataDoneHandler, ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler, ++ dslFramerDataDoneHandlerType txDataDoneHandler); ++ ++extern void HdlcByteReset(void *gDslVars, hdlcByteControl *hbyCtrl); ++extern void HdlcByteRxFlush(void *gDslVars, hdlcByteControl *hbyCtrl); ++extern int HdlcByteRx(void *gDslVars, hdlcByteControl *hbyCtrl, int nBytes, uchar *srcPtr) FAST_TEXT; ++extern int HdlcByteTx(void *gDslVars, hdlcByteControl *hbyCtrl, int nBytes, uchar *dstPtr) FAST_TEXT; ++extern Boolean HdlcByteTxIdle(void *gDslVars, hdlcByteControl *hbyCtrl); ++ ++extern Boolean HdlcBitInit( ++ void *gDslVars, ++ hdlcBitControl *hbiCtrl, ++ bitMap setup, ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler, ++ dslFramerDataDoneHandlerType rxDataDoneHandler, ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler, ++ dslFramerDataDoneHandlerType txDataDoneHandler); ++ ++extern void HdlcBitReset(void *gDslVars, hdlcByteControl *hbiCtrl); ++extern int HdlcBitRx(void *gDslVars, hdlcBitControl *hbiCtrl, int nBytes, uchar *srcPtr) FAST_TEXT; ++extern int HdlcBitTx(void *gDslVars, hdlcBitControl *hbiCtrl, int nBytes, uchar *dstPtr) FAST_TEXT; ++ ++#endif /* HdlcFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MathUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MathUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MathUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MathUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,135 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/************************************************************************ ++ * ++ * MathUtil.h: ++ * ++ * Description: ++ * This file contains the exported interface for MathUtil.c module. ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.6 $ ++ * ++ * $Id: MathUtil.h,v 1.6 2004/04/13 00:21:13 ilyas Exp $ ++ * ++ * $Log: MathUtil.h,v $ ++ * Revision 1.6 2004/04/13 00:21:13 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.5 2001/08/16 02:18:08 khp ++ * - mark functions with FAST_TEXT to reduce cycle counts for QPROC targets ++ * (replaces use of LMEM_INSN) ++ * ++ * Revision 1.4 1999/10/06 04:55:22 liang ++ * Added function to multiply two long values to save result as VeryLong. ++ * ++ * Revision 1.3 1999/08/05 19:42:52 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.2 1999/03/26 03:29:59 liang ++ * Export CosSin table. ++ * ++ * Revision 1.1 1998/10/28 01:28:07 liang ++ * *** empty log message *** ++ * ++ * Revision 1.12 1998/02/10 17:19:49 scott ++ * Changed MathVL routines to return arguments using pointers ++ * ++ * Revision 1.11 1997/12/13 06:12:07 mwg ++ * Added more Atan2 flavors ++ * ++ * Revision 1.10 1997/11/18 01:11:48 mwg ++ * Removed symbols which accidently slipped in. ++ * ++ * Revision 1.9 1997/11/03 19:07:52 scott ++ * No longer redefine max() and min() if already defined ++ * ++ * Revision 1.8 1997/07/30 01:35:20 liang ++ * Add more accurate atan2 function UtilLongLongAtan2. ++ * ++ * Revision 1.7 1997/07/21 20:23:19 mwg ++ * Added new function: UtilBlockCos() ++ * ++ * Revision 1.6 1997/03/21 23:50:10 liang ++ * Added initial version of V8bis module to CVS tree. ++ * ++ * Revision 1.5 1997/03/19 18:35:34 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.4 1997/01/21 00:36:15 mwg ++ * Added new function: UtilBlockCosSin() ++ * ++ * Revision 1.3 1996/06/18 21:14:45 mwg ++ * Modified VLDivVL by allowing to specify the result scaling. ++ * ++ * Revision 1.2 1996/06/12 02:31:59 mwg ++ * Added 64bit arithmetic functions. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:15 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.4 1995/12/04 23:08:15 liang ++ * Add file Math/LinearToLog.c. ++ * ++ ************************************************************************/ ++#ifndef MathUtilPh ++#define MathUtilPh ++ ++/* Exported tables */ ++extern const short UtilCosTable[]; ++ ++/* Exported functions */ ++extern ComplexShort UtilCosSin(ushort angle); ++extern long UtilBlockCosSin (int nValues, long angle, long delta, ComplexShort *dstPtr); ++extern long UtilBlockCos (int nValues, long angle, long delta, short *dstPtr); ++extern ushort UtilShortShortAtan2(ComplexShort point); ++extern ushort UtilLongShortAtan2(ComplexLong point); ++extern ulong UtilShortLongAtan2(ComplexShort point) FAST_TEXT; ++extern ulong UtilLongLongAtan2(ComplexLong point) FAST_TEXT; ++extern ushort UtilSqrt(ulong y); ++extern ushort UtilMaxMagnitude(int blkSize, ComplexShort *dataPtr); ++extern short UtilQ0LinearToQ4dB (ulong x); ++extern ulong UtilQ4dBToQ12Linear (short x); ++extern void UtilAdjustComplexMagnitude(ComplexShort *srcPtr, short mag, short adjustment); ++ ++extern void VLMultLongByLong(long x, long y, VeryLong *dst); ++extern void VLMultShort (VeryLong x, short y, VeryLong *dst); ++extern void VLAddVL (VeryLong x, VeryLong y, VeryLong *dst); ++extern void VLAddLong (VeryLong x, long y, VeryLong *dst); ++extern void VLSubVL (VeryLong x, VeryLong y, VeryLong *dst); ++extern void VLSubLong (VeryLong x, long y, VeryLong *dst); ++extern void VLDivVL (VeryLong x, VeryLong y, int scale, long *dst); ++extern void VLShiftLeft(VeryLong x, int shift, VeryLong *dst); ++extern void VLShiftRight(VeryLong x, int shift, VeryLong *dst); ++ ++ ++#define UtilAtan2 UtilShortShortAtan2 ++#define UtilLongAtan2 UtilLongShortAtan2 ++ ++/* Standard Macros */ ++#undef abs ++#define abs(x) ((x) >= 0 ? (x) : -(x)) ++ ++#undef max ++#define max(x, y) ((x) >= (y) ? (x) : (y)) ++ ++#undef min ++#define min(x, y) ((x) <= (y) ? (x) : (y)) ++ ++#endif /* MathUtilPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MipsAsm.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MipsAsm.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MipsAsm.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MipsAsm.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,264 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/************************************************************************ ++ * ++ * MipsAsm.h: ++ * ++ * Description: ++ * This file contains definitions specific to MIPS assembly ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: MipsAsm.h,v 1.5 2004/04/13 00:16:59 ilyas Exp $ ++ * ++ * $Log: MipsAsm.h,v $ ++ * Revision 1.5 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.4 2002/09/12 04:08:50 ilyas ++ * Added macros for BCM MIPS specific instructions ++ * ++ * Revision 1.3 2000/11/18 21:28:19 mprahlad ++ * ifdef bcm47xx - ++ * define MSUB(src1,src2) msub src1, src2 ++ * change Mult(dst, src1, src2) to use "mul" instead of "mult; mflo" ++ * define Mul(src1, src2) mult src1, src2 ++ * ++ * Revision 1.2 2000/07/28 21:05:05 mprahlad ++ * Macros specific to bcm47xx added. ++ * ++ * Revision 1.1 1999/08/05 19:52:57 liang ++ * Copied from the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.5 1999/04/02 23:16:21 mwg ++ * Fixed a minor comatibility issue with mult ++ * ++ * Revision 1.4 1999/02/03 20:25:43 mwg ++ * Added an option for R4010 ++ * ++ * Revision 1.3 1998/10/30 02:21:34 mwg ++ * Added targets for 4640 ++ * ++ * Revision 1.2 1998/10/16 18:52:09 ilyas ++ * Added ASM_PROLOG[5-7] macros to save on stores ++ * ++ * Revision 1.1 1998/06/03 23:28:39 mwg ++ * Renamed from DinoDefs.h ++ * ++ * Revision 1.6 1998/02/09 18:23:11 scott ++ * Added EMBEDDED_CALLING_CONVENTION (GreenHill) and R3900/R4102 ++ * ++ * Revision 1.5 1997/03/19 18:35:02 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.4 1996/10/02 20:28:41 liang ++ * Remove parameter "acc" from the non-DINO version of MAD. ++ * ++ * Revision 1.3 1996/10/02 19:44:36 liang ++ * Separated MultAdd into MAD and MADW, added NO_DINO_WRITEBACK option. ++ * ++ * Revision 1.2 1996/08/14 03:06:07 liang ++ * Modified macro MultAdd so that the assembly code build works. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1994/11/04 22:41:29 mwg ++ * Added #ifdefs for different targets. ++ * ++ ************************************************************************/ ++ ++#ifndef _MIPS_ASM_H_ ++#define _MIPS_ASM_H_ ++ ++#define zero $0 ++#define v0 $2 ++#define v1 $3 ++#define a0 $4 ++#define a1 $5 ++#define a2 $6 ++#define a3 $7 ++#define t0 $8 ++#define t1 $9 ++#define t2 $10 ++#define t3 $11 ++#define t4 $12 ++#define t5 $13 ++#define t6 $14 ++#define t7 $15 ++#define s0 $16 ++#define s1 $17 ++#define s2 $18 ++#define s3 $19 ++#define s4 $20 ++#define s5 $21 ++#define s6 $22 ++#define s7 $23 ++#define t8 $24 ++#define t9 $25 ++#define k0 $26 ++#define k1 $27 ++#define gp $28 ++#define sp $29 ++#define fp $30 ++#define s8 $30 ++#define ra $31 ++ ++#ifdef EMBEDDED_CALLING_CONVENTION ++ ++/* Support for GreenHills embedded calling convention */ ++ ++#define ASM_PROLOG subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); \ ++ sw $10, 24(sp); \ ++ sw $11, 28(sp); ++ ++#define ASM_PROLOG5 subu sp, 32; \ ++ sw $8, 16(sp); ++ ++#define ASM_PROLOG6 subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); ++ ++#define ASM_PROLOG7 subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); \ ++ sw $10, 24(sp); ++ ++#define ASM_EPILOG addu sp, 32 ++ ++#else ++#define ASM_PROLOG ++#define ASM_PROLOG5 ++#define ASM_PROLOG6 ++#define ASM_PROLOG7 ++#define ASM_EPILOG ++#endif ++ ++#ifdef DINO /* Special DSP extensions to MIPS core */ ++ ++#ifndef NO_DINO_WRITEBACK /* DSP extensions with writeback register */ ++ ++#define MAD(src1, src2) .set noreorder ; mad $0, src1, src2 ; .set reorder ++#define MADW(acc, src1, src2) .set noreorder ; mad acc, src1, src2 ; .set reorder ++#define Mult(dst, src1, src2) .set noreorder ; mult dst, src1, src2 ; .set reorder ++#define MultU(dst, src1, src2) .set noreorder ; multu dst, src1, src2 ; .set reorder ++ ++#else /* NO_DINO_WRITEBACK */ ++ ++#define MAD(src1, src2) .set noreorder ; mad $0, src1, src2 ; .set reorder ++#define MADW(acc, src1, src2) .set noreorder ; mad $0, src1, src2 ; mflo acc ; .set reorder ++#define Mult(dst, src1, src2) multu src1, src2 ; mflo dst ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#endif /* NO_DINO_WRITEBACK */ ++ ++#else /* DINO */ ++ ++#if defined(R3900) ++ ++#define MAD(src1, src2) madd $0, src1, src2 ++#define MADW(acc, src1, src2) madd acc, src1, src2 ++#define Mult(dst, src1, src2) mult dst, src1, src2 ++#define MultU(dst, src1, src2) multu dst, src1, src2 ++ ++#elif defined(bcm47xx_INSTR_MACROS) && defined(bcm47xx) ++ ++#define mips_froo(s1,s2,s3) s1##s2##s3 ++#define MSUB(s1,s2) .set noreorder ; mips_froo(msub_,s1,s2) ; .set reorder ++#define MAD(s1,s2) .set noreorder ; mips_froo(mad_,s1,s2) ; .set reorder ++#define MADW(acc, s1,s2) .set noreorder ; mips_froo(mad_,s1,s2) ; mflo acc ; .set reorder ++ ++#include "BCM4710.h" ++ ++#define Mult(dst, src1, src2) mul dst, src1, src2 ++#define Mul( src1, src2) mult src1, src2 ; ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#elif defined(bcm47xx) ++#define MSUB(src1, src2) msub src1, src2 ++#define MAD(src1, src2) madd src1, src2 ++#define MADW(acc, src1, src2) .set noreorder ; madd src1, src2; mflo acc ; .set reorder ++/* ++#define Mult(dst, src1, src2) mult src1, src2 ; mflo dst ++*/ ++#define Mult(dst, src1, src2) mul dst , src1, src2 ; ++#define Mul( src1, src2) mult src1, src2 ; ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#else ++ ++#ifdef R4102 ++#define MAD(src1, src2) madd16 src1, src2 ++#define MADW(acc, src1, src2) madd16 src1, src2 ; mflo acc ++#else /* R4102 */ ++ ++#ifdef R4640 ++ ++#define MAD(src1, src2) madd $0, src1, src2 ++#define MADW(acc, src1, src2) madd src1, src2; mflo acc ++ ++#else /* R4640 */ ++ ++#ifdef R4010 ++ ++#define MAD(src1, src2) madd src1, src2 ++#define MADW(acc, src1, src2) madd src1, src2; mflo acc ++ ++#else ++#define MAD(src1, src2) .set noat ;\ ++ mflo $at ;\ ++ sw $2, -4(sp) ;\ ++ multu src1, src2 ;\ ++ mflo $2 ;\ ++ addu $at, $2, $at ;\ ++ lw $2, -4(sp) ;\ ++ mtlo $at ;\ ++ .set at ++ ++#define MADW(acc, src1, src2) .set noat ;\ ++ mflo $at ;\ ++ sw $2, -4(sp) ;\ ++ multu src1, src2 ;\ ++ mflo $2 ;\ ++ addu $at, $2, $at ;\ ++ lw $2, -4(sp) ;\ ++ move acc, $at ;\ ++ mtlo $at ;\ ++ .set at ++#endif /* R4010 */ ++#endif /* R4102 */ ++#endif /* R4640 */ ++ ++#define Mult(dst, src1, src2) mul dst, src1, src2 ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#endif /* !3900 */ ++#endif /* DINO */ ++ ++ ++ ++ ++ ++ ++ ++ ++#endif /* _MIPS_ASM_H_ */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MiscUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MiscUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MiscUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/MiscUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,65 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * MiscUtil.h -- Miscellaneous utilities ++ * ++ * Description: ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg Haixiang Liang ++ * ++ * $Revision: 1.4 $ ++ * ++ * $Id: MiscUtil.h,v 1.4 2004/04/13 00:21:46 ilyas Exp $ ++ * ++ * $Log: MiscUtil.h,v $ ++ * Revision 1.4 2004/04/13 00:21:46 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.3 2001/07/21 01:21:06 ilyas ++ * Added more functions for int to string conversion used by log file ++ * ++ * Revision 1.2 1999/08/05 19:42:56 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.1 1999/01/27 22:10:12 liang ++ * Initial version. ++ * ++ * Revision 1.1 1997/07/10 01:18:45 mwg ++ * Initial revision. ++ * ++ * ++ * ++ *****************************************************************************/ ++#ifndef _MISC_UTIL_H_ ++#define _MISC_UTIL_H_ ++ ++extern long SM_DECL GetRateValue(dataRateMap rate); ++extern int SM_DECL DecToString(ulong value, uchar *dstPtr, uint nDigits); ++extern int SM_DECL HexToString(ulong value, uchar *dstPtr, uint nDigits); ++extern char * SM_DECL DecToStr(char *s, ulong num); ++extern char * SM_DECL SignedToStr(char *s, long num); ++extern char * SM_DECL HexToStr(char *s, ulong num); ++ ++#define EvenParityBit(x) ((z = (y = x ^ (x >> 4)) ^ (y >> 2)) ^ (z >> 1)) ++#define OddParityBit(x) (EvenParityBit(x) ^ 1) ++ ++extern void ParityApply(int nBytes, int nDataBits, int parity, uchar *srcPtr, uchar *dstPtr); ++extern void ParityStrip(int nBytes, int nDataBits, int parity, uchar *srcPtr, uchar *dstPtr, statusHandlerType statusHandler); ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Que.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Que.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Que.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/Que.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,106 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * Que.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of a simple queue ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef QueHeader_H_ ++#define QueHeader_H_ ++ ++typedef void * _QueItem; ++ ++typedef struct _QueHeader ++ { ++ _QueItem *head; /* first item in the queue */ ++ _QueItem *tail; /* last item in the queue */ ++ } QueHeader; ++ ++/* Queue management macros */ ++ ++#define QueInit(pqHdr) (((QueHeader *)(pqHdr))->head = ((QueHeader *)(pqHdr))->tail = NULL) ++#define QueEmpty(pqHdr) (NULL == ((QueHeader *)(pqHdr))->head) ++ ++#define QueFirst(pqHdr) ((QueHeader *)(pqHdr))->head ++#define QueLast(pqHdr) ((QueHeader *)(pqHdr))->tail ++#define QueNext(pqItem) (*((void **)(pqItem))) ++ ++ ++#define QueRemoveFirst(pqHdr) do { \ ++ if (!QueEmpty(pqHdr)) { \ ++ ((QueHeader *)(pqHdr))->head = *((QueHeader *)(pqHdr))->head; \ ++ if (QueEmpty(pqHdr)) \ ++ ((QueHeader *)(pqHdr))->tail = NULL; \ ++ } \ ++} while (0) ++#define QueRemove(pqHdr) QueRemoveFirst(pqHdr) ++ ++ ++#define QueAddLast(pqHdr,pqItem) do { \ ++ QueNext(pqItem) = NULL; \ ++ if (NULL != ((QueHeader *)(pqHdr))->tail) \ ++ *((QueHeader *)(pqHdr))->tail = (pqItem); \ ++ else \ ++ ((QueHeader *)(pqHdr))->head = (_QueItem *)(pqItem); \ ++ ((QueHeader *)(pqHdr))->tail = (_QueItem *)(pqItem); \ ++} while (0) ++#define QueAdd(pqHdr,pItem) QueAddLast(pqHdr,pItem) ++ ++#define QueAddFirst(pqHdr,pqItem) do { \ ++ if (NULL == ((QueHeader *)(pqHdr))->tail) \ ++ ((QueHeader *)(pqHdr))->tail = (_QueItem *)(pqItem); \ ++ QueNext(pqItem) = ((QueHeader *)(pqHdr))->head; \ ++ ((QueHeader *)(pqHdr))->head = (_QueItem *)(pqItem); \ ++} while (0) ++ ++ ++#define QueGet(pqHdr) \ ++ (void *) QueFirst(pqHdr); \ ++ QueRemove(pqHdr); ++ ++#define QueMerge(pqHdr1,pqHdr2) do { \ ++ if (NULL == ((QueHeader *)(pqHdr1))->tail) \ ++ ((QueHeader *)(pqHdr1))->head = ((QueHeader *)(pqHdr2))->head; \ ++ else \ ++ QueNext(((QueHeader *)(pqHdr1))->tail) = ((QueHeader *)(pqHdr2))->head; \ ++ if (NULL != ((QueHeader *)(pqHdr2))->tail) \ ++ ((QueHeader *)(pqHdr1))->tail = ((QueHeader *)(pqHdr2))->tail; \ ++} while (0) ++ ++#define QueCopy(pqHdr1,pqHdr2) do { \ ++ ((QueHeader *)(pqHdr1))->head = ((QueHeader *)(pqHdr2))->head; \ ++ ((QueHeader *)(pqHdr1))->tail = ((QueHeader *)(pqHdr2))->tail; \ ++} while (0) ++ ++#define QueForEach(pqHdr,f,ref) do { \ ++ _QueItem *p = ((QueHeader *)(pqHdr))->head; \ ++ \ ++ while (NULL != p) { \ ++ if ( (f)((void *)p, ref) ) break; \ ++ p = QueNext(p); \ ++ } \ ++} while (0) ++ ++#endif /* QueHeader_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftAtmVc.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftAtmVc.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftAtmVc.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftAtmVc.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,569 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftAtmVc.h ++ * ++ * Description: ++ * This file contains ATM VC definitions ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.27 $ ++ * ++ * $Id: SoftAtmVc.h,v 1.27 2004/06/02 22:26:17 ilyas Exp $ ++ * ++ * $Log: SoftAtmVc.h,v $ ++ * Revision 1.27 2004/06/02 22:26:17 ilyas ++ * Added ATM counters for G.992.3 ++ * ++ * Revision 1.26 2004/03/10 22:57:20 ilyas ++ * Added I.432 scramling control ++ * ++ * Revision 1.25 2003/09/23 00:21:59 ilyas ++ * Added status to indicate ATM header compression ++ * ++ * Revision 1.24 2003/08/27 02:00:50 ilyas ++ * Original implementation of ATM header compression ++ * ++ * Revision 1.23 2003/02/25 04:13:15 ilyas ++ * Added standard Broadcom header ++ * ++ * Revision 1.22 2003/01/10 23:25:48 ilyas ++ * Added ATM status definition ++ * ++ * Revision 1.21 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.20 2002/04/02 09:58:00 ilyas ++ * Initial implementatoin of BERT ++ * ++ * Revision 1.19 2001/10/09 22:35:14 ilyas ++ * Added more ATM statistics and OAM support ++ * ++ * Revision 1.18 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.17 2001/02/23 05:49:57 ilyas ++ * Added routed 1483 encapsulation ++ * ++ * Revision 1.16 2001/02/09 04:18:18 ilyas ++ * Added framer for bridged ethernet PDUs ++ * ++ * Revision 1.15 2001/02/09 01:55:27 ilyas ++ * Added status codes and macros to support printing of AAL packets ++ * ++ * Revision 1.14 2000/09/21 17:28:35 ilyas ++ * Added VBR support to traffic management code, separated UBR to a different ++ * Tx list, changed some of the algorithms ++ * ++ * Revision 1.13 2000/08/23 18:42:13 ilyas ++ * Added AAL2, added VcConfigure functions, moved commonly used look-up ++ * tables for CRC calculation to AtmLayer ++ * ++ * Revision 1.12 2000/08/02 03:06:22 ilyas ++ * Added support for reserving space in RX packets for ATm protocols ++ * ++ * Revision 1.11 2000/07/28 17:23:39 ilyas ++ * Added ATM connect/disconnect statuses ++ * ++ * Revision 1.10 2000/07/25 02:16:12 ilyas ++ * Added EClip (with Eth to ATM ARP translation) implementation ++ * ++ * Revision 1.9 2000/07/23 20:57:14 ilyas ++ * Added ATM framer and protocol layers ++ * ++ * Revision 1.8 2000/07/17 21:08:16 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.7 2000/06/09 18:33:04 liang ++ * Fixed Irix compiler warnings. ++ * ++ * Revision 1.6 2000/05/18 21:47:31 ilyas ++ * Added detection of preassigned cells such as OAM F4, F5 ++ * ++ * Revision 1.5 2000/05/14 01:50:11 ilyas ++ * Added more statuses to ATM code ++ * ++ * Revision 1.4 2000/05/10 02:41:28 liang ++ * Added status report for no cell memory ++ * ++ * Revision 1.3 2000/05/09 23:00:27 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.2 2000/05/03 03:53:00 ilyas ++ * Added support for pVc to vcID translation needed for LOG file and other ++ * definitions for ATM data in LOG file ++ * ++ * Revision 1.1 2000/04/19 00:21:35 ilyas ++ * Fixed some problems and added Out Of Band (OOB) support to ATM packets ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftAtmVcHeader ++#define SoftAtmVcHeader ++ ++/* ++** ++** ATM UNI types ++** ++*/ ++ ++#define AtmLinkFlags(bMap,name) (((bMap) >> name##Shift) & name##Mask) ++ ++/* ATM service category types */ ++ ++#define kAtmSrvcCBR 1 /* Constant Bit Rate */ ++#define kAtmSrvcVBR 2 /* Variable Bit Rate */ ++#define kAtmSrvcUBR 4 /* Unspecified Bit Rate */ ++#define kAtmSrvcABR 8 /* Available Bit Rate */ ++#define kAtmSrvcUnknown 0xFF ++ ++/* ATM AAL types (as encoded at UNI) */ ++ ++#define kAtmAalIE 0x58 ++ ++#define kAtmRaw 0 ++#define kAtmAal1 1 ++#define kAtmAal2 2 ++#define kAtmAal34 3 ++#define kAtmAal5 5 ++#define kAtmAalUser 16 ++#define kAtmAalUnknown 0xFF ++ ++/* ATM AAL1 parameters */ ++ ++#define kAal1SubTypeId 0x85 ++ ++#define kAal1TransportShift 0 ++#define kAal1TransportMask 0x7 ++ ++#define kAal1NullTransport 0 ++#define kAal1VoiceTransport 1 ++#define kAal1CircuitTransport 2 ++#define kAal1AudioTransport 4 ++#define kAal1VideoTransport 5 ++ ++ ++#define kAal1CBRId 0x86 ++ ++#define kAal1CBRShift 24 ++#define kAal1CBRMask 0xFF ++ ++#define kAal1CBR64 1 ++#define kAal1CBR1544 4 /* DS1 */ ++#define kAal1CBR6312 5 /* DS2 */ ++#define kAal1CBR32064 6 ++#define kAal1CBR44736 7 /* DS3 */ ++#define kAal1CBR97728 8 ++#define kAal1CBR2048 0x10 /* E1 */ ++#define kAal1CBR8448 0x11 /* E2 */ ++#define kAal1CBR34368 0x12 /* E3 */ ++#define kAal1CBR139264 0x13 ++#define kAal1CBR64xN 0x40 ++#define kAal1CBR8xN 0x41 ++ ++ ++#define kAal1MultiplierId 0x87 ++ ++#define kAal1ClockRecoveryId 0x88 ++ ++#define kAal1ClockRecoveryShift 3 ++#define kAal1ClockRecoveryMask 0x3 ++ ++#define kAal1ClockRecoveryNull 1 /* synchronous transport */ ++#define kAal1ClockRecoverySRTS 1 /* asynchronous transport */ ++#define kAal1ClockRecoveryAdaptive 2 ++ ++ ++#define kAal1ECMId 0x89 /* Error correction method */ ++ ++#define kAal1ECMShift (kAal1ClockRecoveryShift + 2) ++#define kAal1ECMMask 0x3 ++ ++#define kAal1ECMNull 0 ++#define kAal1ECMLossSensitive 1 ++#define kAal1ECMDelaySensitive 2 ++ ++ ++#define kAal1SDTBlockSizeId 0x8A ++ ++#define kAal1CellFillId 0x8B ++ ++/* ATM AAL34 and AAL5 parameters */ ++ ++#define kAalFwdMaxSDUSizeId 0x8C ++#define kAalBacMaxkSDUSizeId 0x81 ++ ++#define kAal34MidRangeId 0x82 ++ ++#define kAalSSCSTypeId 0x84 ++ ++#define kAalSSCSAssured 1 ++#define kAalSSCSNonAssured 2 ++#define kAalSSCSFrameRelay 4 ++ ++/* ATM AAL2 parameters */ ++ ++#define kAal2SSNone 0 ++#define kAal2SSSAR 1 ++#define kAal2SSTED 2 ++#define kAal2SSSARMask 3 ++#define kAal2SSType1 4 ++#define kAal2SSType3 5 ++ ++typedef struct { ++ uchar aalType; ++ union { ++ struct { ++ bitMap aal1Flags; ++ ulong cbrRate; ++ ushort blkSize; ++ uchar sarUsed; ++ } aal1Params; ++ struct { ++ ushort fwdMaxCpSize; /* Max "common part" packet size */ ++ ushort backMaxCpSize; ++ ushort cidLow; ++ ushort cidHigh; ++ ushort fwdMaxSsSize; /* Max "service specific" packet size */ ++ ushort backMaxSsSize; ++ uchar sscsType; ++ } aal2Params; ++ struct { ++ ushort fwdMaxSDUSize; ++ ushort backMaxSDUSize; ++ ushort midLow; ++ ushort midHigh; ++ uchar sscsType; ++ } aal34Params; ++ struct { ++ ushort fwdMaxSDUSize; ++ ushort backMaxSDUSize; ++ uchar sscsType; ++ } aal5Params; ++ } param; ++} atmAalParams; ++ ++/* ATM Traffic Descriptor types (as encoded at UNI) */ ++ ++#define kAtmTrafficIE 0x59 ++ ++#define kTrafficFwdPeakCellRateId0 0x82 ++#define kTrafficBackPeakCellRateId0 0x83 ++#define kTrafficFwdPeakCellRateId 0x84 ++#define kTrafficBackPeakCellRateId 0x85 ++ ++#define kTrafficFwdSustainCellRateId0 0x88 ++#define kTrafficBackSustainCellRateId0 0x89 ++#define kTrafficFwdSustainCellRateId 0x90 ++#define kTrafficBackSustainCellRateId 0x91 ++ ++#define kTrafficFwdMaxBurstSizeId0 0xA0 ++#define kTrafficBackMaxBurstSizeId0 0xA1 ++#define kTrafficFwdMaxBurstSizeId 0xB0 ++#define kTrafficBackMaxBurstSizeId 0xB1 ++ ++#define kTrafficBestEffortId 0xBE ++#define kTrafficMgrOptionsId 0xBF ++ ++#define kTrafficMaxTolerance 0x7FFFFFFF ++ ++/* trafficFlags coding */ ++ ++#define kTrafficTagFwd 1 ++#define kTrafficTagBack 2 ++#define kTrafficBestEffort 4 ++ ++typedef struct { ++ ulong tPCR0; /* CLP = 0, time between cells in us */ ++ ulong tPCR; /* CLP = 0+1 */ ++ ulong tolPCR; /* tolerance for PCR in us */ ++ ++ ulong tSCR0; /* CLP = 0 */ ++ ulong tSCR; /* CLP = 0+1 */ ++ ulong tolSCR; /* tolerance for SCR in us */ ++ ++ uchar atmServiceType; /* CBR, VBR, UBR, etc. */ ++ uchar trafficFlags; ++} atmTrafficParams; ++ ++/* ATM Broadband Bearer Capabilty (BBC) types (as encoded at UNI) */ ++ ++#define kAtmBBCIE 0x5E ++ ++#define kBBCClassShift 0 ++#define kBBCClassMask 0x1F ++ ++#define kBBCClassA 0x1 ++#define kBBCClassC 0x3 ++#define kBBCClassX 0x10 ++ ++ ++#define kBBCTrafficShift (kBBCClassShift + 5) ++#define kBBCTrafficMask 0x7 ++ ++#define kBBCTrafficNull 0 ++#define kBBCTrafficCBR 1 ++#define kBBCTrafficVBR 2 ++ ++ ++#define kBBCTimingShift (kBBCTrafficShift + 3) ++#define kBBCTimingMask 0x3 ++ ++#define kBBCTimingNull 0 ++#define kBBCTimingRequired 1 ++#define kBBCTimingNotRequired 2 ++ ++ ++#define kBBCClippingShift (kBBCTimingShift + 2) ++#define kBBCClippingMask 0x3 ++ ++#define kBBCNoClipping 0 ++#define kBBCClippingOk 1 ++ ++#define kBBCConnectionShift (kBBCClippingShift + 2) ++#define kBBCConnectionMask 0x3 ++ ++#define kBBCPoint2Point 0 ++#define kBBCPoint2MPoint 1 ++ ++/* ATM Broadband High/Low Layer Information (BHLI/BLLI) types (as encoded at UNI) */ ++ ++#define kAtmBHLIIE 0x5D ++#define kAtmBLLIIE 0x5F ++ ++/* ATM QoS types (as encoded at UNI) */ ++ ++#define kAtmQoSIE 0x5C ++ ++#define kQoSNull 0 ++#define kQoSClass1 1 ++#define kQoSClass2 2 ++#define kQoSClass3 3 ++#define kQoSClass4 4 ++#define kQoSReserved 0xFF ++ ++typedef struct { ++ uchar fwdQoSClass; ++ uchar backQoSClass; ++} atmQoSParams; ++ ++/* ATM MID definitions (ConfigureHandler) */ ++ ++#define kAtmMidEntireVc ((ulong) -1) ++ ++typedef struct { ++ void *pUserVc; /* VC id from the caller: has to be 1st !!! */ ++ ulong vci; ++ uchar defaultCLP; /* default CLP for tx packets on this VC */ ++ uchar framerId; ++ uchar protoId; ++ uchar protoRxBytesReserved; /* # bytes reserved by protocol in the beginning of Rx packet */ ++ uchar protoTxBytesReserved; /* # bytes reserved by protocol in the beginning of Tx packet */ ++ ++ atmAalParams aalParams; ++ atmTrafficParams rxTrafficParams; ++ atmTrafficParams txTrafficParams; ++ bitMap bbcFlags; ++ atmQoSParams qosParams; ++} atmVcParams; ++ ++/* ++** ++** ATM Out of Band (OOB) packet information ++** ++*/ ++ ++typedef struct { ++ Boolean clp; /* Cell Loss Prioroty */ ++ uchar aalType; ++ union { ++ struct { ++ uchar payloadType; ++ } aalRawParams; ++ struct { ++ uchar payloadType; ++ ushort mid; ++ } aal34Params; ++ struct { ++ uchar uui; /* Uses to user indicator */ ++ uchar cpi; /* common part indicator */ ++ } aal5Params; ++ } aalParam; ++} atmOobPacketInfo; ++ ++/* ++** ++** ATM setup bit definition ++** ++*/ ++ ++#define kAtmCorrectHecErrors 1 ++#define kCorrectHecErrors kAtmCorrectHecErrors ++#define kAtmPhyHeaderCompression 2 ++#define kAtmPhyNoDataScrambling 4 ++ ++#define kAtmTxIdleTimeoutMask 0x6 ++#define kAtmTxIdleNoTimeout 0 ++#define kAtmTxIdleTimeout10s 2 ++#define kAtmTxIdleTimeout30s 4 ++#define kAtmTxIdleTimeout60s 6 ++ ++/* ++** ++** ATM framer modes and protocol definitions ++** ++*/ ++ ++#define kAtmFramerNone 0 ++#define kAtmFramerISO 1 ++#define kAtmFramerIP 2 ++#define kAtmFramerEth 3 ++#define kAtmFramerEthWithCRC 4 ++ ++#define kAtmProtoNone 0 ++#define kAtmProtoEClip 1 ++#define kAtmProtoERouted1483 2 ++#define kAtmProtoPPP 3 ++ ++ ++/* ++** ++** ATM status codes ++** ++*/ ++ ++typedef void (*atmStatusHandler) (void *gDslVars, ulong statusCode, ...); ++ ++/* physical layer I.432 */ ++ ++#define kAtmStatRxHunt 1 ++#define kAtmStatRxPreSync 2 ++#define kAtmStatRxSync 3 ++#define kAtmStatRxPlOamCell 4 ++#define kAtmStatBertResult 5 ++#define kAtmStatHec 6 ++#define kAtmStatHdrCompr 7 ++#define kAtmStatCounters 8 ++ ++/* ATM layer */ ++ ++#define kAtmLayerStatFirst 100 ++#define kAtmStatRxDiscarded 100 ++#define kAtmStatTxDelayed 101 ++ ++#define kAtmStatVcCreated 102 ++#define kAtmStatVcStarted 103 ++#define kAtmStatVcStopped 104 ++#define kAtmStatVcDeleted 105 ++ ++#define kAtmStatTimeout 106 ++#define kAtmStatNoCellMemory 107 ++#define kAtmStatPrintCell 108 ++#define kAtmStatInvalidCell 109 ++#define kAtmStatUnassignedCell 110 ++#define kAtmStatOamF4SegmentCell 111 ++#define kAtmStatOamF4End2EndCell 112 ++#define kAtmStatOamI371Cell 113 ++#define kAtmStatOamF5SegmentCell 114 ++#define kAtmStatOamF5End2EndCell 115 ++#define kAtmStatReservedCell 116 ++ ++#define kAtmStatConnected 117 ++#define kAtmStatDisconnected 118 ++ ++#define kAtmStatRxPacket 119 ++#define kAtmStatTxPacket 120 ++ ++#define kAtmStatOamLoopback 121 ++ ++ ++typedef struct _atmPhyCounters { ++ ushort id; ++ ushort bertStatus; ++ ulong bertCellTotal; ++ ulong bertCellCnt; ++ ulong bertBitErrors; ++ ++ ulong rxHecCnt; ++ ulong rxCellTotal; ++ ulong rxCellData; ++ ulong rxCellDrop; ++} atmPhyCounters; ++ ++/* AAL layer */ ++ ++ ++ ++/* ++** ++** ATM log file definitions ++** ++*/ ++ ++/* ATM log file flags */ ++ ++#define kAtmLogFrameFlagMask 3 /* mask */ ++ ++#define kAtmLogFrameFlagNone 0 /* nothing */ ++#define kAtmLogFrameFlagNoData 1 /* no data only frame size */ ++#define kAtmLogFrameFlagBinData 2 /* data in binary form */ ++#define kAtmLogFrameFlagTextData 3 /* data in text form */ ++ ++#define kAtmLogSendFrameShift 0 ++#define kAtmLogSendFrameNoData (kAtmLogFrameFlagNoData << kAtmLogSendFrameShift) ++#define kAtmLogSendFrameBinData (kAtmLogFrameFlagBinData << kAtmLogSendFrameShift) ++#define kAtmLogSendFrameTextData (kAtmLogFrameFlagTextData << kAtmLogSendFrameShift) ++ ++#define kAtmLogRcvFrameShift 2 ++#define kAtmLogRcvFrameNone (kAtmLogFrameFlagNone << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameNoData (kAtmLogFrameFlagNoData << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameBinData (kAtmLogFrameFlagBinData << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameTextData (kAtmLogFrameFlagTextData << kAtmLogRcvFrameShift) ++ ++#define kAtmLogSendCompleteFrameShift 4 ++#define kAtmLogSendCompleteFrameNone (kAtmLogFrameFlagNone << kAtmLogSendCompleteFrameShift) ++#define kAtmLogSendCompleteFrameNoData (kAtmLogFrameFlagNoData << kAtmLogSendCompleteFrameShift) ++ ++#define kAtmLogReturnFrameShift 6 ++#define kAtmLogReturnFrameNoData (kAtmLogFrameFlagNoData << kAtmLogReturnFrameShift) ++ ++#define kAtmLogCellFlag (1 << 8) ++ ++/* ATM log codes */ ++ ++#define kAtmLogSendFrame 1 ++#define kAtmLogRcvFrame 2 ++#define kAtmLogSendFrameComplete 3 ++#define kAtmLogReturnFrame 4 ++#define kAtmLogVcAllocate 5 ++#define kAtmLogVcFree 6 ++#define kAtmLogVcActivate 7 ++#define kAtmLogVcDeactivate 8 ++#define kAtmLogTimer 9 ++#define kAtmLogCell 10 ++#define kAtmLogVcConfigure 11 ++ ++#define kAtmLogRxCellHeader 12 ++#define kAtmLogRxCellData 13 ++#define kAtmLogTxCell 14 ++ ++#endif /* SoftAtmVcHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,675 @@ ++/**************************************************************************** ++ * ++ * SoftDsl.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the DSL ++ * global variable structure. ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.72 $ ++ * ++ * $Id: SoftDsl.gh,v 1.72 2004/04/30 23:05:19 kdu Exp $ ++ * ++ * $Log: SoftDsl.gh,v $ ++ * Revision 1.72 2004/04/30 23:05:19 kdu ++ * Fixed interop issues in TDC lab for TMM. ++ * ++ * Revision 1.70 2004/04/10 23:30:48 ilyas ++ * Defined gloval structure for slow (SDRAM) data ++ * ++ * Revision 1.69 2004/04/02 18:33:45 gsyu ++ * Share MuxFramer buffers with scratch memory ++ * ++ * Revision 1.68 2004/02/04 20:12:38 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.67 2004/02/03 19:10:37 gsyu ++ * Added separated carrierInfo structures for G992P5 ++ * ++ * Revision 1.66 2004/01/26 04:21:06 yongbing ++ * Merge changes in ADSL2 branch into Annex A branch ++ * ++ * Revision 1.65 2004/01/13 19:12:07 gsyu ++ * Added two more variables for Double upstream ++ * ++ * Revision 1.64 2003/12/04 02:10:37 linyin ++ * Add a variable for FbmsOL mode ++ * ++ * Revision 1.63 2003/11/20 00:57:50 yongbing ++ * Merge ADSL2 functionalities into Annex A branch ++ * ++ * Revision 1.62 2003/11/05 01:59:12 liang ++ * Add vendor ID code for Infineon. ++ * ++ * Revision 1.61 2003/08/12 22:59:41 khp ++ * - for Haixiang: added support for ADSL_MARGIN_TWEAK_TEST ++ * ++ * Revision 1.60 2003/08/01 00:08:19 liang ++ * Added firmware ID for Samsung ADI 930 DSLAM. ++ * ++ * Revision 1.59 2003/07/14 14:40:08 khp ++ * - AnnexB: added bad SNR2 retrain counter to connectin setup ++ * ++ * Revision 1.58 2003/06/25 02:40:22 liang ++ * Added firmware ID for Annex A UE9000 ADI918 (from Aliant, Canada). ++ * ++ * Revision 1.57 2003/06/25 00:00:40 ilyas ++ * -added firmware IDs for TI 4000C and AC5 (Annex B) ++ * ++ * Revision 1.56 2003/05/31 01:50:38 khp ++ * -add firmware IDs for ECI16 and ECI16A ++ * ++ * Revision 1.55 2003/03/27 19:30:52 liang ++ * Add and initialize new connectionSetup field coVendorFirmwareID under module ADSL_IDENTIFY_VENDOR_FIRMWARE. ++ * ++ * Revision 1.54 2002/12/13 18:35:48 yongbing ++ * Add support for G.992.2 Annex C in start up ++ * ++ * Revision 1.53 2002/12/06 02:06:33 liang ++ * Moved the T1.413 RAck1/RAck2 switching variables to connection setup structure. ++ * ++ * Revision 1.52 2002/11/26 02:49:46 liang ++ * Added variable codingGainDecrement to the connectionSetup structure to solve the C-Rates-RA option failure problem. ++ * ++ * Revision 1.51 2002/10/20 18:56:16 khp ++ * - for linyin: ++ * - #ifdef NEC_NSIF_WORKAROUND: ++ * - add status and fail counter for NSIF ++ * ++ * Revision 1.50 2002/09/28 02:36:50 yongbing ++ * Add retrain in T1.413 with R-Ack1 tone ++ * ++ * Revision 1.49 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.48 2002/07/19 01:51:35 liang ++ * Added vendor ID constant for Alcatel. ++ * ++ * Revision 1.47 2002/06/27 21:51:08 liang ++ * Added xmt and rcv tone selection bitmap in connection setup. ++ * ++ * Revision 1.46 2002/06/11 20:48:06 liang ++ * Added CO vendor ID field to connectionSetup structure. ++ * ++ * Revision 1.45 2002/06/06 03:05:43 khp ++ * -use boolean in connectup setup instead of localCapabilities.features to indicate FBM mode ++ * ++ * Revision 1.44 2002/03/22 19:38:58 yongbing ++ * Modify for co-exist of G994P1 and T1P413 ++ * ++ * Revision 1.43 2002/03/02 00:52:40 ilyas ++ * AnnexC delay needs to be long for prototype ++ * ++ * Revision 1.42 2002/01/19 23:59:17 ilyas ++ * Added support for LOG and eye data to ADSL core target ++ * ++ * Revision 1.41 2002/01/16 19:03:59 ilyas ++ * Added HOST_ONLY ifdefs around ADSL core data ++ * ++ * Revision 1.40 2002/01/14 17:41:04 liang ++ * Move xmt & rcv sample buffers to top level. ++ * ++ * Revision 1.39 2001/12/21 22:45:34 ilyas ++ * Added support for ADSL MIB data object ++ * ++ * Revision 1.38 2001/12/13 02:24:22 ilyas ++ * Added G997 (Clear EOC and G997 framer) support ++ * ++ * Revision 1.37 2001/11/30 05:56:31 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.36 2001/10/19 00:12:07 ilyas ++ * Added support for frame oriented (no ATM) data link layer ++ * ++ * Revision 1.29.2.5 2001/10/03 01:44:00 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.29.2.4 2001/08/18 00:00:36 georgep ++ * Add variable to store annexC pathDelay ++ * ++ * Revision 1.29.2.3 2001/08/08 17:33:27 yongbing ++ * Merge with tag SoftDsl_2_17 ++ * ++ * Revision 1.35 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.34 2001/08/28 03:26:32 ilyas ++ * Added support for running host and adsl core parts separately ("dual" mode) ++ * ++ * Revision 1.33 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.32 2001/05/18 21:21:44 liang ++ * Save the current number of rcv samples to line handler for QProc test. ++ * ++ * Revision 1.31 2001/04/25 01:20:11 ilyas ++ * ++ * Don't use DSL frame functions if ATM_LAYER is not defined ++ * ++ * Revision 1.30 2001/03/25 06:11:20 liang ++ * Combined separate loop attenuation status for ATUR & ATUC into one status. ++ * Replace separate hardware AGC info status for ATUR & ATUC into hardware AGC ++ * request status and hardware AGC obtained status. ++ * Use store AGC command to save hardware AGC value instead of returning value ++ * from status report. ++ * ++ * Revision 1.29 2001/03/17 03:00:46 georgep ++ * Added agcInfo to connectionSetupStruct ++ * ++ * Revision 1.28 2001/02/10 03:03:09 ilyas ++ * Added one more DslFrame function ++ * ++ * Revision 1.27 2000/08/31 19:04:24 liang ++ * Added scratch buffer structure definition. ++ * ++ * Revision 1.26 2000/07/23 20:52:52 ilyas ++ * Added xxxFrameBufSetAddress() function for ATM framer layers ++ * Rearranged linkLayer functions in one structure which is passed as a ++ * parameter to xxxLinkLayerInit() function to be set there ++ * ++ * Revision 1.25 2000/07/18 21:42:25 ilyas ++ * Fixed compiler warning about pointer casting ++ * ++ * Revision 1.24 2000/07/18 21:18:45 ilyas ++ * Added GLOBAL_PTR_BIAS feature to utilize full 64K MIPS relative addressing space ++ * ++ * Revision 1.23 2000/07/18 20:03:24 ilyas ++ * Changed DslFrame functions definitions to macros, ++ * Removed gDslVars from their parameter list ++ * ++ * Revision 1.22 2000/07/17 21:08:15 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.21 2000/05/09 23:00:26 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.20 2000/05/03 03:57:04 ilyas ++ * Added LOG file support for writing ATM data ++ * ++ * Revision 1.19 2000/04/19 00:31:47 ilyas ++ * Added global SoftDsl functions for Vc, added OOB info functions ++ * ++ * Revision 1.18 2000/04/13 08:36:22 yura ++ * Added SoftDslSetRefData, SoftDslGetRefData functions ++ * ++ * Revision 1.17 2000/04/13 05:38:54 georgep ++ * Added T1p413 "Activation and Acknowledgement" which can substitute G994P1 ++ * ++ * Revision 1.16 2000/04/05 22:30:42 liang ++ * Changed function & constant names from G992p2 to G992 for the Main module. ++ * ++ * Revision 1.15 2000/04/04 04:16:06 liang ++ * Merged with SoftDsl_0_03 from old tree. ++ * ++ * Revision 1.15 2000/04/04 01:47:21 ilyas ++ * Implemented abstract dslFrame and dslFrameBuffer objects ++ * ++ * Revision 1.14 2000/04/01 02:53:33 georgep ++ * Added pointer to G992p2Profile inside connectionSetup ++ * ++ * Revision 1.13 2000/03/18 01:27:56 georgep ++ * Changed connectionSetup to include G992p1 Capabilities ++ * ++ * Revision 1.12 2000/02/29 01:39:05 georgep ++ * put variable haveRemoteCapabilities inside connectionSetupStruct ++ * ++ * Revision 1.11 2000/02/08 00:44:36 liang ++ * Fix the gDslVars definition for Irix environment. ++ * ++ * Revision 1.10 1999/11/19 00:59:29 george ++ * Define physicalLayerVars as a union ++ * ++ * Revision 1.9 1999/11/11 19:19:42 george ++ * Porting to 16Bit Compiler ++ * ++ * Revision 1.8 1999/11/09 20:26:17 george ++ * Added G992P2_PROFILE to modules list ++ * ++ * Revision 1.7 1999/10/27 23:01:54 wan ++ * Add G.994.1 setup in dslConnectionSetupStruct for setting up Initiation side ++ * ++ * Revision 1.6 1999/08/12 21:16:27 george ++ * Move profileVars definition to G992p2/G992p2Profile.gh ++ * ++ * Revision 1.5 1999/08/10 18:20:43 george ++ * Define fastRetrainVars ++ * ++ * Revision 1.4 1999/07/16 02:03:02 liang ++ * Added Tx & Rx data handler function pointers. ++ * ++ * Revision 1.3 1999/07/03 01:40:15 liang ++ * Redefined dsl command parameter list and added connection setup struct. ++ * ++ * Revision 1.2 1999/02/10 01:56:37 liang ++ * Added hooks for G994.1 and G992.2. ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftDslGlobals ++#define SoftDslGlobals ++ ++#include "SoftDsl.h" ++ ++#ifdef G992P2_PROFILE ++#include "G992p2Profile.gh" ++#endif ++ ++typedef enum ++ { ++ kVendorUnknown = 0, ++ kVendorBroadcom, ++ kVendorGlobespan, ++ kVendorADI, ++ kVendorTI, ++ kVendorCentillium, ++ kVendorAlcatel, ++ kVendorInfineon ++ } VendorIDType; ++ ++#define kDslVendorFirwareUnknown 0 ++typedef enum ++ { ++ kVendorADI_Anaconda = 1, ++ kVendorADI_ECI918, ++ kVendorADI_ECI930, ++ kVendorADI_Cisco, ++ kVendorADI_UE9000_918, ++ kVendorADI_Samsung_930, ++ kVendorTI_4000C_ERICSSON_350, ++ kVendorTI_4000C_SEIMENS, ++ kVendorADI_ECI16_AnnexB = 50, /* leave space for more Annex A types */ ++ kVendorADI_ECI16A_AnnexB, ++ kVendorTI_4000C_AnnexB, ++ kVendorTI_AC5_AnnexB ++ } VendorFirmwareIDType; ++ ++#define kDslXmtToneSelectionStartTone 0 ++#ifdef G992P1_ANNEX_B ++#define kDslXmtToneSelectionEndTone 63 ++#else ++#define kDslXmtToneSelectionEndTone 31 ++#endif ++#define kDslXmtToneSelectionNumOfTones (kDslXmtToneSelectionEndTone-kDslXmtToneSelectionStartTone+1) ++#define kDslXmtToneSelectionNumOfBytes ((kDslXmtToneSelectionNumOfTones+7)/8) ++#define kDslRcvToneSelectionStartTone 32 ++#define kDslRcvToneSelectionEndTone 255 ++#define kDslRcvToneSelectionNumOfTones (kDslRcvToneSelectionEndTone-kDslRcvToneSelectionStartTone+1) ++#define kDslRcvToneSelectionNumOfBytes ((kDslRcvToneSelectionNumOfTones+7)/8) ++ ++#define kDslT1p413RAckModeTryRAck1 0x01 ++#define kDslT1p413RAckModeTryRAck2 0x02 ++#define kDslT1p413RAckModeTrialMask 0x0F ++#define kDslT1p413RAckModeSelected 0x10 ++#define kDslT1p413RAckModeTrialCount 10 /* when in trial mode */ ++#define kDslT1p413RAckModeSwitchCount 20 /* when mode is selected */ ++ ++#ifdef ADSL_MARGIN_TWEAK_TEST ++#define kDslMarginTweakNumOfTones 256 ++#endif ++ ++typedef struct ++ { ++ Boolean haveRemoteCapabilities; ++ dslModulationType selectedModulation; ++ dslModulationType startupModulation; ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++ ushort downstreamMinCarr, downstreamMaxCarr; ++#else ++ uchar downstreamMinCarr, downstreamMaxCarr; ++#endif ++ uchar upstreamMinCarr, upstreamMaxCarr; ++#if defined(DOUBLE_UP_STREAM) ++ Boolean isDoubleUsEnabled; ++ short selectedPilotTone; ++#endif ++ dslDataPumpCapabilities localCapabilities, remoteCapabilities; ++#ifdef G992P3 ++ g992p3DataPumpCapabilities localCarrierInfoG992p3AnnexA; ++ g992p3DataPumpCapabilities remoteCarrierInfoG992p3AnnexA; ++ g992p3DataPumpCapabilities selectedCarrierInfoG992p3AnnexA; ++ uchar xmtG992p3State; ++#ifdef G992P5 ++ g992p3DataPumpCapabilities localCarrierInfoG992p5AnnexA; ++ g992p3DataPumpCapabilities remoteCarrierInfoG992p5AnnexA; ++ g992p3DataPumpCapabilities selectedCarrierInfoG992p5AnnexA; ++#endif /* G992P5 */ ++#endif /* G992P3 */ ++ uchar handshakingDuplexMode; ++ Boolean handshakingClientInitiation; ++ short handshakingXmtPowerLevel; ++ uchar handshakingXmtCarrierSet; ++ short hwAgcQ4dB; /* for loop attenuation calculation */ ++ uchar coVendorID; ++#ifdef ADSL_IDENTIFY_VENDOR_FIRMWARE ++ uchar coVendorFirmwareID; ++#endif ++ uchar codingGainDecrement; /* coding gain decrement in Q4dB for initial rate calculation */ ++ uchar xmtToneSelection[kDslXmtToneSelectionNumOfBytes]; ++ uchar rcvToneSelection[kDslRcvToneSelectionNumOfBytes]; ++#ifdef G992_ANNEXC ++ Boolean isFbmMode; ++ Boolean isFbmsOLMode; ++ long xmtToRcvPathDelay; ++#endif ++#if defined(T1P413) && defined(XMT_RACT2_FOR_ADI_COMPATIBILITY) ++ uchar t1p413RAckModeUsed; ++ uchar t1p413RAckModeCounter; ++#endif ++#ifdef G992P1_ANNEX_B ++ uchar badSNR2RetrainCounter; ++#endif ++#ifdef ADSL_MARGIN_TWEAK_TEST ++ short marginTweakExtraPowerQ4dB; ++ char marginTweakTableQ4dB[kDslMarginTweakNumOfTones]; ++#endif ++#ifdef G992P2_PROFILE ++ G992p2ProfileVarsStruct* profileVarsPtr; ++#endif ++#ifdef TDC_IOP_FIX_SEIMENS_TI ++ char t1p413RetrainCounter; /* 0: no retrain needed; 1: force to T1.413 mode and retrain after R-MSG1; 2: 2nd T1.413 session, go to showtime */ ++#endif ++#ifdef ANSI_CACT12_PING_PONG ++ char t1p413SkipToneIndex; /* to alternate between CAct1 and CAct2 detection */ ++#endif ++ } dslConnectionSetupStruct; ++ ++#ifdef ADSL_FRAMER ++#include "MuxFramer.gh" ++#endif ++ ++#ifdef ATM ++#include "SoftAtm.gh" ++#endif ++ ++#ifdef DSL_PACKET ++#include "DslPacket.gh" ++#endif ++ ++#ifdef G997_1_FRAMER ++#include "G997.gh" ++#ifdef G992P3 ++#include "G992p3OvhMsg.gh" ++#endif ++#endif ++ ++#ifdef ADSL_MIB ++#include "AdslMib.gh" ++#endif ++ ++#ifndef HOST_ONLY ++#ifdef T1P413 ++#include "T1p413Main.gh" ++#endif ++ ++#ifdef G994P1 ++#include "G994p1Main.gh" ++#endif ++ ++#ifdef G992 ++#include "G992Main.gh" ++#endif ++ ++#include "SoftDslSampleBuffers.gh" ++#endif ++ ++typedef struct __dslSlowVarsStruct ++ { ++ int tmp; ++ } ++ dslSlowVarsStruct; ++ ++typedef struct __dslVarsStruct ++ { ++ bitMap setup; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++ dslDriverCallbackType driverCallback; ++ ++ rcvHandlerType rcvHandlerPtr; ++ xmtHandlerType xmtHandlerPtr; ++ ++#ifndef ADSLCORE_ONLY ++ dslCommandHandlerType adslCoreCommandHandlerPtr; ++#endif ++ dslCommandHandlerType dataPumpCommandHandlerPtr; ++ ++ dslStatusHandlerType internalStatusHandlerPtr; ++ dslStatusHandlerType externalStatusHandlerPtr; ++#ifndef ADSLCORE_ONLY ++ dslStatusHandlerType externalLinkLayerStatusHandlerPtr; ++#endif ++ ++ dslDirectionType direction; ++ dslConnectionSetupStruct connectionSetup; ++ ++#ifdef NEC_NSIF_WORKAROUND ++ uchar G994NsStatus; ++ uchar G994NsFailCounter; ++#endif ++ ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ ++ linkLayerFunctions LinkLayerFunctions; ++ dslSlowVarsStruct *dslSlowVars; ++ ++#ifdef DSL_FRAME_FUNCTIONS ++ dslFrameFunctions DslFrameFunctions; ++#endif ++ ulong refData; ++ ulong execTime; ++ int currRcvNSamps; ++ ++#ifndef HOST_ONLY ++ DslSampleBuffersStruct sampleBuffersVars; ++ ++#ifdef G992P2_PROFILE ++ G992p2ProfileVarsStruct G992p2ProfileVars; ++#endif ++ ++#ifdef ADSL_FRAMER ++ muxFramerVarsStruct muxFramerVars; ++#endif ++#endif /* HOST_ONLY */ ++ ++#ifdef DSL_LINKLAYER ++ union ++ { ++#ifdef ATM ++ atmVarsStruct atmVars; ++#endif ++#ifdef DSL_PACKET ++ dslPacketVarsStruct dslPacketVars; ++#endif ++ } linkLayerVars; ++#endif ++ ++#ifdef G997_1_FRAMER ++ g997VarsStruct G997Vars; ++#ifdef G992P3 ++ g992p3OvhMsgVarsStruct G992p3OvhMsgVars; ++#endif ++#endif ++ ++#ifdef ADSL_MIB ++ adslMibVarsStruct adslMibVars; ++#endif ++ ++#ifndef HOST_ONLY ++ union ++ { ++#ifdef T1P413 ++ T1p413VarsStruct T1p413Vars; ++#endif ++#ifdef G994P1 ++ G994p1VarsStruct G994p1Vars; ++#endif ++#ifdef G992 ++ G992VarsStruct G992Vars; ++#endif ++ } physicalLayerVars; ++ union ++ { ++#ifdef G992 ++ G992ScratchVarsStruct G992ScratchVars; ++#endif ++#if defined(ADSL_FRAMER) && defined(SHARE_MUX_FRAMER_VARS) ++ muxFramerSharedVarsStruct muxFramerSharedVars; ++#endif ++ } scratchVars; ++#endif /* HOST_ONLY */ ++ ++ } ++ dslVarsStruct; ++ ++#ifndef GLOBAL_PTR_BIAS ++#define gDslGlobalVarPtr ((struct __dslVarsStruct *)gDslVars) ++#define gDslGlobalSlowVarPtr (gDslGlobalVarPtr->dslSlowVars) ++#else ++#define gDslGlobalVarPtr ((struct __dslVarsStruct *) (void*)((uchar*)(gDslVars) - GLOBAL_PTR_BIAS)) ++#define gDslGlobalSlowVarPtr ((struct __dslSlowVarsStruct *) (void*)((uchar*)(gDslGlobalVarPtr->dslSlowVars) - GLOBAL_PTR_BIAS)) ++#endif ++ ++#define gDslSampleBuffersVars (gDslGlobalVarPtr->sampleBuffersVars) ++ ++#define gDslMuxFramerVars (gDslGlobalVarPtr->muxFramerVars) ++#define gDslMuxFramerSharedVars (gDslGlobalVarPtr->scratchVars.muxFramerSharedVars) ++#define gDslLinkLayerVars (gDslGlobalVarPtr->linkLayerVars) ++#define gDslAtmVars (gDslGlobalVarPtr->linkLayerVars.atmVars) ++#define gDslPacketVars (gDslGlobalVarPtr->linkLayerVars.dslPacketVars) ++#define gG997Vars (gDslGlobalVarPtr->G997Vars) ++ ++#ifdef G992P3 ++#define gG992p3OvhMsgVars (gDslGlobalVarPtr->G992p3OvhMsgVars) ++#endif ++ ++#define gAdslMibVars (gDslGlobalVarPtr->adslMibVars) ++ ++#define gT1p413Vars (gDslGlobalVarPtr->physicalLayerVars.T1p413Vars) ++#define gG994p1Vars (gDslGlobalVarPtr->physicalLayerVars.G994p1Vars) ++#define gG992Vars (gDslGlobalVarPtr->physicalLayerVars.G992Vars) ++#define gG992p2ProfileVars (gDslGlobalVarPtr->G992p2ProfileVars) ++ ++#define gG992ScratchVars (gDslGlobalVarPtr->scratchVars.G992ScratchVars) ++ ++#ifndef gEyeHandlerPtr ++#define gEyeHandlerPtr (gDslGlobalVarPtr->eyeHandlerPtr) ++#endif ++ ++#ifndef gLogHandlerPtr ++#define gLogHandlerPtr (gDslGlobalVarPtr->logHandlerPtr) ++#endif ++ ++#ifdef VP_SIMULATOR ++#define gDriverCallback(x) (gDslGlobalVarPtr->driverCallback)(x) ++#else ++#define gDriverCallback(x) ++#endif ++ ++/* ++** ++** Frame functions callouts ++** ++*/ ++ ++#define gDslFrameFunc (gDslGlobalVarPtr->DslFrameFunctions) ++ ++#define DslFrameBufferGetLength(gDslVars, fb) \ ++ gDslFrameFunc.__DslFrameBufferGetLength(fb) ++ ++#define DslFrameBufferGetAddress(gDslVars, fb) \ ++ gDslFrameFunc.__DslFrameBufferGetAddress(fb) ++ ++#define DslFrameBufferSetLength(gDslVars, fb, l) \ ++ gDslFrameFunc.__DslFrameBufferSetLength(fb, l) ++ ++#define DslFrameBufferSetAddress(gDslVars, fb, p) \ ++ gDslFrameFunc.__DslFrameBufferSetAddress(fb, p) ++ ++#define DslFrameInit(gDslVars, f) \ ++ gDslFrameFunc.__DslFrameInit(f) ++ ++#define DslFrameGetLength(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetLength(pFrame) ++ ++#define DslFrameGetBufCnt(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetBufCnt(pFrame) ++ ++#define DslFrameGetFirstBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetFirstBuffer(pFrame) ++ ++#define DslFrameGetNextBuffer(gDslVars, pFrBuffer) \ ++ gDslFrameFunc.__DslFrameGetNextBuffer(pFrBuffer) ++ ++#define DslFrameSetNextBuffer(gDslVars, pFrBuf, pFrBufNext) \ ++ gDslFrameFunc.__DslFrameSetNextBuffer(pFrBuf, pFrBufNext) ++ ++#define DslFrameGetLastBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetLastBuffer(pFrame) ++ ++#define DslFrameGetLinkFieldAddress(gDslVars, f) \ ++ gDslFrameFunc.__DslFrameGetLinkFieldAddress(f) ++ ++#define DslFrameGetFrameAddressFromLink(gDslVars, lnk) \ ++ gDslFrameFunc.__DslFrameGetFrameAddressFromLink(lnk) ++ ++ ++#define DslFrameGetOobInfo(gDslVars, f, pOobInfo) \ ++ gDslFrameFunc.__DslFrameGetOobInfo(f, pOobInfo) ++ ++#define DslFrameSetOobInfo(gDslVars, f, pOobInfo) \ ++ gDslFrameFunc.__DslFrameSetOobInfo(f, pOobInfo) ++ ++ ++#define DslFrameEnqueBufferAtBack(gDslVars, f, b) \ ++ gDslFrameFunc.__DslFrameEnqueBufferAtBack(f, b) ++ ++#define DslFrameEnqueFrameAtBack(gDslVars, fMain, f) \ ++ gDslFrameFunc.__DslFrameEnqueFrameAtBack(fMain, f) ++ ++#define DslFrameEnqueBufferAtFront(gDslVars, f, b) \ ++ gDslFrameFunc.__DslFrameEnqueBufferAtFront(f, b) ++ ++#define DslFrameEnqueFrameAtFront(gDslVars, fMain, f) \ ++ gDslFrameFunc.__DslFrameEnqueFrameAtFront(fMain, f) ++ ++#define DslFrameDequeBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameDequeBuffer(pFrame) ++ ++#define DslFrameAllocMemForFrames(gDslVars, frameNum) \ ++ gDslFrameFunc.__DslFrameAllocMemForFrames(frameNum) ++ ++#define DslFrameFreeMemForFrames(gDslVars, hMem) \ ++ gDslFrameFunc.__DslFrameFreeMemForFrames(hMem) ++ ++#define DslFrameAllocFrame(gDslVars, handle) \ ++ gDslFrameFunc.__DslFrameAllocFrame(handle) ++ ++#define DslFrameFreeFrame(gDslVars, handle, pFrame) \ ++ gDslFrameFunc.__DslFrameFreeFrame(handle, pFrame) ++ ++#define DslFrameAllocMemForBuffers(gDslVars, ppMemPool, bufNum, memSize) \ ++ gDslFrameFunc.__DslFrameAllocMemForBuffers(ppMemPool, bufNum, memSize) ++ ++#define DslFrameFreeMemForBuffers(gDslVars, hMem, memSize, pMemPool) \ ++ gDslFrameFunc.__DslFrameFreeMemForBuffers(hMem, memSize, pMemPool) ++ ++#define DslFrameAllocBuffer(gDslVars, handle, pMem, length) \ ++ gDslFrameFunc.__DslFrameAllocBuffer(handle, pMem, length) ++ ++#define DslFrameFreeBuffer(gDslVars, handle, pBuf) \ ++ gDslFrameFunc.__DslFrameFreeBuffer(handle, pBuf) ++ ++#define DslFrame2Id(gDslVars, handle, pFrame) \ ++ gDslFrameFunc.__DslFrame2Id(handle, pFrame) ++ ++#define DslFrameId2Frame(gDslVars, handle, frameId) \ ++ gDslFrameFunc.__DslFrameId2Frame (handle, frameId) ++ ++ ++#endif /* SoftDslGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftDsl.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,2920 @@ ++/**************************************************************************** ++ * ++ * SoftDsl.h ++ * ++ * ++ * Description: ++ * This file contains the exported interface for SoftDsl.c ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.275 $ ++ * ++ * $Id: SoftDsl.h,v 1.275 2005/04/28 22:55:36 ilyas Exp $ ++ * ++ * $Log: SoftDsl.h,v $ ++ * Revision 1.275 2005/04/28 22:55:36 ilyas ++ * Cleaned up kDslG992RunAnnexaP3ModeInAnnexaP5, kG992EnableAnnexM and kDslAtuChangeTxFilterRequest definitions ++ * ++ * Revision 1.274 2005/04/27 20:57:32 yongbing ++ * Implement 32 frequency break points for TSSI, PR 30211 ++ * ++ * Revision 1.273 2005/04/02 03:27:52 kdu ++ * PR30236: Define kDslEnableRoundUpDSLoopAttn, this is shared with kDslCentilliumCRCWorkAroundEnabled. ++ * ++ * Revision 1.272 2005/04/01 21:56:39 ilyas ++ * Added more test commands definitions ++ * ++ * Revision 1.271 2005/02/11 05:03:57 ilyas ++ * Added support for DslOs ++ * ++ * Revision 1.270 2005/02/11 03:33:22 lke ++ * Support 2X, 4X, and 8X spectrum in ANNEX_I DS ++ * ++ * Revision 1.269 2005/01/08 00:11:58 ilyas ++ * Added definition for AnnexL status ++ * ++ * Revision 1.268 2004/12/18 00:52:35 mprahlad ++ * Add Dig US Pwr cutback status ++ * ++ * Revision 1.267 2004/11/08 22:21:38 ytan ++ * init swap state after retrain ++ * ++ * Revision 1.266 2004/11/05 21:16:50 ilyas ++ * Added support for pwmSyncClock ++ * ++ * Revision 1.265 2004/10/28 20:05:17 gsyu ++ * Fixed compilation errors for simulation targets ++ * ++ * Revision 1.264 2004/10/23 00:16:35 nino ++ * Added kDslHardwareSetRcvAGC status to set absolute rcv agc gain. ++ * ++ * Revision 1.263 2004/10/22 21:21:06 ilyas ++ * Fixed bit definition overlap in demodCapabilities ++ * ++ * Revision 1.262 2004/10/20 00:43:20 gsyu ++ * Added constants to support new xmt sample buffer control scheme ++ * ++ * Revision 1.261 2004/10/12 01:09:28 nino ++ * Remove kDslHardwareEnablePwmSyncClk and kDslHardwareSetPwmSyncClkFreq ++ * status definitions. Add kDslEnablePwmSyncClk and kDslSetPwmSyncClkFreq ++ * command definitions. ++ * ++ * Revision 1.260 2004/10/11 20:21:26 nino ++ * Added kDslHardwareEnablePwmSyncClk and kDslHardwareSetPwmSynClkFreq hardware statuses. ++ * ++ * Revision 1.259 2004/10/07 19:17:29 nino ++ * Added kDslHardwareGetRcvAGC status. ++ * ++ * Revision 1.258 2004/10/02 00:17:14 nino ++ * Added kDslHardwareAGCSetPga2 and kDslSetPilotEyeDisplay status definitions. ++ * ++ * Revision 1.257 2004/08/27 01:00:30 mprahlad ++ * ++ * Keep kDslAtuChangeTxFilterRequest defined by default so ADSL1 only targets can ++ * build ++ * ++ * Revision 1.256 2004/08/20 19:00:34 ilyas ++ * Added power management code for 2+ ++ * ++ * Revision 1.255 2004/08/17 23:18:25 kdu ++ * Merged interop changes for TDC lab from a023e9. ++ * ++ * Revision 1.254 2004/07/22 00:56:03 yongbing ++ * Add ADSL2 Annex B modulation definition ++ * ++ * Revision 1.253 2004/07/16 22:23:28 nino ++ * - Defined macros to extract subcarrier and supported set information ++ * for tssi. Subcarrier and suported set indicator is packed into ++ * dsSubcarrier index array. ++ * ++ * Revision 1.252 2004/07/01 00:11:22 nino ++ * Added preliminary code for debugDataHandler (inside of #if DEBUG_DATA_HANDLER). ++ * ++ * Revision 1.251 2004/06/24 03:08:39 ilyas ++ * Added GFC mapping control for ATM bonding ++ * ++ * Revision 1.250 2004/06/23 00:03:20 khp ++ * - shorten self test result register length to 1 (satisfied requirement ++ * at DT, no known requirement anywhere else) ++ * ++ * Revision 1.249 2004/06/15 20:18:33 ilyas ++ * Made D uchar again for compatibility with older ADSl drivers that use this structure. ADSL driver will rely on G992p3 parameters for large D ++ * ++ * Revision 1.248 2004/06/12 00:26:03 gsyu ++ * Added constants for AnnexM ++ * ++ * Revision 1.247 2004/06/10 18:53:24 yjchen ++ * add large D support ++ * ++ * Revision 1.246 2004/06/04 01:55:00 linyin ++ * Add a constant for SRA enable/disable ++ * ++ * Revision 1.245 2004/05/19 23:22:23 linyin ++ * Support L2 ++ * ++ * Revision 1.244 2004/05/15 03:04:58 ilyas ++ * Added L3 test definition ++ * ++ * Revision 1.243 2004/05/14 03:04:38 ilyas ++ * Fixed structure name typo ++ * ++ * Revision 1.242 2004/05/14 02:01:01 ilyas ++ * Fixed structure name typo ++ * ++ * Revision 1.241 2004/05/14 01:21:49 nino ++ * Added kDslSignalAttenuation, kDslAttainableNetDataRate kDslHLinScale constant definitions. ++ * ++ * Revision 1.240 2004/05/13 19:07:58 ilyas ++ * Added new statuses for ADSL2 ++ * ++ * Revision 1.239 2004/05/01 01:09:51 ilyas ++ * Added power management command and statuses ++ * ++ * Revision 1.238 2004/04/23 22:50:38 ilyas ++ * Implemented double buffering to ensure G.997 HDLC frame (OvhMsg) is continuous ++ * ++ * Revision 1.237 2004/03/31 18:57:39 ilyas ++ * Added drop on data error capability control ++ * ++ * Revision 1.236 2004/03/30 03:11:30 ilyas ++ * Added #ifdef for CFE build ++ * ++ * Revision 1.235 2004/03/29 23:06:39 ilyas ++ * Added status for BG table update ++ * ++ * Revision 1.234 2004/03/17 02:49:49 ilyas ++ * Turn off ATM bit reversal for Alcatel DSLAM only ++ * ++ * Revision 1.233 2004/03/11 03:09:48 mprahlad ++ * Add test mode for afeloopback test ++ * ++ * Revision 1.232 2004/03/10 23:15:53 ilyas ++ * Added ETSI modem support ++ * ++ * Revision 1.231 2004/03/04 19:28:14 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.230 2004/02/28 00:06:21 ilyas ++ * Added OLR message definitions for ADSL2+ ++ * ++ * Revision 1.229 2004/02/13 03:21:15 mprahlad ++ * define kDslAturHwAgcMaxGain correctly for 6348 ++ * ++ * Revision 1.228 2004/02/09 05:06:17 yongbing ++ * Add ADSL2 bit swap function ++ * ++ * Revision 1.227 2004/02/04 02:08:19 linyin ++ * remove the redefined kG992p5AnnexA ++ * ++ * Revision 1.226 2004/02/04 01:41:48 linyin ++ * Add some variables for G992P5 ++ * ++ * Revision 1.225 2004/02/03 19:12:22 gsyu ++ * Added a dedicate structure and constants for G992P5 ++ * ++ * Revision 1.224 2004/01/24 01:18:34 ytan ++ * add multi-section swapping flag ++ * ++ * Revision 1.223 2004/01/17 00:21:48 ilyas ++ * Added commands and statuses for OLR ++ * ++ * Revision 1.222 2004/01/13 19:12:37 gsyu ++ * Added more constants for Double upstream ++ * ++ * Revision 1.221 2003/12/23 21:19:04 mprahlad ++ * Define BCM6348_TEMP_MOVE_TO_LMEM to FAST_TEXT for 6348 targets - this is for ++ * ADSL2/AnnexA multimode builds - move a few functions to Lmem for now to avoid ++ * changes for swap on 6348. ++ * ++ * Revision 1.220 2003/12/19 21:21:53 ilyas ++ * Added dying gasp support for ADSL2 ++ * ++ * Revision 1.219 2003/12/05 02:09:51 mprahlad ++ * Leave the AnalogEC defs in - saves ifdef-ing all uses of these defines. ++ * Include Bcm6345_To_Bcm6348.h - to be able to pick up macros for the ++ * transition ++ * ++ * Revision 1.218 2003/12/04 02:10:58 linyin ++ * Redefine some constants for supporting different pilot and TTR ++ * ++ * Revision 1.217 2003/12/03 02:24:39 gsyu ++ * Reverse previous check in for Double Upstream demo ++ * ++ * Revision 1.215 2003/11/20 00:58:47 yongbing ++ * Merge ADSL2 functionalities into Annex A branch ++ * ++ * Revision 1.214 2003/11/06 00:35:06 nino ++ * Added kDslWriteAfeRegCmd and kDslReadAfeRegCmd commands. ++ * ++ * Revision 1.213 2003/11/05 21:04:23 ilyas ++ * Added more codes for LOG data ++ * ++ * Revision 1.212 2003/10/22 00:51:52 yjchen ++ * define constant for quiet line noise ++ * ++ * Revision 1.211 2003/10/20 22:08:57 nino ++ * Added kDslSetRcvGainCmd and kDslBypassRcvHpfCmd debug commands. ++ * ++ * Revision 1.210 2003/10/18 00:04:59 yjchen ++ * define constants for G992P3 diagnostic mode channel response ++ * ++ * Revision 1.209 2003/10/17 22:41:29 yongbing ++ * Add INP message support ++ * ++ * Revision 1.208 2003/10/16 00:06:09 uid1249 ++ * Moved G.994 definitions from G.994p1MainTypes.h ++ * ++ * Revision 1.207 2003/10/15 20:45:11 linyin ++ * Add some constants for support Revision 2 ++ * ++ * Revision 1.206 2003/10/14 22:04:02 ilyas ++ * Added Nino's AFE statuses for 6348 ++ * ++ * Revision 1.205 2003/10/10 18:49:26 gsyu ++ * Added test modes to workaround the clock domain crossing bug, PR18038 ++ * ++ * Revision 1.204 2003/09/30 19:27:46 mprahlad ++ * ifdef AnalogEC definies with #ifndef BCM6348_SRC ++ * ++ * Revision 1.203 2003/09/26 19:36:34 linyin ++ * Add annexi constant and vars ++ * ++ * Revision 1.202 2003/09/25 20:16:13 yjchen ++ * remove featureNTR definition ++ * ++ * Revision 1.201 2003/09/08 20:29:51 ilyas ++ * Added test commands for chip regression tests ++ * ++ * Revision 1.200 2003/08/26 00:58:14 ilyas ++ * Added I432 reset command (for header compression) ++ * Fixed SoftDsl time (for I432 header compression) ++ * ++ * Revision 1.199 2003/08/26 00:37:29 ilyas ++ * #ifdef'ed DslFrameFunctions in dslCommand structure to save space ++ * ++ * Revision 1.198 2003/08/22 22:45:00 liang ++ * Change the NF field in G992CodingParams from uchar to ushort to support K=256 (dataRate=255*32kbps) in fast path. ++ * ++ * Revision 1.197 2003/08/21 21:19:05 ilyas ++ * Changed dataPumpCapabilities structure for G992P3 ++ * ++ * Revision 1.196 2003/08/12 22:44:28 khp ++ * - for Haixiang: added kDslTestMarginTweak command and marginTweakSpec ++ * ++ * Revision 1.195 2003/07/24 17:28:16 ovandewi ++ * added Tx filter change request code ++ * ++ * Revision 1.194 2003/07/24 15:48:55 yongbing ++ * Reduce TSSI buffer size to avoid crash at the beginning of G.994.1. Need to find out why ++ * ++ * Revision 1.193 2003/07/19 07:11:47 nino ++ * Revert back to version 1.191. ++ * ++ * Revision 1.191 2003/07/17 21:25:25 yongbing ++ * Add support for READSL2 and TSSI ++ * ++ * Revision 1.190 2003/07/14 19:42:33 yjchen ++ * add constants for G992P3 ++ * ++ * Revision 1.189 2003/07/10 23:07:11 liang ++ * Add demodCapability bit to minimize showtime ATUC xmt power through b&g table. ++ * ++ * Revision 1.188 2003/07/08 22:18:50 liang ++ * Added demodCapability bit for G.994.1 Annex A multimode operation. ++ * ++ * Revision 1.187 2003/07/07 23:24:43 ilyas ++ * Added G.dmt.bis definitions ++ * ++ * Revision 1.186 2003/06/25 02:44:02 liang ++ * Added demod capability bit kDslUE9000ADI918FECFixEnabled. ++ * Added back kDslHWEnableAnalogECUpdate & kDslHWEnableAnalogEC for backward compatibility (annex A). ++ * ++ * Revision 1.185 2003/06/18 01:39:19 ilyas ++ * Added AFE test commands. Add #defines for driver's builds ++ * ++ * Revision 1.184 2003/06/06 23:58:09 ilyas ++ * Added command and status for standalone AFE tests ++ * ++ * Revision 1.183 2003/05/29 21:09:32 nino ++ * - kDslHWEnableAnalogECUpdate define replaced with kDslHWSetDigitalEcUpdateMode ++ * - kDslHWEnableAnalogEC define replaced with kDslHWDisableDigitalECUpdate ++ * ++ * Revision 1.182 2003/04/15 22:08:15 liang ++ * Changed one of the demodCapability bit name from last checkin. ++ * ++ * Revision 1.181 2003/04/13 19:25:54 liang ++ * Added three more demodCapability bits. ++ * ++ * Revision 1.180 2003/04/02 02:09:17 liang ++ * Added demodCapability bit for ADI low rate option fix disable. ++ * ++ * Revision 1.179 2003/03/18 18:22:06 yongbing ++ * Use 32 tap TEQ for Annex I ++ * ++ * Revision 1.178 2003/03/06 00:58:07 ilyas ++ * Added SetStausBuffer command ++ * ++ * Revision 1.177 2003/02/25 00:46:26 ilyas ++ * Added T1.413 EOC vendor ID ++ * ++ * Revision 1.176 2003/02/21 23:30:54 ilyas ++ * Added Xmtgain command framing mode status and T1413VendorId parameters ++ * ++ * Revision 1.175 2003/02/07 22:13:55 liang ++ * Add demodCapabilities bits for sub-sample alignment and higher T1.413 level (used internally only). ++ * ++ * Revision 1.174 2003/01/23 02:54:07 liang ++ * Added demod capability bit for bitswap enable. ++ * ++ * Revision 1.173 2002/12/13 18:36:33 yongbing ++ * Add support for G.992.2 Annex C ++ * ++ * Revision 1.172 2002/12/10 23:27:12 ilyas ++ * Extended dslException parameter structure to allow printout from DslDiags ++ * ++ * Revision 1.171 2002/12/06 02:10:19 liang ++ * Moved the T1.413 RAck1/RAck2 switching variables to connection setup structure. ++ * Added/Modified the training progress codes for T1.413 RAck1/RAck2 and upstream 2x IFFT disable. ++ * ++ * Revision 1.170 2002/11/11 00:20:05 liang ++ * Add demod capability constant for internally disabling upstream 2x IFFT in T1.413 mode. ++ * ++ * Revision 1.169 2002/11/06 03:46:19 liang ++ * Add training progress code for upstream 2x IFFT disable. ++ * ++ * Revision 1.168 2002/11/01 01:41:06 ilyas ++ * Added flags for Centillium 4103 workarround ++ * ++ * Revision 1.167 2002/10/26 01:26:11 gsyu ++ * Move SoftDslLineHandler from SDRAM to LMEM ++ * ++ * Revision 1.166 2002/10/20 18:56:20 khp ++ * - for linyin ++ * - #ifdef NEC_NSIF_WORKAROUND: ++ * - add macros to extract NSIF status and fail counter vars ++ * ++ * Revision 1.165 2002/10/14 05:24:35 liang ++ * Add training status code to request alternate xmt filter (for Samsung 6-port ADI918 DSLAMs) to meet KT 2km spec. ++ * ++ * Revision 1.164 2002/10/08 21:44:50 ilyas ++ * Fixed EOC stuffing byte to indicate "no synchronization" action ++ * ++ * Revision 1.163 2002/10/03 19:34:24 ilyas ++ * Added size for EOC serial number register ++ * ++ * Revision 1.162 2002/09/28 02:42:27 yongbing ++ * Add retrain in T1.413 with R-Ack1 tone ++ * ++ * Revision 1.161 2002/09/28 01:23:35 gsyu ++ * Reverse us2xifft change so that we can install new us2xifft on the tree ++ * ++ * Revision 1.160 2002/09/26 23:30:48 yongbing ++ * Add synch symbol detection in Showtime ++ * ++ * Revision 1.159 2002/09/20 23:47:52 khp ++ * - for gsyu: enable 2X IFFT for Annex A (XMT_FFT_SIZE_2X) ++ * ++ * Revision 1.158 2002/09/14 03:26:39 ilyas ++ * Changed far-end RDI reporting ++ * ++ * Revision 1.157 2002/09/13 21:10:54 ilyas ++ * Added reporting of remote modem LOS and RDI. ++ * Moved G992CodingParams definition to SoftDsl.h ++ * ++ * Revision 1.156 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.155 2002/09/09 21:31:30 linyin ++ * Add two constant to support long reach ++ * ++ * Revision 1.154 2002/09/07 01:31:51 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.153 2002/09/04 22:36:14 mprahlad ++ * defines for non standard info added ++ * ++ * Revision 1.152 2002/08/02 21:59:09 liang ++ * Enable G.992.2 carrierInfo in capabitilities when G.992.1 annex A is used for G.992.2. ++ * ++ * Revision 1.151 2002/07/29 20:01:03 ilyas ++ * Added command for Atm VC map table change ++ * ++ * Revision 1.150 2002/07/18 22:30:47 liang ++ * Add xmt power and power cutback related constants. ++ * ++ * Revision 1.149 2002/07/11 01:30:58 ilyas ++ * Changed status for ShowtimeMargin reporting ++ * ++ * Revision 1.148 2002/07/09 19:19:09 ilyas ++ * Added status parameters for ShowtimeSNRMargin info and command to filter ++ * out SNR margin data ++ * ++ * Revision 1.147 2002/06/27 21:50:24 liang ++ * Added test command related demodCapabilities bits. ++ * ++ * Revision 1.146 2002/06/26 21:29:00 liang ++ * Added dsl test cmd structure and showtime margin connection info status. ++ * ++ * Revision 1.145 2002/06/15 05:15:51 ilyas ++ * Added definitions for Ping, Dying Gasp and other test commands ++ * ++ * Revision 1.144 2002/05/30 19:55:15 ilyas ++ * Added status for ADSL PHY MIPS exception ++ * Changed conflicting definition for higher rates (S=1/2) ++ * ++ * Revision 1.143 2002/05/21 23:41:07 yongbing ++ * First check-in of Annex C S=1/2 codes ++ * ++ * Revision 1.142 2002/04/29 22:25:09 georgep ++ * Merge from branch annexC_demo - add status message constants ++ * ++ * Revision 1.141 2002/04/18 19:00:35 ilyas ++ * Added include file for builds in CommEngine environment ++ * ++ * Revision 1.140 2002/04/18 00:18:36 yongbing ++ * Add detailed timeout error messages ++ * ++ * Revision 1.139 2002/04/02 10:03:18 ilyas ++ * Merged BERT from AnnexA branch ++ * ++ * Revision 1.138 2002/03/26 01:42:29 ilyas ++ * Added timeout message constants for annex C ++ * ++ * Revision 1.137 2002/03/22 19:39:22 yongbing ++ * Modify for co-exist of G994P1 and T1P413 ++ * ++ * Revision 1.136 2002/03/22 01:19:40 ilyas ++ * Add status message constants for total FEXT Bits, NEXT bits ++ * ++ * Revision 1.135 2002/03/10 22:32:24 liang ++ * Added report constants for LOS recovery and timing tone index. ++ * ++ * Revision 1.134 2002/03/07 22:06:32 georgep ++ * Replace ifdef G992P1 with G992P1_ANNEX_A for annex A variables ++ * ++ * Revision 1.133 2002/02/16 01:08:18 georgep ++ * Add log constant for showtime mse ++ * ++ * Revision 1.132 2002/02/08 04:36:27 ilyas ++ * Added commands for LOG file and fixed Idle mode pointer update ++ * ++ * Revision 1.131 2002/01/24 20:21:30 georgep ++ * Add logging defines, remove fast retrain defines ++ * ++ * Revision 1.130 2002/01/19 23:59:17 ilyas ++ * Added support for LOG and eye data to ADSL core target ++ * ++ * Revision 1.129 2002/01/16 23:43:54 liang ++ * Remove the carriage return character from last checkin. ++ * ++ * Revision 1.128 2002/01/15 22:27:13 ilyas ++ * Added command for ADSL loopback ++ * ++ * Revision 1.127 2002/01/10 07:18:22 ilyas ++ * Added status for printf (mainly for ADSL core debugging) ++ * ++ * Revision 1.126 2001/12/21 22:45:34 ilyas ++ * Added support for ADSL MIB data object ++ * ++ * Revision 1.125 2001/12/13 02:24:22 ilyas ++ * Added G997 (Clear EOC and G997 framer) support ++ * ++ * Revision 1.124 2001/11/30 05:56:31 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.123 2001/11/15 19:01:07 yongbing ++ * Modify only T1.413 part to the top of tree based on AnnexBDevelopment branch ++ * ++ * Revision 1.122 2001/10/19 00:12:07 ilyas ++ * Added support for frame oriented (no ATM) data link layer ++ * ++ * Revision 1.121 2001/10/09 22:35:13 ilyas ++ * Added more ATM statistics and OAM support ++ * ++ * Revision 1.105.2.20 2001/11/27 02:32:03 liang ++ * Combine vendor ID, serial #, and version number into SoftModemVersionNumber.c. ++ * ++ * Revision 1.105.2.19 2001/11/21 01:29:14 georgep ++ * Add a status message define for annexC ++ * ++ * Revision 1.105.2.18 2001/11/08 23:26:28 yongbing ++ * Add carrier selection function for Annex A and B ++ * ++ * Revision 1.105.2.17 2001/11/07 22:55:30 liang ++ * Report G992 rcv msg CRC error as what it is instead of time out. ++ * ++ * Revision 1.105.2.16 2001/11/05 19:56:21 liang ++ * Add DC offset info code. ++ * ++ * Revision 1.105.2.15 2001/10/16 00:47:16 yongbing ++ * Add return-to-T1p413 starting point if in error ++ * ++ * Revision 1.105.2.14 2001/10/15 23:14:01 yjchen ++ * remove ADSL_SINGLE_SYMBOL_BLOCK ++ * ++ * Revision 1.105.2.13 2001/10/12 18:07:16 yongbing ++ * Add support for T1.413 ++ * ++ * Revision 1.105.2.12 2001/10/04 00:23:52 liang ++ * Add connection info constants for TEQ coef and PSD. ++ * ++ * Revision 1.105.2.11 2001/10/03 01:44:01 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.105.2.10 2001/09/28 22:10:04 liang ++ * Add G994 exchange message status reports. ++ * ++ * Revision 1.105.2.9 2001/09/26 18:08:21 georgep ++ * Send status error message in case features field is not setup properly ++ * ++ * Revision 1.105.2.8 2001/09/05 01:58:13 georgep ++ * Added status message for annexC measured delay ++ * ++ * Revision 1.105.2.7 2001/08/29 00:37:52 georgep ++ * Add log constants for annexC ++ * ++ * Revision 1.105.2.6 2001/08/18 00:01:34 georgep ++ * Add constants for annexC ++ * ++ * Revision 1.105.2.5 2001/08/08 17:33:28 yongbing ++ * Merge with tag SoftDsl_2_17 ++ * ++ * Revision 1.120 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.119 2001/08/28 03:26:32 ilyas ++ * Added support for running host and adsl core parts separately ("dual" mode) ++ * ++ * Revision 1.118 2001/08/16 02:16:10 khp ++ * - mark functions with FAST_TEXT to reduce cycle counts for QPROC targets ++ * (replaces use of LMEM_INSN) ++ * ++ * Revision 1.117 2001/06/18 20:06:35 ilyas ++ * Added forward declaration of dslCommandStruc to avoid gcc warnings ++ * ++ * Revision 1.116 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.115 2001/06/01 22:00:33 ilyas ++ * Changed ATM PHY interface to accomodate UTOPIA needs ++ * ++ * Revision 1.114 2001/05/16 06:22:24 liang ++ * Added status reports for xmt & rcv prefix enable position. ++ * ++ * Revision 1.113 2001/05/02 20:34:32 georgep ++ * Added log constants for snr1 calculation ++ * ++ * Revision 1.112 2001/04/25 01:20:11 ilyas ++ * ++ * Don't use DSL frame functions if ATM_LAYER is not defined ++ * ++ * Revision 1.111 2001/04/17 21:13:00 georgep ++ * Define status constant kDslHWSetDigitalEcUpdateShift ++ * ++ * Revision 1.110 2001/04/16 23:38:36 georgep ++ * Add HW AGC constants for ATUR ++ * ++ * Revision 1.109 2001/04/06 23:44:53 georgep ++ * Added status constant for setting up digitalEcGainShift ++ * ++ * Revision 1.108 2001/03/29 05:58:34 liang ++ * Replaced the Aware compatibility codes with automatic detection codes. ++ * ++ * Revision 1.107 2001/03/25 06:11:22 liang ++ * Combined separate loop attenuation status for ATUR & ATUC into one status. ++ * Replace separate hardware AGC info status for ATUR & ATUC into hardware AGC ++ * request status and hardware AGC obtained status. ++ * Use store AGC command to save hardware AGC value instead of returning value ++ * from status report. ++ * ++ * Revision 1.106 2001/03/24 00:43:22 liang ++ * Report more checksum results (NumOfCalls, txSignal, rxSignal & eyeData). ++ * ++ * Revision 1.105 2001/03/16 23:57:31 georgep ++ * Added more loop attenuation reporting status constants ++ * ++ * Revision 1.104 2001/03/15 00:22:07 liang ++ * Back to version 1.101. ++ * ++ * Revision 1.103 2001/03/15 00:03:44 yjchen ++ * use kDslATURHardwareAGCInfo for AltoE14 AGC as well ++ * ++ * Revision 1.102 2001/03/14 23:10:56 yjchen ++ * add defns for AltoE14 AGC ++ * ++ * Revision 1.101 2001/03/08 23:31:34 georgep ++ * Added R, S, D, coding parameters to dslDataPumpCapabilities ++ * ++ * Revision 1.100 2001/02/10 03:03:09 ilyas ++ * Added one more DslFrame function ++ * ++ * Revision 1.99 2001/02/09 01:55:27 ilyas ++ * Added status codes and macros to support printing of AAL packets ++ * ++ * Revision 1.98 2001/01/30 23:28:10 georgep ++ * Added kDslDspControlStatus for handling changes to dsp params ++ * ++ * Revision 1.97 2001/01/12 01:17:18 georgep ++ * Added bit in demodCapabilities for analog echo cancellor ++ * ++ * Revision 1.96 2001/01/04 05:51:03 ilyas ++ * Added more dslStatuses ++ * ++ * Revision 1.95 2000/12/21 05:46:07 ilyas ++ * Added name for struct _dslFrame ++ * ++ * Revision 1.94 2000/12/13 22:04:39 liang ++ * Add Reed-Solomon coding enable bit in demodCapabilities. ++ * ++ * Revision 1.93 2000/11/29 20:42:02 liang ++ * Add defines for SNR & max achivable rate status and DEC enable demodCapabilities bit. ++ * ++ * Revision 1.92 2000/09/22 21:55:13 ilyas ++ * Added support for DSL + Atm physical layer only (I.432) simulations ++ * ++ * Revision 1.91 2000/09/10 09:20:53 lkaplan ++ * Improve interface for sending Eoc messages ++ * ++ * Revision 1.90 2000/09/08 19:37:58 lkaplan ++ * Added code for handling EOC messages ++ * ++ * Revision 1.89 2000/09/07 23:02:27 georgep ++ * Add HarwareAGC Bit to demod Capabilities ++ * ++ * Revision 1.88 2000/09/01 00:57:34 georgep ++ * Added Hardware AGC status defines ++ * ++ * Revision 1.87 2000/08/31 19:04:26 liang ++ * Added external reference for stack size requirement test functions. ++ * ++ * Revision 1.86 2000/08/24 23:16:46 liang ++ * Increased sample block size for noBlock. ++ * ++ * Revision 1.85 2000/08/23 18:34:39 ilyas ++ * Added XxxVcConfigure function ++ * ++ * Revision 1.84 2000/08/05 00:25:04 georgep ++ * Redefine sampling freq constants ++ * ++ * Revision 1.83 2000/08/03 14:04:00 liang ++ * Add hardware time tracking clock error reset code. ++ * ++ * Revision 1.82 2000/07/23 20:52:52 ilyas ++ * Added xxxFrameBufSetAddress() function for ATM framer layers ++ * Rearranged linkLayer functions in one structure which is passed as a ++ * parameter to xxxLinkLayerInit() function to be set there ++ * ++ * Revision 1.81 2000/07/18 20:03:24 ilyas ++ * Changed DslFrame functions definitions to macros, ++ * Removed gDslVars from their parameter list ++ * ++ * Revision 1.80 2000/07/17 21:08:15 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.79 2000/06/21 20:38:44 georgep ++ * Added bit to demodCapabilities for HW_TIME_TRACKING ++ * ++ * Revision 1.78 2000/06/19 19:57:55 georgep ++ * Added constants for logging of HWResampler data ++ * ++ * Revision 1.77 2000/06/02 18:57:21 ilyas ++ * Added support for DSL buffers consisting of many ATM cells ++ * ++ * Revision 1.76 2000/05/27 02:19:28 liang ++ * G992MonitorParams structure is moved here, and Tx/Rx data handler type definitions changed. ++ * ++ * Revision 1.75 2000/05/15 18:17:21 liang ++ * Added statuses for sent and received frames ++ * ++ * Revision 1.74 2000/05/14 01:56:38 ilyas ++ * Added ATM cell printouts ++ * ++ * Revision 1.73 2000/05/09 23:00:26 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.72 2000/05/03 18:01:18 georgep ++ * Removed old function declarations for Eoc/Aoc ++ * ++ * Revision 1.71 2000/05/03 03:57:04 ilyas ++ * Added LOG file support for writing ATM data ++ * ++ * Revision 1.70 2000/05/02 00:04:36 liang ++ * Add showtime monitoring and message exchange info constants. ++ * ++ * Revision 1.69 2000/04/28 23:34:20 yongbing ++ * Add constants for reporting error events in performance monitoring ++ * ++ * Revision 1.68 2000/04/21 23:09:04 liang ++ * Added G992 time out training progress constant. ++ * ++ * Revision 1.67 2000/04/19 00:31:47 ilyas ++ * Added global SoftDsl functions for Vc, added OOB info functions ++ * ++ * Revision 1.66 2000/04/18 00:45:31 yongbing ++ * Add G.DMT new frame structure, define G992P1_NEWFRAME to enable, need ATM layer to work ++ * ++ * Revision 1.65 2000/04/15 01:48:34 georgep ++ * Added T1p413 status constants ++ * ++ * Revision 1.64 2000/04/13 08:36:22 yura ++ * Added SoftDslSetRefData, SoftDslGetRefData functions ++ * ++ * Revision 1.63 2000/04/13 05:42:35 georgep ++ * Added constant for T1p413 ++ * ++ * Revision 1.62 2000/04/05 21:49:54 liang ++ * minor change. ++ * ++ * Revision 1.61 2000/04/04 04:16:06 liang ++ * Merged with SoftDsl_0_03 from old tree. ++ * ++ * Revision 1.65 2000/04/04 01:47:21 ilyas ++ * Implemented abstract dslFrame and dslFrameBuffer objects ++ * ++ * Revision 1.64 2000/04/01 08:12:10 yura ++ * Added preliminary revision of the SoftDsl driver architecture ++ * ++ * Revision 1.63 2000/04/01 02:55:33 georgep ++ * New defines for G992p2Profile Structure ++ * ++ * Revision 1.62 2000/04/01 00:50:36 yongbing ++ * Add initial version of new frame structure for full-rate ++ * ++ * Revision 1.61 2000/03/24 03:30:45 georgep ++ * Define new constant kDslUpstreamSamplingFreq ++ * ++ * Revision 1.60 2000/03/23 19:51:30 georgep ++ * Define new features bits for G992p1 ++ * ++ * Revision 1.59 2000/03/18 01:28:41 georgep ++ * Changed connectionSetup to include G992p1 Capabilities ++ * ++ * Revision 1.58 2000/02/29 01:40:03 georgep ++ * Changed modulationtype defines to be the same as SPAR1 in G994p1 ++ * ++ * Revision 1.57 1999/11/19 01:03:19 george ++ * Use Block Size 256 for single symbol Mode ++ * ++ * Revision 1.56 1999/11/18 02:37:43 george ++ * Porting to 16Bit ++ * ++ * Revision 1.55 1999/11/12 02:12:55 george ++ * Added status constant for reporting of profile channel matching calculation ++ * ++ * Revision 1.54 1999/11/11 19:19:42 george ++ * Porting to 16Bit Compiler ++ * ++ * Revision 1.53 1999/11/05 01:27:06 liang ++ * Add recovery-from-inpulse-noise progress report. ++ * ++ * Revision 1.52 1999/11/02 02:06:27 george ++ * Added SNRMargin training status value ++ * ++ * Revision 1.51 1999/10/27 23:02:03 wan ++ * Add G.994.1 setup in dslConnectionSetupStruct for setting up Initiation side ++ * ++ * Revision 1.50 1999/10/25 21:55:36 liang ++ * Renamed the constant for FEQ output error. ++ * ++ * Revision 1.49 1999/10/23 02:20:55 george ++ * Add debug data codes ++ * ++ * Revision 1.48 1999/10/19 23:59:06 liang ++ * Change line handler interface to work with nonsymmetric sampling freq. ++ * ++ * Revision 1.47 1999/10/09 01:38:04 george ++ * Define maxProfileNumber ++ * ++ * Revision 1.46 1999/10/07 23:30:51 wan ++ * Add G.994.1 Tone and Fast Retrain Recov detections in G.992p2 SHOWTIME and Fast Retrain ++ * ++ * Revision 1.45 1999/10/06 13:59:27 liang ++ * Escape to G994.1 should be done through status instead of command. ++ * ++ * Revision 1.44 1999/10/06 02:01:28 george ++ * Add kDslReturnToG994p1Cmd ++ * ++ * Revision 1.43 1999/09/30 19:29:58 george ++ * Add reporting constant for Fast Retrain ++ * ++ * Revision 1.42 1999/09/16 23:41:56 liang ++ * Added command for host forced retrain. ++ * ++ * Revision 1.41 1999/08/20 00:47:25 wan ++ * Add constants for Fast Retrain progress status ++ * ++ * Revision 1.40 1999/08/16 18:06:01 wan ++ * Add more reporting constants for Fast Retrain ++ * ++ * Revision 1.39 1999/08/12 00:18:10 wan ++ * Add several Fast Retrain Status constants ++ * ++ * Revision 1.38 1999/08/10 18:25:38 george ++ * Define constants used for Fast Retrain ++ * ++ * Revision 1.37 1999/07/31 01:47:43 george ++ * Add status constants for eoc/aoc ++ * ++ * Revision 1.36 1999/07/27 18:19:52 george ++ * declare aoc/eoc functions ++ * ++ * Revision 1.35 1999/07/19 22:44:47 george ++ * Add constants for G994p1 Message Exchange ++ * ++ * Revision 1.34 1999/07/16 02:03:03 liang ++ * Modified Dsl link layer command spec structure. ++ * ++ * Revision 1.33 1999/07/14 22:53:16 george ++ * Add Constants for G994p1 ++ * ++ * Revision 1.32 1999/07/13 00:02:26 liang ++ * Added more feature bits. ++ * ++ * Revision 1.31 1999/07/09 01:58:14 wan ++ * Added more constants G.994.1 testing reports ++ * ++ * Revision 1.30 1999/07/07 23:51:04 liang ++ * Added rcv power and loop attenuation reports. ++ * ++ * Revision 1.29 1999/07/06 21:32:01 liang ++ * Added some aux. feature bits, and field performanceMargin was changed to noiseMargin in Capabilities. ++ * ++ * Revision 1.28 1999/07/03 01:40:17 liang ++ * Redefined dsl command parameter list and added connection setup struct. ++ * ++ * Revision 1.27 1999/07/02 00:41:18 liang ++ * Add bit and gain logging as well as rcv carrier range status. ++ * ++ * Revision 1.26 1999/06/25 21:37:10 wan ++ * Work in progress for G994.1. ++ * ++ * Revision 1.25 1999/06/16 00:54:36 liang ++ * Added Tx/Rx SHOWTIME active training progress codes. ++ * ++ * Revision 1.24 1999/06/11 21:59:37 wan ++ * Added G994.1 fail status constant. ++ * ++ * Revision 1.23 1999/06/11 21:29:01 liang ++ * Constants for C/R-Msgs was changed to C/R-Msg. ++ * ++ * Revision 1.22 1999/06/08 02:49:42 liang ++ * Added SNR data logging. ++ * ++ * Revision 1.21 1999/06/07 21:05:08 liang ++ * Added more training status values. ++ * ++ * Revision 1.20 1999/05/22 02:18:26 liang ++ * More constant defines. ++ * ++ * Revision 1.19 1999/05/14 22:49:35 liang ++ * Added more status codes and debug data codes. ++ * ++ * Revision 1.18 1999/04/12 22:41:39 liang ++ * Work in progress. ++ * ++ * Revision 1.17 1999/04/01 20:28:07 liang ++ * Added RReverb detect event status. ++ * ++ * Revision 1.16 1999/03/26 03:29:54 liang ++ * Add DSL debug data constants. ++ * ++ * Revision 1.15 1999/03/08 21:58:00 liang ++ * Added more constant definitions. ++ * ++ * Revision 1.14 1999/03/02 01:49:36 liang ++ * Added more connection info codes. ++ * ++ * Revision 1.13 1999/03/02 00:25:55 liang ++ * Added DSL tx and rx data handler type definitions. ++ * ++ * Revision 1.12 1999/02/27 01:16:55 liang ++ * Increase allowable static memory size to a VERY large number for now. ++ * ++ * Revision 1.11 1999/02/25 00:24:06 liang ++ * Increased symbol block size to 16. ++ * ++ * Revision 1.10 1999/02/23 22:03:26 liang ++ * Increased maximal static memory size allowed. ++ * ++ * Revision 1.9 1999/02/17 02:39:21 ilyas ++ * Changes for NDIS ++ * ++ * Revision 1.8 1999/02/11 22:44:30 ilyas ++ * More definitions for ATM ++ * ++ * Revision 1.7 1999/02/10 01:56:38 liang ++ * Added hooks for G994.1 and G992.2. ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftDslHeader ++#define SoftDslHeader ++ ++/* for builds in Linux/VxWorks CommEngine environment */ ++#if (defined(__KERNEL__) && !defined(LINUX_DRIVER)) || defined(VXWORKS) || defined(_WIN32_WCE) || defined(TARG_OS_RTEMS) || defined(_CFE_) ++#include "AdslCoreDefs.h" ++#else ++#include "Bcm6345_To_Bcm6348.h" /* File for 45->48 changes */ ++#endif ++ ++#ifndef SoftModemPh ++#include "SoftModem.h" ++#endif ++ ++#ifdef DSL_OS ++#include "DslOs.h" ++#endif ++ ++/* ++** ++** Type definitions ++** ++*/ ++ ++#if defined(ATM) || defined(DSL_PACKET) ++#define DSL_LINKLAYER ++#endif ++ ++#if defined(ATM_LAYER) || defined(DSL_PACKET_LAYER) || defined(G997_1_FRAMER) ++#define DSL_FRAME_FUNCTIONS ++#endif ++ ++#define FLD_OFFSET(type,fld) ((int)(void *)&(((type *)0)->fld)) ++ ++#include "Que.h" ++#include "SoftAtmVc.h" ++ ++typedef struct _dslFrameBuffer ++ { ++ struct _dslFrameBuffer *next; /* link to the next buffer in the frame */ ++ void *pData; /* pointer to data */ ++ ulong length; /* size (in bytes) of data */ ++ } dslFrameBuffer; ++ ++typedef struct _dslFrame ++ { ++ ulong Reserved[3]; ++ ++ ulong totalLength; /* total amount of data in the packet */ ++ int bufCnt; /* buffer counter */ ++ struct _dslFrameBuffer *head; /* first buffer in the chain */ ++ struct _dslFrameBuffer *tail; /* last buffer in the chain */ ++ } dslFrame; ++ ++ ++/* VC types and parameters */ ++ ++#define kDslVcAtm 1 ++ ++typedef struct ++ { ++ ulong vcType; ++ union ++ { ++ atmVcParams atmParams; ++ } params; ++ } dslVcParams; ++ ++/* ++** Assuming that dslVcParams.params is the first field in VC ++** and RefData is the first field in dslVcParams.params ++*/ ++ ++#define DslVcGetRefData(pVc) (*(void **) (pVc)) ++ ++/* Frame OOB types */ ++ ++#define kDslFrameAtm 1 ++ ++typedef struct ++ { ++ ulong frameType; ++ union ++ { ++ atmOobPacketInfo atmInfo; ++ } param; ++ } dslOobFrameInfo; ++ ++ ++typedef struct ++ { ++ ulong (SM_DECL *__DslFrameBufferGetLength) (dslFrameBuffer *fb); ++ void * (SM_DECL *__DslFrameBufferGetAddress) (dslFrameBuffer *fb); ++ void (SM_DECL *__DslFrameBufferSetLength) (dslFrameBuffer *fb, ulong l); ++ void (SM_DECL *__DslFrameBufferSetAddress) (dslFrameBuffer *fb, void *p); ++ ++ void (SM_DECL *__DslFrameInit) (dslFrame *f); ++ ulong (SM_DECL *__DslFrameGetLength) (dslFrame *pFrame); ++ ulong (SM_DECL *__DslFrameGetBufCnt) (dslFrame *pFrame); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetFirstBuffer) (dslFrame *pFrame); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetNextBuffer) (dslFrameBuffer *pFrBuffer); ++ void (SM_DECL *__DslFrameSetNextBuffer) (dslFrameBuffer *pFrBuf, dslFrameBuffer *pFrBufNext); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetLastBuffer) (dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameGetLinkFieldAddress) (dslFrame *f); ++ dslFrame * (SM_DECL *__DslFrameGetFrameAddressFromLink) (void *lnk); ++ ++ Boolean (SM_DECL *__DslFrameGetOobInfo) (dslFrame *f, dslOobFrameInfo *pOobInfo); ++ Boolean (SM_DECL *__DslFrameSetOobInfo) (dslFrame *f, dslOobFrameInfo *pOobInfo); ++ ++ void (SM_DECL *__DslFrameEnqueBufferAtBack) (dslFrame *f, dslFrameBuffer *b); ++ void (SM_DECL *__DslFrameEnqueFrameAtBack) (dslFrame *fMain, dslFrame *f); ++ void (SM_DECL *__DslFrameEnqueBufferAtFront) (dslFrame *f, dslFrameBuffer *b); ++ void (SM_DECL *__DslFrameEnqueFrameAtFront) (dslFrame *fMain, dslFrame *f); ++ dslFrameBuffer * (SM_DECL *__DslFrameDequeBuffer) (dslFrame *pFrame); ++ ++ void * (SM_DECL *__DslFrameAllocMemForFrames) (ulong frameNum); ++ void (SM_DECL *__DslFrameFreeMemForFrames) (void *hMem); ++ dslFrame * (SM_DECL *__DslFrameAllocFrame) (void *handle); ++ void (SM_DECL *__DslFrameFreeFrame) (void *handle, dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameAllocMemForBuffers) (void **ppMemPool, ulong bufNum, ulong memSize); ++ void (SM_DECL *__DslFrameFreeMemForBuffers) (void *hMem, ulong memSize, void *pMemPool); ++ dslFrameBuffer * (SM_DECL *__DslFrameAllocBuffer) (void *handle, void *pMem, ulong length); ++ void (SM_DECL *__DslFrameFreeBuffer) (void *handle, dslFrameBuffer *pBuf); ++ ++ /* for LOG file support */ ++ ++ ulong (SM_DECL *__DslFrame2Id)(void *handle, dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameId2Frame)(void *handle, ulong frameId); ++ } dslFrameFunctions; ++ ++#define DslFrameDeclareFunctions( name_prefix ) \ ++extern ulong SM_DECL name_prefix##BufferGetLength(dslFrameBuffer *fb); \ ++extern void * SM_DECL name_prefix##BufferGetAddress(dslFrameBuffer *fb); \ ++extern void SM_DECL name_prefix##BufferSetLength(dslFrameBuffer *fb, ulong l); \ ++extern void SM_DECL name_prefix##BufferSetAddress(dslFrameBuffer *fb, void *p); \ ++ \ ++extern void SM_DECL name_prefix##Init(dslFrame *f); \ ++extern ulong SM_DECL name_prefix##GetLength (dslFrame *pFrame); \ ++extern ulong SM_DECL name_prefix##GetBufCnt(dslFrame *pFrame); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetFirstBuffer(dslFrame *pFrame); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetNextBuffer(dslFrameBuffer *pFrBuffer); \ ++extern void SM_DECL name_prefix##SetNextBuffer(dslFrameBuffer *pFrBuf, dslFrameBuffer *pFrBufNext); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetLastBuffer(dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##GetLinkFieldAddress(dslFrame *f); \ ++extern Boolean SM_DECL name_prefix##GetOobInfo(dslFrame *f, dslOobFrameInfo *pOobInfo); \ ++extern Boolean SM_DECL name_prefix##SetOobInfo(dslFrame *f, dslOobFrameInfo *pOobInfo); \ ++extern dslFrame* SM_DECL name_prefix##GetFrameAddressFromLink(void *lnk); \ ++extern void SM_DECL name_prefix##EnqueBufferAtBack(dslFrame *f, dslFrameBuffer *b); \ ++extern void SM_DECL name_prefix##EnqueFrameAtBack(dslFrame *fMain, dslFrame *f); \ ++extern void SM_DECL name_prefix##EnqueBufferAtFront(dslFrame *f, dslFrameBuffer *b); \ ++extern void SM_DECL name_prefix##EnqueFrameAtFront(dslFrame *fMain, dslFrame *f); \ ++extern dslFrameBuffer * SM_DECL name_prefix##DequeBuffer(dslFrame *pFrame); \ ++ \ ++extern void * SM_DECL name_prefix##AllocMemForFrames(ulong frameNum); \ ++extern void SM_DECL name_prefix##FreeMemForFrames(void *hMem); \ ++extern dslFrame * SM_DECL name_prefix##AllocFrame(void *handle); \ ++extern void SM_DECL name_prefix##FreeFrame(void *handle, dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##AllocMemForBuffers(void **ppMemPool, ulong bufNum, ulong memSize); \ ++extern void SM_DECL name_prefix##FreeMemForBuffers(void *hMem, ulong memSize, void *pMemPool); \ ++extern dslFrameBuffer * SM_DECL name_prefix##AllocBuffer(void *handle, void *pMem, ulong length); \ ++extern void SM_DECL name_prefix##FreeBuffer(void *handle, dslFrameBuffer *pBuf); \ ++extern ulong SM_DECL name_prefix##2Id(void *handle, dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##Id2Frame(void *handle, ulong frameId); ++ ++ ++#define DslFrameAssignFunctions( var, name_prefix ) do { \ ++ (var).__DslFrameBufferGetLength = name_prefix##BufferGetLength; \ ++ (var).__DslFrameBufferGetAddress= name_prefix##BufferGetAddress; \ ++ (var).__DslFrameBufferSetLength = name_prefix##BufferSetLength; \ ++ (var).__DslFrameBufferSetAddress= name_prefix##BufferSetAddress; \ ++ \ ++ (var).__DslFrameInit = name_prefix##Init; \ ++ (var).__DslFrameGetLength = name_prefix##GetLength; \ ++ (var).__DslFrameGetBufCnt = name_prefix##GetBufCnt; \ ++ (var).__DslFrameGetFirstBuffer = name_prefix##GetFirstBuffer; \ ++ (var).__DslFrameGetNextBuffer = name_prefix##GetNextBuffer; \ ++ (var).__DslFrameSetNextBuffer = name_prefix##SetNextBuffer; \ ++ (var).__DslFrameGetLastBuffer = name_prefix##GetLastBuffer; \ ++ (var).__DslFrameGetLinkFieldAddress = name_prefix##GetLinkFieldAddress; \ ++ (var).__DslFrameGetFrameAddressFromLink = name_prefix##GetFrameAddressFromLink; \ ++ \ ++ (var).__DslFrameGetOobInfo = name_prefix##GetOobInfo; \ ++ (var).__DslFrameSetOobInfo = name_prefix##SetOobInfo; \ ++ \ ++ (var).__DslFrameEnqueBufferAtBack = name_prefix##EnqueBufferAtBack; \ ++ (var).__DslFrameEnqueFrameAtBack = name_prefix##EnqueFrameAtBack; \ ++ (var).__DslFrameEnqueBufferAtFront= name_prefix##EnqueBufferAtFront; \ ++ (var).__DslFrameEnqueFrameAtFront = name_prefix##EnqueFrameAtFront; \ ++ (var).__DslFrameDequeBuffer = name_prefix##DequeBuffer; \ ++ \ ++ (var).__DslFrameAllocMemForFrames = name_prefix##AllocMemForFrames; \ ++ (var).__DslFrameFreeMemForFrames = name_prefix##FreeMemForFrames; \ ++ (var).__DslFrameAllocFrame = name_prefix##AllocFrame; \ ++ (var).__DslFrameFreeFrame = name_prefix##FreeFrame; \ ++ (var).__DslFrameAllocMemForBuffers= name_prefix##AllocMemForBuffers; \ ++ (var).__DslFrameFreeMemForBuffers = name_prefix##FreeMemForBuffers; \ ++ (var).__DslFrameAllocBuffer = name_prefix##AllocBuffer; \ ++ (var).__DslFrameFreeBuffer = name_prefix##FreeBuffer; \ ++ \ ++ (var).__DslFrame2Id = name_prefix##2Id; \ ++ (var).__DslFrameId2Frame = name_prefix##Id2Frame; \ ++} while (0) ++ ++typedef struct ++ { ++ Boolean febe_I; ++ Boolean fecc_I; ++ Boolean los, rdi; ++ Boolean ncd_I; ++ Boolean hec_I; ++#ifdef G992P3 ++ Boolean lpr; ++#endif ++ ++#ifdef G992P1_NEWFRAME ++ ++ Boolean febe_F; ++ Boolean fecc_F; ++ Boolean ncd_F; ++ Boolean hec_F; ++ ++#endif ++ } G992MonitorParams; ++ ++typedef struct ++ { ++ ushort K; ++ uchar S, R; ++ uchar D; ++#ifdef G992P3 ++ uchar T, SEQ; ++#endif ++ directionType direction; ++ ++#ifdef G992P1_NEWFRAME ++ ++ ushort N; ++ ushort NF; ++ uchar RSF; ++ ++ uchar AS0BF, AS1BF, AS2BF, AS3BF, AEXAF; ++ ushort AS0BI; ++ uchar AS1BI, AS2BI, AS3BI, AEXAI; ++ ++ uchar LS0CF, LS1BF, LS2BF, LEXLF; ++ uchar LS0CI, LS1BI, LS2BI, LEXLI; ++ ++ uchar mergedModeEnabled; ++ ++#endif ++ ++ } G992CodingParams; ++ ++typedef struct ++ { ++ uchar Nlp; ++ uchar Nbc; ++ uchar MSGlp; ++ ushort MSGc; ++ ++ ulong L; ++ ushort M; ++ ushort T; ++ ushort D; ++ ushort R; ++ ushort B; ++ } G992p3CodingParams; ++ ++/* Power Management Message definitions (used in command and status) */ ++ ++typedef struct ++ { ++ long msgType; ++ union ++ { ++ long value; ++ struct ++ { ++ long msgLen; ++ void *msgData; ++ } msg; ++ } param; ++ } dslPwrMessage; ++ ++/* Power Management commands and responses */ ++ ++#define kPwrSimpleRequest 1 ++#define kPwrL2Request 2 ++#define kPwrL2TrimRequest 3 ++ ++#define kPwrGrant 0x80 ++#define kPwrReject 0x81 ++#define kPwrL2Grant 0x82 ++#define kPwrL2Reject 0x83 ++#define kPwrL2TrimGrant 0x84 ++#define kPwrL2TrimReject 0x85 ++#define kPwrL2Grant2p 0x86 ++ ++#define kPwrBusy 0x01 ++#define kPwrInvalid 0x02 ++#define kPwrNotDesired 0x03 ++#define kPwrInfeasibleParam 0x04 ++ ++/* Power Management reason codes */ ++ ++/* OLR definitions (used in command and status) */ ++ ++typedef struct ++ { ++ ushort msgType; ++ ushort nCarrs; ++ ushort L[4]; ++ uchar B[4]; ++ void *carrParamPtr; ++ } dslOLRMessage; ++ ++typedef struct ++ { ++ uchar ind; ++ uchar gain; ++ uchar gb; ++ } dslOLRCarrParam; ++ ++typedef struct ++ { ++ ushort ind; ++ uchar gain; ++ uchar gb; ++ } dslOLRCarrParam2p; ++ ++/* OLR messages */ ++ ++#define kOLRRequestType1 1 ++#define kOLRRequestType2 2 ++#define kOLRRequestType3 3 ++#define kOLRRequestType4 4 ++#define kOLRRequestType5 5 ++#define kOLRRequestType6 6 ++ ++#define kOLRDeferType1 0x81 ++#define kOLRRejectType2 0x82 ++#define kOLRRejectType3 0x83 ++ ++/* OLR reason codes */ ++ ++#define kOLRBusy 1 ++#define kOLRInvalidParam 2 ++#define kOLRNotEnabled 3 ++#define kOLRNotSupported 4 ++ ++/* common EOC definitions */ ++#define kG992EocStuffingByte 0x0C ++ ++/* showtime monitor counters */ ++#define kG992ShowtimeRSCodewordsRcved 0 /* number of Reed-Solomon codewords received */ ++#define kG992ShowtimeRSCodewordsRcvedOK 1 /* number of Reed-Solomon codewords received with all symdromes zero */ ++#define kG992ShowtimeRSCodewordsRcvedCorrectable 2 /* number of Reed-Solomon codewords received with correctable errors */ ++#define kG992ShowtimeRSCodewordsRcvedUncorrectable 3 /* number of Reed-Solomon codewords received with un-correctable errors */ ++#define kG992ShowtimeSuperFramesRcvd 4 /* number of super frames received */ ++#define kG992ShowtimeSuperFramesRcvdWrong 5 /* number of super frames received with CRC error */ ++#define kG992ShowtimeLastUncorrectableRSCount 6 /* last recorded value for kG992ShowtimeRSCodewordsRcvedUncorrectable */ ++#define kG992ShowtimeLastWrongSuperFrameCount 7 /* last recorded value for kG992ShowtimeSuperFramesRcvdWrong */ ++#define kG992ShowtimeNumOfShortResync 8 /* number of short interrupt recoveries by FEQ */ ++ ++#define kG992ShowtimeNumOfFEBE 9 /* number of other side superframe errors */ ++#define kG992ShowtimeNumOfFECC 10 /* number of other side superframe FEC errors */ ++#define kG992ShowtimeNumOfFHEC 11 /* number of far-end ATM header CRC errors */ ++#define kG992ShowtimeNumOfFOCD 12 /* number of far-end OCD events */ ++#define kG992ShowtimeNumOfFLCD 13 /* number of far-end LCD events */ ++#define kG992ShowtimeNumOfHEC 14 /* number of ATM header CRC errors */ ++#define kG992ShowtimeNumOfOCD 15 /* number of OCD events */ ++#define kG992ShowtimeNumOfLCD 16 /* number of LCD events */ ++ ++#define kG992ShowtimeNumOfMonitorCounters (kG992ShowtimeNumOfLCD+1) /* always last number + 1 */ ++#define kG992ShowtimeMonitorReportNumber 9 ++ ++#define kG992ShowtimeLCDNumShift 1 ++#define kG992ShowtimeLCDFlag 1 ++ ++typedef int (SM_DECL *dslFrameHandlerType) (void *gDslVars, void *pVc, ulong mid, dslFrame *); ++ ++typedef void* (SM_DECL *dslHeaderHandlerType) (void *gDslVars, ulong hdr, uchar hdrHec); ++typedef void* (SM_DECL *dslTxFrameBufferHandlerType) (void *gDslVars, int*, void*); ++typedef void* (SM_DECL *dslRxFrameBufferHandlerType) (void *gDslVars, int, void*); ++ ++typedef void* (SM_DECL *dslVcAllocateHandlerType) (void *gDslVars, void *); ++typedef void (SM_DECL *dslVcFreeHandlerType) (void *gDslVars, void *); ++typedef Boolean (SM_DECL *dslVcActivateHandlerType) (void *gDslVars, void *); ++typedef void (SM_DECL *dslVcDeactivateHandlerType) (void *gDslVars, void *); ++typedef Boolean (SM_DECL *dslVcConfigureHandlerType) (void *gDslVars, void *pVc, ulong mid, void *); ++ ++typedef ulong (SM_DECL *dslLinkVc2IdHandlerType) (void *gDslVars, void *); ++typedef void* (SM_DECL *dslLinkVcId2VcHandlerType) (void *gDslVars, ulong); ++typedef void* (SM_DECL *dslGetFramePoolHandlerType) (void *gDslVars); ++ ++typedef void (SM_DECL *dslLinkCloseHandlerType) (void *gDslVars); ++typedef int (SM_DECL *dslTxDataHandlerType)(void *gDslVars, int, int, uchar*, G992MonitorParams*); ++typedef int (SM_DECL *dslRxDataHandlerType)(void *gDslVars, int, uchar*, G992MonitorParams*); ++ ++typedef void (SM_DECL *dslLinkStatusHandler) (void *gDslVars, ulong statusCode, ...); ++ ++typedef Boolean (SM_DECL *dslPhyInitType) ( ++ void *gDslVars, ++ bitMap setupMap, ++ dslHeaderHandlerType rxCellHeaderHandlerPtr, ++ dslRxFrameBufferHandlerType rxFrameHandlerPtr, ++ dslTxFrameBufferHandlerType txFrameHandlerPtr, ++ atmStatusHandler statusHandlerPtr); ++ ++struct _dslFramerBufDesc; ++ ++typedef Boolean (SM_DECL *dslFramerDataGetPtrHandlerType) (void *gDslVars, struct _dslFramerBufDesc *pBufDesc); ++typedef void (SM_DECL *dslFramerDataDoneHandlerType) (void *gDslVars, struct _dslFramerBufDesc *pBufDesc); ++ ++typedef void (SM_DECL *dslDriverCallbackType) (void *gDslVars); ++ ++#ifdef DSL_PACKET ++ ++typedef struct ++ { ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ } dslPacketPhyFunctions; ++ ++typedef Boolean (SM_DECL *dslPacketPhyInitType) ( ++ void *gDslVars, ++ bitMap setupMap, ++ dslPacketPhyFunctions dslPhyFunctions, ++ dslLinkStatusHandler statusHandlerPtr); ++ ++ ++#endif /* DSL_PACKET */ ++ ++ ++typedef int dslDirectionType; ++typedef bitMap dslModulationType; ++typedef bitMap dslLinkLayerType; ++ ++/* ++** ++** Log data codes ++** ++*/ ++ ++#define kDslEyeData eyeData ++ ++#define kDslLogComplete (inputSignalData - 1) ++#define kDslLogInputData inputSignalData ++#define kDslLogInputData1 (inputSignalData + 1) ++#define kDslLogInputData2 (inputSignalData + 2) ++#define kDslLogInputData3 (inputSignalData + 3) ++ ++/* ++** ++** Status codes ++** ++*/ ++ ++typedef long dslStatusCode; ++#define kFirstDslStatusCode 256 ++#define kDslError (kFirstDslStatusCode + 0) ++#define kAtmStatus (kFirstDslStatusCode + 1) ++#define kDslTrainingStatus (kFirstDslStatusCode + 2) ++#define kDslConnectInfoStatus (kFirstDslStatusCode + 3) ++#define kDslEscapeToG994p1Status (kFirstDslStatusCode + 4) ++#define kDslFrameStatus (kFirstDslStatusCode + 5) ++#define kDslReceivedEocCommand (kFirstDslStatusCode + 6) ++#define kDslSendEocCommandDone (kFirstDslStatusCode + 7) ++#define kDslSendEocCommandFailed (kFirstDslStatusCode + 8) ++#define kDslWriteRemoteRegisterDone (kFirstDslStatusCode + 9) ++#define kDslReadRemoteRegisterDone (kFirstDslStatusCode + 10) ++#define kDslExternalError (kFirstDslStatusCode + 11) ++#define kDslDspControlStatus (kFirstDslStatusCode + 12) ++#define kDslATUHardwareAGCRequest (kFirstDslStatusCode + 13) ++#define kDslPacketStatus (kFirstDslStatusCode + 14) ++#define kDslG997Status (kFirstDslStatusCode + 15) ++#define kDslPrintfStatus (kFirstDslStatusCode + 16) ++#define kDslPrintfStatus1 (kFirstDslStatusCode + 17) ++#define kDslExceptionStatus (kFirstDslStatusCode + 18) ++#define kDslPingResponse (kFirstDslStatusCode + 19) ++#define kDslShowtimeSNRMarginInfo (kFirstDslStatusCode + 20) ++#define kDslGetOemParameter (kFirstDslStatusCode + 21) ++#define kDslOemDataAddrStatus (kFirstDslStatusCode + 22) ++#define kDslDataAvailStatus (kFirstDslStatusCode + 23) ++/* #define kDslAtuChangeTxFilterRequest (kFirstDslStatusCode + 24) */ ++#define kDslTestPllPhaseResult (kFirstDslStatusCode + 25) ++#ifdef BCM6348_SRC ++#define kDslHardwareAGCSetPga1 (kFirstDslStatusCode + 26) ++#define kDslHardwareAGCDecPga1 (kFirstDslStatusCode + 27) ++#define kDslHardwareAGCIncPga1 (kFirstDslStatusCode + 28) ++#define kDslHardwareAGCSetPga2Delta (kFirstDslStatusCode + 29) ++#endif ++#define kDslOLRRequestStatus (kFirstDslStatusCode + 30) ++#define kDslOLRResponseStatus (kFirstDslStatusCode + 31) ++#define kDslOLRBitGainUpdateStatus (kFirstDslStatusCode + 32) ++#define kDslPwrMgrStatus (kFirstDslStatusCode + 33) ++#define kDslEscapeToT1p413Status (kFirstDslStatusCode + 34) ++#ifdef BCM6348_SRC ++#define kDslHardwareAGCSetPga2 (kFirstDslStatusCode + 35) ++#define kDslHardwareGetRcvAGC (kFirstDslStatusCode + 36) ++#endif ++#define kDslUpdateXmtReadPtr (kFirstDslStatusCode + 37) ++#define kDslHardwareSetRcvAGC (kFirstDslStatusCode + 38) ++#ifdef BCM6348_SRC ++#define kDslSetDigUsPwrCutback (kFirstDslStatusCode + 39) ++#endif ++ ++#define kClientSideInitiation 0 ++#define kClientSideRespond 1 ++#define kCentralSideInitiation 2 ++#define kCentralSideRespond 3 ++ ++/* OEM parameter ID definition */ ++ ++#define kDslOemG994VendorId 1 ++#define kDslOemG994XmtNSInfo 2 ++#define kDslOemG994RcvNSInfo 3 ++#define kDslOemEocVendorId 4 ++#define kDslOemEocVersion 5 ++#define kDslOemEocSerNum 6 ++#define kDslOemT1413VendorId 7 ++#define kDslOemT1413EocVendorId 8 ++ ++typedef long dslErrorCode; ++ ++typedef long atmStatusCode; ++typedef long dslFramerStatusCode; ++ ++typedef long atmErrorCode; ++ ++typedef long dslTrainingStatusCode; ++ ++#define kDslStartedG994p1 0 ++#define kDslStartedT1p413HS 1 ++ ++/* reserved for G.994.1: 1 ~ 8 */ ++ ++#define kDslG994p1MessageDet 100 ++#define kDslG994p1ToneDet 101 ++#define kDslG994p1RToneDet 102 ++#define kDslG994p1FlagDet 103 ++#define kDslG994p1GalfDet 104 ++#define kDslG994p1ErrorFrameDet 105 ++#define kDslG994p1BadFrameDet 106 ++#define kDslG994p1SilenceDet 107 ++#define kDslG994p1RcvTimeout 108 ++#define kDslG994p1XmtFinished 109 ++#define kDslG994p1ReturntoStartup 110 ++#define kDslG994p1InitiateCleardown 111 ++#define kDslG994p1StartupFinished 112 ++#define kDslG994p1RcvNonStandardInfo 113 ++#define kDslG994p1XmtNonStandardInfo 114 ++ ++#define kG994p1MaxNonstdMessageLength 64 ++ ++#define kDslFinishedT1p413 1100 ++#define kDslT1p413DetectedCTone 1101 ++#define kDslT1p413DetectedCAct 1102 ++#define kDslT1p413DetectedCReveille 1103 ++#define kDslT1p413DetectedRActReq 1104 ++#define kDslT1p413DetectedRQuiet1 1105 ++#define kDslT1p413DetectedRAct 1106 ++#define kDslT1p413TimeoutCReveille 1107 ++#define kDslT1p413ReturntoStartup 1108 ++ ++#define kDslG994p1Timeout 8 ++#define kDslFinishedG994p1 9 ++#define kDslStartedG992p2Training 10 ++#define kDslG992p2DetectedPilotSymbol 11 ++#define kDslG992p2DetectedReverbSymbol 12 ++#define kDslG992p2TEQCalculationDone 13 ++#define kDslG992p2TrainingFEQ 14 ++#define kDslG992p2Phase3Started 15 ++#define kDslG992p2ReceivedRates1 16 ++#define kDslG992p2ReceivedMsg1 17 ++#define kDslG992p2Phase4Started 18 ++#define kDslG992p2ReceivedRatesRA 19 ++#define kDslG992p2ReceivedMsgRA 20 ++#define kDslG992p2ReceivedRates2 21 ++#define kDslG992p2ReceivedMsg2 22 ++#define kDslG992p2ReceivedBitGainTable 23 ++#define kDslG992p2TxShowtimeActive 24 ++#define kDslG992p2RxShowtimeActive 25 ++#define kDslG992p2TxAocMessage 26 ++#define kDslG992p2RxAocMessage 27 ++#define kDslG992p2TxEocMessage 28 ++#define kDslG992p2RxEocMessage 29 ++#define kDslFinishedG992p2Training 30 ++#define kDslRecoveredFromImpulseNoise 31 ++#define kDslG992Timeout 32 ++#define kDslT1p413Isu1SglByteSymDetected 33 /* detected T1.413 Issue 1 single byte per symbol mode */ ++#define kDslG992RxPrefixOnInAFewSymbols 34 ++#define kDslG992TxPrefixOnInAFewSymbols 35 ++#define kDslAnnexCXmtCPilot1Starting 36 ++#define kDslXmtToRcvPathDelay 37 ++#define kDslFeaturesUnsupported 38 ++#define kDslG992RcvMsgCrcError 39 ++#define kDslAnnexCDetectedStartHyperframe 40 ++ ++#define kDslG992AnnexCTimeoutCPilot1Detection 41 ++#define kDslG992AnnexCTimeoutCReverb1Detection 42 ++#define kDslG992AnnexCTimeoutECTraining 43 ++#define kDslG992AnnexCTimeoutHyperframeDetector 44 ++#define kDslG992AnnexCTimeoutSendRSegue2 45 ++#define kDslG992AnnexCTimeoutDetectCSegue1 46 ++#define kDslG992AnnexCAlignmentErrDetected 47 ++#define kDslG992AnnexCTimeoutSendRSegueRA 48 ++#define kDslG992AnnexCTimeoutSendRSegue4 49 ++#define kDslG992AnnexCTimeoutCSegue2Detection 50 ++#define kDslG992AnnexCTimeoutCSegue3Detection 51 ++/* Progress report for fast retrain */ ++ ++#define kG994p1EventToneDetected 54 ++#define kDslG992p2RcvVerifiedBitAndGain 55 ++#define kDslG992p2ProfileChannelResponseCalc 56 ++#define kDslG992AnnexCTotalFEXTBits 57 ++#define kDslG992AnnexCTotalNEXTBits 58 ++#define kDslG992AnnexCTotalFEXTCarrs 59 ++#define kDslG992AnnexCTotalNEXTCarrs 60 ++ ++#define kDslG992p3ReceivedMsgFmt 61 ++#define kDslG992p3ReceivedMsgPcb 62 ++ ++#define kDslG992p3AnnexLMode 63 ++ ++/* performance monitoring report */ ++ ++#define kG992DataRcvDetectFastRSCorrection 70 ++#define kG992DataRcvDetectInterleaveRSCorrection 71 ++#define kG992DataRcvDetectFastCRCError 72 ++#define kG992DataRcvDetectInterleaveCRCError 73 ++#define kG992DataRcvDetectFastRSError 74 ++#define kG992DataRcvDetectInterleaveRSError 75 ++#define kG992DataRcvDetectLOS 76 ++#define kG992DecoderDetectRDI 77 ++#define kG992DataRcvDetectLOSRecovery 78 ++#define kG992AtmDetectHEC 79 ++#define kG992AtmDetectOCD 180 ++#define kG992AtmDetectCD 181 ++#define kG992DecoderDetectRemoteLOS 182 ++#define kG992DecoderDetectRemoteLOSRecovery 183 ++#define kG992DecoderDetectRemoteRDI 184 ++#define kG992DecoderDetectRemoteRDIRecovery 185 ++#define kG992RcvDetectSyncSymbolOffset 186 ++#define kG992Upstream2xIfftDisabled 187 ++#if defined(G992P5) ++#define kDslG992RunAnnexaP3ModeInAnnexaP5 188 /* run Annex C mode in Annex I compiled codes */ ++#else ++#define kDslG992RunAnnexCModeInAnnexI 188 /* run Annex C mode in Annex I compiled codes */ ++#endif ++ ++/* OLR PHY status */ ++ ++#define kG992EventSynchSymbolDetected 189 ++#define kG992EventReverseSynchSymbolDetected 190 ++#define kG992EventL2CReverbSymbolDetected 191 ++#define kG992EventL2CSegueSymbolDetected 192 ++ ++/* ANNEX_M */ ++#define kG992EnableAnnexM 191 ++ ++#define kDslAtuChangeTxFilterRequest 192 ++ ++/* detailed error messages reports */ ++ ++#define kDslG992XmtRReverbRAOver4000 80 ++#define kDslG992XmtRReverb5Over4000 81 ++#define kDslG992RcvCSegue2Failed 82 ++#define kDslG992RcvCSegueRAFailed 83 ++#define kDslG992RcvCSegue3Failed 84 ++#define kDslG992RcvShowtimeStartedTooLate 85 ++#define kDslG992XmtRReverb3Over4000 86 ++#define kDslG992RcvFailDetCSegue1InWindow 87 ++#define kDslG992RcvCPilot1Failed 88 ++#define kDslG992RcvCReverb1Failed 89 ++#define kG992ControlAllRateOptionsFailedErr 90 ++#define kG992ControlInvalidRateOptionErr 91 ++#define kDslG992XmtInvalidXmtDErr 92 ++#define kDslG992BitAndGainCalcFailed 93 ++#define kDslG992BitAndGainVerifyFailed 94 ++ ++#define kDslT1p413RetrainToUseCorrectRAck 95 ++#define kDslUseAlternateTxFilter 96 ++#define kDslT1p413RetrainToUseCorrectIFFT 97 ++ ++typedef long dslConnectInfoStatusCode; ++#define kG992p2XmtToneOrderingInfo 0 ++#define kG992p2RcvToneOrderingInfo 1 ++#define kG992p2XmtCodingParamsInfo 2 ++#define kG992p2RcvCodingParamsInfo 3 ++#define kG992p2TrainingRcvCarrEdgeInfo 4 ++#define kG992ShowtimeMonitoringStatus 5 ++#define kG992MessageExchangeRcvInfo 6 ++#define kG992MessageExchangeXmtInfo 7 ++#define kG994MessageExchangeRcvInfo 8 ++#define kG994MessageExchangeXmtInfo 9 ++ ++#define kDslATURClockErrorInfo 10 ++#define kDslATURcvPowerInfo 11 ++#define kDslATUAvgLoopAttenuationInfo 12 ++#define kDslHWTimeTrackingResetClockError 13 ++#define kDslHWTimeTrackingClockTweak 14 ++#define kDslATUHardwareAGCObtained 15 ++#define kDslTEQCoefInfo 16 ++#define kDslRcvCarrierSNRInfo 17 ++#define kDslMaxReceivableBitRateInfo 18 ++#define kDslHWSetDigitalEcUpdateMode 19 ++#define kDslHWEnableDigitalECUpdate 20 ++#define kDslHWDisableDigitalECUpdate 21 ++#define kDslHWEnableDigitalEC 22 ++#define kDslHWSetDigitalEcGainShift 23 ++#define kDslHWSetDigitalEcUpdateShift 24 ++#define kDslRcvPsdInfo 25 ++#define kDslHWdcOffsetInfo 26 ++#define kG994SelectedG994p1CarrierIndex 27 ++#define kDslSelectedTimingTone 28 ++ ++#define kDslHWEnableAnalogECUpdate kDslHWSetDigitalEcUpdateMode ++#define kDslHWEnableAnalogEC kDslHWDisableDigitalECUpdate ++ ++#define kG992AocMessageExchangeRcvInfo 29 ++#define kG992AocMessageExchangeXmtInfo 30 ++#define kG992AocBitswapTxStarted 31 ++#define kG992AocBitswapRxStarted 32 ++#define kG992AocBitswapTxCompleted 33 ++#define kG992AocBitswapRxCompleted 34 ++#define kDslChannelResponseLog 35 ++#define kDslChannelResponseLinear 36 ++#define kDslChannelQuietLineNoise 37 ++ ++#define kDslATUCXmtPowerCutbackInfo 40 ++#define kDslATURXmtPowerCutbackInfo 41 ++#define kDslATUCXmtPowerInfo 42 ++#define kDslATURXmtPowerInfo 43 ++ ++#define kDslFramingModeInfo 50 ++#define kDslG992VendorID 51 ++ ++#ifdef BCM6348_SRC ++#define kDslHWSetRcvFir2OutputScale 52 ++#endif ++ ++#define kDslSignalAttenuation 53 ++#define kDslAttainableNetDataRate 54 ++#define kDslHLinScale 55 ++ ++#define kG992p3XmtCodingParamsInfo 60 ++#define kG992p3RcvCodingParamsInfo 61 ++#define kG992p3PwrStateInfo 62 ++#define kG992PilotToneInfo 63 ++ ++#define kDslSetPilotEyeDisplay 64 ++ ++#define kDslAturHwAgcResolutionMask (0xFFFFFFF8) ++#define kDslAturHwAgcMinGain ((-12)<<4) ++#ifndef BCM6348_SRC ++#define kDslAturHwAgcMaxGain (30<<4) ++#else ++#define kDslAturHwAgcMaxGain (36<<4) ++#endif ++ ++#define kDslFrameStatusSend 1 ++#define kDslFrameStatusSendComplete 2 ++#define kDslFrameStatusRcv 3 ++#define kDslFrameStatusReturn 4 ++ ++typedef struct _dslFramerStatus ++ { ++ dslFramerStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nRxFrameTotal; ++ long nRxFrameError; ++ long nTxFrameTotal; ++ } statistic; ++ } param; ++ } dslFramerStatus; ++ ++typedef struct ++ { ++ dslStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ atmStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ long vci; ++ long mid; ++ long aalType; ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long vcId; ++ long vci; ++ long aalType; ++ ulong fwdPeakCellTime; ++ ulong backPeakCellTime; ++ } vcInfo; ++ struct ++ { ++ long cellHdr; ++ long oamCmd; ++ } oamInfo; ++ struct ++ { ++ void *pVc; ++ char *pHdr; ++ void *cellHdr; ++ void *cellData; ++ } cellInfo; ++ struct ++ { ++ long totalBits; ++ long errBits; ++ } bertInfo; ++ } param; ++ } atmStatus; ++#ifdef DSL_PACKET ++ dslFramerStatus dslPacketStatus; ++#endif ++#ifdef G997_1_FRAMER ++ dslFramerStatus g997Status; ++#endif ++ struct ++ { ++ dslTrainingStatusCode code; ++ long value; ++ } dslTrainingInfo; ++ struct ++ { ++ dslConnectInfoStatusCode code; ++ long value; ++ void *buffPtr; ++ } dslConnectInfo; ++ struct ++ { ++ long maxMarginCarrier; ++ long maxSNRMargin; ++ long minMarginCarrier; ++ long minSNRMargin; ++ long avgSNRMargin; ++ long nCarriers; ++ void *buffPtr; ++ } dslShowtimeSNRMarginInfo; ++ struct ++ { ++ long code; ++ long vcId; ++ long timeStamp; ++ } dslFrameInfo; ++#ifdef G997_1 ++ struct ++ { ++ long msgId; ++ long msgType; ++ char *dataPtr; ++ } dslClearEocMsg; ++#endif ++ struct ++ { ++ char *fmt; ++ long argNum; ++ void *argPtr; ++ } dslPrintfMsg; ++ struct ++ { ++ ulong nBits; ++ ulong nBlocks; ++ ulong nBitErrors; ++ ulong nBlockErrors; ++ ++ ulong nAudioBits; ++ ulong nAudioBlocks; ++ ulong nAudioSyncErrors; ++ ulong nAudioBlockErrors; ++ } testResults; ++ struct ++ { ++ ulong code; ++ uchar *valuePtr; ++ ulong length; ++ } dslDataRegister; ++ struct ++ { ++ ulong code; ++ char *desc; ++ } dslExternalError; ++ struct ++ { ++ ulong numberOfCalls; ++ ulong txSignalChecksum; ++ ulong rxSignalChecksum; ++ ulong eyeDataChecksum; ++ } checksums; ++ struct ++ { ++ int sp; ++ int argc; ++ int *argv; ++ int *stackPtr; ++ int stackLen; ++ } dslException; ++ struct ++ { ++ ulong paramId; ++ void *dataPtr; ++ ulong dataLen; ++ } dslOemParameter; ++ struct ++ { ++ void *dataPtr; ++ ulong dataLen; ++ } dslDataAvail; ++ dslOLRMessage dslOLRRequest; ++ dslPwrMessage dslPwrMsg; ++ } param; ++ } dslStatusStruct; ++ ++typedef void (SM_DECL *dslStatusHandlerType) (void *gDslVars, dslStatusStruct*); ++ ++ ++/* ++** ++** Command codes ++** ++*/ ++ ++typedef long dslCommandCode; ++#define kFirstDslCommandCode 256 ++#define kDslIdleCmd (kFirstDslCommandCode + 0) ++#define kDslIdleRcvCmd (kFirstDslCommandCode + 1) ++#define kDslIdleXmtCmd (kFirstDslCommandCode + 2) ++#define kDslStartPhysicalLayerCmd (kFirstDslCommandCode + 3) ++#define kDslStartRetrainCmd (kFirstDslCommandCode + 4) ++#define kDslSetFrameFunctions (kFirstDslCommandCode + 5) ++#define kDslSendEocCommand (kFirstDslCommandCode + 6) ++#define kDslWriteRemoteRegister (kFirstDslCommandCode + 7) ++#define kDslReadRemoteRegister (kFirstDslCommandCode + 8) ++#define kDslWriteLocalRegister (kFirstDslCommandCode + 9) ++#define kDslReadLocalRegister (kFirstDslCommandCode + 10) ++#define kDslStoreHardwareAGCCmd (kFirstDslCommandCode + 11) ++#define kDslSetCommandHandlerCmd (kFirstDslCommandCode + 12) ++#define kSetLinkLayerStatusHandlerCmd (kFirstDslCommandCode + 13) ++#define kDslSetG997Cmd (kFirstDslCommandCode + 14) ++#define kDslLoopbackCmd (kFirstDslCommandCode + 15) ++#define kDslDiagSetupCmd (kFirstDslCommandCode + 16) ++#define kDslSetDriverCallbackCmd (kFirstDslCommandCode + 17) ++#define kDslDiagStopLogCmd (kFirstDslCommandCode + 18) ++#define kDslDiagStartBERT (kFirstDslCommandCode + 19) ++#define kDslDiagStopBERT (kFirstDslCommandCode + 20) ++#define kDslPingCmd (kFirstDslCommandCode + 21) ++#define kDslDyingGaspCmd (kFirstDslCommandCode + 22) ++#define kDslTestCmd (kFirstDslCommandCode + 23) ++#define kDslFilterSNRMarginCmd (kFirstDslCommandCode + 24) ++#define kDslAtmVcMapTableChanged (kFirstDslCommandCode + 25) ++#define kDslGetOemDataAddrCmd (kFirstDslCommandCode + 26) ++#define kDslAtmReportHEC (kFirstDslCommandCode + 27) ++#define kDslAtmReportCD (kFirstDslCommandCode + 28) ++#define kDslSetXmtGainCmd (kFirstDslCommandCode + 29) ++#define kDslSetStatusBufferCmd (kFirstDslCommandCode + 30) ++#define kDslAfeTestCmd (kFirstDslCommandCode + 31) ++#define kDslI432ResetCmd (kFirstDslCommandCode + 32) ++#define kDslSetRcvGainCmd (kFirstDslCommandCode + 33) ++#define kDslBypassRcvHpfCmd (kFirstDslCommandCode + 34) ++#define kDslWriteAfeRegCmd (kFirstDslCommandCode + 35) ++#define kDslReadAfeRegCmd (kFirstDslCommandCode + 36) ++#define kDslOLRRequestCmd (kFirstDslCommandCode + 37) ++#define kDslOLRResponseCmd (kFirstDslCommandCode + 38) ++#define kDslI432SetScrambleCmd (kFirstDslCommandCode + 39) ++#define kDslPwrMgrCmd (kFirstDslCommandCode + 40) ++#define kDslAtmGfcMappingCmd (kFirstDslCommandCode + 41) ++ ++#ifdef BCM6348_SRC ++#define kDslEnablePwmSyncClk (kFirstDslCommandCode + 42) ++#define kDslSetPwmSyncClkFreq (kFirstDslCommandCode + 43) ++#endif ++ ++#define kG994p1Duplex 1 ++#define kG994p1HalfDuplex 2 ++ ++/* Eoc Messages from ATU-C to ATU-R */ ++#define kDslEocHoldStateCmd 1 ++#define kDslEocReturnToNormalCmd 2 ++#define kDslEocPerformSelfTestCmd 3 ++#define kDslEocRequestCorruptCRCCmd 4 ++#define kDslEocRequestEndCorruptCRCCmd 5 ++#define kDslEocNotifyCorruptCRCCmd 6 ++#define kDslEocNotifyEndCorruptCRCCmd 7 ++#define kDslEocRequestTestParametersUpdateCmd 8 ++#define kDslEocGrantPowerDownCmd 9 ++#define kDslEocRejectPowerDownCmd 10 ++ ++/* Eoc Messages from ATU-R to ATU-C */ ++#define kDslEocRequestPowerDownCmd 11 ++#define kDslEocDyingGaspCmd 12 ++ ++/* Clear Eoc Messages */ ++#define kDslClearEocFirstCmd 100 ++#define kDslClearEocSendFrame 100 ++#define kDslClearEocSendComplete 101 ++#define kDslClearEocRcvedFrame 102 ++#define kDslClearEocSendComplete2 103 ++ ++#define kDslClearEocMsgLengthMask 0xFFFF ++#define kDslClearEocMsgNumMask 0xFF0000 ++#define kDslClearEocMsgDataVolatileMask 0x1000000 ++#define kDslClearEocMsgDataVolatile kDslClearEocMsgDataVolatileMask ++#define kDslClearEocMsgExtraSendComplete 0x2000000 ++ ++/* ADSL Link Power States */ ++#define kDslPowerFullOn 0 ++#define kDslPowerLow 1 ++#define kDslPowerIdle 3 ++ ++/* ATU-R Data Registers */ ++#define kDslVendorIDRegister 1 ++#define kDslRevisionNumberRegister 2 ++#define kDslSerialNumberRegister 3 ++#define kDslSelfTestResultsRegister 4 ++#define kDslLineAttenuationRegister 5 ++#define kDslSnrMarginRegister 6 ++#define kDslAturConfigurationRegister 7 ++#define kDslLinkStateRegister 8 ++ ++#define kDslVendorIDRegisterLength 8 ++#define kDslRevisionNumberRegisterLength 32 ++#define kDslSerialNumberRegisterLength 32 ++#define kDslSelfTestResultsRegisterLength 1 ++#define kDslLineAttenuationRegisterLength 1 ++#define kDslSnrMarginRegisterLength 1 ++#define kDslAturConfigurationRegisterLength 30 ++#define kDslLinkStateRegisterLength 1 ++ ++/* Dsl Diags setup flags */ ++#define kDslDiagEnableEyeData 1 ++#define kDslDiagEnableLogData 2 ++ ++/* Dsl test commands */ ++typedef long dslTestCmdType; ++#define kDslTestBackToNormal 0 ++#define kDslTestReverb 1 ++#define kDslTestMedley 2 ++#define kDslTestToneSelection 3 ++#define kDslTestNoAutoRetrain 4 ++#define kDslTestMarginTweak 5 ++#define kDslTestEstimatePllPhase 6 ++#define kDslTestReportPllPhaseStatus 7 ++#define kDslTestAfeLoopback 8 ++#define kDslTestL3 9 ++#define kDslTestAdsl2DiagMode 10 ++#define kDslTestRetL0 11 ++ ++/* Xmt gain default setting */ ++#define kDslXmtGainAuto 0x80000000 ++ ++/* Unit (AFE) test commands */ ++#define kDslAfeTestLoadImage 0 ++#define kDslAfeTestPatternSend 1 ++#define kDslAfeTestLoadImageOnly 2 ++#define kDslAfeTestPhyRun 3 ++#define kDslAfeTestLoadBuffer 4 ++ ++typedef struct ++ { ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++ ushort downstreamMinCarr, downstreamMaxCarr; ++#else ++ uchar downstreamMinCarr, downstreamMaxCarr; ++#endif ++ uchar upstreamMinCarr, upstreamMaxCarr; ++ }carrierInfo; ++ ++#if defined(G992P3) && !defined(BCM6348_SRC) ++#define FAST_TEXT_TYPE ++#else ++#define FAST_TEXT_TYPE FAST_TEXT ++#endif ++ ++#if defined(BCM6348_SRC) ++#define BCM6348_TEMP_MOVE_TO_LMEM ++#else ++#define BCM6348_TEMP_MOVE_TO_LMEM ++#endif ++ ++#ifdef G992P3 ++#define PRINT_DEBUG_INFO ++#else ++#define PRINT_DEBUG_INFO ++#endif ++ ++#ifdef G992P3 ++ ++#define kG992p3MaxSpectBoundsUpSize 16 ++#define kG992p3MaxSpectBoundsDownSize 16 ++ ++/* G.994 definitions */ ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 1 ***/ ++ ++#define kG994p1G992p3AnnexASpectrumBoundsUpstream 0x01 ++#define kG994p1G992p3AnnexASpectrumShapingUpstream 0x02 ++#define kG994p1G992p3AnnexASpectrumBoundsDownstream 0x04 ++#define kG994p1G992p3AnnexASpectrumShapingDownstream 0x08 ++#define kG994p1G992p3AnnexATxImageAboveNyquistFreq 0x10 ++#define kG994p1G992p3AnnexLReachExtended 0x20 ++#define kG994p1G992p3AnnexMSubModePSDMasks 0x20 ++ ++#define kG994p1G992p3AnnexLUpNarrowband 0x02 ++#define kG994p1G992p3AnnexLUpWideband 0x01 ++#define kG994p1G992p3AnnexLDownNonoverlap 0x01 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 2 ***/ ++ ++#define kG994p1G992p3AnnexADownOverheadDataRate 0x01 ++#define kG994p1G992p3AnnexAUpOverheadDataRate 0x02 ++#define kG994p1G992p3AnnexAMaxNumberDownTPSTC 0x04 ++#define kG994p1G992p3AnnexAMaxNumberUpTPSTC 0x08 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 3,5,7,9 ***/ ++ ++#define kG994p1G992p3AnnexADownSTM_TPS_TC 0x01 ++#define kG994p1G992p3AnnexAUpSTM_TPS_TC 0x02 ++#define kG994p1G992p3AnnexADownATM_TPS_TC 0x04 ++#define kG994p1G992p3AnnexAUpATM_TPS_TC 0x08 ++#define kG994p1G992p3AnnexADownPTM_TPS_TC 0x10 ++#define kG994p1G992p3AnnexAUpPTM_TPS_TC 0x20 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 4,6,8,10 ***/ ++ ++#define kG994p1G992p3AnnexADownPMS_TC_Latency 0x01 ++#define kG994p1G992p3AnnexAUpPMS_TC_Latency 0x02 ++ ++/*** ++ * TSSI ++ * ++ * TSSI information is specified in 2 parts: subcarrier index, ++ * tssi value, and an indication of whether or no the tone specified ++ * is part of the supported set. ++ * ++ * The subcarrier index information is currently stored in the ++ * dsSubcarrierIndex array defined below. The tssi value are stored ++ * in the dsLog_tss array. ++ * ++ * The subcarrier index information only occupies the lower 12 bits ++ * of the available 16 bits (short type). Therefore, we will pack the ++ * supported set information in bit 15. ++ */ ++#define kG992DsSubCarrierIndexMask (0x0fff) /* AND mask to ectract ds subcarrier index */ ++#define kG992DsSubCarrierSuppSetMask (0x8000) /* AND mask to extract supported set indication */ ++ ++#define G992GetDsSubCarrierIndex(arg) ((arg) & kG992DsSubCarrierIndexMask) ++#define G992GetDsSubCarrierSuppSetIndication(arg) (((arg) & kG992DsSubCarrierSuppSetMask) >> 15) ++ ++/* Caution: Do not change anything in this structure definition, including associated constant */ ++/* This structure definition is used only by the driver and any change impose incompatibility issue in driver */ ++/* The structure following this structure (g992p3PhyDataPumpCapabilities) can be changed in PHY application */ ++ ++typedef struct ++ { ++ Boolean rcvNTREnabled, shortInitEnabled, diagnosticsModeEnabled; ++ ++ char featureSpectrum, featureOverhead; ++ char featureTPS_TC[4], featurePMS_TC[4]; ++ ++ short rcvNOMPSDus, rcvMAXNOMPSDus, rcvMAXNOMATPus; ++ short usSubcarrierIndex[kG992p3MaxSpectBoundsUpSize], ++ usLog_tss[kG992p3MaxSpectBoundsUpSize]; ++ short numUsSubcarrier; ++ short rcvNOMPSDds, rcvMAXNOMPSDds, rcvMAXNOMATPds; ++ short dsSubcarrierIndex[kG992p3MaxSpectBoundsDownSize], ++ dsLog_tss[kG992p3MaxSpectBoundsDownSize]; ++ short numDsSubcarrier; ++ uchar sizeIDFT, fillIFFT; ++ uchar readsl2Upstream, readsl2Downstream; ++ uchar minDownOverheadDataRate, minUpOverheadDataRate; ++ uchar maxDownSTM_TPSTC, maxDownATM_TPSTC, maxDownPTM_TPSTC; ++ uchar maxUpSTM_TPSTC, maxUpATM_TPSTC, maxUpPTM_TPSTC; ++ ++ short minDownSTM_TPS_TC[4], maxDownSTM_TPS_TC[4], ++ minRevDownSTM_TPS_TC[4], maxDelayDownSTM_TPS_TC[4]; ++ uchar maxErrorDownSTM_TPS_TC[4], minINPDownSTM_TPS_TC[4]; ++ short minUpSTM_TPS_TC[4], maxUpSTM_TPS_TC[4], ++ minRevUpSTM_TPS_TC[4], maxDelayUpSTM_TPS_TC[4]; ++ uchar maxErrorUpSTM_TPS_TC[4], minINPUpSTM_TPS_TC[4]; ++ ++ short maxDownPMS_TC_Latency[4], maxUpPMS_TC_Latency[4]; ++ short maxDownR_PMS_TC_Latency[4], maxDownD_PMS_TC_Latency[4]; ++ short maxUpR_PMS_TC_Latency[4], maxUpD_PMS_TC_Latency[4]; ++ ++ short minDownATM_TPS_TC[4], maxDownATM_TPS_TC[4], ++ minRevDownATM_TPS_TC[4], maxDelayDownATM_TPS_TC[4]; ++ uchar maxErrorDownATM_TPS_TC[4], minINPDownATM_TPS_TC[4]; ++ short minUpATM_TPS_TC[4], maxUpATM_TPS_TC[4], ++ minRevUpATM_TPS_TC[4], maxDelayUpATM_TPS_TC[4]; ++ uchar maxErrorUpATM_TPS_TC[4], minINPUpATM_TPS_TC[4]; ++ ++ short minDownPTM_TPS_TC[4], maxDownPTM_TPS_TC[4], ++ minRevDownPTM_TPS_TC[4], maxDelayDownPTM_TPS_TC[4]; ++ uchar maxErrorDownPTM_TPS_TC[4], minINPDownPTM_TPS_TC[4]; ++ short minUpPTM_TPS_TC[4], maxUpPTM_TPS_TC[4], ++ minRevUpPTM_TPS_TC[4], maxDelayUpPTM_TPS_TC[4]; ++ uchar maxErrorUpPTM_TPS_TC[4], minINPUpPTM_TPS_TC[4]; ++ ++ ushort subModePSDMasks; ++ } g992p3DataPumpCapabilities; ++ ++#define kG992p3p5MaxSpectBoundsUpSize 16 ++#define kG992p3p5MaxSpectBoundsDownSize 32 ++ ++typedef struct ++ { ++ Boolean rcvNTREnabled, shortInitEnabled, diagnosticsModeEnabled; ++ ++ char featureSpectrum, featureOverhead; ++ char featureTPS_TC[4], featurePMS_TC[4]; ++ ++ short rcvNOMPSDus, rcvMAXNOMPSDus, rcvMAXNOMATPus; ++ short usSubcarrierIndex[kG992p3p5MaxSpectBoundsUpSize], ++ usLog_tss[kG992p3p5MaxSpectBoundsUpSize]; ++ short numUsSubcarrier; ++ short rcvNOMPSDds, rcvMAXNOMPSDds, rcvMAXNOMATPds; ++ short dsSubcarrierIndex[kG992p3p5MaxSpectBoundsDownSize], ++ dsLog_tss[kG992p3p5MaxSpectBoundsDownSize]; ++ short numDsSubcarrier; ++ uchar sizeIDFT, fillIFFT; ++ uchar readsl2Upstream, readsl2Downstream; ++ uchar minDownOverheadDataRate, minUpOverheadDataRate; ++ uchar maxDownSTM_TPSTC, maxDownATM_TPSTC, maxDownPTM_TPSTC; ++ uchar maxUpSTM_TPSTC, maxUpATM_TPSTC, maxUpPTM_TPSTC; ++ ++ short minDownSTM_TPS_TC[4], maxDownSTM_TPS_TC[4], ++ minRevDownSTM_TPS_TC[4], maxDelayDownSTM_TPS_TC[4]; ++ uchar maxErrorDownSTM_TPS_TC[4], minINPDownSTM_TPS_TC[4]; ++ short minUpSTM_TPS_TC[4], maxUpSTM_TPS_TC[4], ++ minRevUpSTM_TPS_TC[4], maxDelayUpSTM_TPS_TC[4]; ++ uchar maxErrorUpSTM_TPS_TC[4], minINPUpSTM_TPS_TC[4]; ++ ++ short maxDownPMS_TC_Latency[4], maxUpPMS_TC_Latency[4]; ++ short maxDownR_PMS_TC_Latency[4], maxDownD_PMS_TC_Latency[4]; ++ short maxUpR_PMS_TC_Latency[4], maxUpD_PMS_TC_Latency[4]; ++ ++ short minDownATM_TPS_TC[4], maxDownATM_TPS_TC[4], ++ minRevDownATM_TPS_TC[4], maxDelayDownATM_TPS_TC[4]; ++ uchar maxErrorDownATM_TPS_TC[4], minINPDownATM_TPS_TC[4]; ++ short minUpATM_TPS_TC[4], maxUpATM_TPS_TC[4], ++ minRevUpATM_TPS_TC[4], maxDelayUpATM_TPS_TC[4]; ++ uchar maxErrorUpATM_TPS_TC[4], minINPUpATM_TPS_TC[4]; ++ ++ short minDownPTM_TPS_TC[4], maxDownPTM_TPS_TC[4], ++ minRevDownPTM_TPS_TC[4], maxDelayDownPTM_TPS_TC[4]; ++ uchar maxErrorDownPTM_TPS_TC[4], minINPDownPTM_TPS_TC[4]; ++ short minUpPTM_TPS_TC[4], maxUpPTM_TPS_TC[4], ++ minRevUpPTM_TPS_TC[4], maxDelayUpPTM_TPS_TC[4]; ++ uchar maxErrorUpPTM_TPS_TC[4], minINPUpPTM_TPS_TC[4]; ++ ++ ushort subModePSDMasks; ++ } g992p3PhyDataPumpCapabilities; ++#endif ++ ++typedef struct ++ { ++ dslModulationType modulations; ++ bitMap auxFeatures; ++ bitMap features; ++ bitMap demodCapabilities; ++ bitMap demodCapabilities2; ++ ushort noiseMargin; /* Q4 dB */ ++#ifdef G992_ATUC ++ short xmtRSf, xmtRS, xmtS, xmtD; ++ short rcvRSf, rcvRS, rcvS, rcvD; ++#endif ++#ifdef G992P1_ANNEX_A ++ bitMap subChannelInfo; ++ carrierInfo carrierInfoG992p1; ++#endif ++#ifdef G992P1_ANNEX_B ++ bitMap subChannelInfoAnnexB; ++ carrierInfo carrierInfoG992p1AnnexB; ++#endif ++#ifdef G992_ANNEXC ++ bitMap subChannelInfoAnnexC; ++ carrierInfo carrierInfoG992p1AnnexC; ++#endif ++#if defined(G992P1_ANNEX_I) ++ bitMap subChannelInfoAnnexI; ++ carrierInfo carrierInfoG992p1AnnexI; ++#endif ++#ifdef G992P5 ++ bitMap subChannelInfop5; ++ carrierInfo carrierInfoG992p5; ++#endif ++#if defined(G992P2) || (defined(G992P1_ANNEX_A) && defined(G992P1_ANNEX_A_USED_FOR_G992P2)) ++ carrierInfo carrierInfoG992p2; ++#endif ++ ushort maxDataRate; ++ uchar minDataRate; ++#ifdef G992P3 ++ g992p3DataPumpCapabilities *carrierInfoG992p3AnnexA; ++#endif ++#ifdef G992P5 ++ g992p3DataPumpCapabilities *carrierInfoG992p5AnnexA; ++#endif ++ } dslDataPumpCapabilities; ++ ++struct __dslCommandStruct; ++typedef Boolean (*dslCommandHandlerType) (void *gDslVars, struct __dslCommandStruct*); ++typedef struct __dslCommandStruct ++ { ++ dslCommandCode command; ++ union ++ { ++ long value; ++ Boolean flag; ++ struct ++ { ++ dslTestCmdType type; ++ union ++ { ++ struct ++ { ++ ulong xmtStartTone, xmtNumOfTones; ++ ulong rcvStartTone, rcvNumOfTones; ++ uchar *xmtMap, *rcvMap; ++ } toneSelectSpec; ++ struct ++ { ++ long extraPowerRequestQ4dB; ++ long numOfCarriers; ++ char *marginTweakTableQ4dB; ++ } marginTweakSpec; ++ } param; ++ } dslTestSpec; ++ struct ++ { ++ dslDirectionType direction; ++ dslDataPumpCapabilities capabilities; ++ } dslModeSpec; ++ struct ++ { ++ bitMap setup; ++ ulong eyeConstIndex1; ++ ulong eyeConstIndex2; ++ ulong logTime; ++ } dslDiagSpec; ++ struct ++ { ++ void *pBuf; ++ ulong bufSize; ++ } dslStatusBufSpec; ++ struct ++ { ++ ulong type; ++ void *afeParamPtr; ++ ulong afeParamSize; ++ void *imagePtr; ++ ulong imageSize; ++ } dslAfeTestSpec; ++ struct ++ { ++ dslLinkLayerType type; ++ bitMap setup; ++ union ++ { ++ struct ++ { ++ dataRateMap rxDataRate; ++ dataRateMap txDataRate; ++ long rtDelayQ4ms; ++ ulong rxBufNum; ++ ulong rxCellsInBuf; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslPhyInitType atmPhyInitPtr; ++ } atmLinkSpec; ++ struct ++ { ++ dslHeaderHandlerType rxHeaderHandlerPtr; ++ dslRxFrameBufferHandlerType rxDataHandlerPtr; ++ dslTxFrameBufferHandlerType txHandlerPtr; ++ } atmPhyLinkSpec; ++#ifdef DSL_PACKET ++ struct ++ { ++ ulong rxBufNum; ++ ulong rxBufSize; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslPacketPhyInitType dslPhyInitPtr; ++ } dslPacketLinkSpec; ++ dslPacketPhyFunctions dslPacketPhyLinkSpec; ++#endif ++ struct ++ { ++ txDataHandlerType txDataHandlerPtr; ++ rxDataHandlerType rxDataHandlerPtr; ++ } nullLinkSpec; ++ } param; ++ } dslLinkLayerSpec; ++#ifdef G997_1 ++#ifdef G997_1_FRAMER ++ struct ++ { ++ bitMap setup; ++ ulong rxBufNum; ++ ulong rxBufSize; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ } dslG997Cmd; ++#endif ++ struct ++ { ++ long msgId; ++ long msgType; ++ char *dataPtr; ++ } dslClearEocMsg; ++#endif ++ struct ++ { ++ ulong code; ++ uchar *valuePtr; ++ ulong length; ++ } dslDataRegister; ++ union ++ { ++ dslStatusHandlerType statusHandlerPtr; ++ dslCommandHandlerType commandHandlerPtr; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++#if defined(DEBUG_DATA_HANDLER) ++ debugDataHandlerType debugDataHandlerPtr; ++#endif ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslDriverCallbackType driverCallback; ++ } handlerSpec; ++#if !defined(CHIP_SRC) || defined(DSL_FRAME_FUNCTIONS) ++ dslFrameFunctions DslFunctions; ++#endif ++ dslOLRMessage dslOLRRequest; ++ dslPwrMessage dslPwrMsg; ++ } param; ++ } dslCommandStruct; ++ ++ ++ ++ ++typedef struct ++ { ++ dslCommandHandlerType linkCommandHandlerPtr; ++ timerHandlerType linkTimerHandlerPtr; ++ dslLinkCloseHandlerType linkCloseHandlerPtr; ++ ++ dslFrameHandlerType linkSendHandlerPtr; ++ dslFrameHandlerType linkReturnHandlerPtr; ++ ++ dslVcAllocateHandlerType linkVcAllocateHandlerPtr; ++ dslVcFreeHandlerType linkVcFreeHandlerPtr; ++ dslVcActivateHandlerType linkVcActivateHandlerPtr; ++ dslVcDeactivateHandlerType linkVcDeactivateHandlerPtr; ++ dslVcConfigureHandlerType linkVcConfigureHandlerPtr; ++ ++ dslLinkVc2IdHandlerType linkVc2IdHandlerPtr; ++ dslLinkVcId2VcHandlerType linkVcId2VcHandlerPtr; ++ dslGetFramePoolHandlerType linkGetFramePoolHandlerPtr; ++ ++#ifndef ADSLCORE_ONLY ++ dslHeaderHandlerType linkRxCellHeaderHandlerPtr; ++ dslRxFrameBufferHandlerType linkRxCellDataHandlerPtr; ++ dslTxFrameBufferHandlerType linkTxCellHandlerPtr; ++#endif ++ ++ txDataHandlerType linkTxDataHandlerPtr; ++ rxDataHandlerType linkRxDataHandlerPtr; ++ } linkLayerFunctions; ++ ++#ifndef ADSLCORE_ONLY ++ ++#define LinkLayerAssignFunctions( var, name_prefix ) do { \ ++ (var).linkCommandHandlerPtr = name_prefix##CommandHandler; \ ++ (var).linkTimerHandlerPtr = name_prefix##TimerHandler; \ ++ (var).linkCloseHandlerPtr = name_prefix##CloseHandler; \ ++ \ ++ (var).linkSendHandlerPtr = name_prefix##SendFrameHandler; \ ++ (var).linkReturnHandlerPtr = name_prefix##ReturnFrameHandler; \ ++ \ ++ (var).linkVcAllocateHandlerPtr = name_prefix##VcAllocateHandler; \ ++ (var).linkVcFreeHandlerPtr = name_prefix##VcFreeHandler; \ ++ (var).linkVcActivateHandlerPtr = name_prefix##VcActivateHandler; \ ++ (var).linkVcDeactivateHandlerPtr = name_prefix##VcDeactivateHandler; \ ++ (var).linkVcConfigureHandlerPtr = name_prefix##VcConfigureHandler; \ ++ \ ++ (var).linkVc2IdHandlerPtr = name_prefix##Vc2IdHandler; \ ++ (var).linkVcId2VcHandlerPtr = name_prefix##VcId2VcHandler; \ ++ (var).linkGetFramePoolHandlerPtr = name_prefix##GetFramePoolHandler; \ ++ \ ++ (var).linkRxCellHeaderHandlerPtr = name_prefix##RxCellHeaderHandler; \ ++ (var).linkRxCellDataHandlerPtr = name_prefix##RxCellDataHandler; \ ++ (var).linkTxCellHandlerPtr = name_prefix##TxCellHandler; \ ++ \ ++ (var).linkTxDataHandlerPtr = name_prefix##TxDataHandler; \ ++ (var).linkRxDataHandlerPtr = name_prefix##RxDataHandler; \ ++} while (0) ++ ++#else ++ ++#define LinkLayerAssignFunctions( var, name_prefix ) do { \ ++ (var).linkCommandHandlerPtr = name_prefix##CommandHandler; \ ++ (var).linkTimerHandlerPtr = name_prefix##TimerHandler; \ ++ (var).linkCloseHandlerPtr = name_prefix##CloseHandler; \ ++ \ ++ (var).linkSendHandlerPtr = name_prefix##SendFrameHandler; \ ++ (var).linkReturnHandlerPtr = name_prefix##ReturnFrameHandler; \ ++ \ ++ (var).linkVcAllocateHandlerPtr = name_prefix##VcAllocateHandler; \ ++ (var).linkVcFreeHandlerPtr = name_prefix##VcFreeHandler; \ ++ (var).linkVcActivateHandlerPtr = name_prefix##VcActivateHandler; \ ++ (var).linkVcDeactivateHandlerPtr = name_prefix##VcDeactivateHandler; \ ++ (var).linkVcConfigureHandlerPtr = name_prefix##VcConfigureHandler; \ ++ \ ++ (var).linkVc2IdHandlerPtr = name_prefix##Vc2IdHandler; \ ++ (var).linkVcId2VcHandlerPtr = name_prefix##VcId2VcHandler; \ ++ (var).linkGetFramePoolHandlerPtr = name_prefix##GetFramePoolHandler; \ ++ \ ++ (var).linkTxDataHandlerPtr = name_prefix##TxDataHandler; \ ++ (var).linkRxDataHandlerPtr = name_prefix##RxDataHandler; \ ++} while (0) ++ ++#endif ++ ++typedef struct ++ { ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ } upperLayerFunctions; ++ ++ ++/* ++ * Debug data ++ */ ++#define kDslFirstDebugData 1000 ++#define kDslXmtPerSymTimeCompData (kDslFirstDebugData + 0) ++#define kDslRcvPerSymTimeCompData (kDslFirstDebugData + 1) ++#define kDslXmtAccTimeCompData (kDslFirstDebugData + 2) ++#define kDslRcvAccTimeCompData (kDslFirstDebugData + 3) ++#define kDslRcvPilotToneData (kDslFirstDebugData + 4) ++#define kDslTEQCoefData (kDslFirstDebugData + 5) ++#define kDslTEQInputData (kDslFirstDebugData + 6) ++#define kDslTEQOutputData (kDslFirstDebugData + 7) ++#define kDslRcvFFTInputData (kDslFirstDebugData + 8) ++#define kDslRcvFFTOutputData (kDslFirstDebugData + 9) ++#define kDslRcvCarrierSNRData (kDslFirstDebugData + 10) ++#define kDslXmtToneOrderingData (kDslFirstDebugData + 11) ++#define kDslRcvToneOrderingData (kDslFirstDebugData + 12) ++#define kDslXmtGainData (kDslFirstDebugData + 13) ++#define kDslRcvGainData (kDslFirstDebugData + 14) ++#define kDslMseData (kDslFirstDebugData + 15) ++#define kDslFEQOutErrData (kDslFirstDebugData + 16) ++#define kDslFEQCoefData (kDslFirstDebugData + 17) ++#define kDslShowtimeMseData (kDslFirstDebugData + 18) ++#define kDslTimeEstimationHWPhaseTweak (kDslFirstDebugData + 24) ++#define kDslSlicerInput (kDslFirstDebugData + 40) ++#define kDslXmtConstellations (kDslFirstDebugData + 41) ++#define kDslSnr1ShiftData (kDslFirstDebugData + 50) ++#define kDslSnr1InputData (kDslFirstDebugData + 51) ++#define kDslSnr1ReverbAvgData (kDslFirstDebugData + 52) ++#define kDslAnnexCFextSnrData (kDslFirstDebugData + 53) ++#define kDslAnnexCNextSnrData (kDslFirstDebugData + 54) ++#define kG994p1OutputXmtSample (kDslFirstDebugData + 100) ++#define kG994p1OutputMicroBit (kDslFirstDebugData + 101) ++#define kG994p1OutputBit (kDslFirstDebugData + 102) ++#define kG994p1OutputTimer (kDslFirstDebugData + 103) ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.1 Defininitive constants */ ++/****************************************************************************/ ++ ++/* dslDirectionType */ ++ ++#define kATU_C 0 ++#define kATU_R 1 ++ ++/* ATM setup maps */ ++ ++#define kAtmCallMgrEnabled 0x00000001 /* Bit 0 */ ++#define kAtmAAL1FecEnabledMask 0x00000006 /* Bit 1 */ ++#define kAtmAAL1HiDelayFecEnabled 0x00000002 /* Bit 2 */ ++#define kAtmAAL1LoDelayFecEnabled 0x00000004 /* Bit 3 */ ++ ++/* dslLinkLayerType */ ++ ++#define kNoDataLink 0 ++#define kAtmLink 0x00000001 ++#define kAtmPhyLink 0x00000002 ++#define kDslPacketLink 0x00000003 ++#define kDslPacketPhyLink 0x00000004 ++ ++/* dslModulationType */ ++#define kNoCommonModulation 0x00000000 ++#define kG994p1 0x00000020 /* G.994.1 or G.hs */ ++#define kT1p413 0x00000040 /* T1.413 handshaking */ ++#define kG992p1AnnexA 0x00000001 /* G.992.1 or G.dmt Annex A */ ++#define kG992p1AnnexB 0x00000002 /* G.992.1 or G.dmt Annex B */ ++#define kG992p1AnnexC 0x00000004 /* G.992.1 or G.dmt Annex C */ ++#define kG992p2AnnexAB 0x00000008 /* G.992.2 or G.lite Annex A/B */ ++#define kG992p2AnnexC 0x00000010 /* G.992.2 or G.lite Annex C */ ++#define kG992p3AnnexA 0x00000100 /* G.992.3 or G.DMTbis Annex A */ ++#define kG992p3AnnexB 0x00000200 /* G.992.3 or G.DMTbis Annex A */ ++#define kG992p1AnnexI 0x00000400 /* G.992.1 Annex I */ ++#define kG992p5AnnexA 0x00010000 /* G.992.5 Annex A */ ++#define kG992p5AnnexB 0x00020000 /* G.992.5 Annex B */ ++#define kG992p5AnnexI 0x00040000 /* G.992.5 Annex I */ ++#define kG992p3AnnexM 0x00080000 /* G.992.3 Annex M */ ++#define kG992p5AnnexM 0x01000000 /* G.992.5 Annex M */ ++ ++/* demodCapabilities bitmap */ ++#define kEchoCancellorEnabled 0x00000001 ++#define kSoftwareTimeErrorDetectionEnabled 0x00000002 ++#define kSoftwareTimeTrackingEnabled 0x00000004 ++#define kDslTrellisEnabled 0x00000008 ++#define kHardwareTimeTrackingEnabled 0x00000010 ++#define kHardwareAGCEnabled 0x00000020 ++#define kDigitalEchoCancellorEnabled 0x00000040 ++#define kReedSolomonCodingEnabled 0x00000080 ++#define kAnalogEchoCancellorEnabled 0x00000100 ++#define kT1p413Issue1SingleByteSymMode 0x00000200 ++#define kDslAturXmtPowerCutbackEnabled 0x00000400 ++#ifdef G992_ANNEXC_LONG_REACH ++#define kDslAnnexCPilot48 0x00000800 ++#define kDslAnnexCReverb33_63 0x00001000 ++#endif ++#ifdef G992_ANNEXC ++#define kDslCentilliumCRCWorkAroundEnabled 0x00002000 ++#else ++#define kDslEnableRoundUpDSLoopAttn 0x00002000 ++#endif ++#define kDslBitSwapEnabled 0x00004000 ++#define kDslADILowRateOptionFixDisabled 0x00008000 ++#define kDslAnymediaGSPNCrcFixEnabled 0x00010000 ++#define kDslMultiModesPreferT1p413 0x00020000 ++#define kDslT1p413UseRAck1Only 0x00040000 ++#define kDslUE9000ADI918FECFixEnabled 0x00080000 ++#define kDslG994AnnexAMultimodeEnabled 0x00100000 ++#define kDslATUCXmtPowerMinimizeEnabled 0x00200000 ++#define kDropOnDataErrorsDisabled 0x00400000 ++#define kDslSRAEnabled 0x00800000 ++ ++#define kDslT1p413HigherToneLevelNeeded 0x01000000 ++#define kDslT1p413SubsampleAlignmentEnabled 0x02000000 ++#define kDslT1p413DisableUpstream2xIfftMode 0x04000000 ++ ++/* test mode related demodCapabilities, for internal use only */ ++#define kDslTestDemodCapMask 0xF8000000 ++#define kDslSendReverbModeEnabled 0x10000000 ++#define kDslSendMedleyModeEnabled 0x20000000 ++#define kDslAutoRetrainDisabled 0x40000000 ++#define kDslPllWorkaroundEnabled 0x80000000 ++#define kDslAfeLoopbackModeEnabled 0x08000000 ++ ++/* demodCapabilities bitmap2 */ ++ ++#define kDslAnnexCProfile1 0x00000001 ++#define kDslAnnexCProfile2 0x00000002 ++#define kDslAnnexCProfile3 0x00000004 ++#define kDslAnnexCProfile4 0x00000008 ++#define kDslAnnexCProfile5 0x00000010 ++#define kDslAnnexCProfile6 0x00000020 ++#define kDslAnnexCPilot64 0x00000040 ++#define kDslAnnexCPilot48 0x00000080 ++#define kDslAnnexCPilot32 0x00000100 ++#define kDslAnnexCPilot16 0x00000200 ++#define kDslAnnexCA48B48 0x00000400 ++#define kDslAnnexCA24B24 0x00000800 ++#define kDslAnnexCReverb33_63 0x00001000 ++#define kDslAnnexCCReverb6_31 0x00002000 ++ ++#define kDslAnnexIShapedSSVI 0x00004000 ++#define kDslAnnexIFlatSSVI 0x00008000 ++ ++#define kDslAnnexIPilot64 0x00010000 ++#define kDslAnnexIA48B48 0x00020000 ++#define kDslAnnexIPilot128 0x00040000 ++#define kDslAnnexIPilot96 0x00080000 ++ ++/* Features bitmap */ ++#define kG992p2RACK1 0x00000001 ++#define kG992p2RACK2 0x00000002 ++#define kG992p2DBM 0x00000004 ++#define kG992p2FastRetrain 0x00000008 ++#define kG992p2RS16 0x00000010 ++#define kG992p2ClearEOCOAM 0x00000020 ++#define kG992NTREnabled 0x00000040 ++#define kG992p2EraseAllStoredProfiles 0x00000080 ++#define kG992p2FeaturesNPar2Mask 0x0000003B ++#define kG992p2FeaturesNPar2Shift 0 ++ ++#define kG992p1RACK1 0x00000100 ++#define kG992p1RACK2 0x00000200 ++#define kG992p1STM 0x00000800 ++#define kG992p1ATM 0x00001000 ++#define kG992p1ClearEOCOAM 0x00002000 ++#define kG992p1FeaturesNPar2Mask 0x00003B00 ++#define kG992p1FeaturesNPar2Shift 8 ++#define kG992p1DualLatencyUpstream 0x00004000 ++#define kG992p1DualLatencyDownstream 0x00008000 ++#define kG992p1HigherBitRates 0x40000000 ++ ++#if defined(G992P1_ANNEX_I) ++#define kG992p1HigherBitRates1over3 0x80000000 ++#define kG992p1AnnexIShapedSSVI 0x00000001 ++#define kG992p1AnnexIFlatSSVI 0x00000002 ++#define kG992p1AnnexIPilotFlag 0x00000008 ++#define kG992p1AnnexIPilot64 0x00000001 ++#define kG992p1AnnexIPilot128 0x00000004 ++#define kG992p1AnnexIPilot96 0x00000008 ++#define kG992p1AnnexIPilotA48B48 0x00000010 ++#endif ++ ++#define kG992p1AnnexBRACK1 0x00010000 ++#define kG992p1AnnexBRACK2 0x00020000 ++#define kG992p1AnnexBUpstreamTones1to32 0x00040000 ++#define kG992p1AnnexBSTM 0x00080000 ++#define kG992p1AnnexBATM 0x00100000 ++#define kG992p1AnnexBClearEOCOAM 0x00200000 ++#define kG992p1AnnexBFeaturesNPar2Mask 0x003F0000 ++#define kG992p1AnnexBFeaturesNPar2Shift 16 ++ ++#define kG992p1AnnexCRACK1 0x01000000 ++#define kG992p1AnnexCRACK2 0x02000000 ++#define kG992p1AnnexCDBM 0x04000000 ++#define kG992p1AnnexCSTM 0x08000000 ++#define kG992p1AnnexCATM 0x10000000 ++#define kG992p1AnnexCClearEOCOAM 0x20000000 ++#define kG992p1AnnexCFeaturesNPar2Mask 0x3F000000 ++#define kG992p1AnnexCFeaturesNPar2Shift 24 ++ ++#define kG992p1HigherBitRates1over3 0x80000000 ++ ++/* auxFeatures bitmap */ ++#define kG994p1PreferToExchangeCaps 0x00000001 ++#define kG994p1PreferToDecideMode 0x00000002 ++#define kG994p1PreferToMPMode 0x00000004 ++#define kAfePwmSyncClockShift 3 ++#define kAfePwmSyncClockMask (0xF << kAfePwmSyncClockShift) ++#define AfePwmSyncClockEnabled(val) (((val) & kAfePwmSyncClockMask) != 0) ++#define AfePwmGetSyncClockFreq(val) ((((val) & kAfePwmSyncClockMask) >> kAfePwmSyncClockShift) - 1) ++#define AfePwmSetSyncClockFreq(val,freq) ((val) |= ((((freq)+1) << kAfePwmSyncClockShift) & kAfePwmSyncClockMask)) ++ ++/* SubChannel Info bitMap for G992p1 */ ++#define kSubChannelASODownstream 0x00000001 ++#define kSubChannelAS1Downstream 0x00000002 ++#define kSubChannelAS2Downstream 0x00000004 ++#define kSubChannelAS3Downstream 0x00000008 ++#define kSubChannelLSODownstream 0x00000010 ++#define kSubChannelLS1Downstream 0x00000020 ++#define kSubChannelLS2Downstream 0x00000040 ++#define kSubChannelLS0Upstream 0x00000080 ++#define kSubChannelLS1Upstream 0x00000100 ++#define kSubChannelLS2Upstream 0x00000200 ++#define kSubChannelInfoOctet1Mask 0x0000001F ++#define kSubChannelInfoOctet2Mask 0x000003E0 ++#define kSubChannelInfoOctet1Shift 0 ++#define kSubChannelInfoOctet2Shift 5 ++ ++/****************************************************************************/ ++/* 3. Interface functions. */ ++/* */ ++/****************************************************************************/ ++ ++#ifdef G992P1 ++#if defined(G992P1_ANNEX_I2X) || defined(G992P5) ++/* lke */ ++#define kDslSamplingFreq 4416000 ++#define kDslMaxFFTSize 1024 ++#define kDslMaxFFTSizeShift 10 ++#elif defined(G992P1_ANNEX_I4X) ++#define kDslSamplingFreq 8832000 ++#define kDslMaxFFTSize 2048 ++#define kDslMaxFFTSizeShift 11 ++#elif defined(G992P1_ANNEX_I8X) ++#define kDslSamplingFreq 17664000 ++#define kDslMaxFFTSize 4096 ++#define kDslMaxFFTSizeShift 12 ++#else ++#define kDslSamplingFreq 2208000 ++#define kDslMaxFFTSize 512 ++#define kDslMaxFFTSizeShift 9 ++#endif ++#else ++#define kDslSamplingFreq 1104000 ++#define kDslMaxFFTSize 256 ++#define kDslMaxFFTSizeShift 8 ++#endif ++ ++#if defined(G992_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ) ++#define kDslATURUpstreamSamplingFreq 276000 ++#define kDslATURFFTSizeShiftUpstream 6 ++#elif defined(G992_ATUR_UPSTREAM_SAMPLING_FREQ_552KHZ) ++#define kDslATURUpstreamSamplingFreq 552000 ++#define kDslATURFFTSizeShiftUpstream 7 ++#else ++#define kDslATURUpstreamSamplingFreq kDslSamplingFreq ++#define kDslATURFFTSizeShiftUpstream kDslMaxFFTSizeShift ++#endif ++ ++#if defined(G992_ATUC_UPSTREAM_SAMPLING_FREQ_276KHZ) ++#define kDslATUCUpstreamSamplingFreq 276000 ++#define kDslATUCFFTSizeShiftUpstream 6 ++#elif defined(G992_ATUC_UPSTREAM_SAMPLING_FREQ_552KHZ) ++#define kDslATUCUpstreamSamplingFreq 552000 ++#define kDslATUCFFTSizeShiftUpstream 7 ++#else ++#define kDslATUCUpstreamSamplingFreq kDslSamplingFreq ++#define kDslATUCFFTSizeShiftUpstream kDslMaxFFTSizeShift ++#endif ++ ++#define kDslMaxSamplesPerSymbol (kDslMaxFFTSize+kDslMaxFFTSize/16) ++ ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++#define kDslMaxTEQLength 32 ++#else ++#define kDslMaxTEQLength 16 ++#endif ++ ++#define kDslMaxSymbolBlockSize 1 ++#define kDslMaxSampleBlockSize (kDslMaxSymbolBlockSize*kDslMaxSamplesPerSymbol) ++ ++#ifdef G992_ANNEXC ++#define kG992AnnexCXmtToRcvPathDelay 512 /* In samples at kDslSamplingFreq */ ++#endif ++ ++/*** For compatibility with existing test codes ***/ ++#if !defined(TARG_OS_RTEMS) ++typedef dslStatusCode modemStatusCode; ++typedef dslStatusStruct modemStatusStruct; ++typedef dslStatusHandlerType statusHandlerType; ++typedef dslCommandCode modemCommandCode; ++typedef dslCommandStruct modemCommandStruct; ++typedef dslCommandHandlerType commandHandlerType; ++#endif ++ ++extern void SM_DECL SoftDslSetRefData (void *gDslVars, ulong refData); ++extern ulong SM_DECL SoftDslGetRefData (void *gDslVars); ++extern int SM_DECL SoftDslGetMemorySize(void); ++extern void SM_DECL SoftDslInit (void *gDslVars); ++extern void SM_DECL SoftDslReset (void *gDslVars); ++extern void SM_DECL SoftDslLineHandler (void *gDslVars, int rxNSamps, int txNSamps, short *rcvPtr, short *xmtPtr) FAST_TEXT; ++extern Boolean SM_DECL SoftDslCommandHandler (void *gDslVars, dslCommandStruct *cmdPtr); ++ ++/* swap Lmem functions */ ++#if defined(bcm47xx) && defined(SWAP_LMEM) ++extern int SoftDslSwapLmem(void *gDslVars, int sectionN, int imageN); ++extern void init_SoftDslSwapLmem(void); ++#endif ++ ++/* SoftDsl time functions */ ++ ++extern ulong SM_DECL SoftDslGetTime(void *gDslVars); ++#define __SoftDslGetTime(gv) gDslGlobalVarPtr->execTime ++ ++extern void SM_DECL SoftDslTimer(void *gDslVars, ulong timeMs); ++ ++/* SoftDsl IO functions */ ++ ++extern void SM_DECL SoftDslClose (void *gDslVars); ++extern int SM_DECL SoftDslSendFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++extern int SM_DECL SoftDslReturnFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++ ++/* SoftDsl connection functions */ ++ ++extern void* SM_DECL SoftDslVcAllocate(void *gDslVars, dslVcParams *pVcParams); ++extern void SM_DECL SoftDslVcFree(void *gDslVars, void *pVc); ++extern Boolean SM_DECL SoftDslVcActivate(void *gDslVars, void *pVc); ++extern void SM_DECL SoftDslVcDeactivate(void *gDslVars, void *pVc); ++extern Boolean SM_DECL SoftDslVcConfigure(void *gDslVars, void *pVc, ulong mid, dslVcParams *pVcParams); ++ ++/* Special functions for LOG support */ ++ ++extern ulong SM_DECL SoftDslVc2Id(void *gDslVars, void *pVc); ++extern void* SM_DECL SoftDslVcId2Vc(void *gDslVars, ulong vcId); ++extern void* SM_DECL SoftDslGetFramePool(void *gDslVars); ++ ++/* Functions for host mode execution */ ++ ++extern void* SM_DECL SoftDslRxCellHeaderHandler (void *gDslVars, ulong hdr, uchar hdrHec); ++extern void* SM_DECL SoftDslRxCellDataHandler (void *gDslVars, int, void*); ++extern void* SM_DECL SoftDslTxCellHandler (void *gDslVars, int*, void*); ++extern Boolean SM_DECL SoftDslPhyCommandHandler (void *gDslVars, dslCommandStruct *cmdPtr); ++ ++/* Functions getting OEM parameters including G994 non standard info management */ ++ ++extern char* SM_DECL SoftDslGetTrainingVendorIDString(void *gDslVars); ++extern char* SM_DECL SoftDslGetVendorIDString(void *gDslVars); ++extern char* SM_DECL SoftDslGetSerialNumberString(void *gDslVars); ++extern char* SM_DECL SoftDslGetRevString(void *gDslVars); ++extern int SM_DECL SoftDslRevStringSize(void *gDslVars); ++extern int SM_DECL SoftDslSerNumStringSize(void *gDslVars); ++ ++extern void* SM_DECL SoftDslGetG994p1RcvNonStdInfo(void *gDslVars, ulong *pLen); ++extern void* SM_DECL SoftDslGetG994p1XmtNonStdInfo(void *gDslVars, ulong *pLen); ++ ++#ifdef G997_1_FRAMER ++ ++/* G997 functions */ ++ ++extern int SM_DECL SoftDslG997SendFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++extern int SM_DECL SoftDslG997ReturnFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++ ++#endif ++ ++#ifdef ADSL_MIB ++extern void * SM_DECL SoftDslMibGetData (void *gDslVars, int dataId, void *pAdslMibData); ++#endif ++ ++#define SoftDsl SoftDslLineHandler ++#define kSoftDslMaxMemorySize (32768*16384) ++ ++/* ++ * Internal functions ++ */ ++ ++extern void SoftDslStatusHandler (void *gDslVars, dslStatusStruct *status) FAST_TEXT; ++extern void SoftDslInternalStatusHandler (void *gDslVars, dslStatusStruct *status); ++ ++/* ++ * DSL OS functions ++ */ ++ ++#ifdef DSL_OS ++ ++#define SoftDslIsBgAvailable(gDslVars) (DSLOS_THREAD_INACTIVE == DslOsGetThreadState(&(gDslGlobalVarPtr->tcbDslBg))) ++#define SoftDslGetBgThread(gDslVars) \ ++ ((DSLOS_THREAD_INACTIVE != DslOsGetThreadState(&(gDslGlobalVarPtr->tcbDslBg))) ? &gDslGlobalVarPtr->tcbDslBg : NULL) ++#define SoftDslBgStart(gDslVars, pFunc) \ ++ DslOsCreateThread(&gDslGlobalVarPtr->tcbDslBg, DSLOS_PRIO_HIGHEST - 10, pFunc, gDslVars, \ ++ WB_ADDR(gDslGlobalVarPtr->bgStack), sizeof(gDslGlobalVarPtr->bgStack)) ++#define SoftDslBgStop(gDslVars) DslOsDeleteThread(&gDslGlobalVarPtr->tcbDslBg) ++ ++#define SoftDslEnterCritical() DslOsEnterCritical() ++#define SoftDslLeaveCritical(id) DslOsLeaveCritical(id) ++ ++#else ++ ++#define SoftDslIsBgAvailable(gDslVars) 1 ++#define SoftDslGetBgThread(gDslVars) 1 ++#define SoftDslBgStart(gDslVars, pFunc) (*pFunc)(gDslVars) ++#define SoftDslBgStop(gDslVars) ++ ++#define SoftDslEnterCritical() 0 ++#define SoftDslLeaveCritical(id) ++ ++#endif ++ ++/* ++ * DSL frames and native frame functions ++ */ ++ ++DslFrameDeclareFunctions (DslFrameNative) ++ ++/* ++ * These functions are for testing purpose, they are defined outside. ++ */ ++#ifdef STACK_SIZE_REQUIREMENT_TEST ++extern void StackSizeTestInitializeStackBeforeEntry(void); ++extern void StackSizeTestCheckStackAfterExit(void); ++extern void StackSizeTestBackupStack(void); ++extern void StackSizeTestRestoreStack(void); ++#endif /* STACK_SIZE_REQUIREMENT_TEST */ ++ ++#ifdef NEC_NSIF_WORKAROUND ++#define SoftDslGetG994NsStatus(gDslVars) (gDslGlobalVarPtr->G994NsStatus) ++#define SoftDslGetG994NsFailCounter(gDslVars) (gDslGlobalVarPtr->G994NsFailCounter) ++#endif ++ ++#endif /* SoftDslHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModem.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModem.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModem.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModem.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,3128 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftModem.h ++ * ++ * ++ * Description: ++ * This file contains the exported interface for SoftModem.c ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.16 $ ++ * ++ * $Id: SoftModem.h,v 1.16 2004/04/14 21:16:51 ilyas Exp $ ++ * ++ * $Log: SoftModem.h,v $ ++ * Revision 1.16 2004/04/14 21:16:51 ilyas ++ * Merged with the latest changes in ADSL driver ++ * ++ * Revision 1.15 2004/04/13 00:56:10 ilyas ++ * Merged the latest ADSL driver changes for RTEMS ++ * ++ * Revision 1.14 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.13 2003/02/22 05:07:11 ilyas ++ * Added VendorID for T1.413 mode ++ * ++ * Revision 1.12 2002/10/03 19:34:24 ilyas ++ * Added size for EOC serial number register ++ * ++ * Revision 1.11 2002/09/07 01:37:22 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.10 2001/12/13 02:25:34 ilyas ++ * Added definitions for G997 ++ * ++ * Revision 1.9 2001/11/30 05:56:34 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.7.2.2 2001/11/27 02:32:05 liang ++ * Combine vendor ID, serial #, and version number into SoftModemVersionNumber.c. ++ * ++ * Revision 1.7.2.1 2001/10/03 01:44:10 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.8 2001/09/21 19:19:01 ilyas ++ * Minor fixes for VxWorks build ++ * ++ * Revision 1.7 2000/07/17 21:08:16 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.6 2000/05/03 04:09:11 ilyas ++ * Added ID for ATM log data ++ * ++ * Revision 1.5 2000/04/01 01:07:44 liang ++ * Changed file names and some module names. ++ * ++ * Revision 1.4 2000/03/02 20:18:12 ilyas ++ * Added test status code for ATM VC finished ++ * ++ * Revision 1.3 1999/08/05 20:02:11 liang ++ * Merged with the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.2 1999/01/27 22:19:08 liang ++ * Merge with SoftModem_3_1_02. ++ * Include SoftDsl.h conditionlly so that the test utilities from SoftModem ++ * can be used without major change. It can be merged easily to SoftModem. ++ * ++ * Revision 1.170 1998/12/22 00:52:52 liang ++ * Added auxFeatures bit kV8HoldANSamUntilDetCI. When it is set, ANSam won't be ++ * sent until CI is detected (normally ANSam will be sent after 200ms). This is ++ * useful in V34 half duplex fax mode. ++ * ++ * Revision 1.169 1998/12/19 04:46:52 mwg ++ * Added bits for fax/data calling tones ++ * ++ * Revision 1.168 1998/12/17 02:46:10 scott ++ * Removed overlay-related commands/statuses and added ++ * kSetTrainingDelayReductionCmd ++ * ++ * Revision 1.167 1998/12/12 03:17:42 scott ++ * Added overlay commands and statuses ++ * ++ * Revision 1.166 1998/12/02 05:34:23 mwg ++ * Fixed a problem with bong tone detection ++ * ++ * Revision 1.165 1998/11/26 00:22:44 yura ++ * Added two more log data types: modulatorInputData & modulatorOutputData ++ * ++ * Revision 1.164 1998/11/19 03:08:04 mwg ++ * Added kSetCallProgressParamsCmd ++ * ++ * Revision 1.163 1998/11/18 23:00:03 liang ++ * Added a separate command kLoopbackTestAutoRespEnableCmd to enable or disable ++ * the loopback test auto respond feature when the modem is already on-line. ++ * ++ * Revision 1.162 1998/11/13 20:50:21 scott ++ * SoftModemInternalStatusHandler is now SM_DECL as well ++ * ++ * Revision 1.161 1998/11/13 20:42:25 scott ++ * Added SM_DECL type to entrypoint functions ++ * ++ * Revision 1.160 1998/11/13 03:02:54 scott ++ * Added SoftModemTimer prototype. ++ * Also include V.8bis types if AT_COMMANDS_V8BIS is defined. ++ * ++ * Revision 1.159 1998/11/12 01:22:46 scott ++ * Increased number of AT registers to 46 ++ * ++ * Revision 1.158 1998/11/05 22:35:18 yura ++ * Added two more S-registers ++ * ++ * Revision 1.157 1998/11/05 03:09:54 mwg ++ * Added kLapmRetryFailed to the list of LAPM errors ++ * ++ * Revision 1.156 1998/11/05 00:13:20 liang ++ * Add new connectionInfo status kLoopbackSelfTestNewErrs to report ++ * new bit errors whenever it happens. ++ * ++ * Revision 1.155 1998/11/04 07:11:33 mwg ++ * Moved declaration for SoftModemATPrintf() to SoftModem.h ++ * ++ * Revision 1.154 1998/10/29 07:24:49 mwg ++ * *** empty log message *** ++ * ++ * Revision 1.153 1998/10/15 02:09:37 luisgm ++ * added separate data rate mask for Flex to dataPumpCapabilities structure ++ * ++ * Revision 1.152 1998/10/14 00:12:15 scott ++ * Added kMnpOOBFrameCmd and command.frameSpec ++ * ++ * Revision 1.151 1998/10/09 02:19:22 luisgm ++ * added FlexV8bisStruct member to dataPumpCapabilities struc to store flex v8bis info, added define for kFlexSkipV8bis ++ * ++ * Revision 1.150 1998/10/06 19:36:33 mwg ++ * Limited 56K rates to 53K ++ * ++ * Revision 1.149 1998/10/03 03:43:38 ilyas ++ * Added status codes for Audio ++ * ++ * Revision 1.148 1998/10/01 02:03:17 mwg ++ * Added external pulse dialer option ++ * ++ * Revision 1.147 1998/09/30 01:44:26 mwg ++ * Added new functions SoftModemGetWriteBufferSize() & SoftModemGetReadBufferSize() ++ * ++ * Revision 1.146 1998/09/22 03:44:38 scott ++ * Added ALWAYS_LONG_ALIGN() macro ++ * ++ * Revision 1.145 1998/09/21 21:49:22 scott ++ * Added logDataCodes for mnpDecoder(Input/Output)Data ++ * ++ * Revision 1.144 1998/08/31 22:57:21 luisgm ++ * added constants for Flex data rates + kFlexEventTRN2AFinished ++ * ++ * Revision 1.143 1998/08/18 05:09:53 mwg ++ * Increased AT command buffer size to 128 ++ * ++ * Revision 1.142 1998/08/18 03:45:54 ilyas ++ * Integrated Audio into V70 test ++ * ++ * Revision 1.141 1998/08/14 17:46:04 ilyas ++ * Integrated Audio and G729a ++ * ++ * Revision 1.140 1998/08/10 21:42:19 mwg ++ * Added space and mark parity ++ * ++ * Revision 1.139 1998/08/08 03:39:33 scott ++ * Moved the C6xDefs and PentiumDefs includes before the internal function ++ * prototypes (to permit their redefinitions) ++ * ++ * Revision 1.138 1998/08/07 20:37:27 yura ++ * Added new S-register for &T commands ++ * ++ * Revision 1.137 1998/08/01 05:22:09 mwg ++ * Implemented split memory model ++ * ++ * Revision 1.136 1998/07/22 02:12:22 liang ++ * Added self test mode for loopback test. ++ * ++ * Revision 1.135 1998/07/21 01:19:03 liang ++ * Changed loopback test command parameter interface to use regular modeSpec. ++ * ++ * Revision 1.134 1998/07/18 03:52:10 liang ++ * Added V54 loop 2 test for V22. ++ * ++ * Revision 1.133 1998/07/15 02:45:03 mwg ++ * Added new connection info code: kPCMSpectralShapingBits ++ * ++ * Revision 1.132 1998/07/15 00:18:48 liang ++ * Add special turn off command for V34 fax to handle different turn off procedures. ++ * ++ * Revision 1.131 1998/07/13 22:19:49 liang ++ * Add V8 CI detection status and ANSam disable aux feature. ++ * ++ * Revision 1.130 1998/07/08 17:09:13 scott ++ * Added USE_LONG_ALIGN; support for 6 and PentiumDefs.h files ++ * ++ * Revision 1.129 1998/07/03 23:28:13 mwg ++ * Added Fax Class 2 defines ++ * ++ * Revision 1.128 1998/07/03 23:17:33 mwg ++ * Insuread command/status structures are long aligned ++ * ++ * Revision 1.127 1998/06/23 16:48:01 mwg ++ * Fixed a longstanding problem typical for Win95 VxD: whenever new ++ * VxD is intalled the confuguration profile may not match the old one but ++ * since the crc is correct it is still being downloaded. To avoid the problem ++ * a crc for the version number was added to avoid confusion between profiles ++ * of different versions. ++ * ++ * Revision 1.126 1998/06/19 21:04:06 liang ++ * Add auxiliary feature bit kV90ServerNotDetSbarAfterJdbarFix. ++ * ++ * Revision 1.125 1998/06/11 22:48:14 liang ++ * Add kPCM28000bpsShift constant. ++ * ++ * Revision 1.124 1998/06/05 22:11:51 liang ++ * New V90 DIL works through data mode. ++ * ++ * Revision 1.123 1998/06/01 23:03:41 liang ++ * Add v90RcvdDilDiffData logging. ++ * ++ * Revision 1.122 1998/06/01 21:24:38 mwg ++ * Changed some of the names. ++ * ++ * Revision 1.121 1998/05/13 04:55:22 mwg ++ * Now passing the number of spectral shaping bits in aux features ++ * ++ * Revision 1.120 1998/05/13 02:53:13 liang ++ * Add field "value" to command param structure. ++ * ++ * Revision 1.119 1998/05/12 04:42:23 mwg ++ * Replaced some of the status messages ++ * ++ * Revision 1.118 1998/05/11 23:36:10 mwg ++ * Added 8000Hz symbol rate to the map ++ * ++ * Revision 1.117 1998/05/05 04:28:39 liang ++ * V90 works up to data mode first version. ++ * ++ * Revision 1.116 1998/04/21 09:36:45 mwg ++ * Fixed a few problems for 16Khz and added 32Khz. ++ * ++ * Revision 1.115 1998/04/17 22:33:54 liang ++ * Added V90 DIL for mu-law PCM. ++ * ++ * Revision 1.114 1998/04/15 22:36:39 mwg ++ * Added new parameters to kDialCmd to allow individual control of each ++ * DTMF group attenuation. ++ * ++ * Revision 1.113 1998/04/15 18:16:22 ilyas ++ * Integrated V.8bis and changed coding of LinkLayerType to bitMap ++ * ++ * Revision 1.112 1998/04/15 07:59:06 mwg ++ * Added new status codes for V.90 ++ * ++ * Revision 1.111 1998/04/11 00:29:16 mwg ++ * Fixed the warnings which appeared when Irix builds were upgraded to ++ * gcc 2.8.1 ++ * ++ * Revision 1.110 1998/04/11 00:25:01 ilyas ++ * More V.70 statuses ++ * ++ * Revision 1.109 1998/04/10 23:29:31 mwg ++ * Added new field to capabilities: dataRates56K ++ * ++ * Revision 1.108 1998/04/09 02:02:56 mwg ++ * Added status for Ja detection. ++ * ++ * Revision 1.107 1998/04/03 02:05:30 ilyas ++ * More V.70 commands added ++ * ++ * Revision 1.106 1998/04/02 06:15:39 mwg ++ * Added coding type (Mu-law/A-law) status reporting. ++ * ++ * Revision 1.105 1998/03/30 09:53:57 mwg ++ * Added definition for k56Flex modulation for future use. ++ * ++ * Revision 1.104 1998/03/27 17:56:09 ilyas ++ * Added definitions for V.70 ++ * ++ * Revision 1.103 1998/03/26 23:29:04 liang ++ * Added first version of IMD estimation. ++ * ++ * Revision 1.102 1998/03/20 04:37:26 mwg ++ * Increased the size of the nominal variance to 32 bit. ++ * ++ * Revision 1.101 1998/03/06 01:22:04 yura ++ * Improved Win95 VxD segmentation handling ++ * ++ * Revision 1.100 1998/03/06 01:06:18 liang ++ * Add initial version of V90 phase 1 and 2. ++ * ++ * Revision 1.99 1998/03/05 23:42:22 mwg ++ * (hxl) Implemented enable/disable call waiting command. ++ * ++ * Revision 1.98 1998/02/26 06:13:06 mwg ++ * Increased the number of AT S-registers to account for newly introduced ++ * S9 and S10. ++ * ++ * Revision 1.97 1998/02/25 18:18:25 scott ++ * Added v42bisCycleCount for V42BIS_THROUGHPUT_CONTROL ++ * ++ * Revision 1.96 1998/02/24 05:31:20 mwg ++ * Added stuff required by international version of AT command processor. ++ * ++ * Revision 1.95 1998/02/17 01:14:10 scott ++ * Reenabled sys/types.h for Linux builds ++ * ++ * Revision 1.94 1998/02/16 22:32:23 scott ++ * Changed copyright notice ++ * ++ * Revision 1.93 1998/02/16 22:17:44 scott ++ * Turned off include of sys/types.h for normal builds ++ * ++ * Revision 1.92 1998/02/16 21:53:28 scott ++ * Exclude sys/types.h for another compiler ++ * ++ * Revision 1.91 1998/02/09 18:24:10 scott ++ * Fixed ComplexShort type to work around bugs in MS and GreenHill compilers ++ * ++ * Revision 1.90 1998/01/27 01:37:36 mwg ++ * Added new log identifier for pcm infidelity data. ++ * ++ * Revision 1.89 1998/01/22 19:49:32 liang ++ * Add auxFeature bit kFaxV34HDXAllowAsymCtrlChan. ++ * ++ * Revision 1.88 1998/01/21 02:32:01 liang ++ * Add more V34 half duplex training progress codes. ++ * ++ * Revision 1.87 1997/12/23 03:28:25 liang ++ * Add more half duplex V34 related constants. ++ * ++ * Revision 1.86 1997/12/18 19:38:50 scott ++ * Added agcData log type. ++ * Added kDisableFaxFastClearDown demod capability ++ * ++ * Revision 1.85 1997/12/18 06:02:45 mwg ++ * Added a function to reenable DC offset tracking. ++ * ++ * Revision 1.84 1997/12/17 22:46:30 mwg ++ * Minor modifications to X2 escape status reporting. ++ * ++ * Revision 1.83 1997/12/16 06:49:45 mwg ++ * Implemented proper data rate reporting for PCM modem. ++ * ++ * Revision 1.82 1997/12/13 06:11:08 mwg ++ * Added X2 interface hooks ++ * ++ * Revision 1.81 1997/12/02 06:21:33 mwg ++ * Implemented kSetATRegister command. ++ * ++ * Revision 1.80 1997/11/27 02:11:41 liang ++ * Add code for half duplex V34 control channel. ++ * ++ * Revision 1.79 1997/11/19 19:52:48 guy ++ * Added constant to define V.34 half duplex operation ++ * ++ * Revision 1.78 1997/10/24 05:15:53 scott ++ * Added AGC and phase hit recovery to demodCapabilities ++ * ++ * Revision 1.77 1997/10/01 02:47:50 liang ++ * Add PCM interface. ++ * ++ * Revision 1.76 1997/09/29 15:48:04 yura ++ * Added #pragma statement for W95 Vxd ++ * ++ * Revision 1.75 1997/09/18 20:32:39 scott ++ * Do not include VxD support files if GENERATE_DEPENDENCIES is defined. ++ * ++ * Revision 1.74 1997/09/18 12:40:55 yura ++ * Removed #ifdef statments to be more robust ++ * ++ * Revision 1.73 1997/09/17 17:32:41 scott ++ * Do not include sys/types.h for 6 ++ * ++ * Revision 1.72 1997/08/08 00:53:48 mwg ++ * Added fields for LAP-M frames printout. ++ * Added fields in auxFeatures to pass preemphasis filter parameters ++ * to V.34 phase 3 when doing PTT testing. ++ * ++ * Revision 1.71 1997/08/06 03:41:45 yura ++ * Added a few includes and defines needed by Win 95 driver. ++ * ++ * Revision 1.70 1997/08/05 03:22:10 liang ++ * Add equalizer center tap adjustment calculation related constants. ++ * ++ * Revision 1.69 1997/07/29 02:44:19 mwg ++ * Added new field to dataPumpCapabilities structure. This field is not ++ * yet exposed to external interface and currently is only used to ++ * enable PTT testing. ++ * Added new commands: kStartDataModemPTTTestCmd & kStartDataModemLoopbackTestCmd ++ * ++ * Revision 1.68 1997/07/22 22:05:10 liang ++ * Change sample rate setup as a normal command. ++ * ++ * Revision 1.67 1997/07/21 23:23:30 liang ++ * Define SoftModemSetSampleRate as null when SAMPLE_RATE_CONVERSION is not defined. ++ * ++ * Revision 1.66 1997/07/21 22:38:36 liang ++ * Change sample rate converter structure so that sample rate can be changed ++ * on the fly (at very begining) to either 8KHz or 9600Hz. ++ * ++ * Revision 1.65 1997/07/21 20:22:01 mwg ++ * Added statusInfoData to the log identifiers. ++ * ++ * Revision 1.64 1997/07/16 20:40:07 scott ++ * Added multitone monitor fields ++ * ++ * Revision 1.63 1997/07/10 02:31:08 mwg ++ * 1. Added kRxFrameHDLCFlags detected status for the ++ * framingInfo. ++ * 2. Added kLapmMNPFrameDetected status to lapmStatusCode. ++ * 3. Increased the number of AT registers to 35 ++ * 4. Modified LinkLayerSpec structure in modemCommandStruc ++ * to provide the initial values of rxDataRate & ++ * txDataRate and RT delay for the cases when ++ * link layer is started *after* the data connection ++ * is established and the status snooper is unable ++ * to determine the rates and RT delay. ++ * 5. Added a few extra *empty* constant definitions for ++ * disabled features. ++ * ++ * Revision 1.62 1997/07/02 19:15:05 scott ++ * Added bits for Bel103 & Bel212 modulations. ++ * ++ * Revision 1.61 1997/07/02 05:15:16 mwg ++ * Added MNP code. ++ * ++ * Revision 1.60 1997/07/01 23:52:48 mwg ++ * Modified the record test setup to log and use all the commands. ++ * ++ * Revision 1.59 1997/06/25 19:11:26 mwg ++ * 1. Added new framingInfoCode values for Async framing error reporting; ++ * 2. Added a substructure to pass serial data format for kSetDTERate cmd; ++ * ++ * Revision 1.58 1997/05/28 02:05:08 liang ++ * Add PCM modem phase 2 codes. ++ * ++ * Revision 1.57 1997/05/12 21:55:08 liang ++ * Add call waiting tone detector module. ++ * ++ * Revision 1.56 1997/03/21 23:50:08 liang ++ * Added initial version of V8bis module to CVS tree. ++ * ++ * Revision 1.55 1997/03/19 18:35:05 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.54 1997/03/11 11:11:45 mwg ++ * Added code to report V42bis statistics. ++ * ++ * Revision 1.53 1997/03/04 06:21:08 mwg ++ * Added logging of most commands. ++ * ++ * Revision 1.52 1997/02/28 23:45:13 liang ++ * Added training progress status report kPhaseJitterDeactivated. ++ * ++ * Revision 1.51 1997/02/28 22:23:22 mwg ++ * Implemented the following features: ++ * - Cleardown for fax modulations V.27, V.29 V.17 ++ * - Rockwell compatible bitmap report (needed by a customer) ++ * ++ * Revision 1.50 1997/02/28 03:05:31 mwg ++ * Added more logging data types. ++ * ++ * Revision 1.49 1997/02/27 05:28:58 mwg ++ * Added RxFrameOK report. ++ * ++ * Revision 1.48 1997/02/27 01:48:53 liang ++ * Add kV8MenuDataWord1 and kV8MenuDataWord2 connectionInfo status. ++ * ++ * Revision 1.47 1997/02/24 02:30:27 mwg ++ * Added new log data: predictorErrData ++ * ++ * Revision 1.46 1997/02/22 03:00:22 liang ++ * Add echoCancelledSignalData. ++ * ++ * Revision 1.45 1997/02/21 01:26:42 liang ++ * Add six more bits for the Demodulator capabilities to deal with 2nd order ++ * time tracking & PLLs, as well as shorter NEEC & PFEEC, and front end HBF. ++ * ++ * Revision 1.44 1997/02/17 03:09:00 mwg ++ * Added LAPM statistics printout. ++ * ++ * Revision 1.43 1997/02/04 08:38:47 mwg ++ * Added dc cancelled samples printout. ++ * ++ * Revision 1.42 1997/01/29 21:40:28 mwg ++ * Changed the way timers work: now time is passed as Q4 ms instead of ticks. ++ * Completed the 8KHz front end implementation. ++ * Got rid of kSamplesPerSecond constant. ++ * ++ * Revision 1.41 1997/01/24 07:13:50 mwg ++ * Added new statuses for automoder. ++ * ++ * Revision 1.40 1997/01/23 02:03:08 mwg ++ * Replaced old sample rate conversion with the newer one. ++ * Still has to resolve the automoding issue. ++ * ++ * Revision 1.39 1997/01/21 00:55:04 mwg ++ * Added 8KHz front end functionality. ++ * ++ * Revision 1.38 1996/11/13 00:30:55 liang ++ * Add kAutoLoadReductionEnabled to demodCapabilities so that PFEEC, FEEC, IEEC ++ * can be disabled automatically, but for worst processor loading test they ++ * won't be disabled when this bit is not set. ++ * ++ * Revision 1.37 1996/11/07 23:07:18 mwg ++ * Rearranged global variables to allow V.17 short training. ++ * ++ * Revision 1.36 1996/09/17 23:55:05 liang ++ * Change kMaxDataBlockSize from 16 to 24 to handle high data rates. ++ * ++ * Revision 1.35 1996/09/05 19:43:39 liang ++ * Removed caller ID error status code kCallerIDUnknownMessageType, and ++ * added caller ID status codes kCallerIDUnknownMessage & kCallerIDWholeMessage. ++ * Changed the callerIDStatus report structure. ++ * ++ * Revision 1.34 1996/08/29 00:36:57 liang ++ * Added kLapmTxFrameStatus and kLapmRxFrameStatus. ++ * ++ * Revision 1.33 1996/08/27 22:56:01 liang ++ * Added kResetHardware status code. ++ * ++ * Revision 1.32 1996/08/23 23:35:35 liang ++ * Add kATDebugStatus and function SoftModemGetHybridDelay. ++ * ++ * Revision 1.31 1996/08/22 01:13:19 yg ++ * Added AT command processor. ++ * ++ * Revision 1.30 1996/08/12 21:46:47 mwg ++ * Added code to report capabilities. ++ * ++ * Revision 1.29 1996/08/10 01:59:59 mwg ++ * Added report of the sent rate sequence; ++ * ++ * Revision 1.28 1996/08/07 22:15:02 mwg ++ * Added new status reports: ++ * kRemoteFreqOffset ++ * kIEECDeactivated ++ * kPFEECDeactivated ++ * ++ * Revision 1.27 1996/06/27 05:15:48 mwg ++ * Added V.24 circuit status. ++ * ++ * Revision 1.26 1996/06/27 02:12:43 mwg ++ * Cleaned the code. ++ * ++ * Revision 1.25 1996/06/20 23:57:30 mwg ++ * Added new training progress status. ++ * ++ * Revision 1.24 1996/06/18 21:13:50 mwg ++ * Added trellis MSE data logging. ++ * ++ * Revision 1.23 1996/06/12 02:31:10 mwg ++ * Added new type: VeryLong ++ * ++ * Revision 1.22 1996/06/08 22:15:39 mwg ++ * Added new status report: kCleardownStarted ++ * Added new field for the features: kV34bisEnabled ++ * ++ * Revision 1.21 1996/05/31 00:29:11 liang ++ * Add feature bit kV34ExtraINFOPreamble. ++ * ++ * Revision 1.20 1996/05/30 23:28:31 mwg ++ * Replaced enums with #defines ++ * ++ * Revision 1.19 1996/05/25 00:38:27 mwg ++ * Added kProjectedDataRate training progress report. ++ * ++ * Revision 1.18 1996/05/24 23:27:15 mwg ++ * Added mode status codes. ++ * ++ * Revision 1.17 1996/05/10 05:39:59 liang ++ * Move the includes for DEBUG inside "ifndef SoftModemTypes" so that ++ * cap build won't break. ++ * ++ * Revision 1.16 1996/05/08 01:49:34 mwg ++ * Added capability to setup auxiliary data channel handlers. ++ * ++ * Revision 1.15 1996/05/07 22:51:08 liang ++ * Added group delay estimation and improved symbol rate selection process. ++ * ++ * Revision 1.14 1996/05/06 06:49:09 mwg ++ * Fixed linux problems. ++ * ++ * Revision 1.13 1996/05/02 08:40:16 mwg ++ * Merged in Chromatic bug fixes. ++ * ++ * Revision 1.12 1996/05/02 02:26:21 mwg ++ * Added code to implement dozing functionality for v.34. ++ * ++ * Revision 1.11 1996/05/01 22:43:13 mwg ++ * Added new command: kDozeCmd; ++ * ++ * Revision 1.10 1996/05/01 19:20:16 liang ++ * Add command codes kInitiateRetrainCmd and kInitiateRateRenegotiationCmd. ++ * ++ * Revision 1.9 1996/04/25 01:12:37 mwg ++ * Added new flag: rapid preliminary EC training. ++ * ++ * Revision 1.8 1996/04/20 02:26:22 mwg ++ * Added preliminary far-end echo support ++ * ++ * Revision 1.7 1996/04/15 23:26:16 mwg ++ * Changed flag definitions for v34 modem. ++ * ++ * Revision 1.6 1996/04/04 02:35:50 liang ++ * Change kCid from 0x0080 to 0x0004 (0x0080 is defined as kV32). ++ * ++ * Revision 1.5 1996/03/08 23:07:01 mwg ++ * Added name for the struct. ++ * ++ * Revision 1.4 1996/03/02 00:59:27 liang ++ * Added typedef for V34CodingParameters structure. ++ * ++ * Revision 1.3 1996/02/27 02:28:31 mwg ++ * Fixed a bug in kLapmLongADPEnabled definition. ++ * ++ * Revision 1.2 1996/02/19 23:50:59 liang ++ * Removed compressionSetup parameter from the link layer command structure. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1996/01/15 23:26:04 liang ++ * Change the softmodem command structure name from SoftwareModemCommand ++ * to SoftwareModemCommandParameters. ++ * ++ *****************************************************************************/ ++#ifndef SoftModemPh ++#define SoftModemPh ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.1 General types */ ++/****************************************************************************/ ++ ++#ifndef SM_DECL ++#define SM_DECL ++#endif ++ ++#ifdef __VxWORKS__ ++#include ++#endif ++ ++#ifdef DEBUG ++/* We have to define __wchar_t for Linux */ ++#if defined __linux__ && !defined _NO_WHCAR_DEF_ ++typedef long int __wchar_t; ++#endif ++#if !defined(__KERNEL__) && !defined(_CFE_) ++#include ++#include ++#endif ++ ++#if defined(__linux__) || defined (__unix__) || defined (__unix) || (defined (__mips__) && !defined(_CFE_) && !defined(VXWORKS) && !defined(TARG_OS_RTEMS))/* enable if necessary, but not for dos-based builds */ ++#include ++#endif ++ ++ ++#endif /* DEBUG */ ++ ++#if defined(W95_DRIVER) ++#pragma code_seg("_LTEXT", "LCODE") ++#pragma data_seg("_LDATA", "LCODE") ++#pragma const_seg("_LDATA", "LCODE") ++#pragma bss_seg("_LDATA", "LCODE") ++#pragma pack(1) ++#endif /* W95_DRIVER */ ++ ++#ifndef SoftModemTypes ++#include "SoftModemTypes.h" ++#endif /* SoftModemTypes */ ++ ++ ++typedef struct ++ { ++ schar x, y; ++ } ComplexByte; ++ ++typedef struct ++ { ++ uchar numerator; ++ uchar denominator; ++ } Ratio; ++ ++#ifdef PEGASUS ++typedef union ++ { ++ struct ++ { ++ short x, y; ++ }; ++ ++ long foo; ++ } ComplexShort; ++#else ++typedef struct ++ { ++ short x, y; ++#ifdef GREENHILL ++ long a[0]; ++#endif ++ } ComplexShort; ++#endif ++ ++typedef struct ++ { ++ long x, y; ++ } ComplexLong; ++ ++typedef struct ++ { ++ ushort x0, x1, x2; ++ short x3; ++ } VeryLong; ++ ++typedef union ++ { ++ struct ++ { ++ uchar number; ++ uchar defaultValue; /* default value */ ++ uchar maxValue; /* max allowed value */ ++ uchar minValue; /* should be greater then maxValue to make reg readonly */ ++ } param; ++ long alignment; ++ } SRegisterDefinition; ++ ++#define MacroPaste2(a,b) a##b ++#define MacroPaste(a,b) MacroPaste2(a,b) ++#define ALWAYS_LONG_ALIGN() long MacroPaste(ALIGNMENT,__LINE__); ++ ++#ifdef USE_LONG_ALIGN ++#define LONG_ALIGN() ALWAYS_LONG_ALIGN() ++#else ++#define LONG_ALIGN() ++#endif ++ ++typedef ulong bitMap; ++ ++typedef int pace; ++#define kStop 0 ++#define kVerySlow 1 ++#define kSlow 2 ++#define kMedium 3 ++#define kFast 4 ++ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.2 Modem specific types */ ++/****************************************************************************/ ++ ++typedef long directionType; ++#define kXmt 0 ++#define kRcv 1 ++#define kXmtRcv 2 ++ ++ ++#define originating kXmt ++#define answering kRcv ++#define kOrg kXmt ++#define kAns kRcv ++#define kOrgAns kXmtRcv ++ ++#define ORIGINATING originating ++#define ANSWERING answering ++ ++typedef int pcmCodingType; ++#define kMuLawPCM 0 ++#define kALawPCM 1 ++ ++#define kMuLawPCMScaleShift 2 ++#define kALawPCMScaleShift 3 ++ ++/* link layer and framer share defines */ ++typedef bitMap framerType; ++typedef bitMap linkLayerType; ++#define kNoFramer 0 ++#define kSync 0x00000001 ++#define kAsync 0x00000002 ++#define kHDLC 0x00000004 ++#define kLapm 0x00000008 ++#define kMnp 0x00000010 ++#define kV70 0x00000020 ++#define kSAM 0x00000040 ++ ++ ++typedef bitMap modulationMap; ++typedef bitMap symbolRateMap; ++typedef bitMap dataRateMap; ++typedef bitMap featureMap; ++typedef bitMap breakType; ++ ++typedef bitMap audioType; ++#define kRawAudio 0 ++#define kAudioG729A 1 ++#define kAudioG729 2 ++#define kAudioG723 3 ++ ++ ++#ifndef ADSL_MODEM ++typedef long modemStatusCode; ++#endif ++ /* Information status Codes: 1-31 */ ++#define kSetSampleRate 1 ++#define kModulationKnown 2 ++#define kRxSymbolRate 3 ++#define kTxSymbolRate 4 ++#define kRxCarrierFreq 5 ++#define kTxCarrierFreq 6 ++#define kTxPreemphasisFilter 7 ++#define kTxPowerAdjustment 8 ++#define kRemoteTxPreemphasisFilter 9 ++#define kRemoteTxPowerAdjustment 10 ++#define kRxRateKnown 11 ++#define kTxRateKnown 12 ++#define kRxDataModeActive 13 ++#define kTxDataModeActive 14 ++#define kTxSignalCompleted 15 ++#define kDTMFSignalDetected 16 ++#define kModemSignalDetected 17 ++#define kCallProgressSignalDetected 18 ++#define kCustomSignalDetected 19 ++#define kFaxPreambleDetected 20 ++#define kV24CircuitStatusChange 21 ++#define kHookStateChange 22 ++#define kCallWaitingToneDetected 23 ++#define kMultiToneSignalDetected 24 ++#define kPulseShuntStateChange 25 ++#define kRingFrequency 26 ++ ++ ++ /* Warning status Codes: 32-64 */ ++#define kError 32 ++#define kV34Exception 33 ++#define kClearDownLocal 34 ++#define kClearDownRemote 35 ++#define kCarrierPresent 36 ++#define kCarrierLost 37 ++#define kRetrainingLocal 38 ++#define kRetrainingRemote 39 ++#define kRateRenegotiationLocal 40 ++#define kRateRenegotiationRemote 41 ++#define kFallbackStarted 42 ++#define kFallForwardStarted 43 ++#define kCleardownStarted 44 ++#define kIllegalCommand 45 ++ ++ /* Auxiliary status Codes: 64-.. */ ++#define kTrainingProgress 64 ++#define kConnectionInfo 65 ++#define kDialerStatus 66 ++#define kFramingInfo 67 ++#define kBreakReceived 68 ++#define kLapmStatus 69 ++#define kLapmParameter 70 ++#define kV42bisStatus 71 ++#define kCallerIDStatus 72 ++#define kIOStatus 73 ++#define kCapabilitiesStatus 74 ++#define kSpeakerStatus 75 ++#define kATProfileChanged 76 ++#define kATDebugStatus 77 ++#define kResetHardware 78 ++#define kV8bisStatus 79 ++#define kMnpStatus 80 ++#define kMnpParameter 81 ++#define kV70Status 82 ++#define kV70Parameter 83 ++#define kFaxClass2Status 84 ++#define kAudioStatus 85 ++#define kAudioParameter 86 ++#define kOverlayStatus 87 ++#define kCallerIDCircuitStatus 88 ++#define kV80Status 89 ++#define kV80Parameter 90 ++#define kLocalCountryChanged 91 ++#define kDTERateChanged 92 ++#define kATResponse 93 ++#define kFramerConfigured 94 ++#define kA8RStatus 95 ++#define kA8TStatus 96 ++#define kVersionStatus 97 ++ ++ /* Testing status codes: 128-... */ ++ /* These statuses are generated by modem test suit */ ++#define kTestFinished 128 ++#define kConnectivityTestFinished 129 ++#define kTestCheckSum 130 ++#define kLogFileControl 131 ++#define kTestAtmVcFinished 132 ++#define kTestClearEocFinished 133 ++#define kTestG997Finished 134 ++ ++typedef long modemErrorCode; ++#define kNoError 0 ++#define kErrorTimerExpired 1 ++#define kErrorNoSReceived 2 ++#define kErrorNoSbarReceived 3 ++ ++ ++typedef long dialerStatusCode; ++#define kDialCompleted 0 ++#define kNoDialToneDetected 1 ++#define kBongToneDetected 2 ++#define kNoBongToneDetected 3 ++#define kErrorIllegalDialModifier 5 ++#define kDialStarted 6 ++#define kExternalPulseDialDigit 7 ++ ++ ++typedef long framingInfoCode; ++#define kRxFrameOK 0 ++#define kRxFrameTooLong 1 ++#define kRxFrameCRCError 2 ++#define kTxFrameUnderrun 3 ++#define kRxFrameOverrun 4 ++#define kRxFrameAborted 5 ++#define kRxFrameParityError 6 ++#define kRxFrameFormatError 7 ++#define kRxFrameHDLCFlagsDetected 8 ++ ++ ++typedef long IOStatusCode; ++#define kRxDataReady 0 ++#define kRxBufferOverflow 1 ++#define kTxSpaceAvailable 2 ++#define kTxBufferEmpty 3 ++ ++typedef long capabilitiesStatusCode; ++#define kSymbolRates 0 ++#define kDataRates 1 ++#define kFeatures 2 ++#define kDemodCapabilities 3 ++#define kRateThresholdAdjustment 4 ++#define kXmtLevel 5 ++#define kHybridDelay 6 ++#define kAuxFeatures 7 ++ ++ ++typedef long A8TStatusCode; ++#define kA8TFinished 0 ++ ++typedef long callerIDStatusCode; ++#define kCallerIDError 0 ++#define kCallerIDChannelSeizureReceived 1 ++#define kCallerIDMarkSignalReceived 2 ++#define kCallerIDTime 3 ++#define kCallerIDTelnum 4 ++#define kCallerIDName 5 ++#define kCallerIDEnd 6 ++#define kCallerIDUnknownMessage 7 ++#define kCallerIDWholeMessage 8 ++ ++ ++typedef long callerIDErrorCode; ++#define kCallerIDNoError 0 ++#define kCallerIDMarkSignalError 1 ++#define kCallerIDTooManyMarkBits 2 ++#define kCallerIDMessageTooLong 3 ++#define kCallerIDChecksumError 4 ++ ++ ++typedef long connectionInfoCode; ++#define kRTDelay 1 ++#define kRxSignalLevel 2 ++#define kTimingOffset 3 ++#define kFreqOffset 4 ++#define kPhaseJitter 5 ++#define kSNR 6 ++#define kNearEchoLevel 7 ++#define kSER 8 ++#define kNearEndDelay 9 ++#define kFarEchoLevel 10 ++#define kL1L2SNRDifference 11 ++#define kDCOffset 12 ++#define kTotalRxPower 13 ++#define kRemoteFreqOffset 14 ++/* obsolete #define kV8MenuDataWord1 15 */ ++/* obsolete #define kV8MenuDataWord2 16 */ ++#define kPCMP2AnalogDetSNR 17 ++#define kPCMP2DigitalDetSNR 18 ++#define kPCMP2RBSDetSNR 19 ++#define kEqCenterTapOffset 20 ++#define kPCMPadValue 21 ++#define kPCMRBSMap 22 ++#define kPCMCodingType 23 ++#define kPCMSpectralShapingBits 24 ++#define kLoopbackSelfTestResult 25 ++#define kEyeQuality 26 ++#define kLoopbackSelfTestNewErrs 27 ++#define kV34EqlLengthStatus 28 ++#define kV34EqlOffsetStatus 29 ++#define kV8CallMenuData 30 ++#define kV8JointMenuData 31 ++#define kPCMClientIeecLengthStatus 32 ++#define kPCMClientIeecOffsetStatus 33 ++#define kSeamlessRateChange 34 ++ ++typedef long trainingProgressCode; ++#define kPeriodicalSignalDetected 0 ++#define kPhaseReversalDetected 1 ++#define kSignalStartDetected 2 ++#define kSignalEndDetected 3 ++#define kSSignalDetected 4 ++#define kSbarSignalDetected 5 ++#define kJ4SignalDetected 6 ++#define kJ16SignalDetected 7 ++#define kJprimeSignalDetected 8 ++#define kMPSignalDetected 9 ++#define kMPprimeSignalDetected 10 ++#define kMPSignalSent 11 ++#define kMPprimeSignalSent 12 ++#define kRateSignalDetected 13 ++#define kESignalDetected 14 ++#define kRateSignalSent 15 ++ ++#define kAutomodingTryModulation 16 ++#define kAutomodingCompleted 17 ++#define kRCFaxBitMapStatus 18 ++ ++#define kV8CIDetected 19 ++#define kV8ANSToneDetected 20 ++#define kV8ANSamDetected 21 ++#define kV8CMDetected 22 ++#define kV8JMDetected 23 ++#define kV8CJDetected 24 ++#define kV8Finished 25 ++ ++#define kV34Phase2Started 26 ++#define kV34Phase2INFOSequenceDetected 27 ++#define kV34Phase2NearEndEchoDetected 28 ++#define kV34Phase2L1Receiving 29 ++#define kV34Phase2L2Receiving 30 ++#define kV34Phase2Finished 31 ++#define kV34Phase3Started 32 ++#define kV34Phase3Finished 33 ++#define kV34Phase4Started 34 ++#define kV34Phase4Finished 35 ++#define kV34DecoderParameters 36 ++#define kV34EncoderParameters 37 ++ ++#define kMaxLocalRxDataRate 38 ++#define kMaxLocalTxDataRate 39 ++#define kMaxRemoteRxDataRate 40 ++#define kMaxRemoteTxDataRate 41 ++#define kProjectedDataRate 42 ++#define kFEECDeactivated 43 ++#define kIEECDeactivated 44 ++#define kPFEECDeactivated 45 ++#define kPhaseJitterDeactivated 46 ++ ++#define kPCMP2DetectedDigitalConnection 47 ++#define kPCMP2DetectedRBS 48 ++#define kX2DetectedPhase1Escape 49 ++ ++#define kStarted1200BpsTraining 50 ++#define kStarted2400BpsTraining 51 ++#define kUnscrambledOneDetected 52 ++#define kScrambled1200BpsOneDetected 53 ++#define kScrambled2400BpsOneDetected 54 ++#define kV22BisS1Detected 55 ++#define kV22InitiateLoop2Test 56 ++#define kV22RespondLoop2Test 57 ++#define kV22Loop2TestAlt01Detected 58 ++ ++#define kDataModemLoop1TestStarted 59 ++#define kDataModemLoop1TestFinished 60 ++#define kDataModemLoop2TestStarted 61 ++#define kDataModemLoop2TestFinished 62 ++#define kDataModemLoop3TestStarted 63 ++#define kDataModemLoop3TestFinished 64 ++#define kDataModemSelfLoopTestEnabled 65 ++ ++#define kPCMPhase3Started 70 ++#define kPCMPhase3Finished 71 ++#define kPCMPhase4Started 72 ++#define kPCMPhase4Finished 73 ++ ++#define kV90JaSignalDetected 74 ++#define kV90JdSignalDetected 75 ++#define kV90JdPrimeSignalDetected 76 ++#define kV90RSignalDetected 77 ++#define kV90RBarSignalDetected 78 ++#define kV90CPSignalDetected 79 ++ ++#define kV90CPtSignalSent 80 ++#define kV90CPSignalSent 81 ++#define kV90CPprimeSignalSent 82 ++ ++ ++#define kV34SeamlessRateChangeRequestSent 83 ++#define kV34SeamlessRateChangeUpdateSent 84 ++#define kV34SeamlessRateChangeRequestReceived 85 ++#define kV34SeamlessRateChangeUpdateReceived 86 ++#define kV34SeamlessRateChangeUpdateTimeout 87 ++ ++#define kV90JaSignalAcknowledged 88 ++ ++#define kV34HCtrlChanPPhDetected 100 ++#define kV34HCtrlChanMPhDetected 101 ++#define kV34HCtrlChanRatesKnown 102 ++#define kV34HDXCtrlChanBinary1Detected 103 ++#define kV34HDXPhase3Started 104 ++#define kV34HDXPhase3Finished 105 ++#define kV34HDXPrimChanBinary1Detected 106 ++#define kFlexEventTRN2AFinished 107 ++ ++#define kV32RanginigStarted 108 ++#define kV32RangingStarted 108 ++#define kV32RanginigFinished 109 ++#define kV32RangingFinished 109 ++ ++ ++typedef long lapmStatusCode; ++#define kLapmDisconnected 0 /* LAPM disconnected */ ++#define kLapmConnected 1 /* LAPM is connected */ ++#define kLapmV42ODPDetected 2 /* LAPM ODP is detected */ ++#define kLapmV42ADPDetected 3 /* LAPM V.42 ADP is detected */ ++#define kLapmUnknownADPDetected 4 /* LAPM Unsupported ADP is detected */ ++#define kLapmTimeout 5 /* LAPM Timeout */ ++#define kLapmMNPFrameDetected 6 /* LAPM detected MNP frame */ ++#define kLapmDPDetectionTimedOut 7 /* LAPM Unsupported ADP is detected */ ++#define kLapmError 8 /* LAPM Error */ ++#define kLapmTestResult 9 /* LAPM loopback test result */ ++#define kLapmTxFrameStatus 10 ++#define kLapmRxFrameStatus 11 ++#define kLapmTxStatistics 12 ++#define kLapmRxStatistics 13 ++ ++typedef long lapmTakedownReason; ++#define kLapmRemoteDisconnect 0 ++#define kLapmLocalDisconnect 1 ++#define kLapmCannotConnect 2 ++#define kLapmProtocolError 3 ++#define kLapmCompressionError 4 ++#define kLapmInactivityTimer 5 ++#define kLapmRetryFailed 6 ++ ++ ++typedef long lapmParameterCode; ++#define kLapmXmtK 0 ++#define kLapmRcvK 1 ++#define kLapmXmtN401 2 ++#define kLapmRcvN401 3 ++#define kLapmTESTSupport 4 ++#define kLapmSREJSupport 5 ++#define kLapmCompDir 6 ++#define kLapmCompDictSize 7 ++#define kLapmCompStringSize 8 ++ ++ ++typedef long lapmErrorCode; ++#define kLapmNoError 0 ++#define kLapmBufferOverflow 1 ++#define kLapmFrameTooLong 2 ++#define kLapmBadFrame 3 ++#define kLapmUnknownEvent 4 ++/* 6 is reserved for kLapmRetryFailed defined above */ ++ ++ ++typedef long lapmTestResultCode; ++#define kLapmTestPassed 0 ++#define kLapmTestRequestIgnored 1 ++#define kLapmTestAlreadyInProgress 2 ++#define kLapmTestNotSupported 3 ++#define kLapmTestFailed 4 ++ ++ ++typedef long v42bisStatusCode; ++#define kV42bisEncoderTransparentMode 0 /* V.42bis encoder transparent mode active */ ++#define kV42bisEncoderCompressedMode 1 /* V.42bis encoder compressed mode active */ ++#define kV42bisDecoderTransparentMode 2 /* V.42bis decoder transparent mode active */ ++#define kV42bisDecoderCompressedMode 3 /* V.42bis decoder compressed mode active */ ++#define kV42bisError 4 /* V.42bis error */ ++#define kV42bisEncoderStatistics 5 ++#define kV42bisDecoderStatistics 6 ++ ++ ++typedef long v42bisErrorCode; ++#define kV42bisUndefinedEscSequence 0 /* V.42bis undefined escape sequence */ ++#define kV42bisCodewordSizeOverflow 1 /* V.42bis codeword size overflow */ ++#define kV42bisUndefinedCodeword 2 /* V.42bis undefined codeword */ ++ ++typedef long mnpStatusCode; ++#define kMnpDisconnected 0 /* Mnp disconnected */ ++#define kMnpConnected 1 /* Mnp is connected */ ++#define kMnpFallback 2 /* Mnp is falling back to buffer mode */ ++#define kMnpError 3 /* Mnp Error */ ++#define kMnpTimeout 4 /* Mnp Timeout */ ++#define kMnpInvalidLT 5 /* Invalid LT received */ ++#define kMnpRetransmitFrame 6 ++#define kMnpNack 7 ++#define kMnpTxFrameStatus 8 ++#define kMnpRxFrameStatus 9 ++#define kMnpTxStatistics 10 ++#define kMnpRxStatistics 11 ++ ++typedef long mnpTakedownReason; ++#define kMnpRemoteDisconnect 0 ++#define kMnpLocalDisconnect 1 ++#define kMnpCannotConnect 2 ++#define kMnpProtocolError 3 ++#define kMnpCompressionError 4 ++#define kMnpInactivityTimer 5 ++#define kMnpRetryFailed 6 ++ ++ ++typedef long mnpParameterCode; ++#define kMnpProtocolLevel 0 ++#define kMnpServiceClass 1 ++#define kMnpOptimizationSupport 2 ++#define kMnpCompressionSupport 3 ++#define kMnpN401 4 ++#define kMnpK 5 ++ ++ ++typedef long mnpErrorCode; ++#define kMnpNoError 0 ++#define kMnpBufferOverflow 1 ++#define kMnpFrameTooLong 2 ++#define kMnpBadFrame 3 ++#define kMnpUnknownEvent 4 ++ ++ ++typedef long v70StatusCode; ++#define kV70Disconnected 0 /* V70 disconnected */ ++#define kV70Connected 1 /* V70 is connected */ ++#define kV70Error 2 /* V70 Error */ ++#define kV70Timeout 3 /* V70 Timeout */ ++#define kV70ChannelDown 4 /* V70 channel released */ ++#define kV70ChannelUp 5 /* V70 channel established */ ++#define kV70AudioChannelDown 6 /* V70 audio channel released */ ++#define kV70AudioChannelUp 7 /* V70 audio channel established */ ++#define kV70DataChannelDown 8 /* V70 data channel released */ ++#define kV70DataChannelUp 9 /* V70 data channel established */ ++#define kV70OOBChannelDown 10 /* V70 out-of-band channel released */ ++#define kV70OOBChannelUp 11 /* V70 out-of-band channel established */ ++#define kV70TxFrameStatus 12 ++#define kV70RxFrameStatus 13 ++#define kV70TxStatistics 14 ++#define kV70RxStatistics 15 ++#define kV70StateTransition 16 ++ ++typedef long v70TakedownReason; ++#define kV70RemoteDisconnect 0 ++#define kV70LocalDisconnect 1 ++#define kV70CannotConnect 2 ++#define kV70ProtocolError 3 ++#define kV70CompressionError 4 ++#define kV70InactivityTimer 5 ++#define kV70RetryFailed 6 ++ ++ ++typedef long v70ParameterCode; ++#define kV70SuspendResume 0 ++#define kV70CrcLength 1 ++#define kV70NumberOfDLCs 2 ++#define kV70uIH 3 ++ ++#define kV70LapmXmtK 10 ++#define kV70LapmRcvK 11 ++#define kV70LapmXmtN401 12 ++#define kV70LapmRcvN401 13 ++#define kV70LapmTESTSupport 14 ++#define kV70LapmSREJSupport 15 ++#define kV70LapmCompDir 16 ++#define kV70LapmCompDictSize 17 ++#define kV70LapmCompStringSize 18 ++ ++#define kV70AudioHeader 20 /* if audio header is present in audio frames */ ++#define kV70BlockingFactor 21 /* audio blocking factor (default 1) */ ++#define kV70SilenceSuppression 22 /* audio silence suppression */ ++ ++ ++ ++typedef long v70ErrorCode; ++#define kV70NoError 0 ++#define kV70BadFrame 1 ++ ++typedef long audioStatusCode; ++#define kAudioFramesLost 0 /* One or more audio frames were lost */ ++#define kAudioTxBufferOverflow 1 ++#define kAudioRxBufferOverflow 2 ++#define kAudioRxBufferUnderflow 3 ++ ++ ++typedef long v80StatusCode; ++#define kV80Disconnected 0 /* V80 disconnected */ ++#define kV80Connected 1 /* V80 is connected */ ++#define kV80Error 2 /* V80 Error */ ++#define kV80InBandStatus 3 /* V80 in-band SAM status */ ++#define kV80TxFrameStatus 12 ++#define kV80RxFrameStatus 13 ++#define kV80TxStatistics 14 ++#define kV80RxStatistics 15 ++ ++typedef long v80TakedownReason; ++#define kV80RemoteDisconnect 0 ++#define kV80LocalDisconnect 1 ++ ++typedef long v80ErrorCode; ++#define kV80NoError 0 ++#define kV80BadFrame 1 ++ ++typedef long overlayStatusCode; ++#define kOverlayBegin 0 /* DSP has halted */ ++#define kOverlayEnd 1 /* DSP has received entire overlay */ ++#define kOverlayElapsedTime 2 /* time elapsed(as viewed by datapump) during overlay */ ++#define kOverlayRecordingData 3 /* ms of data that we are recording */ ++#define kOverlayReplayingData 4 /* ms of data that we have replayed so far */ ++#define kOverlayReplayDone 5 /* playback is done */ ++ ++/* types for kOverlayRecording/ReplayingData */ ++#define kOverlayTxData 0 ++#define kOverlayRxData 1 ++ ++/* ++ * Rockwell faxmodem compatible bitmap (kRCFaxBitMapStatus) ++ */ ++#define kRCFaxFCD 0x01 ++#define kRCFaxP2 0x02 ++#define kRCFaxPN 0x04 ++#define kRCFaxDCD 0x08 ++#define kRCFaxTX 0x10 ++#define kRCFaxCTS 0x20 ++ ++ ++#ifndef ADSL_MODEM ++typedef long modemCommandCode; ++#endif ++ /* Basic Action commands 00-63 */ ++#define kIdleCmd 0 ++#define kStartFaxModemCmd 1 ++#define kStartDataModemCmd 2 ++#define kStartCallProgressMonitorCmd 3 ++#define kSendTonesCmd 4 ++#define kStartCallerIDRcvCmd 5 ++#define kSetLinkLayerCmd 6 ++#define kSetFramerCmd 7 ++#define kTestLinkLayerCmd 8 ++#define kIdleRcvCmd 9 ++#define kIdleXmtCmd 10 ++#define kSetStatusHandlerCmd 11 ++#define kSetEyeHandlerCmd 12 ++#define kSetLogHandlerCmd 13 ++#define kSendBreakCmd 14 ++#define kSendTestCmd 15 ++#define kDisconnectLinkCmd 16 ++#define kSetXmtGainCmd 17 ++#define kStartADSICmd 18 ++#define kSetHybridDelayCmd 19 ++#define kCleardownCmd 20 ++#define kInitiateRetrainCmd 21 ++#define kInitiateRateRenegotiationCmd 22 ++#define kDialToneIndicator 23 ++#define kSetRxDataHandler 24 /* not used yet */ ++#define kSetTxDataHandler 25 /* not used yet */ ++#define kSetAuxRxDataHandler 26 ++#define kSetAuxTxDataHandler 27 ++#define kRingIndicatorCmd 28 ++#define kDTERateIndicatorCmd 29 ++#define kStartV8bisCmd 30 ++#define kSendMultiTonesCmd 31 ++#define kSetMultiToneParamsCmd 32 ++#define kSetModemSampleRateCmd 33 ++#define kStartDataModemPTTTestCmd 34 ++#define kStartDataModemLoopbackTestCmd 35 ++#define kRingFrequencyCmd 36 ++#define kSetCallWaitingDetectorStateCmd 37 ++#define kV34HDXTurnOffCurrentModeCmd 38 ++#define kSetAudioCmd 39 ++#define kLoopbackTestAutoRespEnableCmd 40 ++#define kSetCallProgressParamsCmd 41 ++#define kSetTrainingDelayReductionCmd 42 ++#define kSetFaxECMPageBufferPtrCmd 43 ++#define kSetLineCurrentStateCmd 44 ++#define kSetFramerParameterCmd 45 ++#define kStartDozeCmd 46 ++#define kEndDozeCmd 47 ++#define kStartRingFrequencyDetectorCmd 48 ++#define kSetBufferingDelayAdjustmentCmd 49 ++ ++ /* Composite action commands 64-127 */ ++#define kDialCmd 64 ++#define kSendCallingToneCmd 65 ++#define kV24CircuitChangeCmd 66 ++#define kStartATModeCmd 67 ++#define kStopATModeCmd 68 ++#define kSetATRegister 69 ++#define kSetATRegisterLimits 70 ++#define kSetATIResponse 71 ++#define kEnableATDebugMode 72 ++#define kSetWhiteListEntry 73 ++#define kSetBlackListEntry 74 ++ ++#define kV70Setup 75 /* additional V70 configuration */ ++#define kEstablishChannel 76 /* Establish new link layer channel (V70) */ ++#define kReleaseChannel 77 /* Release link layer channel (V70) */ ++#define kWaitChannelEstablished 78 /* Wait for establishment of the new link layer channel (V70) */ ++ ++/* unused 79 */ ++#define kMnpOOBFrameCmd 80 ++#define kV80InBandCmd 81 /* V80 In-band commands */ ++#define kSetV250IdString 82 ++#define kSetInternationalTablesCmd 83 ++#define kConfigureCountryCmd 84 ++#define kConigureCountryCmd 84 ++#define kV8ControlCmd 85 ++#define kV8bisSendMessage 86 ++#define kSetHWIdCmd 87 ++#define kSetCodecIdCmd 88 ++#define kOverCurrentDetected 89 ++ ++ ++ ++typedef long v8ControlType; ++#define kEnableDTEControl 1 ++#define kSetV8ControlTimeout 2 ++#define kSetCIValue 3 ++#define kSetCMValue 4 ++#define kSetJMValue 5 ++#define kSendCJ 6 ++#define kSetCallFunctionCategory 7 ++ ++typedef long v250IdStringCode; ++#define kGMIString 1 ++#define kGMMString 2 ++#define kGMRString 3 ++#define kGSNString 4 ++#define kGOIString 5 ++ ++typedef long kCallProgressParameterCode; ++#define kModemSignalPowerThreshold 1 ++#define kDialtonePowerThreshold 2 ++#define kRingBackPowerThreshold 3 ++#define kBusyPowerThreshold 4 ++#define kReorderPowerThreshold 5 ++#define k2ndDTnPowerThreshold 6 ++#define kMinDialtoneTime 7 ++#define kDialtoneFreqRange 8 ++#define kRingBackFreqRange 9 ++#define kBusyFreqRange 10 ++#define kReorderFreqRange 11 ++#define k2ndDTnFreqRange 12 ++ ++ ++typedef long framerParameterCode; ++#define kSetHDLCLeadingFlags 0 ++#define kHDLCResetFlagDetection 1 ++#define kSyncFramerSetup 2 ++#define kHDLCSendCRC 3 ++#define kHDLCSendFlags 4 ++#define kHDLCSendAborts 5 ++ ++ ++typedef long logDataCode; ++#define eyeData 0 ++#define mseData 1 ++#define rxData 2 ++#define txData 3 ++#define neecData 4 ++#define eqlData 5 ++#define ieecData 6 ++#define feecData 7 ++#define eqlPllData 8 ++#define feecPllData 9 ++#define timingData 10 ++#define pjPhaseErrData 11 ++#define pjEstimateData 12 ++#define pjEstDiffData 13 ++#define pjCoefData 14 ++#define inputSignalData 15 ++#define outputSignalData 16 ++#define agcGainData 17 ++#define automoderData 18 ++#define v8CMData 19 ++#define v8JMData 20 ++#define inputAfterNeecData 21 ++#define eqlErrData 22 ++#define dpskMicrobitsData 23 ++#define v34P2LSamplesData 24 ++#define phaseSplittedLData 25 ++#define fftedLData 26 ++#define channelSNRData 27 ++#define noiseEstimateData 28 ++#define signalEstimateData 29 ++#define v34INFOData 30 ++#define v34ChanProbData 31 ++#define v34P2OutputData 32 ++#define v8ANSamDetectData 33 ++#define pFeecData 34 ++#define channelDelayData 35 ++#define timingOffsetData 36 ++#define trellisMSEData 37 ++#define interpolatedSignalData 38 ++#define dcCancelledSignalData 39 ++#define echoCancelledSignalData 40 ++#define predictorErrData 41 ++#define commandInfoData 42 ++#define unusedInfoData 43 ++#define atCommandInfoData 44 ++#define atResponseInfoData 45 ++#define hwTerminalTxData 46 ++#define hwTerminalRxData 47 ++#define statusInfoData 48 ++#define channelResponseData 49 ++#define channelImpulseRespData 50 ++#define x2PcmP1DetectorInData 51 ++#define x2PcmP1DetectorOutData 52 ++#define eqlRealData 53 ++#define ieecRealData 54 ++#define neecOutputData 55 ++#define precodedEqlOutputData 56 ++#define eqlRealErrData 57 ++#define idealEqlOutputData 58 ++#define agcData 59 ++#define pcmInfidelityData 60 ++#define v42bisCycleCount 61 ++#define pcmImdOffsetCoefData 62 ++#define pcmImdOffsetData 63 ++#define v90RcvdDilLongData 64 ++#define v90RcvdDilShortData 65 ++#define v90DilProducedData 66 ++#define pcmEncoderKbitsData 67 ++#define pcmEncoderMbitsData 68 ++#define pcmEncoderSbitsData 69 ++#define pcmDecoderKbitsData 70 ++#define pcmDecoderMbitsData 71 ++#define pcmDecoderSbitsData 72 ++#define v90CPorCPtData 73 ++#define mnpDecoderInputData 74 ++#define mnpDecoderOutputData 75 ++#define v42bisEncoderInputData 76 ++#define v42bisDecoderInputData 77 ++#define modulatorInputData 78 ++#define modulatorOutputData 79 ++#define encodedStatusData 80 ++#define blockFramerTxData 81 ++#define blockFramerRxData 82 ++#define framerTxData 83 ++#define framerRxData 84 ++#define dpskBasebandData 85 ++#define dpskBasebandLPFedData 86 ++#define dpskRealData 87 ++#define bandEdgeCorrectedSignalData 88 ++#define atmLogData 89 ++#define clearEocLogData 90 ++#define g997LogData 91 ++ ++ ++#define kLogDataDelimiter 0xFEFEFEFE ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.3 Handlers */ ++/****************************************************************************/ ++ ++typedef void (SM_DECL *rcvHandlerType) (void *gDslVars, int, short*); ++typedef void (SM_DECL *xmtHandlerType) (void *gDslVars, int, short*); ++typedef int (SM_DECL *xmtHandlerWithRtnValType) (void *gDslVars, int, short*); ++typedef void (SM_DECL *timerHandlerType) (void *gDslVars, long); ++typedef int (SM_DECL *interpolatorHandlerType) (void *gDslVars, int, short*, short*); ++typedef void (SM_DECL *controlHandlerType) (void *gDslVars, int); ++ ++typedef int (SM_DECL *txDataHandlerType) (void *gDslVars, int, uchar*); ++typedef int (SM_DECL *rxDataHandlerType) (void *gDslVars, int, uchar*); ++ ++typedef bitMap (SM_DECL *signalDetectorType) (void *gDslVars, int, long, long*); ++ ++ ++typedef void (SM_DECL *hookHandlerType) (void *gDslVars, Boolean); ++ ++typedef short* (SM_DECL *sampBuffPtrType) (void *gDslVars, int); ++ ++typedef void (SM_DECL *eyeHandlerType) (void *gDslVars, int, ComplexShort*); ++typedef void (SM_DECL *logHandlerType) (void *gDslVars, logDataCode, ...); ++ ++typedef void (SM_DECL *voidFuncType) (void *gDslVars); ++ ++typedef int (SM_DECL *txAudioHandlerType) (void *gDslVars, int, short*); ++typedef int (SM_DECL *rxAudioHandlerType) (void *gDslVars, int, short*); ++ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.4 Structures */ ++/****************************************************************************/ ++ ++/* ++ * AT command processor definitions ++ */ ++#define kATRegistersNumber 56 ++#define kFirstConfigurationRegister 500 ++#define kLastConfigurationRegister 515 ++#define kFirstInternationalRegister 516 ++#define kLastInternationalRegister 595 ++ ++ ++ ++#define kATMaxDialStringSize 128 ++typedef struct ++ { ++ struct ++ { ++ uchar loadNumber; /* Which profile to load upon powerup/reset */ ++ uchar countryCode; /* T.35 Country Code */ ++ uchar profile[2][kATRegistersNumber]; ++ uchar dialString[4][kATMaxDialStringSize + 1]; ++ } config; ++ ulong versionCode; ++ ulong crcCheckSum; ++ } NVRAMConfiguration; ++ ++/* Structure to hold international settings */ ++typedef struct ++ { ++ char *name; ++ int countryCode; ++ const SRegisterDefinition *userRegisters; ++ const ulong *configRegisters; ++ } CountryDescriptor; ++ ++/* ++ * V.34 coding parameters structure ++ */ ++ ++typedef struct ++ { ++ /* DO NOT CHANGE THE ORDER OF FIELDS IN THIS STRUCTURE! ++ * (Some assembly code depends on it!) If you ++ * must add fields, please do so at the bottom. ++ */ ++ ++ int symbolRateIndex, ++ dataRateIndex, ++ userSNRAdjustment; ++ Boolean auxChannel, ++ expConstellation, ++ precoding, ++ nonlinearCoding; ++ schar J, /* number of data frames in superframe */ ++ P, /* number of mapping frames in a data frame */ ++ r, /* number of high mapping frames in a data frame */ ++ b, /* number of data bits in a mapping frame */ ++ W, /* number of aux bits in a data frame */ ++ K, /* number of S bits in a mapping frame */ ++ q, /* number of Q bits in a 2D symbol */ ++ M; /* number of rings in shell mapping */ ++ long nominalVariance; /* the signal variance which gives 1e-2 BLER Q10 */ ++ int bitsPerDataFrame; ++ short quantRoundOff, ++ quantMask; ++ uchar nTrellisStates, ++ log2NTrellisStates; ++ short gain1xmt, ++ gain2xmt, ++ gain1rcv, ++ gain2rcv; ++ ushort bitInversionPattern; ++ } V34CodingParams; ++ ++typedef long v8bisStatusCode; ++typedef bitMap v8bisConnectionSetup; ++#if defined(V8BIS) || defined(AT_COMMANDS_V8BIS) ++#include "V8bisMainTypes.h" ++#endif ++ ++#define kMaxMultiTones 4 /* MultiTone: search for up to this many tones at once */ ++ ++#ifndef ADSL_MODEM ++typedef struct ++ { ++ modemStatusCode code; ++ union ++ { ++ long value; ++ long freq; ++ modemErrorCode error; ++ modulationMap modulation; ++ modulationMap modemSignal; ++ dataRateMap dataRate; ++ long dtmfSignal; ++ bitMap callProgressSignal; ++ bitMap customSignal; ++ void *ptr; ++ struct ++ { ++ long detected; ++ long numTones; ++ long tones[kMaxMultiTones]; ++ } multiToneInfo; ++ struct ++ { ++ v8bisStatusCode code; ++ long value; ++ } v8bisStatus; ++ struct ++ { ++ trainingProgressCode code; ++ long value; ++ } trainingInfo; ++ struct ++ { ++ long code; ++ long value; ++ } v24Circuit; ++ struct ++ { ++ trainingProgressCode code; ++ void* ptr; ++ } advancedTrainingInfo; ++ struct ++ { ++ capabilitiesStatusCode code; ++ long value; ++ } capabilitiesStatusInfo; ++ struct ++ { ++ connectionInfoCode code; ++ long value; ++ } connectionInfo; ++ struct ++ { ++ connectionInfoCode code; ++ int length; ++ uchar *ptr; ++ } advancedConnectionInfo; ++ struct ++ { ++ dialerStatusCode code; ++ long value; ++ long makeTime; ++ long breakTime; ++ } dialerStatus; ++ struct ++ { ++ long enabled; ++ long volume; ++ } speakerStatus; ++ framingInfoCode framingInfo; ++ IOStatusCode ioStatus; ++ struct ++ { ++ lapmStatusCode code; ++ union ++ { ++ long value; ++ lapmTakedownReason reason; ++ lapmErrorCode error; ++ lapmTestResultCode testResult; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ } param; ++ } lapmStatus; ++ struct ++ { ++ lapmParameterCode code; ++ long value; ++ } lapmParameter; ++ struct ++ { ++ v42bisStatusCode code; ++ union ++ { ++ long value; ++ v42bisErrorCode error; ++ struct ++ { ++ long nBytesIn; ++ long nBytesOut; ++ } statistic; ++ } param; ++ } v42bisStatus; ++ struct ++ { ++ mnpStatusCode code; ++ union ++ { ++ long value; ++ mnpTakedownReason reason; ++ mnpErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ ulong nSize; ++ uchar *Buffer; ++ } fallback; ++ struct ++ { ++ char *header; ++ void *frame; ++ } frame; ++ struct ++ { ++ long nack; ++ long rFrameNo; ++ } timeout; ++ struct ++ { ++ long frameNo; ++ long framesPending; ++ } retrFrame; ++ } param; ++ } mnpStatus; ++ struct ++ { ++ mnpParameterCode code; ++ long value; ++ } mnpParameter; ++ struct ++ { ++ v70StatusCode code; ++ union ++ { ++ long value; ++ v70TakedownReason reason; ++ v70ErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nack; ++ long rFrameNo; ++ } timeout; ++ struct ++ { ++ long frameNo; ++ long framesPending; ++ } retrFrame; ++ struct ++ { ++ long ChannelId; ++ long DLCI; ++ ulong LcNum; ++ v70TakedownReason reason; ++ } channelInfo; ++ struct ++ { ++ long ChannelId; ++ long stateOld; ++ long stateNew; ++ } stateInfo; ++ } param; ++ ulong v70Time; ++ } v70Status; ++ struct ++ { ++ audioStatusCode code; ++ union ++ { ++ long value; ++ struct ++ { ++ long nReq; ++ long nAvail; ++ } buffer; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ } param; ++ } audioStatus; ++ struct ++ { ++ v80StatusCode code; ++ union ++ { ++ long value; ++ v80TakedownReason reason; ++ v80ErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long code; ++ long value; ++ } inBand; ++ } param; ++ ulong v80Time; ++ } v80Status; ++ struct ++ { ++ v70ParameterCode code; ++ long value; ++ } v70Parameter; ++ struct ++ { ++ breakType type; ++ long length; ++ } breakStatus; ++ struct ++ { ++ callerIDStatusCode code; ++ union ++ { ++ long value; ++ struct ++ { ++ callerIDErrorCode code; ++ long value; ++ } callerIDError; ++ struct ++ { ++ long length; ++ char* ptr; ++ } message; ++ } param; ++ } callerIDStatus; ++ struct ++ { ++ ulong signal; ++ uchar *msg1; ++ long msg1Length; ++ uchar *msg2; ++ long msg2Length; ++ } A8RStatus; ++ struct ++ { ++ overlayStatusCode code; ++ long value; ++ long value2; ++ } overlayStatus; ++ struct ++ { ++ ulong nBits; ++ ulong nBlocks; ++ ulong nBitErrors; ++ ulong nBlockErrors; ++ ++ ulong nAudioBits; ++ ulong nAudioBlocks; ++ ulong nAudioSyncErrors; ++ ulong nAudioBlockErrors; ++ } testResults; ++ ulong checksum; ++ struct ++ { ++ ulong sizeM; ++ uchar *filename; ++ } logFileControlStatus; ++ struct ++ { ++ long direction; ++ long module; ++ long message; ++ long data; ++ } ++ faxClass2Status; ++ ++ } param; ++ } modemStatusStruct; ++ ++typedef void (SM_DECL *statusHandlerType) (void *gDslVars, modemStatusStruct*); ++#endif /* ADSL_MODEM */ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.5 Command structure */ ++/****************************************************************************/ ++ ++typedef struct ++ { ++ Boolean remoteModemIsFlex; ++ uchar countryCode; ++ ushort manufacturerId; ++ uchar licenseeId; ++ uchar productCapabilities; ++ Boolean digitalModeFlag; ++ Boolean prototypeFlag; ++ uchar version; ++ } ++FlexV8bisStruct; ++ ++typedef struct ++ { ++ symbolRateMap symbolRates; ++ dataRateMap dataRates; ++ dataRateMap dataRates56k; ++ dataRateMap dataRatesFlex; ++ featureMap features; ++ bitMap auxFeatures; ++ bitMap demodCapabilities; ++ long rateThresholdAdjustment; /* dB Q4 */ ++ FlexV8bisStruct flexRemoteV8bisInfo; ++ } dataPumpCapabilities; ++ ++#ifndef ADSL_MODEM ++typedef struct SoftwareModemCommandParameters ++ { ++ modemCommandCode command; ++ union ++ { ++ long xmtGain; ++ ulong hybridDelayQ4ms; ++ long modemSampleRate; ++ long timeInMs; ++ long state; ++ long freq; ++ NVRAMConfiguration *nvramConfigurationPtr; ++ long enabled; ++ long value; ++ uchar *phoneNumber; ++ uchar *faxECMPageBufferPtr; ++ CountryDescriptor *countryDescriptorTable; ++ struct ++ { ++ dataRateMap dteRate; ++ bitMap format; ++ } dteRateSpec; ++ struct ++ { ++ v8ControlType code; ++ long value; ++ uchar *buffer; ++ } v8ControlSpec; ++ struct ++ { ++ directionType direction; ++ v8bisConnectionSetup setup; ++ void *capPtr; ++ voidFuncType confirmMsFunc; ++ voidFuncType genMsFunc; ++ xmtHandlerWithRtnValType ogmFunc; ++ } v8bisSpec; ++ struct ++ { ++ directionType direction; ++ } ADSISpec; ++ struct ++ { ++ directionType direction; ++ modulationMap modulations; ++ dataPumpCapabilities capabilities; ++ } modeSpec; ++ struct ++ { ++ long time, ++ freq1, ++ freq2, ++ freq3, ++ freq4, ++ mag1, ++ mag2, ++ mag3, ++ mag4; ++ } toneSpec; ++ struct ++ { ++ long signal; ++ uchar *msg1; ++ long msg1Length; ++ uchar *msg2; ++ long msg2Length; ++ long sig_en; ++ long msg_en; ++ long supp_delay; ++ } ++ v8bisMessageSpec; ++ struct ++ { ++ linkLayerType type; ++ bitMap setup; ++ dataRateMap rxDataRate; ++ dataRateMap txDataRate; ++ long rtDelayQ4ms; ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } linkLayerSpec; ++ struct ++ { ++ framerType type; ++ bitMap setup; ++ directionType direction; ++ long fill[2]; /* need to match linkLayerSpec */ ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } framerSpec; ++ struct ++ { ++ framerParameterCode code; ++ long value; ++ } framerParameterSpec; ++ struct ++ { ++ bitMap callProgressDetectorSetup; ++ signalDetectorType callProgressDetectorPtr; /* if nil, use defaults */ ++ signalDetectorType customDetectorPtr; /* if nil, no custom detector */ ++ } callProgressMonitorSpec; ++ struct ++ { ++ ulong maxTones; /* maximum number of simultaneous tones to detect */ ++ ulong allowableVariance; /* maximum cumulative variance in the eight interpolated frequencies */ ++ ulong totalPowerThreshold; /* ignore complete block if power less than this */ ++ ulong powerShiftThreshold; /* ignore a bin if its power is less than (totalPowerValue >> powerShiftThreshold) */ ++ ulong toneMatchThresholdHz; /* tones within +/- this many Hz of original tone are considered the same tone */ ++ ulong binSeparation; /* ignore tones with a spacing of less than this */ ++ ulong outsideFreqDeviation; /* an individual value in the interpolated array can be up to this many Hz outside of the expected angle range */ ++ } multiToneSpec; ++ struct ++ { ++ uchar *dialString; /* nil limited string for DTMF dialing sequence */ ++ long pulseBreakTime, ++ pulseMakeTime, ++ pulseInterDigitTime, ++ toneDigitTime, ++ toneInterDigitTime, ++ toneLoGroupMag, ++ toneHiGroupMag, ++ flashTime, ++ pauseTime, ++ signalWaitTimeout, ++ blindDialingTimeout; ++ bitMap dialerSetup; ++ bitMap callProgressDetectorSetup; ++ signalDetectorType callProgressDetectorPtr; /* if nil, use defaults */ ++ signalDetectorType customDetectorPtr; /* if nil, no custom detector */ ++ hookHandlerType hookHandlerPtr; /* nil if DTMF dialing specified*/ ++ } dialSpec; ++ struct ++ { ++ long timeOn, ++ timeOff, ++ freq; ++ } callingToneSpec; ++ union ++ { ++ statusHandlerType statusHandlerPtr; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } handlerSpec; ++ struct ++ { ++ breakType type; ++ long length; ++ } breakSpec; ++ struct ++ { ++ long length; ++ uchar *dataPtr; ++ } lapmTestSpec; ++ struct ++ { ++ bitMap setupLapm; ++ rxDataHandlerType rxAudioHandlerPtr; ++ txDataHandlerType txAudioHandlerPtr; ++ } v70SetupSpec; ++ struct ++ { ++ ulong ChannelId; ++ ulong LogChannelNum; ++ ulong PortNum; ++ } EstChannelSpec; ++ struct ++ { ++ ulong ChannelId; ++ } WaitChannelSpec; ++ struct ++ { ++ ulong ChannelId; ++ ulong LogChannelNum; ++ ulong PortNum; ++ ulong DLCI; ++ } RelChannelSpec; ++ struct ++ { ++ audioType type; ++ bitMap setup; ++ dataRateMap rxAudioRate; ++ dataRateMap txAudioRate; ++ rxAudioHandlerType rxAudioHandlerPtr; ++ txAudioHandlerType txAudioHandlerPtr; ++ } audioSpec; ++ struct ++ { ++ long code; ++ long value; ++ } v24Circuit; ++ struct ++ { ++ ulong code; ++ ulong value; ++ ulong minValue; ++ ulong maxValue; ++ } atRegister; ++ struct ++ { ++ long code; ++ uchar *response; ++ } atiSpec; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frameSpec; ++ struct ++ { ++ long code; ++ union ++ { ++ long value; ++ struct ++ { ++ long loFreq1; ++ long hiFreq1; ++ long loFreq2; ++ long hiFreq2; ++ } freqRange; ++ } params; ++ } callProgressParamSpec; ++ struct ++ { ++ v250IdStringCode v250IdCode; ++ uchar *v250IdString; ++ } v250IdSpec; ++ ++ } param; ++ } modemCommandStruct; ++ ++typedef Boolean (*commandHandlerType) (modemCommandStruct*); ++#endif /* ADSL_MODEM */ ++ ++ ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.1 Definitive constants */ ++/****************************************************************************/ ++ ++#define kMaxSampleBlockSize 48 ++#define kMaxDataBlockSize 48 ++ ++#define kMaxDialStringLength 127 ++#define kCallProgressSampleRate 7200 ++ ++#define kMaxCallerIDMessageLength 80 ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.2 Bit maps */ ++/****************************************************************************/ ++ ++/* modulationMap */ ++ ++#define kIdle 0x00000000 ++#define kV25 0x00000001 ++#define kV8 0x00000002 ++#define kCid 0x00000004 ++#define kV8bis 0x00000008 ++#define kV21 0x00000010 ++#define kV22 0x00000020 ++#define kV23 0x00000040 ++#define kV32 0x00000080 ++#define kV34 0x00000100 ++#define kX2 0x00000200 ++#define kV90 0x00000400 ++#define k56Flex 0x00000800 ++#define kV27 0x00001000 ++#define kV29 0x00002000 ++#define kV17 0x00004000 ++#define kV34HDX 0x00008000 ++#define kV34HDXC 0x00010000 ++#define kBell103 0x00100000 ++#define kBell212 0x00200000 ++#define kDataCallingTone 0x01000000 ++#define kFaxCallingTone 0x02000000 ++ ++#define kV22FastNZConnect 0x04000000 ++#define kV22FastNNZConnect 0x08000000 ++#define kV22FastConnect (kV22FastNZConnect|kV22FastNNZConnect) ++#define kV22bisFastConnect 0x10000000 ++ ++ ++#define kDataModulations (kV25 | kV8 | kV21 | kV22FastConnect | kV22bisFastConnect | kV22 | kV23 | kV32 | kV34 | kBell103 | kBell212) ++#define kDataOnlyModulations (kV21 | kV22 | kV23 | kV32 | kBell103 | kBell212) ++#define kPCMModulations (kV90 | kX2 | k56Flex) ++ ++#define kFaxModulations (kV25 | kV21 | kV27 | kV29 | kV17) ++#define kFaxOnlyModulations (kV27 | kV29 | kV17) ++#define kFaxModulationShift 12 ++ ++/* symbolRateMap */ ++ ++#define k1200Hz 0x00000001 ++#define k1600Hz 0x00000002 ++#define k2400Hz 0x00000004 ++#define k2743Hz 0x00000008 ++#define k2800Hz 0x00000010 ++#define k3000Hz 0x00000020 ++#define k3200Hz 0x00000040 ++#define k3429Hz 0x00000080 ++#define k8000Hz 0x00000100 ++ ++#define kAllSymbolRates ( k1200Hz | k1600Hz | k2400Hz | k2743Hz | \ ++ k2800Hz | k3000Hz | k3429Hz | k8000Hz ) ++ ++/* dataRateMap */ ++ ++#define k75bps 0x00000002 ++#define k300bps 0x00000004 ++#define k600bps 0x00000008 ++#define k1200bps 0x00000010 ++#define k2400bps 0x00000020 ++#define k4800bps 0x00000040 ++#define k7200bps 0x00000080 ++#define k9600bps 0x00000100 ++#define k12000bps 0x00000200 ++#define k14400bps 0x00000400 ++#define k16800bps 0x00000800 ++#define k19200bps 0x00001000 ++#define k21600bps 0x00002000 ++#define k24000bps 0x00004000 ++#define k26400bps 0x00008000 ++#define k28800bps 0x00010000 ++#define k31200bps 0x00020000 ++#define k33600bps 0x00040000 ++#define k36000bps 0x00080000 ++#define k38400bps 0x00100000 ++#define k57600bps 0x00200000 ++#define k115200bps 0x00400000 ++#define k230400bps 0x00800000 ++#define k460800bps 0x01000000 ++#define k921600bps 0x02000000 ++/* ++ * kPCMRate is used to identify that the reported rate is ++ * PCM modulation rate, and is only used for PCM modulation while ++ * reporting rate !!!! ++ */ ++#define kPCMRate 0x40000000 ++#define kPCMFlexRate 0x80000000 ++#define kAllDataRates 0x0FFFFFFF ++ ++/* rates specific for X2 and V.90 */ ++#define kPCM25333bps 0x00000001 ++#define kPCM26666bps 0x00000002 ++#define kPCM28000bps 0x00000004 ++#define kPCM29333bps 0x00000008 ++#define kPCM30666bps 0x00000010 ++#define kPCM32000bps 0x00000020 ++#define kPCM33333bps 0x00000040 ++#define kPCM34666bps 0x00000080 ++#define kPCM36000bps 0x00000100 ++#define kPCM37333bps 0x00000200 ++#define kPCM38666bps 0x00000400 ++#define kPCM40000bps 0x00000800 ++#define kPCM41333bps 0x00001000 ++#define kPCM42666bps 0x00002000 ++#define kPCM44000bps 0x00004000 ++#define kPCM45333bps 0x00008000 ++#define kPCM46666bps 0x00010000 ++#define kPCM48000bps 0x00020000 ++#define kPCM49333bps 0x00040000 ++#define kPCM50666bps 0x00080000 ++#define kPCM52000bps 0x00100000 ++#define kPCM53333bps 0x00200000 ++#define kPCM54666bps 0x00400000 ++#define kPCM56000bps 0x00800000 ++#define kPCM57333bps 0x01000000 ++ ++#define kV90ServerToClientDataRates \ ++ ( kPCM28000bps | kPCM29333bps | kPCM30666bps | \ ++ kPCM32000bps | kPCM33333bps | kPCM34666bps | \ ++ kPCM36000bps | kPCM37333bps | kPCM38666bps | \ ++ kPCM40000bps | kPCM41333bps | kPCM42666bps | \ ++ kPCM44000bps | kPCM45333bps | kPCM46666bps | \ ++ kPCM48000bps | kPCM49333bps | kPCM50666bps | \ ++ kPCM52000bps | kPCM53333bps | kPCM54666bps | \ ++ kPCM56000bps | kPCM57333bps ) ++ ++#define kV90ClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | \ ++ k14400bps | k16800bps | k19200bps | k21600bps | \ ++ k24000bps | k26400bps | k28800bps | k31200bps | \ ++ k33600bps ) ++ ++ ++ ++#define kX2ServerToClientDataRates \ ++ ( kPCM25333bps | kPCM26666bps | kPCM28000bps | \ ++ kPCM29333bps | kPCM30666bps | kPCM32000bps | \ ++ kPCM33333bps | \ ++ kPCM34666bps | kPCM36000bps | kPCM37333bps | \ ++ kPCM38666bps | kPCM40000bps | kPCM41333bps | \ ++ kPCM42666bps | kPCM44000bps | kPCM45333bps | \ ++ kPCM46666bps | kPCM48000bps | kPCM49333bps | \ ++ kPCM50666bps | kPCM52000bps | kPCM53333bps | \ ++ kPCM54666bps | kPCM56000bps | kPCM57333bps ) ++#define kX2ClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | k14400bps | \ ++ k16800bps | k19200bps | k21600bps | k24000bps | k26400bps | k28800bps | \ ++ k31200bps ) ++ ++ /* ++ Rates specific for Flex ++ */ ++#define kPCMFlex32000bps 0x00000001 ++#define kPCMFlex34000bps 0x00000002 ++#define kPCMFlex36000bps 0x00000004 ++#define kPCMFlex38000bps 0x00000008 ++#define kPCMFlex40000bps 0x00000010 ++#define kPCMFlex42000bps 0x00000020 ++#define kPCMFlex44000bps 0x00000040 ++#define kPCMFlex46000bps 0x00000080 ++#define kPCMFlex48000bps 0x00000100 ++#define kPCMFlex50000bps 0x00000200 ++#define kPCMFlex52000bps 0x00000400 ++#define kPCMFlex54000bps 0x00000800 ++#define kPCMFlex56000bps 0x00001000 ++#define kPCMFlex58000bps 0x00002000 ++#define kPCMFlex60000bps 0x00004000 ++ ++#define kFlexServerToClientDataRates \ ++ ( kPCMFlex32000bps | kPCMFlex34000bps | kPCMFlex36000bps | kPCMFlex38000bps | \ ++ kPCMFlex40000bps | kPCMFlex42000bps | kPCMFlex44000bps | kPCMFlex46000bps | \ ++ kPCMFlex48000bps | kPCMFlex50000bps | kPCMFlex52000bps | kPCMFlex52000bps | \ ++ kPCMFlex54000bps | kPCMFlex56000bps | kPCMFlex58000bps | kPCMFlex60000bps ) ++ ++#define kFlexClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | \ ++ k14400bps | k16800bps | k19200bps | k21600bps | \ ++ k24000bps | k26400bps | k28800bps | k31200bps ) ++ ++ ++#define k2400BitShift 5 ++#define k4800BitShift 6 ++ ++#define kPCM28000bpsShift 2 ++ ++#define kV21Rates k300bps ++#define kV22Rates k1200bps ++#define kV22bisRates (k1200bps | k2400bps) ++#define kV23Rates (k75bps | k1200bps) ++#define kCidRates (k1200bps) ++#define kV32Rates (k4800bps | k9600bps) ++#define kV32bisRates (kV32Rates | k7200bps | k12000bps | k14400bps) ++#define kV32terboRates (kV32bisRates | k16800bps | k19200bps) ++#define kV34Rates ( k2400bps | k4800bps | k7200bps | k9600bps | k12000bps | k14400bps | \ ++ k16800bps | k19200bps | k21600bps | k24000bps | k26400bps | k28800bps | \ ++ k31200bps | k33600bps ) ++ ++#define kV27Rates (k2400bps | k4800bps) ++#define kV29Rates (k4800bps | k7200bps | k9600bps) ++#define kBell103Rates k300bps ++#define kBell212Rates k1200bps ++ ++ ++/* Demodulator capabilities */ ++#define kNeecEnabled 0x00000001 ++#define kPFeecEnabled 0x00000002 ++#define kIeecEnabled 0x00000004 ++#define kFeecEnabled 0x00000008 ++ ++#define kRapidEqualizerTraining 0x00000010 ++#define kRapidPECTraining 0x00000020 ++#define kRapidECTraining 0x00000040 ++#define kAutoLoadReductionEnabled 0x00000080 ++ ++#define kTimingTrackingEnabled 0x00000100 ++#define kPhaseLockedLoopEnabled 0x00000200 ++#define kFeecPhaseLockedLoopEnabled 0x00000400 ++#define kPhaseJitterTrackingEnabled 0x00000800 ++ ++#define kClockErrorTrackingEnabled 0x00001000 ++#define kFreqOffsetTrackingEnabled 0x00002000 ++#define kFeecFreqOffsetTrackingEnabled 0x00004000 ++ ++#define kShorterNeecEnabled 0x00008000 ++#define kShorterPFeecEnabled 0x00010000 ++#define kFrondEndHPFilterEnabled 0x00020000 ++#define kGainControlEnabled 0x00040000 ++#define kPhaseHitControlEnabled 0x00080000 ++#define kBandEdgeCorrectorEnabled 0x00100000 ++#define kDisableFaxFastClearDown 0x00200000 ++ ++#define kImdOffsetCompensationEnabled 0x00400000 ++ ++#define kV34ShortEqlLengthExtShift 23 ++#define kV34ShortEqlLengthExtMask (0x3< */ ++#define kSAM8bitSYNHuntDisabled 0 ++#define kSAM8bitSYNHuntEnabled ((ulong)1 << kSAMTransparentIdleTypeShift) ++#define kSAM16bitSYNHuntEnabled ((ulong)2 << kSAMTransparentIdleTypeShift) ++ ++/* */ ++#define kSAMSendFlagsOnIdle 0 ++#define kSAMSendMarksOnIdle ((ulong)1 << kSAMFramedIdleTypeShift) ++ ++/* */ ++#define kSAMAbortOnUnderrun 0 ++#define kSAMFlagsOnUnderrun ((ulong)1 << kSAMFramedOverrunActionShift) ++ ++/* */ ++#define kSAMHalfDuplexNoAuto 0 ++#define kSAMHalfDuplexAuto ((ulong)1 << kSAMHalfDuplexModeShift) ++ ++ ++/* */ ++#define kSAMNoCRC 0 ++#define kSAM16bitCRC ((ulong)1 << kSAMCRCTypeShift) ++#define kSAM32bitCRC ((ulong)2 << kSAMCRCTypeShift) ++ ++/* */ ++#define kSAMNRZIDisabled 0 ++#define kSAMNRZIEnabled ((ulong)1 << kSAMNRZIEnabledShift) ++ ++ ++/* LAPM setup maps */ ++#define kLapmDirection 0x00000001 /* Bit 0 */ ++#define kLapmSREJEnabled 0x00000002 /* Bit 1 */ ++#define kLapmDetectionEnabled 0x00000004 /* Bit 2 */ ++#define kLapmLongADPEnabled 0x00000008 /* Bit 3 */ ++ ++#define kLapmCompressionEnabledMask 0x00000030 ++#define kLapmTxCompressionEnabled 0x00000010 /* Bit 4 */ ++#define kLapmRxCompressionEnabled 0x00000020 /* Bit 5 */ ++#define kLapmCompressionEnabledShift 4 ++ ++#define kLapmRetryLimitMask 0x000000C0 /* Bits 6,7 */ ++ ++#define kLapmNoRetryLimit 0x00000000 ++#define kLapm4Retries 0x00000040 ++#define kLapm8Retries 0x00000080 ++#define kLapm20Retries 0x000000C0 ++ ++#define kLapmWindowSizeMask 0x00001F00 /* Bits 8-12 */ ++#define kLapmWindowSizeShift 8 ++ ++#define kLapmWindowSize8 0x00000800 ++#define kLapmWindowSize15 0x00000F00 ++ ++ ++#define kLapmInfoFieldSizeMask 0x0000E000 /* Bits 13-15 */ ++#define kLapmInfoField8Bytes 0x00000000 ++#define kLapmInfoField16Bytes 0x00002000 ++#define kLapmInfoField32Bytes 0x00004000 ++#define kLapmInfoField64Bytes 0x00006000 ++#define kLapmInfoField128Bytes 0x00008000 ++#define kLapmInfoField192Bytes 0x0000A000 ++#define kLapmInfoField256Bytes 0x0000C000 ++#define kLapmInfoField512Bytes 0x0000E000 ++#define kLapmInfoFieldSizeShift 13 ++ ++#define kLapmT400Mask 0x00030000 /* Bits 16-17 */ ++#define kLapmAutoT400 0x00000000 ++#define kLapm750msT400 0x00010000 ++#define kLapm3secT400 0x00020000 ++#define kLapm30secT400 0x00030000 ++ ++#define kLapmT401Mask 0x000C0000 /* Bits 18-19 */ ++#define kLapmAutoT401 0x00000000 ++#define kLapm750msT401 0x00040000 ++#define kLapm3secT401 0x00080000 ++#define kLapm6secT401 0x000C0000 ++ ++#define kLapmT403Mask 0x00300000 /* Bits 20-21 */ ++#define kLapmAutoT403 0x00000000 ++#define kLapm750msT403 0x00100000 ++#define kLapm2secT403 0x00200000 ++#define kLapm4secT403 0x00300000 ++ ++ ++ ++#define kLapmDictSizeMask 0x00C00000 /* Bits 22-23 */ ++#define kLapmDictSize512 0x00000000 ++#define kLapmDictSize1024 0x00400000 ++#define kLapmDictSize2048 0x00800000 ++#define kLapmDictSize4096 0x00C00000 ++ ++#define kLapmStringSizeMask 0xFF000000 /* Bits 24-31 */ ++#define kLapmStringSizeShift 24 ++ ++/* MNP setup maps */ ++ ++#define kMnpMinPLevel 0x00000001 /* Bit 0: 1 - Minimal, 0 - Standard */ ++#define kMnpStdPLevel 0x00000000 /* Bit 0: 1 - Minimal, 0 - Standard */ ++ ++#define kMnpOptimizationEnabled 0x00000002 /* Bit 1 */ ++#define kMnpOptimizationDisabled 0x00000000 /* Bit 1 */ ++ ++#define kMnpCompressionEnabled 0x00000004 /* Bit 2 */ ++#define kMnpCompressionDisabled 0x00000000 /* Bit 2 */ ++ ++#define kMnpClassMask 0x00000018 ++#define kMnpClassShift 3 ++#define kMnpClass1 0x00000008 ++#define kMnpClass2 0x00000010 ++#define kMnpClass3 0x00000018 /* Bits 3,4 */ ++ ++#define kMnpMaxRetryMask 0x00000060 /* Bits 5,6 */ ++#define kMnpMaxRetryShift 5 ++#define kMnpNoRetryLimit 0x00000000 ++#define kMnp4Retries 0x00000020 ++#define kMnp8Retries 0x00000040 ++#define kMnp20Retries 0x00000060 ++ ++#define kMnpInfoFieldSizeMask 0x00000380 /* Bits 7-9 */ ++#define kMnpInfoFieldSizeShift 7 ++#define kMnpInfoField8Bytes 0x00000000 ++#define kMnpInfoField16Bytes 0x00000080 ++#define kMnpInfoField32Bytes 0x00000100 ++#define kMnpInfoField64Bytes 0x00000180 ++#define kMnpInfoField128Bytes 0x00000200 ++#define kMnpInfoField192Bytes 0x00000280 ++#define kMnpInfoField256Bytes 0x00000300 ++#define kMnpInfoField260Bytes 0x00000380 ++ ++#define kMnpT400Mask 0x00003000 /* Bits 12,13 */ ++#define kMnpT400Shift 12 ++#define kMnpAutoT400 0x00000000 ++#define kMnp750msT400 0x00001000 ++#define kMnp3secT400 0x00002000 ++#define kMnp6secT400 0x00003000 ++ ++#define kMnpT401Mask 0x0000C000 /* Bits 14,15 */ ++#define kMnpT401Shift 14 ++#define kMnpAutoT401 0x00000000 ++#define kMnp750msT401 0x00004000 ++#define kMnp3secT401 0x00008000 ++#define kMnp6secT401 0x0000C000 ++ ++#define kMnpT403Mask 0x00030000 /* Bits 16,17 */ ++#define kMnpT403Shift 16 ++#define kMnpAutoT403 0x00000000 ++#define kMnp60secT403 0x00010000 ++#define kMnp600secT403 0x00020000 ++#define kMnp3600secT403 0x00030000 ++ ++#define kMnpFallbackTypeMask 0x000C0000 /* Bits 18,19 */ ++#define kMnpFallbackTypeShift 18 ++#define kMnpNoFallback 0x00000000 ++#define kMnpFallbackTime 0x00040000 ++#define kMnpFallback200 0x00080000 ++#define kMnpFallbackChar 0x000C0000 ++ ++#define kMnpWindowSizeMask 0x00300000 /* Bits 20,21 */ ++#define kMnpWindowSizeShift 20 ++#define kMnp1Frame 0x00000000 ++#define kMnp4Frames 0x00100000 ++#define kMnp8Frames 0x00200000 ++#define kMnp16Frames 0x00300000 ++ ++#define kMnpDirection 0x00800000 /* Bit 22 */ ++ ++#define kMnpFallbackCharMask 0xFF000000 /* Bit 24-31 */ ++#define kMnpFallbackCharShift 24 ++ ++/* kV34HDXTurnOffCurrentModeCmd state parameter values */ ++ ++#define kV34HDXTurnOffAsClearDown 0 ++#define kV34HDXTurnOffFromControlSource 1 ++#define kV34HDXTurnOffFromControlDestination 2 ++#define kV34HDXTurnOffFromPrimarySource 3 ++#define kV34HDXTurnOffFromPrimaryDestination 4 ++ ++/* V70 setup maps */ ++ ++#define kV70Direction 0x00000001 /* Bit 0 */ ++#define kV70uIHEnabled 0x00000002 /* Bit 1 */ ++#define kV70AudioHeaderEnabled 0x00000004 /* Bit 2 */ ++#define kV70SilenceSupprEnabled 0x00000008 /* Bit 3 */ ++ ++#define kV70SuspendResumeShift 4 ++#define kV70SuspendResumeMask (3 << kV70SuspendResumeShift) ++#define kV70SuspendResumeDisabled 0x00000000 /* Bit 4,5 */ ++#define kV70SuspendResumeWAddr 0x00000010 /* Bit 4 */ ++#define kV70SuspendResumeWoAddr 0x00000020 /* Bit 5 */ ++ ++#define kV70CrcLengthShift 6 ++#define kV70CrcLengthMask (3 << kV70CrcLengthShift) ++#define kV70CrcLength16 0x00000000 /* Bit 6,7 */ ++#define kV70CrcLength8 0x00000040 /* Bit 6 */ ++#define kV70CrcLength32 0x00000080 /* Bit 7 */ ++ ++#define kV70BlockingFactorShift 8 ++#define kV70BlockingFactorMask (3 << kV70BlockingFactorShift) ++#define kV70BlockingFactor1 0x00000000 /* Bit 8,9 */ ++#define kV70BlockingFactor2 0x00000100 /* Bit 8 */ ++#define kV70BlockingFactor3 0x00000200 /* Bit 9 */ ++#define kV70BlockingFactor4 0x00000300 /* Bit 8,9 */ ++ ++#define kV70InitChannelsShift 10 ++#define kV70InitChannelsMask (1 << kV70InitChannelsShift) ++#define kV70InitNoChannels 0x00000000 /* Bit 10,11 */ ++#define kV70InitDataChannel 0x00000400 /* Bit 10,11 */ ++#define kV70InitAudioChannel 0x00000800 /* Bit 10,11 */ ++#define kV70InitBothChannels 0x00000C00 /* Bit 10,11 */ ++ ++#define kV70OOBEnabled 0x00001000 /* Bit 12 */ ++ ++/* V80 setup maps */ ++ ++#define kV80Direction 0x00000001 /* Bit 0 */ ++ ++#define kV80ModeShift 1 ++#define kV80ModeMask (3 << kV80ModeShift) ++#define kV80SyncMode (0 << kV80ModeShift) ++#define kV80TunnellingMode (1 << kV80ModeShift) ++#define kV80SamMode (2 << kV80ModeShift) ++#define kV80SamTransparentMode (2 << kV80ModeShift) ++#define kV80SamFramedMode (3 << kV80ModeShift) ++ ++#define kV80TransIdleShift 3 ++#define kV80TransIdleMask (3 << kV80TransIdleShift) ++#define kV80TransIdleNoHunt (0 << kV80TransIdleShift) ++#define kV80TransIdleHunt8 (1 << kV80TransIdleShift) ++#define kV80TransIdleHunt16 (2 << kV80TransIdleShift) ++ ++#define kV80FrameIdleShift 5 ++#define kV80FrameIdleMask (1 << kV80FrameIdleShift) ++#define kV80FrameIdleFlags (0 << kV80FrameIdleShift) ++#define kV80FrameIdleMarks (1 << kV80FrameIdleShift) ++ ++#define kV80FrameUnOvShift 6 ++#define kV80FrameUnOvMask (1 << kV80FrameUnOvShift) ++#define kV80FrameUnOvAbort (0 << kV80FrameUnOvShift) ++#define kV80FrameUnOvFlag (1 << kV80FrameUnOvShift) ++ ++#define kV80HdAutoShift 7 ++#define kV80HdAutoMask (1 << kV80HdAutoShift) ++#define kV80HdAutoNormal (0 << kV80HdAutoShift) ++#define kV80HdAutoExtended (1 << kV80HdAutoShift) ++ ++#define kV80CrcTypeShift 8 ++#define kV80CrcTypeMask (3 << kV80CrcTypeShift) ++#define kV80NoCrc (0 << kV80CrcTypeShift) ++#define kV80Crc16 (1 << kV80CrcTypeShift) ++#define kV80Crc32 (2 << kV80CrcTypeShift) ++ ++#define kV80NrziShift 10 ++#define kV80NrziMask (1 << kV80NrziShift) ++#define kV80NrziDisabled (0 << kV80NrziShift) ++#define kV80NrziEnabled (1 << kV80NrziShift) ++ ++#define kV80Syn1Mask 0x00FF0000 /* Bit 16-23 */ ++#define kV80Syn1Shift 16 ++#define kV80Syn2Mask 0xFF000000 /* Bit 24-31 */ ++#define kV80Syn2Shift 24 ++ ++/* kStartCallProgressMonitorCmd setup masks */ ++ ++#define kDTMFDetectorDebouncerEnabled 0x0001 ++#define kModemSignalDetectorDebouncerEnabled 0x0002 ++#define kCallProgressDetectorDebouncerEnabled 0x0004 ++#define kCustomSignalDebouncerEnabled 0x0008 ++#define kFaxCallingToneSuppressionEnabled 0x0010 ++#define kDataCallingToneSuppressionEnabled 0x0020 ++#define kCISuppressionEnabled 0x0040 ++#define kAnsSuppressionEnabled 0x0080 ++ ++/* kDialCmd setup masks (dialerSetup bit fields) */ ++ ++#define kDTMFDialingEnabled 0x0001 ++#define kPulseDialingEnabled 0x0002 ++#define kModeSwitchEnabled 0x0004 ++#define kBlindDialingEnabled 0x0008 ++#define kPulseDialingMethodMask 0x0030 ++#define kDialModifierTranslationMask 0x00C0 ++#define kFlashWhilePulseDialingEnabled 0x0100 ++ ++/* Pulse dialing method */ ++#define kPulseDialingNPulsesPerDigit 0x0000 ++#define kPulseDialingNplusOnePulsesPerDigit 0x0010 ++#define kPulseDialingTenMinusNPulsesPerDigit 0x0020 ++ ++/* Dial modifier translation */ ++#define kTreatWasPause 0x0040 /* Tread 'W' modifier as pause */ ++#define kTreatCommaAsWaitForDialtone 0x0080 ++ ++#ifdef TI_C6X ++#include "C6xDefs.h" ++#endif ++#ifdef PENTIUM_MMX ++#include "PentiumDefs.h" ++#endif ++ ++ ++#if defined(DSP16K) && !defined(SoftModemGlobals) ++/* ensure that code generator does not use r5 */ ++register int *softmodem_h_should_not_be_included_after_softmodem_gh asm("r5"); ++#endif ++ ++/****************************************************************************/ ++/* 3. Interface functions. */ ++/* */ ++/****************************************************************************/ ++ ++#ifdef ADSL_MODEM ++ ++#ifndef SoftDslHeader ++#include "SoftDsl.h" ++#endif ++extern char* SM_DECL SoftModemGetRevString(void); ++extern char* SM_DECL SoftModemGetProductName(void); ++extern char* SM_DECL SoftModemGetBuildDate(void); ++extern char* SM_DECL SoftModemGetFullManufacturerName(void); ++extern char* SM_DECL SoftModemGetShortManufacturerName(void); ++extern int SM_DECL SoftModemRevStringSize(void); ++extern char* SM_DECL SoftModemGetVendorIDString(void); ++extern char* SM_DECL SoftModemGetT1413VendorIDString(void); ++extern char* SM_DECL SoftModemGetSerialNumberString(void); ++extern int SM_DECL SoftModemSerNumStringSize(void); ++#define SoftDslGetProductName SoftModemGetProductName ++#define SoftDslGetBuildDate SoftModemGetBuildDate ++#define SoftDslGetFullManufacturerName SoftModemGetFullManufacturerName ++#define SoftDslGetShortManufacturerName SoftModemGetShortManufacturerName ++ ++#else /* !ADSL_MODEM */ ++ ++extern void SM_DECL SoftModemSetMemoryPtr (void *varsPtr); ++extern void* SM_DECL SoftModemGetMemoryPtr (void); ++extern void SM_DECL SoftModemSetRefData (void *varsPtr); ++extern void* SM_DECL SoftModemGetRefData (void); ++extern int SM_DECL SoftModemGetMemorySize (void); ++extern void SM_DECL SoftModemInit (void); ++extern void SM_DECL SoftModemReset (void); ++extern void SM_DECL SoftModemLineHandler (int sampleCount, short *srcPtr, short *dstPtr); ++extern void SM_DECL SoftModemTimer (long timeQ24ms); ++extern Boolean SM_DECL SoftModemCommandHandler (modemCommandStruct *cmdPtr); ++extern int SM_DECL SoftModemGetExternalMemorySize(void); ++extern void SM_DECL SoftModemSetExternalMemoryPtr(void *varsPtr); ++ ++extern void SM_DECL SoftModemSetPcmCoding (pcmCodingType pcmCoding); ++extern void SM_DECL SoftModemPcmLineHandler (int sampleCount, uchar *srcPtr, uchar *dstPtr); ++ ++/* SoftModem IO functions */ ++extern int SM_DECL SoftModemWrite(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemRead(int nBytes, uchar* dstPtr); ++extern int SM_DECL SoftModemWriteFrame(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemReadFrame(int maxFrameSize, uchar* dstPtr); ++extern int SM_DECL SoftModemCountWritePending(void); ++extern int SM_DECL SoftModemCountReadPending(void); ++extern int SM_DECL SoftModemWriteSpaceAvailable(void); ++extern void SM_DECL SoftModemWriteFlush(void); ++extern void SM_DECL SoftModemReadFlush(void); ++extern int SM_DECL SoftModemGetWriteBufferSize(void); ++extern int SM_DECL SoftModemGetReadBufferSize(void); ++ ++#ifdef AUDIO ++extern int SM_DECL SoftModemAudioHandler(int sampleCount, short *srcPtr, short *dstPtr); ++extern int SM_DECL SoftModemAudioRxDataHandler(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemAudioTxDataHandler(int nBytes, uchar* dstPtr); ++#endif ++ ++ ++#define SoftModemSetGlobalPtr SoftModemSetMemoryPtr ++#define SoftModem SoftModemLineHandler ++#ifndef LINKLAYER_V42BIS_LARGE_DICTIONARY ++#define kSoftModemMaxMemorySize (65536) ++#else ++#define kSoftModemMaxMemorySize (65536 + 8192) ++#endif ++ ++/* ++ * Internal functions ++ */ ++extern long SM_DECL SoftModemGetDCOffset(void); ++extern void SM_DECL SoftModemDisableDCOffsetTracking(void); ++extern void SM_DECL SoftModemEnableDCOffsetTracking(void); ++extern long SM_DECL SoftModemGetRcvPower(void); ++extern ulong SM_DECL SoftModemGetHybridDelay(void); ++extern void SM_DECL SoftModemStatusHandler (modemStatusStruct *status); ++extern Boolean SM_DECL SoftModemInternalCommandHandler (modemCommandStruct *cmdPtr); ++extern void SM_DECL SoftModemInternalStatusHandler (modemStatusStruct *status); ++extern void SM_DECL SoftModemSetControllerOnlyMode(commandHandlerType externalDataPumpCommandHandlerPtr); ++extern char* SM_DECL SoftModemGetRevString(void); ++extern char* SM_DECL SoftModemGetProductName(void); ++extern char* SM_DECL SoftModemGetBuildDate(void); ++extern char* SM_DECL SoftModemGetFullManufacturerName(void); ++extern char* SM_DECL SoftModemGetShortManufacturerName(void); ++extern int SM_DECL SoftModemRevStringSize(void); ++extern char* SM_DECL SoftModemGetVendorIDString(void); ++extern char* SM_DECL SoftModemGetSerialNumberString(void); ++extern void SM_DECL SoftModemAuxTxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemAuxRxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemTxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemRxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemATPrintf(uchar *format, void *arg1, void *arg2, void *arg3); ++ ++#define SoftModemSetInputSaturationLimit(limit) (gSystemVars.inputSignalLimit = limit) ++#define SoftModemResetInputSaturationLimit() (gSystemVars.inputSignalLimit = 0) ++ ++#endif /* !ADSL_MODEM */ ++ ++#endif /* SoftModemPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModemTypes.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModemTypes.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModemTypes.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/bcm96348/softdsl/SoftModemTypes.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,292 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftModemTypes.h ++ * ++ * ++ * Description: ++ * This file contains some of the type declarations for SoftModem ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: SoftModemTypes.h,v 1.9 2004/04/13 00:16:59 ilyas Exp $ ++ * ++ * $Log: SoftModemTypes.h,v $ ++ * Revision 1.9 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.8 2004/01/24 01:35:33 ytan ++ * add multi-section lmem swap ++ * ++ * Revision 1.7 2001/09/21 19:19:01 ilyas ++ * Minor fixes for VxWorks build ++ * ++ * Revision 1.6 2001/08/16 02:16:39 khp ++ * - added definitions for SLOW_DATA and FAST_TEXT, defined to nothing ++ * except when bcm47xx && USE_SLOW_DATA or USE_FAST_TEXT. Any function ++ * that needs to run fast should be marked with FAST_TEXT. Any data that ++ * is not referenced often should be marked with SLOW_DATA. ++ * ++ * Revision 1.5 2001/03/30 00:49:59 liang ++ * Changed warning output message. ++ * ++ * Revision 1.4 2000/06/21 22:24:40 yongbing ++ * Modify WARN micro to limit the number of same warnings printed ++ * ++ * Revision 1.3 1999/08/05 20:02:13 liang ++ * Merged with the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.2 1999/01/27 22:14:29 liang ++ * Merge with SoftModem_3_1_02. ++ * ++ * Revision 1.19 1998/11/17 04:02:39 yura ++ * Fixed WARN and ASSERT redefinition warning for WinNT targets ++ * ++ * Revision 1.18 1998/08/26 19:20:43 scott ++ * Commented out EXCLUDE_CYGWIN32_TYPES define ++ * ++ * Revision 1.17 1998/08/13 19:03:06 scott ++ * Added BitField definition and INT_IS_LONG ++ * ++ * Revision 1.16 1998/08/08 03:39:55 scott ++ * The DEBUG_PTR_ENABLED macro can be used to enable only the DEBUG_PTR macros ++ * ++ * Revision 1.15 1998/07/28 22:21:31 mwg ++ * Fixed problems with NULL & nil being defined incorrectly ++ * ++ * Revision 1.14 1998/07/08 17:09:17 scott ++ * Define ASSERT and WARN only if not already defined ++ * ++ * Revision 1.13 1998/07/02 20:46:34 scott ++ * Added workaround for building certain builds with older SunOS ++ * ++ * Revision 1.12 1998/02/09 18:24:49 scott ++ * Defined "Private" as nothing for GreenHill (to prevent erroneous section ++ * allocations for data) ++ * ++ * Revision 1.11 1997/08/29 21:39:24 scott ++ * Added check for LONG_IS_INT define (for TI C6X support) ++ * ++ * Revision 1.10 1997/05/29 19:50:23 mwg ++ * Added code to avoid type redefintions under SunOS. ++ * ++ * Revision 1.9 1997/03/19 18:35:08 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.8 1997/02/11 00:05:53 mwg ++ * Minor adjustments for Pentium optimization. ++ * ++ * Revision 1.7 1997/01/11 01:30:47 mwg ++ * Added new macro WARN -- the same as ASSERT but without exit. ++ * ++ * Revision 1.6 1996/08/22 20:07:39 liang ++ * When ASSERT fires, only print out information, don't exit. ++ * ++ * Revision 1.5 1996/05/06 06:49:10 mwg ++ * Fixed linux problems. ++ * ++ * Revision 1.4 1996/05/02 08:40:16 mwg ++ * Merged in Chromatic bug fixes. ++ * ++ * Revision 1.3 1996/04/01 20:59:53 mwg ++ * Added macros to setup and use debug pointer. ++ * ++ * Revision 1.2 1996/02/27 01:50:04 mwg ++ * Added ASSERT() macro. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.2 1995/12/03 06:59:31 mwg ++ * Fixed all gcc varnings. We are now running under Linux on a PC! ++ * ++ *****************************************************************************/ ++#ifndef SoftModemTypesh ++#define SoftModemTypesh ++ ++#ifdef LONG_SHORTS ++#define short long ++#define ushort unsigned long ++#endif ++ ++typedef signed char schar; ++typedef unsigned char uchar; ++ ++#if 0 /* This is not currently required */ ++#if defined(_CYGWIN32) && defined(DEBUG) ++#define EXCLUDE_CYGWIN32_TYPES ++#endif ++#endif ++ ++#if !defined(_SYS_TYPES_H) || !defined(TARG_OS_RTEMS) ++#if defined(_CFE_) ++ typedef unsigned int uint; ++ typedef unsigned long ulong; ++ typedef unsigned short ushort; ++#elif defined(TARG_OS_RTEMS) ++#if defined(HOST_ARCH_LINUX) ++ typedef unsigned int uint; ++#endif ++ typedef unsigned long ulong; ++#if defined(HOST_ARCH_LINUX) ++ typedef unsigned short ushort; ++#endif ++#elif defined(EXCLUDE_CYGWIN32_TYPES) || (!defined _NO_TYPE_DEFS_ && !defined _SYS_TYPES_H && !defined __SYS_TYPES_H__ && !defined _SYS_BSD_TYPES_H && !defined _LINUX_TYPES_H) || defined(__sparc__) ++#ifndef EXCLUDE_CYGWIN32_TYPES ++ typedef unsigned int uint; ++#endif ++#ifndef _LINUX_TYPES_H ++ typedef unsigned long ulong; ++#endif ++#if !defined(ushort) && !defined(EXCLUDE_CYGWIN32_TYPES) && !defined(__INCvxTypesOldh) ++ typedef unsigned short ushort; ++#endif ++#endif ++#else ++typedef unsigned long ulong; ++#endif ++ ++#if defined(GREENHILL) || defined(GNUTX39) /* GH allocates private data to incorrect section */ ++#define Private ++#else ++#define Private static ++#endif ++ ++#define Public ++ ++#ifdef NULL ++#undef NULL ++#endif ++#ifdef nil ++#undef nil ++#endif ++ ++#define NULL 0 ++#define nil 0 ++ ++#define false 0 ++#define true 1 ++typedef unsigned char Boolean; ++typedef unsigned int BitField; /* this must occur BEFORE long_is_int/int_is_long defs */ ++ ++#ifdef LONG_IS_INT ++#define long int ++#define ulong uint ++#endif ++ ++#ifdef INT_IS_LONG ++#define int long ++#define uint ulong ++#endif ++ ++#define POSTULATE(postulate) \ ++ do \ ++ { \ ++ typedef struct \ ++ { \ ++ char NegativeSizeIfPostulateFalse[((int)(postulate))*2 - 1]; \ ++ } PostulateCheckStruct; \ ++ } \ ++ while (0) ++ ++#if defined(DEBUG) && !defined(__KERNEL__) ++#ifndef WARN ++#define kDSLNumberWarnTimes 10 ++#define WARN(assertion) \ ++ { static int warnSeveralTimes=0; \ ++ if ((!(assertion))&(warnSeveralTimes ++*/ ++/**************************************************************************** ++ * ++ * AdslCore.c -- Bcm ADSL core driver ++ * ++ * Description: ++ * This file contains BCM ADSL core driver ++ * ++ * ++ * Copyright (c) 2000-2001 Broadcom Corporation ++ * All Rights Reserved ++ * No portions of this material may be reproduced in any form without the ++ * written permission of: ++ * Broadcom Corporation ++ * 16215 Alton Parkway ++ * Irvine, California 92619 ++ * All information contained in this document is Broadcom Corporation ++ * company private, proprietary, and trade secret. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.4 $ ++ * ++ * $Id: AdslCoreDefs.h,v 1.4 2004/07/20 23:45:48 ilyas Exp $ ++ * ++ * $Log: AdslCoreDefs.h,v $ ++ * Revision 1.4 2004/07/20 23:45:48 ilyas ++ * Added driver version info, SoftDslPrintf support. Fixed G.997 related issues ++ * ++ * Revision 1.3 2004/06/10 00:20:33 ilyas ++ * Added L2/L3 and SRA ++ * ++ * Revision 1.2 2004/04/12 23:24:38 ilyas ++ * Added default G992P5 PHY definition ++ * ++ * Revision 1.1 2004/04/08 23:59:15 ilyas ++ * Initial CVS checkin ++ * ++ ****************************************************************************/ ++ ++#ifndef _ADSL_CORE_DEFS_H ++#define _ADSL_CORE_DEFS_H ++ ++#if defined(__KERNEL__) ++#include ++#endif ++ ++#if defined(CONFIG_BCM96348) || defined(BOARD_bcm96348) || defined(_BCM96348_) || defined(CONFIG_BCM96338) || defined(BOARD_bcm96338) || defined(_BCM96338_) ++#ifdef ADSL_ANNEXC ++#include "../adslcore6348C/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcore6348B/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcore6348SA/adsl_defs.h" ++#else ++#include "../adslcore6348/adsl_defs.h" ++#endif ++#endif ++ ++#if defined(__KERNEL__) || defined(TARG_OS_RTEMS) || defined(_CFE_) ++#if defined(CONFIG_BCM96345) || defined(BOARD_bcm96345) || defined(_BCM96345_) ++#ifdef ADSL_ANNEXC ++#include "../adslcore6345C/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcore6345B/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcore6345SA/adsl_defs.h" ++#else ++#include "../adslcore6345/adsl_defs.h" ++#endif ++#endif /* of CONFIG_BCM96345 */ ++#else ++#if defined(CONFIG_BCM96345) ++#ifdef ADSL_ANNEXC ++#include "../adslcoreC/adsl_defs.h" ++#elif defined(ADSL_ANNEXB) ++#include "../adslcoreB/adsl_defs.h" ++#elif defined(ADSL_SADSL) ++#include "../adslcoreSA/adsl_defs.h" ++#else ++#include "../adslcore/adsl_defs.h" ++#endif ++#endif /* of CONFIG_BCM96345 */ ++#endif /* __KERNEL__ */ ++ ++#ifdef _WIN32_WCE ++#define ASSERT(a) ++#endif ++ ++#include "AdslXfaceData.h" ++ ++/* adjust some definitions for the HOST */ ++ ++#undef GLOBAL_PTR_BIAS ++#undef ADSLCORE_ONLY ++#undef USE_SLOW_DATA ++#undef USE_FAST_TEXT ++#undef VP_SIMULATOR ++#undef bcm47xx ++#undef ADSL_FRAMER ++#undef ATM ++#undef ATM_I432 ++#undef DSL_OS ++ ++#define HOST_ONLY ++#define G997_1_FRAMER ++#define ADSL_MIB ++ ++#ifndef FLATTEN_ADDR_ADJUST ++#define FLATTEN_ADDR_ADJUST 0xFFF00000 ++#endif ++ ++/* definitions for combo PHY (AnnexA(ADSL2) and AnnexB) */ ++ ++#if !(defined(ADSL_SINGLE_PHY) || defined(G992_ANNEXC)) ++ ++#undef G992P1_ANNEX_A ++#define G992P1_ANNEX_A ++#undef G992P3 ++#define G992P3 ++#undef G992P5 ++#define G992P5 ++#define G992P1_ANNEX_A ++#undef READSL2 ++#define READSL2 ++#undef G992P1_ANNEX_A_USED_FOR_G992P2 ++#define G992P1_ANNEX_A_USED_FOR_G992P2 ++#undef T1P413 ++#define T1P413 ++ ++#undef G992P1_ANNEX_B ++#define G992P1_ANNEX_B ++ ++#endif ++ ++/* ADSL PHY definition */ ++ ++typedef struct { ++ unsigned long sdramPageAddr; ++ unsigned long sdramImageAddr; ++ unsigned long sdramImageSize; ++ unsigned long sdramPhyImageAddr; ++ unsigned short fwType; ++ unsigned short chipType; ++ unsigned short mjVerNum; ++ unsigned short mnVerNum; ++ char *pVerStr; ++ unsigned long features[4]; ++} adslPhyInfo; ++extern adslPhyInfo adslCorePhyDesc; ++ ++/* chip list */ ++ ++#define kAdslPhyChipMjMask 0xFF00 ++#define kAdslPhyChipMnMask 0x00FF ++#define kAdslPhyChipUnknown 0 ++#define kAdslPhyChip6345 0x100 ++#define kAdslPhyChip6348 0x200 ++#define kAdslPhyChipRev0 0 ++#define kAdslPhyChipRev1 1 ++#define kAdslPhyChipRev2 2 ++#define kAdslPhyChipRev3 3 ++#define kAdslPhyChipRev4 4 ++#define kAdslPhyChipRev5 5 ++ ++#define ADSL_PHY_SUPPORT(f) AdslFeatureSupported(adslCorePhyDesc.features,f) ++#define ADSL_PHY_SET_SUPPORT(p,f) AdslFeatureSet((p)->features,f) ++ ++/* ADSL Driver to/from PHY address and data conversion macros */ ++ ++#ifdef ADSLDRV_LITTLE_ENDIAN ++#define ADSL_ENDIAN_CONV_LONG(x) ( ((x) << 24) | (((x) << 8) & 0x00FF0000) | (((x) >> 8) & 0x0000FF00) | ((unsigned long)(x) >> 24) ) ++#define ADSL_ENDIAN_CONV_SHORT(x) ( ((x) << 8) | ((unsigned short)(x) >> 8) ) ++#define ADSL_ENDIAN_CONV_2SHORTS(x) ( ((x) << 16) | ((unsigned long)(x) >> 16) ) ++#else ++#define ADSL_ENDIAN_CONV_LONG(x) x ++#define ADSL_ENDIAN_CONV_SHORT(x) x ++#define ADSL_ENDIAN_CONV_2SHORTS(x) x ++#endif ++ ++#ifndef ADSL_PHY_XFACE_OFFSET ++#define ADSL_PHY_XFACE_OFFSET 0x00017F90 ++#endif ++#define ADSL_LMEM_XFACE_DATA (0xFFF00000 | ADSL_PHY_XFACE_OFFSET) ++ ++#ifndef ADSL_PHY_SDRAM_START ++#define ADSL_PHY_SDRAM_START 0x10000000 ++#endif ++#ifndef ADSL_PHY_SDRAM_BIAS ++#define ADSL_PHY_SDRAM_BIAS 0x00040000 ++#endif ++#define ADSL_PHY_SDRAM_START_4 (ADSL_PHY_SDRAM_START + ADSL_PHY_SDRAM_BIAS) ++ ++#ifndef ADSL_PHY_SDRAM_PAGE_SIZE ++#define ADSL_PHY_SDRAM_PAGE_SIZE 0x00080000 ++#endif ++ ++#ifdef ADSL_PHY_SDRAM_BIAS ++#define ADSL_SDRAM_IMAGE_SIZE (ADSL_PHY_SDRAM_PAGE_SIZE - ADSL_PHY_SDRAM_BIAS) ++#else ++#define ADSL_SDRAM_IMAGE_SIZE (256*1024) ++#endif ++ ++ ++#ifndef ADSL_PHY_SDRAM_LINK_OFFSET ++#define ADSL_PHY_SDRAM_LINK_OFFSET 0x00040000 ++#endif ++ ++#define ADSL_SDRAM_TOTAL_SIZE 0x00800000 ++#define ADSL_SDRAM_HOST_MIPS_DEFAULT (0xA0000000 | (ADSL_SDRAM_TOTAL_SIZE - ADSL_PHY_SDRAM_PAGE_SIZE + ADSL_PHY_SDRAM_BIAS)) ++ ++#define ADSLXF ((AdslXfaceData *) ADSL_LMEM_XFACE_DATA) ++ ++#define ADSL_MIPS_LMEM_ADDR(a) (((ulong)(a) & 0x19000000) == 0x19000000) ++#define SDRAM_ADDR_TO_HOST(a) ((void *) ((ulong)(a) - adslCorePhyDesc.sdramPhyImageAddr + \ ++ (ADSLXF->sdramBaseAddr ? (unsigned long) ADSLXF->sdramBaseAddr : ADSL_SDRAM_HOST_MIPS_DEFAULT))) ++#define SDRAM_ADDR_TO_ADSL(a) ((void *) (adslCorePhyDesc.sdramPhyImageAddr + ((ulong)(a) - \ ++ (ADSLXF->sdramBaseAddr ? (unsigned long) ADSLXF->sdramBaseAddr : ADSL_SDRAM_HOST_MIPS_DEFAULT)))) ++ ++#define ADSL_ADDR_TO_HOST(addr) ADSL_MIPS_LMEM_ADDR(addr) ? (void *) ((ulong) (addr) | FLATTEN_ADDR_ADJUST) : SDRAM_ADDR_TO_HOST(addr) ++ ++ ++#ifndef DEBUG ++#define DEBUG ++#endif ++ ++#ifndef __SoftDslPrintf ++void __SoftDslPrintf(void *gDslVars, char *fmt, int argNum, ...); ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,94 @@ ++/**************************************************************************** ++ * ++ * AdslMib.gh ++ * ++ * Description: ++ * This is a header file which defines the type for AdslMib ++ * global variable structure. ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.8 $ ++ * ++ * $Id: AdslMib.gh,v 1.8 2004/06/04 18:56:01 ilyas Exp $ ++ * ++ * $Log: AdslMib.gh,v $ ++ * Revision 1.8 2004/06/04 18:56:01 ilyas ++ * Added counter for ADSL2 framing and performance ++ * ++ * Revision 1.7 2003/10/17 21:02:12 ilyas ++ * Added more data for ADSL2 ++ * ++ * Revision 1.6 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.5 2003/07/18 19:07:15 ilyas ++ * Merged with ADSL driver ++ * ++ * Revision 1.4 2002/11/13 21:32:49 ilyas ++ * Added adjustK support for Centillium non-standard framing mode ++ * ++ * Revision 1.3 2002/10/31 20:27:13 ilyas ++ * Merged with the latest changes for VxWorks/Linux driver ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibGlobals ++#define AdslMibGlobals ++ ++#include "AdslMib.h" ++ ++typedef struct ++ { ++ /* MIB data */ ++ ++ adslMibInfo adslMib; ++ ++ /* ADSL state data */ ++ ++ adslMibNotifyHandlerType notifyHandlerPtr; ++ ulong timeSec; ++ ulong timeMs; ++ Boolean currSecondErrored; ++ Boolean currSecondLOS; ++ Boolean currSecondSES; ++ Boolean currSecondFEC; ++ ulong rcvPower; ++ ulong rcvRateBps; ++ ulong xmtRateBps; ++ ulong linkStatus; ++ G992CodingParams rcvParams; ++ G992CodingParams xmtParams; ++ ulong shtCounters[kG992ShowtimeNumOfMonitorCounters]; ++ ulong scratchData; ++ long showtimeMarginThld; ++ ++ /* ADSL diag data */ ++ ++ short snr[kAdslMibMaxToneNum]; ++ short showtimeMargin[kAdslMibMaxToneNum]; ++ uchar bitAlloc[kAdslMibMaxToneNum]; ++ short gain[kAdslMibMaxToneNum]; ++ ComplexShort chanCharLin[kAdslMibMaxToneNum]; ++ short chanCharLog[kAdslMibMaxToneNum]; ++ short quietLineNoise[kAdslMibMaxToneNum]; ++ ++ ushort nTones; ++ uchar nMsgCnt; ++ ulong g992MsgType; ++ uchar rsOption[1+4]; ++ Boolean rsOptionValid; ++ } ++ adslMibVarsStruct; ++ ++#endif /* AdslMibGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMib.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,114 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslMib.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for AdslMib ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: AdslMib.h,v 1.9 2004/04/12 23:34:52 ilyas Exp $ ++ * ++ * $Log: AdslMib.h,v $ ++ * Revision 1.9 2004/04/12 23:34:52 ilyas ++ * Merged the latest ADSL driver chnages for ADSL2+ ++ * ++ * Revision 1.8 2004/03/03 20:14:05 ilyas ++ * Merged changes for ADSL2+ from ADSL driver ++ * ++ * Revision 1.7 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.6 2003/07/18 19:07:15 ilyas ++ * Merged with ADSL driver ++ * ++ * Revision 1.5 2002/10/31 20:27:13 ilyas ++ * Merged with the latest changes for VxWorks/Linux driver ++ * ++ * Revision 1.4 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.3 2002/01/13 22:25:40 ilyas ++ * Added functions to get channels rate ++ * ++ * Revision 1.2 2002/01/03 06:03:36 ilyas ++ * Handle byte moves tha are not multiple of 2 ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibHeader ++#define AdslMibHeader ++ ++#if defined(_CFE_) ++#include "lib_types.h" ++#include "lib_string.h" ++#endif ++ ++#include "AdslMibDef.h" ++ ++/* Interface functions */ ++ ++typedef int (SM_DECL *adslMibNotifyHandlerType) (void *gDslVars, ulong event); ++ ++extern Boolean AdslMibInit(void *gDslVars); ++extern void AdslMibTimer(void *gDslVars, long timeMs); ++extern void AdslMibStatusSnooper (void *gDslVars, dslStatusStruct *status); ++extern void AdslMibSetNotifyHandler(void *gDslVars, adslMibNotifyHandlerType notifyHandlerPtr); ++extern int AdslMibGetModulationType(void *gDslVars); ++extern Boolean AdslMibIsAdsl2Mod(void *gDslVars); ++extern int AdslMibGetActiveChannel(void *gDslVars); ++extern int AdslMibGetGetChannelRate(void *gDslVars, int dir, int channel); ++extern Boolean AdslMibIsLinkActive(void *gDslVars); ++extern int AdslMibPowerState(void *gDslVars); ++extern int AdslMibTrainingState (void *gDslVars); ++extern void AdslMibClearData(void *gDslVars); ++extern void AdslMibClearBertResults(void *gDslVars); ++extern void AdslMibBertStartEx(void *gDslVars, ulong bertSec); ++extern void AdslMibBertStopEx(void *gDslVars); ++extern ulong AdslMibBertContinueEx(void *gDslVars, ulong totalBits, ulong errBits); ++extern void AdslMibSetLPR(void *gDslVars); ++extern void AdslMibSetShowtimeMargin(void *gDslVars, long showtimeMargin); ++extern void AdslMibResetConectionStatCounters(void *gDslVars); ++ ++extern void AdslMibByteMove (int size, void* srcPtr, void* dstPtr); ++extern void AdslMibByteClear(int size, void* dstPtr); ++extern int AdslMibStrCopy(char *srcPtr, char *dstPtr); ++ ++/* AdslMibGetData dataId codes */ ++ ++#define kAdslMibDataAll 0 ++ ++extern void *AdslMibGetData (void *gDslVars, int dataId, void *pAdslMibData); ++ ++extern int AdslMibGetObjectValue ( ++ void *gDslVars, ++ uchar *objId, ++ int objIdLen, ++ uchar *dataBuf, ++ ulong *dataBufLen); ++ ++#endif /* AdslMibHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMibOid.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMibOid.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMibOid.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslMibOid.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,177 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslMibOid.h ++ * ++ * Description: ++ * SNMP object identifiers for ADSL MIB and other related MIBs ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: AdslMibOid.h,v 1.5 2004/06/04 18:56:01 ilyas Exp $ ++ * ++ * $Log: AdslMibOid.h,v $ ++ * Revision 1.5 2004/06/04 18:56:01 ilyas ++ * Added counter for ADSL2 framing and performance ++ * ++ * Revision 1.4 2003/10/17 21:02:12 ilyas ++ * Added more data for ADSL2 ++ * ++ * Revision 1.3 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibOidHeader ++#define AdslMibOidHeader ++ ++#define kOidAdsl 94 ++#define kOidAdslInterleave 124 ++#define kOidAdslFast 125 ++#define kOidAtm 37 ++ ++#define kOidAdslLine 1 ++#define kOidAdslMibObjects 1 ++ ++#define kOidAdslLineTable 1 ++#define kOidAdslLineEntry 1 ++#define kOidAdslLineCoding 1 ++#define kOidAdslLineType 2 ++#define kOidAdslLineSpecific 3 ++#define kOidAdslLineConfProfile 4 ++#define kOidAdslLineAlarmConfProfile 5 ++ ++#define kOidAdslAtucPhysTable 2 ++#define kOidAdslAturPhysTable 3 ++#define kOidAdslPhysEntry 1 ++#define kOidAdslPhysInvSerialNumber 1 ++#define kOidAdslPhysInvVendorID 2 ++#define kOidAdslPhysInvVersionNumber 3 ++#define kOidAdslPhysCurrSnrMgn 4 ++#define kOidAdslPhysCurrAtn 5 ++#define kOidAdslPhysCurrStatus 6 ++#define kOidAdslPhysCurrOutputPwr 7 ++#define kOidAdslPhysCurrAttainableRate 8 ++ ++#define kOidAdslAtucChanTable 4 ++#define kOidAdslAturChanTable 5 ++#define kOidAdslChanEntry 1 ++#define kOidAdslChanInterleaveDelay 1 ++#define kOidAdslChanCurrTxRate 2 ++#define kOidAdslChanPrevTxRate 3 ++#define kOidAdslChanCrcBlockLength 4 ++ ++#define kOidAdslAtucPerfDataTable 6 ++#define kOidAdslAturPerfDataTable 7 ++#define kOidAdslPerfDataEntry 1 ++#define kOidAdslPerfLofs 1 ++#define kOidAdslPerfLoss 2 ++#define kOidAdslPerfLprs 3 ++#define kOidAdslPerfESs 4 ++#define kOidAdslPerfValidIntervals 5 ++#define kOidAdslPerfInvalidIntervals 6 ++#define kOidAdslPerfCurr15MinTimeElapsed 7 ++#define kOidAdslPerfCurr15MinLofs 8 ++#define kOidAdslPerfCurr15MinLoss 9 ++#define kOidAdslPerfCurr15MinLprs 10 ++#define kOidAdslPerfCurr15MinESs 11 ++#define kOidAdslPerfCurr1DayTimeElapsed 12 ++#define kOidAdslPerfCurr1DayLofs 13 ++#define kOidAdslPerfCurr1DayLoss 14 ++#define kOidAdslPerfCurr1DayLprs 15 ++#define kOidAdslPerfCurr1DayESs 16 ++#define kOidAdslPerfPrev1DayMoniSecs 17 ++#define kOidAdslPerfPrev1DayLofs 18 ++#define kOidAdslPerfPrev1DayLoss 19 ++#define kOidAdslPerfPrev1DayLprs 20 ++#define kOidAdslPerfPrev1DayESs 21 ++ ++#define kOidAdslAtucPerfIntervalTable 8 ++#define kOidAdslAturPerfIntervalTable 9 ++#define kOidAdslPerfIntervalEntry 1 ++#define kOidAdslIntervalNumber 1 ++#define kOidAdslIntervalLofs 2 ++#define kOidAdslIntervalLoss 3 ++#define kOidAdslIntervalLprs 4 ++#define kOidAdslIntervalESs 5 ++#define kOidAdslIntervalValidData 6 ++ ++#define kOidAdslAtucChanPerfTable 10 ++#define kOidAdslAturChanPerfTable 11 ++#define kOidAdslChanPerfEntry 1 ++#define kOidAdslChanReceivedBlks 1 ++#define kOidAdslChanTransmittedBlks 2 ++#define kOidAdslChanCorrectedBlks 3 ++#define kOidAdslChanUncorrectBlks 4 ++#define kOidAdslChanPerfValidIntervals 5 ++#define kOidAdslChanPerfInvalidIntervals 6 ++#define kOidAdslChanPerfCurr15MinTimeElapsed 7 ++#define kOidAdslChanPerfCurr15MinReceivedBlks 8 ++#define kOidAdslChanPerfCurr15MinTransmittedBlks 9 ++#define kOidAdslChanPerfCurr15MinCorrectedBlks 10 ++#define kOidAdslChanPerfCurr15MinUncorrectBlks 11 ++#define kOidAdslChanPerfCurr1DayTimeElapsed 12 ++#define kOidAdslChanPerfCurr1DayReceivedBlks 13 ++#define kOidAdslChanPerfCurr1DayTransmittedBlks 14 ++#define kOidAdslChanPerfCurr1DayCorrectedBlks 15 ++#define kOidAdslChanPerfCurr1DayUncorrectBlks 16 ++#define kOidAdslChanPerfPrev1DayMoniSecs 17 ++#define kOidAdslChanPerfPrev1DayReceivedBlks 18 ++#define kOidAdslChanPerfPrev1DayTransmittedBlks 19 ++#define kOidAdslChanPerfPrev1DayCorrectedBlks 20 ++#define kOidAdslChanPerfPrev1DayUncorrectBlks 21 ++ ++#define kOidAdslAtucChanIntervalTable 12 ++#define kOidAdslAturChanIntervalTable 13 ++#define kOidAdslChanIntervalEntry 1 ++#define kOidAdslChanIntervalNumber 1 ++#define kOidAdslChanIntervalReceivedBlks 2 ++#define kOidAdslChanIntervalTransmittedBlks 3 ++#define kOidAdslChanIntervalCorrectedBlks 4 ++#define kOidAdslChanIntervalUncorrectBlks 5 ++#define kOidAdslChanIntervalValidData 6 ++ ++/* AdslExtra OIDs for kOidAdslPrivate, kOidAdslPrivExtraInfo (defined in AdslMibDef.h) */ ++ ++#define kOidAdslExtraConnectionInfo 1 ++#define kOidAdslExtraConnectionStat 2 ++#define kOidAdslExtraFramingMode 3 ++#define kOidAdslExtraTrainingState 4 ++#define kOidAdslExtraNonStdFramingAdjustK 5 ++#define kOidAdslExtraAtmStat 6 ++#define kOidAdslExtraDiagModeData 7 ++#define kOidAdslExtraAdsl2Info 8 ++#define kOidAdslExtraTxPerfCounterInfo 9 ++ ++#define kOidAtmMibObjects 1 ++#define kOidAtmTcTable 4 ++#define kOidAtmTcEntry 1 ++#define kOidAtmOcdEvents 1 ++#define kOidAtmAlarmState 2 ++ ++#endif /* AdslMibOidHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslXfaceData.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslXfaceData.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslXfaceData.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/AdslXfaceData.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,129 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslXfaceData.h -- ADSL Core interface data structure ++ * ++ * Description: ++ * To be included both in SoftDsl and BcmAdslCore driver ++ * ++ * ++ * Copyright (c) 2000-2001 Broadcom Corporation ++ * All Rights Reserved ++ * No portions of this material may be reproduced in any form without the ++ * written permission of: ++ * Broadcom Corporation ++ * 16215 Alton Parkway ++ * Irvine, California 92619 ++ * All information contained in this document is Broadcom Corporation ++ * company private, proprietary, and trade secret. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: AdslXfaceData.h,v 1.9 2004/02/03 02:57:22 ilyas Exp $ ++ * ++ * $Log: AdslXfaceData.h,v $ ++ * Revision 1.9 2004/02/03 02:57:22 ilyas ++ * Added PHY feature settings ++ * ++ * Revision 1.8 2003/07/18 04:50:21 ilyas ++ * Added shared buffer for clEoc messages to avoid copying thru command buffer ++ * ++ * Revision 1.7 2003/02/25 00:46:32 ilyas ++ * Added T1.413 EOC vendor ID ++ * ++ * Revision 1.6 2003/02/21 23:29:13 ilyas ++ * Added OEM vendor ID parameter for T1.413 mode ++ * ++ * Revision 1.5 2002/09/13 21:17:12 ilyas ++ * Added pointers to version and build string to OEM interface structure ++ * ++ * Revision 1.4 2002/09/07 04:16:29 ilyas ++ * Fixed HOST to ADSL MIPS SDRAM address translation for relocatable images ++ * ++ * Revision 1.3 2002/09/07 01:43:59 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.2 2002/01/22 19:03:10 khp ++ * -put sdramBaseAddr at end of Xface struct ++ * ++ * Revision 1.1 2002/01/15 06:25:08 ilyas ++ * Initial implementation of ADSL core firmware ++ * ++ ****************************************************************************/ ++ ++#ifndef AdslXfaceDataHeader ++#define AdslXfaceDataHeader ++ ++#include "CircBuf.h" ++ ++typedef struct _AdslXfaceData { ++ stretchBufferStruct sbSta; ++ stretchBufferStruct sbCmd; ++ unsigned long gfcTable[15]; ++ void *sdramBaseAddr; ++} AdslXfaceData; ++ ++/* Shared SDRAM configuration data */ ++ ++#define kAdslOemVendorIdMaxSize 8 ++#define kAdslOemVersionMaxSize 32 ++#define kAdslOemSerNumMaxSize 32 ++#define kAdslOemNonStdInfoMaxSize 64 ++ ++typedef struct _AdslOemSharedData { ++ unsigned long g994VendorIdLen; ++ unsigned long g994XmtNonStdInfoLen; ++ unsigned long g994RcvNonStdInfoLen; ++ unsigned long eocVendorIdLen; ++ unsigned long eocVersionLen; ++ unsigned long eocSerNumLen; ++ unsigned char g994VendorId[kAdslOemVendorIdMaxSize]; ++ unsigned char eocVendorId[kAdslOemVendorIdMaxSize]; ++ unsigned char eocVersion[kAdslOemVersionMaxSize]; ++ unsigned char eocSerNum[kAdslOemSerNumMaxSize]; ++ unsigned char g994XmtNonStdInfo[kAdslOemNonStdInfoMaxSize]; ++ unsigned char g994RcvNonStdInfo[kAdslOemNonStdInfoMaxSize]; ++ char *gDslVerionStringPtr; ++ char *gDslBuildDataStringPtr; ++ unsigned long t1413VendorIdLen; ++ unsigned char t1413VendorId[kAdslOemVendorIdMaxSize]; ++ unsigned long t1413EocVendorIdLen; ++ unsigned char t1413EocVendorId[kAdslOemVendorIdMaxSize]; ++ unsigned long clEocBufLen; ++ unsigned char *clEocBufPtr; ++} AdslOemSharedData; ++ ++/* feature list */ ++ ++#define kAdslPhyAnnexA 0 ++#define kAdslPhyAnnexB 1 ++#define kAdslPhyAnnexC 2 ++#define kAdslPhySADSL 3 ++#define kAdslPhyAdsl2 4 ++#define kAdslPhyAdslG992p3 4 ++#define kAdslPhyAdsl2p 5 ++#define kAdslPhyAdslG992p5 5 ++#define kAdslPhyAnnexI 6 ++#define kAdslPhyAdslReAdsl2 7 ++#define kAdslPhyG992p2Init 8 ++#define kAdslPhyT1P413 9 ++ ++#define AdslFeatureSupported(fa,f) ((fa)[(f) >> 5] & (1 << ((f) & 0x1F))) ++#define AdslFeatureSet(fa,f) (fa)[(f) >> 5] |= (1 << ((f) & 0x1F)) ++ ++#endif /* AdslXfaceDataHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlankList.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlankList.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlankList.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlankList.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,87 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * BlankList.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of blank list - list of unused items of any size (not less than ++ * sizeof(void *) ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef BlankListHeader ++#define BlankListHeader ++ ++#define BlankListPeek(head) ((void *) (head)) ++#define BlankListNext(p) (*(void **) (p)) ++ ++#define BlankListAdd(pHead,p) do { \ ++ BlankListNext(p) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = (void *) (p); \ ++} while (0) ++ ++#define BlankListAddList(pHead,pFirst,pLast) do { \ ++ if (NULL != (pLast)) { \ ++ BlankListNext(pLast) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = (void *) (pFirst); \ ++ } \ ++} while (0) ++ ++#define BlankListGet(pHead) \ ++ BlankListNext(pHead); \ ++ { \ ++ void **__p; \ ++ __p = (void **) BlankListNext(pHead); \ ++ if (NULL != __p) \ ++ BlankListNext(pHead) = *__p; \ ++ } ++ ++ ++#define BlankListForEach(pHead,f,ref) do { \ ++ void *p = BlankListNext(pHead); \ ++ \ ++ while (NULL != p) { \ ++ if ( (f)((p), ref) ) break; \ ++ p = BlankListNext(p); \ ++ } \ ++} while (0) ++ ++ ++#include "Que.h" ++ ++#define BlankListAddQue(pHead,pqHdr) do { \ ++ if (NULL != ((QueHeader *)(pqHdr))->tail) { \ ++ BlankListNext(((QueHeader *)(pqHdr))->tail) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = ((QueHeader *)(pqHdr))->head; \ ++ } \ ++} while (0) ++ ++#include "DList.h" ++ ++#define BlankListAddDList(pHead,pDListHead) do { \ ++ if (!DListEmpty(pDListHead)) { \ ++ BlankListNext(DListLast(pDListHead)) = BlankListNext(pHead); \ ++ BlankListNext(pHead) = DListFirst(pDListHead); \ ++ } \ ++} while (0) ++ ++#endif /* BlankListHeader */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlockUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlockUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlockUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/BlockUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,235 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/* BlockUtil.h ++ * ++ * Description: ++ * This file contains the interfaces for the fixed point block ++ * processing utilities. ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.23 $ ++ * ++ * $Id: BlockUtil.h,v 1.23 2004/04/13 00:31:10 ilyas Exp $ ++ * ++ * $Log: BlockUtil.h,v $ ++ * Revision 1.23 2004/04/13 00:31:10 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.22 2003/07/11 01:49:01 gsyu ++ * Added BlockShortClearByLong to speed up performance ++ * ++ * Revision 1.21 2003/07/10 22:35:23 gsyu ++ * Speed up BlockByteXXX performance ++ * ++ * Revision 1.20 2003/07/10 22:15:51 gsyu ++ * Added BlockByteMoveByWord to speed up performance ++ * ++ * Revision 1.19 2002/03/12 00:03:03 yongbing ++ * Modify cplxScaleCplxSymbols to accept a shift value instead of an array of shifts ++ * ++ * Revision 1.18 2001/03/14 00:50:25 georgep ++ * All targets use FEQ_PASS_FFTSHIFT, remove code for case where its not defined ++ * ++ * Revision 1.17 2000/11/30 03:54:09 khp ++ * -BlockRealScaleCplxSymbols instead of BlockScaleComplexSymbols ++ * ++ * Revision 1.16 2000/11/29 20:42:12 liang ++ * Add function for ADSL xmt gains with fixed shift. ++ * ++ * Revision 1.15 2000/10/02 19:24:08 georgep ++ * Modify FEQ for new fft, fft outputs a shift for each block ++ * ++ * Revision 1.14 2000/09/09 00:23:48 liang ++ * Add corresponding functions for the ComplexLong FEQ coef. ++ * ++ * Revision 1.13 2000/05/17 01:36:52 yongbing ++ * Add Pentium MMX assembly codes for more block related functions ++ * ++ * Revision 1.12 2000/04/19 19:22:22 yongbing ++ * Add BlockShortScaleby2 function used in G994p1 ++ * ++ * Revision 1.11 2000/04/04 02:28:01 liang ++ * Merged with SoftDsl_0_2 from old tree. ++ * ++ * Revision 1.11 2000/03/14 23:29:01 yongbing ++ * Add Pentim MMX codes for BlockCplxSymbolUpdateCplxScale function ++ * ++ * Revision 1.10 2000/02/16 01:53:00 yongbing ++ * Add Pentium MMX module for FEQ ++ * ++ * Revision 1.9 1999/11/02 02:49:55 liang ++ * Add BlockComplexPower function. ++ * ++ * Revision 1.8 1999/08/05 19:42:34 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.7 1999/06/16 00:54:39 liang ++ * BlockRealScaleComplexSymbols takes a scale shift buffer now. ++ * ++ * Revision 1.6 1999/05/22 02:18:29 liang ++ * Add one more parameter to BlockCplxSymbolUpdateCplxScale function. ++ * ++ * Revision 1.5 1999/05/14 22:49:39 liang ++ * Added two more functions. ++ * ++ * Revision 1.4 1999/03/26 03:29:57 liang ++ * Add function BlockComplexMultLongAcc. ++ * ++ * Revision 1.3 1999/02/22 22:40:59 liang ++ * BlockByteSum takes uchar inputs instead of schar. ++ * ++ * Revision 1.2 1999/02/10 01:56:44 liang ++ * Added BlockByteSum, BlockRealScaleComplexSymbols and BlockCplxScaleComplexSymbols. ++ * ++ * Revision 1.1 1998/10/28 01:35:38 liang ++ * *** empty log message *** ++ * ++ * Revision 1.12 1998/07/08 17:09:25 scott ++ * Removed unnecessary undefs ++ * ++ * Revision 1.11 1998/04/02 06:19:44 mwg ++ * Added two new utilities. ++ * ++ * Revision 1.10 1998/03/26 23:20:55 liang ++ * Added function BlockShortMultiply. ++ * ++ * Revision 1.9 1998/02/16 18:41:00 scott ++ * Added MMX autodetect support ++ * ++ * Revision 1.8 1997/12/13 06:11:35 mwg ++ * Added new functions: ++ * BlockLongSubtract() ++ * BlockLongAdd() ++ * BlockLong2ShortSubtract() ++ * BlockShort2LongMove() ++ * BlockShortInterpolate() ++ * BlockLongCorrelate() ++ * BlockMapShort2Short() ++ * ++ * Revision 1.7 1997/03/19 18:35:10 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.6 1997/02/11 00:08:18 mwg ++ * Added BlockByteMove function ++ * ++ * Revision 1.5 1997/02/04 08:40:08 mwg ++ * Changed interface forBlockReal2ComplexMacc() ++ * ++ * Revision 1.4 1997/01/23 02:04:28 mwg ++ * Added return value to BlockShortMove ++ * ++ * Revision 1.3 1996/12/19 22:34:55 mwg ++ * Added new function BlockFullPower(). ++ * ++ * Revision 1.2 1996/02/21 03:59:15 mwg ++ * Added new function BlockReal2ComplexMacc ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1995/04/04 06:09:32 mwg ++ * Changed the SoftModem status reporting: now the status is a structure/union ++ * where different fields used for different status code. This will enable ++ * efficient status snooping for high level protocols on top of the softmodem. ++ * ++ */ ++ ++#ifndef BlockUtilPh ++#define BlockUtilPh ++ ++extern void BlockLongAdd (int, long*, long*, long*); ++extern void BlockLong2ShortSubtract (int, long*, long*, short*); ++extern void BlockShort2LongMove (int, short*, long*); ++extern void BlockShortMultiply (int, int, short*, short*, short*); ++extern void BlockByteMoveUnaligned (int size, uchar *srcPtr, uchar *dstPtr); ++extern void BlockShortOffset (int, short, short*, short*); ++extern long BlockShortInterpolateWithIncrement (int size, long scaleFactor, long increment, int shift, short* src1Ptr, short* src2Ptr, short* dstPtr); ++extern void BlockReal2ComplexMult (int, short*, ComplexShort*, ComplexShort*); ++extern void BlockComplexConjigateMult (int, ComplexShort*, ComplexShort*, ComplexShort*); ++ ++extern long BlockSum (int, short*); ++extern long BlockByteSum (int, uchar*); ++extern void BlockComplexSum (int, ComplexShort*, ComplexLong*); ++extern void BlockComplexPower (int, int, ComplexShort*, long*); ++extern long BlockFullPower (int, short*); ++extern long BlockLongCorrelate (int, long*, long*); ++ ++extern int BlockSymbol2Byte (int, int, ushort*, uchar*); ++extern int BlockByte2Symbol (int, int, uchar*, ushort*); ++ ++extern void BlockMapShort2Complex (int, ushort*, ComplexByte*, ComplexShort*); ++extern void BlockMapShort2Short (int size, ushort *srcPtr, short *mapPtr, short *dstPtr); ++extern void BlockMapByte2Byte (int size, uchar *srcPtr, uchar *mapPtr, uchar *dstPtr); ++extern void BlockMapByte2Short (int size, uchar *srcPtr, short *mapPtr, short *dstPtr); ++extern void BlockShortMult (int size, int shift, short* src1Ptr, short* src2Ptr, short* dstPtr); ++ ++extern int SM_DECL Idle(void); ++ ++extern void BlockGenerateAngles(int size, ComplexShort *anglePtr, ComplexShort *incPtr, ComplexShort *dstPtr); ++extern void BlockExtractRealPart(int size, ComplexShort *srcPtr, short *dstPtr); ++extern void BlockShortScaleByShift (int size, int shift, short* srcPtr, short* dstPtr); ++ ++#ifndef PENTIUM_REDEFS /* only if these have not been redefined to function pointers */ ++extern long BlockPower (int, short*); ++extern void BlockReal2ComplexMacc (int, int, short*, ComplexShort*, ComplexLong*); ++extern void BlockComplexMult (int, ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockShortScale (int, short, int, short*, short*); ++extern int SM_DECL BlockShortMove (int, short*, short*); ++extern long BlockCorrelate (int, short*, short*); ++ ++extern void BlockRealScaleComplexSymbols(int, int, uchar*, short*, ComplexShort*, ComplexShort*); ++/* FIXME -- the following 3 functions can be removed */ ++extern void BlockCplxScaleComplexSymbols(int, int, int, ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockCplxSymbolUpdateCplxScale(int, int, int, uchar*, ComplexShort*, ++ ComplexShort*, ComplexShort*, ComplexShort*); ++extern void BlockComplexShortFill (int, short, short, ComplexShort*); ++ ++ ++extern void BlockRealScaleCplxSymbols(int, int, int, short*, ComplexShort*, ComplexShort*); ++extern void BlockCplxLongConjigateMultCplxShort(int, ComplexLong*, ComplexShort*, ComplexLong*); ++ ++extern void BlockCplxLongScaleCplxSymbols(int, int, int, ComplexLong*, ComplexShort*, short*, ComplexShort*); ++extern void BlockCplxSymbolUpdateCplxLongScale(int, int, int, int, ++ ComplexShort*, short *, ComplexLong*, ComplexShort*); ++ ++extern void BlockComplexLongFill (int, long, long, ComplexLong*); ++ ++extern void BlockShortSubtract (int, short*, short*, short*); ++extern void BlockLongSubtract (int, long*, long*, long*); ++extern void BlockShortAdd (int, short*, short*, short*); ++extern void BlockByteMove (int, uchar*, uchar*); ++extern void BlockByteMoveByLong (int, uchar*, uchar*); ++extern void SM_DECL BlockByteFill (int, uchar, uchar*); ++extern void BlockByteFillByLong (int, uchar, uchar*); ++extern void BlockByteClear (int, uchar*); ++extern void BlockByteClearByLong (int, uchar*); ++extern void BlockShortFill (int, short, short*); ++extern void BlockShortClear (int, short*); ++extern void BlockShortClearByLong (int, short*); ++extern void BlockLongFill (int, long, long*); ++extern void BlockLongClear (int, long*); ++extern void BlockComplexShortClear (int, ComplexShort*); ++extern void BlockShortInvert (int, short*, short*); ++extern void BlockShortScaleDown (int, short*); ++extern void BlockLongMove (int, long*, long*); ++extern void BlockShortInterpolate (int, short, int, short*, short*, short*); ++extern void BlockComplexMultLongAcc (int, int, ComplexShort*, ComplexShort*, ComplexLong*); ++ ++#endif ++ ++#endif /* BlockUtilPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/CircBuf.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/CircBuf.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/CircBuf.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/CircBuf.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,217 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * CircBuf -- Generic Circular Buffer ++ * ++ * Description: ++ * Implementation of generic circular buffer algorithms ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.14 $ ++ * ++ * $Id: CircBuf.h,v 1.14 2004/06/24 03:10:37 ilyas Exp $ ++ * ++ * $Log: CircBuf.h,v $ ++ * Revision 1.14 2004/06/24 03:10:37 ilyas ++ * Added extra macro to be able to use un-cached variable (for status write) ++ * ++ * Revision 1.13 2004/02/09 23:47:02 ilyas ++ * Fixed last change ++ * ++ * Revision 1.12 2004/02/06 22:52:58 ilyas ++ * Improved stretch buffer write ++ * ++ * Revision 1.11 2002/12/30 23:27:55 ilyas ++ * Added macro for HostDma optimizations ++ * ++ * Revision 1.10 2002/10/26 02:15:02 ilyas ++ * Optimized and added new macros for HostDma ++ * ++ * Revision 1.9 2002/01/22 23:59:29 ilyas ++ * Added paraenthesis around macro argument ++ * ++ * Revision 1.8 2002/01/15 22:28:38 ilyas ++ * Extended macro to support readPtr from uncached address ++ * ++ * Revision 1.7 2001/09/21 19:47:05 ilyas ++ * Fixed compiler warnings for VxWorks build ++ * ++ * Revision 1.6 2001/06/07 18:47:56 ilyas ++ * Added more macros for circular buffer arithmetics ++ * ++ * Revision 1.5 2001/04/18 03:58:34 ilyas ++ * Added LOG file write granularity ++ * ++ * Revision 1.4 2001/01/19 04:34:12 ilyas ++ * Added more macros to circular buffer implementation ++ * ++ * Revision 1.3 2001/01/06 04:01:41 ilyas ++ * Changed the way we write status messages ++ * ++ * Revision 1.2 2001/01/04 05:52:21 ilyas ++ * Added implementation of stretchable circular buffer used in LOG and Status ++ * handlers ++ * ++ * Revision 1.1 2000/05/03 03:45:55 ilyas ++ * Original implementation ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef CircBufHeader_H_ ++#define CircBufHeader_H_ ++ ++ ++typedef struct { ++ char *pStart; ++ char *pEnd; ++ char *pRead; ++ char *pWrite; ++} circBufferStruct; ++ ++/* Initialize circular buffer */ ++ ++#define CircBufferInit(pCB,buf,size) do { \ ++ (pCB)->pStart = (char *) (buf); \ ++ (pCB)->pRead = (pCB)->pWrite = (pCB)->pStart; \ ++ (pCB)->pEnd = (pCB)->pStart + size; \ ++} while (0) ++ ++#define CircBufferGetSize(pCB) ((pCB)->pEnd - (pCB)->pStart) ++#define CircBufferGetStartPtr(pCB) ((void *) (pCB)->pStart) ++#define CircBufferGetEndPtr(pCB) ((void *) (pCB)->pEnd) ++ ++#define CircBufferReset(pCB) (pCB)->pRead = (pCB)->pWrite = (pCB)->pStart ++ ++ ++#define CircBufferGetReadPtr(pCB) ((void *) (pCB)->pRead) ++#define CircBufferGetWritePtr(pCB) ((void *) (pCB)->pWrite) ++ ++ ++#ifndef bcm47xx ++#define CircBufferDistance(pCB,p1,p2,d) ((char*)(p2) - (char*)(p1) - d >= 0 ? \ ++ (char*)(p2) - (char*)(p1) - d : \ ++ ((char*)(p2)- (char*)(p1) - d + ((pCB)->pEnd - (pCB)->pStart))) ++ ++#define CircBufferAddContig(pCB,p,n) ((char*)(p) + (n) == (pCB)->pEnd ? (pCB)->pStart : (char*)(p) + (n)) ++#else ++static __inline int CircBufferDistance(circBufferStruct *pCB, char *p1, char *p2, int d) ++{ ++ int tmp = p2 - p1 - d; ++ ++ return (tmp >= 0 ? tmp : tmp + (pCB->pEnd - pCB->pStart)); ++} ++ ++static __inline char * CircBufferAddContig(circBufferStruct *pCB, char *p, int n) ++{ ++ p += n; ++ return (p == pCB->pEnd ? pCB->pStart : p); ++} ++#endif ++ ++#define CircBufferAdd(pCB,p,n) ((char*)(p) + (n) >= (pCB)->pEnd ? \ ++ (pCB)->pStart + ((char*)(p) + (n) - (pCB)->pEnd) : \ ++ (char*)(p) + (n)) ++ ++#define CircBufferReadUpdate(pCB,n) (pCB)->pRead = CircBufferAdd(pCB,(pCB)->pRead,n) ++#define CircBufferWriteUpdate(pCB,n) (pCB)->pWrite= CircBufferAdd(pCB,(pCB)->pWrite,n) ++ ++#define CircBufferReadUpdateContig(pCB,n) (pCB)->pRead = CircBufferAddContig(pCB,(pCB)->pRead,n) ++#define CircBufferWriteUpdateContig(pCB,n) (pCB)->pWrite= CircBufferAddContig(pCB,(pCB)->pWrite,n) ++ ++#define CircBufferGetReadAvail(pCB) CircBufferDistance(pCB,(pCB)->pRead,(pCB)->pWrite,0) ++#define CircBufferIsReadEmpty(pCB) ((pCB)->pRead == (pCB)->pWrite) ++#define CircBufferGetWriteAvail(pCB) CircBufferDistance(pCB,(pCB)->pWrite,(pCB)->pRead,1) ++#define CircBufferGetWriteAvailN(pCB,n) CircBufferDistance(pCB,(pCB)->pWrite,(pCB)->pRead,n) ++ ++#define CircBufferGetReadContig(pCB) ((unsigned long)(pCB)->pWrite >= (unsigned long) (pCB)->pRead ? \ ++ (pCB)->pWrite - (pCB)->pRead : \ ++ (pCB)->pEnd - (pCB)->pRead) ++ ++#define CircBufferGetWriteContig(pCB) ((pCB)->pEnd - (pCB)->pWrite > CircBufferGetWriteAvail(pCB) ? \ ++ CircBufferGetWriteAvail(pCB) : \ ++ (pCB)->pEnd - (pCB)->pWrite) ++ ++/* ++** ++** structure and macros for "strectch" buffer ++** ++*/ ++ ++typedef struct { ++ char *pStart; ++ char *pEnd; ++ char *pExtraEnd; ++ char *pStretchEnd; ++ char *pRead; ++ char *pWrite; ++} stretchBufferStruct; ++ ++#define StretchBufferInit(pSB,buf,size,extra) do { \ ++ (pSB)->pStart = (char *) (buf); \ ++ (pSB)->pRead = (pSB)->pWrite = (pSB)->pStart; \ ++ (pSB)->pEnd = (pSB)->pStart + (size); \ ++ (pSB)->pStretchEnd = (pSB)->pEnd; \ ++ (pSB)->pExtraEnd = (pSB)->pEnd+(extra); \ ++} while (0) ++ ++#define StretchBufferGetSize(pSB) ((pSB)->pEnd - (pSB)->pStart) ++#define StretchBufferGetStartPtr(pSB) ((void *) (pSB)->pStart) ++#define StretchBufferGetReadPtr(pSB) ((void *) (pSB)->pRead) ++#define StretchBufferGetWritePtr(pSB) ((void *) (pSB)->pWrite) ++#define StretchBufferReset(pSB) ((pSB)->pRead = (pSB)->pWrite = (pSB)->pStart) ++ ++#define StretchBufferGetReadToEnd(pSB) ((pSB)->pStretchEnd - (pSB)->pRead) ++ ++#define StretchBufferGetReadAvail(pSB) ((pSB)->pWrite - (pSB)->pRead >= 0 ? \ ++ (pSB)->pWrite - (pSB)->pRead : \ ++ (pSB)->pStretchEnd - (pSB)->pRead) ++#define _StretchBufferGetWriteAvail(pSB,rd) ((rd) - (pSB)->pWrite > 0 ? \ ++ (rd) - (pSB)->pWrite - 1 : \ ++ ((pSB)->pExtraEnd - (pSB)->pWrite)) ++#define StretchBufferGetWriteAvail(pSB) _StretchBufferGetWriteAvail(pSB, (pSB)->pRead) ++ ++#define StretchBufferReadUpdate(pSB,n) do { \ ++ char *p; \ ++ \ ++ p = (pSB)->pRead + (n); \ ++ (pSB)->pRead = (p >= (pSB)->pStretchEnd ? (pSB)->pStart : p); \ ++} while (0) ++ ++#define _StretchBufferWriteUpdate(pSB,rd,n) do { \ ++ char *p; \ ++ \ ++ p = (pSB)->pWrite + (n); \ ++ if (p >= (pSB)->pEnd) { \ ++ if ((rd) != (pSB)->pStart) { \ ++ (pSB)->pStretchEnd = p; \ ++ (pSB)->pWrite = (pSB)->pStart; \ ++ } \ ++ } \ ++ else \ ++ (pSB)->pWrite = p; \ ++} while (0) ++ ++#define StretchBufferWriteUpdate(pSB,n) _StretchBufferWriteUpdate(pSB,(pSB)->pRead,n) ++ ++#endif /* CircBufHeader_H_ */ ++ ++ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DList.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DList.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DList.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DList.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,131 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * DList.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of double-linked list ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef DListHeader_H_ ++#define DListHeader_H_ ++ ++typedef struct _DListHeader ++ { ++ struct _DListHeader *next; /* next item in the list */ ++ struct _DListHeader *prev; /* prev item in the list */ ++ } DListHeader; ++ ++typedef struct _DListUpHeader ++ { ++ struct _DListUpHeader *next; /* next item in the list */ ++ struct _DListUpHeader *prev; /* prev item in the list */ ++ struct _DListUpHeader *head; /* head of the list */ ++ } DListUpHeader; ++ ++/* Double linked list DList management macros */ ++ ++#define DListInit(pDListHead) do { \ ++ ((DListHeader *)(pDListHead))->next = pDListHead; \ ++ ((DListHeader *)(pDListHead))->prev = pDListHead; \ ++} while (0) ++ ++#define DListNext(pDListEntry) (((DListHeader *)(pDListEntry))->next) ++#define DListPrev(pDListEntry) (((DListHeader *)(pDListEntry))->prev) ++ ++#define DListEntryLinked(pDListEntry) (NULL != DListNext(pDListEntry)) ++#define DListUnlinkEntry(pDListEntry) (DListNext(pDListEntry) = DListPrev(pDListEntry) = NULL) ++ ++#define DListFirst(pDListHead) DListNext(pDListHead) ++#define DListLast(pDListHead) DListPrev(pDListHead) ++#define DListValid(pDListHead,pEntry) ((void *)(pDListHead) != (pEntry)) ++#define DListEmpty(pDListHead) ((void *)pDListHead == ((DListHeader *)pDListHead)->next) ++ ++#define DListInsertAfter(pDListEntry,pEntry) do { \ ++ ((DListHeader *)(pEntry))->next = ((DListHeader *)(pDListEntry))->next; \ ++ ((DListHeader *)(pEntry))->prev = (DListHeader *)(pDListEntry); \ ++ ((DListHeader *)(pDListEntry))->next->prev = (DListHeader *) (pEntry); \ ++ ((DListHeader *)(pDListEntry))->next = (DListHeader *) (pEntry); \ ++} while (0) ++ ++#define DListInsertBefore(pDListEntry,pEntry) do { \ ++ ((DListHeader *)(pEntry))->next = (DListHeader *)(pDListEntry); \ ++ ((DListHeader *)(pEntry))->prev = ((DListHeader *)(pDListEntry))->prev; \ ++ ((DListHeader *)(pDListEntry))->prev->next = (DListHeader *) (pEntry); \ ++ ((DListHeader *)(pDListEntry))->prev = (DListHeader *) (pEntry); \ ++} while (0) ++ ++#define DListInsertTail(pDListHead,pEntry) DListInsertBefore(pDListHead,pEntry) ++#define DListInsertHead(pDListHead,pEntry) DListInsertAfter(pDListHead,pEntry) ++ ++#define DListRemove(pDListEntry) do { \ ++ ((DListHeader *)(pDListEntry))->prev->next = ((DListHeader *)(pDListEntry))->next; \ ++ ((DListHeader *)(pDListEntry))->next->prev = ((DListHeader *)(pDListEntry))->prev; \ ++} while (0) ++ ++ ++#define DListForEach(pDListHead,f,ref) do { \ ++ DListHeader *p = ((DListHeader *)(pDListHead))->next; \ ++ \ ++ while (DListValid(pDListHead,p)) { \ ++ DListHeader *p0 = p; \ ++ p = DListNext(p); \ ++ if ( (f)((void *)p0, ref) ) break; \ ++ } \ ++} while (0) ++ ++ ++/* Double linked list with up link DListUp management macros */ ++ ++#define DListUpInit(pDListHead) do { \ ++ ((DListUpHeader *)(pDListHead))->next = (DListUpHeader *) (pDListHead); \ ++ ((DListUpHeader *)(pDListHead))->prev = (DListUpHeader *) (pDListHead); \ ++ ((DListUpHeader *)(pDListHead))->head = (DListUpHeader *) (pDListHead); \ ++} while (0) ++ ++#define DListUpNext(pDListEntry) ((DListUpHeader *) DListNext(pDListEntry)) ++#define DListUpPrev(pDListEntry) ((DListUpHeader *) DListPrev(pDListEntry)) ++#define DListUpHead(pDListEntry) (((DListUpHeader *)(pDListEntry))->head) ++ ++#define DListUpFirst(pDListHead) DListUpNext(pDListHead) ++#define DListUpLast(pDListHead) DListUpPrev(pDListHead) ++#define DListUpValid(pEntry) (((DListUpHeader *)(pEntry))->head != (void *) pEntry) ++#define DListUpEmpty(pDListHead) DListEmpty(pDListHead) ++ ++#define DListUpInsertAfter(pDListEntry,pEntry) do { \ ++ DListInsertAfter(pDListEntry,pEntry); \ ++ ((DListUpHeader *)(pEntry))->head = ((DListUpHeader *)(pDListEntry))->head; \ ++} while (0) ++ ++#define DListUpInsertBefore(pDListEntry,pEntry) do { \ ++ DListInsertBefore(pDListEntry,pEntry); \ ++ ((DListUpHeader *)(pEntry))->head = ((DListUpHeader *)(pDListEntry))->head; \ ++} while (0) ++ ++#define DListUpInsertTail(pDListHead,pEntry) DListUpInsertBefore(pDListHead,pEntry) ++#define DListUpInsertHead(pDListHead,pEntry) DListUpInsertAfter(pDListHead,pEntry) ++ ++#define DListUpRemove(pDListEntry) DListRemove(pDListEntry) ++#define DListUpForEach(pDListHead,f,ref) DListForEach((DListHeader *)(pDListHead),f,ref) ++ ++#endif /* DListHeader_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DslFramer.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DslFramer.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DslFramer.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/DslFramer.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,159 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * DslFramer.h ++ * ++ * Description: ++ * This file contains common DSL framer definitions ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: DslFramer.h,v 1.3 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: DslFramer.h,v $ ++ * Revision 1.3 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.2 2004/04/12 23:41:10 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef DslFramerHeader ++#define DslFramerHeader ++ ++#include "DList.h" ++ ++#define kDslFramerInitialized 0x80000000 ++ ++/* status codes */ ++ ++#define kDslFramerRxFrame 1 ++#define kDslFramerRxFrameErr 2 ++#define kDslFramerTxFrame 3 ++#define kDslFramerTxFrameErr 4 ++ ++#define kDslFramerRxFrameErrFlushed 1 ++#define kDslFramerRxFrameErrAbort 2 ++#define kDslFramerRxFrameErrPhy 3 ++ ++#define kDslFramerTxFrameErrFlushed 1 ++ ++ ++typedef struct _dslFramerBufDesc { ++ long pkId; ++ long bufFlags; ++ void *bufPtr; ++ long bufLen; ++} dslFramerBufDesc; ++ ++/* data bufDesc flags */ ++ ++#define kDslFramerStartNewFrame 1 ++#define kDslFramerEndOfFrame 2 ++#define kDslFramerAbortFrame 4 ++ ++#define kDslFramerExtraByteShift 3 ++#define kDslFramerExtraByteMask (0x7 << kDslFramerExtraByteShift) ++ ++typedef struct _dslFramerControl { ++ bitMap setup; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ ulong statusCode; ++ ulong statusOffset; ++ ++ int nRxBuffers; ++ int nRxBufSize; ++ int nRxPackets; ++ ++ dslFrame *freeBufListPtr; ++ void *freeBufPool; ++ void *pBufMemory; ++ ++ dslFrame *freePacketListPtr; ++ void *freePacketPool; ++ ++ /* RX working data set */ ++ ++ dslFrame *pRxFrame; ++ dslFrameBuffer *pRxBuf; ++ uchar *pRxBufData; ++ uchar *pRxBufDataEnd; ++ int rxFrameLen; ++ ++ /* TX working data set */ ++ ++ DListHeader dlistTxWaiting; ++ dslFrame *pTxFrame; ++ dslFrameBuffer *pTxBuf; ++ uchar *pTxBufData; ++ uchar *pTxBufDataEnd; ++ ++ /* stats data */ ++ ++ ulong dslByteCntRxTotal; ++ ulong dslByteCntTxTotal; ++ ++ ulong dslFrameCntRxTotal; ++ ulong dslFrameCntRxErr; ++ ulong dslFrameCntTxTotal; ++ ++} dslFramerControl; ++ ++ ++extern Boolean DslFramerInit( ++ void *gDslVars, ++ dslFramerControl *dfCtrl, ++ bitMap setup, ++ ulong statusCode, ++ ulong statusOffset, ++ dslFrameHandlerType rxIndicateHandlerPtr, ++ dslFrameHandlerType txCompleteHandlerPtr, ++ dslStatusHandlerType statusHandlerPtr, ++ ulong rxBufNum, ++ ulong rxBufSize, ++ ulong rxPacketNum); ++extern void DslFramerClose(void *gDslVars, dslFramerControl *dfCtrl); ++extern void DslFramerSendFrame(void *gDslVars, dslFramerControl *dfCtrl, dslFrame *pFrame); ++extern void DslFramerReturnFrame(void *gDslVars, dslFramerControl *dfCtrl, dslFrame *pFrame); ++ ++ ++extern Boolean DslFramerRxGetPtr(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern void DslFramerRxDone (void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern Boolean DslFramerTxGetPtr(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern void DslFramerTxDone(void *gDslVars, dslFramerControl *dfCtrl, dslFramerBufDesc *pBufDesc); ++extern Boolean DslFramerTxIdle (void *gDslVars, dslFramerControl *dfCtrl); ++extern void DslFramerTxFlush(void *gDslVars, dslFramerControl *dfCtrl); ++ ++extern void * DslFramerGetFramePoolHandler(dslFramerControl *dfCtrl); ++extern void DslFramerClearStat(dslFramerControl *dfCtrl); ++ ++extern void DslFramerRxFlushFrame (void *gDslVars, dslFramerControl *dfCtrl, int errCode); ++extern void DslFramerRxFlush(void *gDslVars, dslFramerControl *dfCtrl); ++ ++#endif /* DslFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Flatten.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Flatten.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Flatten.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Flatten.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,115 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * Flatten.h -- Header for Flatten/Unflatten command/status ++ * ++ * Copyright (c) 1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.14 $ ++ * ++ * $Id: Flatten.h,v 1.14 2004/03/04 19:48:52 linyin Exp $ ++ * ++ * $Log: Flatten.h,v $ ++ * Revision 1.14 2004/03/04 19:48:52 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.13 2003/10/17 22:45:14 yongbing ++ * Increase buffer size for large B&G table of G992P3 ++ * ++ * Revision 1.12 2003/08/12 23:16:26 khp ++ * - for Haixiang: added support for ADSL_MARGIN_TWEAK_TEST ++ * ++ * Revision 1.11 2003/02/27 06:33:03 ilyas ++ * Improved free space checking in command buffer (became a problem with ++ * 2 commands SetXmtgain and StartPhy) ++ * ++ * Revision 1.10 2003/01/11 01:27:07 ilyas ++ * Improved checking for available space in status buffer ++ * ++ * Revision 1.9 2002/09/07 01:43:59 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.8 2002/05/16 00:01:52 khp ++ * -added missing #endif ++ * ++ * Revision 1.7 2002/05/15 00:04:48 mprahlad ++ * increase the status buffer size - prevent memory overflow for annexC cases ++ * ++ * Revision 1.6 2002/04/05 04:10:33 linyin ++ * -hack to fit in Annex C firmware in LMEM ++ * ++ * Revision 1.5 2002/04/05 02:45:25 linyin ++ * Make the buffer side larger for annexC ++ * ++ * Revision 1.4 2002/01/30 07:19:06 ilyas ++ * Moved showtime code to LMEM ++ * ++ * Revision 1.3 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.2 2001/04/25 00:30:54 ilyas ++ * Adjusted MaxFrameLen ++ * ++ * Revision 1.1 2001/04/24 21:41:21 ilyas ++ * Implemented status flattening/unflattaning to transfer statuses between ++ * modules asynchronously through the circular buffer ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef _Flatten_H_ ++#define _Flatten_H_ ++ ++#include "CircBuf.h" ++ ++#ifdef ADSL_MARGIN_TWEAK_TEST ++#define kMaxFlattenedCommandSize 272 /* maximum no. of bytes in flattened cmd */ ++#else ++#define kMaxFlattenedCommandSize 128 /* maximum no. of bytes in flattened cmd */ ++#endif ++#if defined(G992_ANNEXC) || defined(G992P3) ++#if defined(G992P5) ++#define kMaxFlattenedStatusSize 2200 /* maximum no. of bytes in flattened status */ ++#else ++#define kMaxFlattenedStatusSize 1100 /* maximum no. of bytes in flattened status */ ++#endif ++#else ++#define kMaxFlattenedStatusSize 550 /* maximum no. of bytes in flattened status */ ++#endif ++ ++#define kMaxFlattenFramelength (kMaxFlattenedStatusSize - (4*sizeof(long)) - 20) ++ ++extern int SM_DECL FlattenCommand (dslCommandStruct *cmd, ulong *dstPtr, ulong nAvail); ++extern int SM_DECL UnflattenCommand(ulong *srcPtr, dslCommandStruct *cmd); ++extern int SM_DECL FlattenStatus (dslStatusStruct *status, ulong *dstPtr, ulong nAvail); ++extern int SM_DECL UnflattenStatus (ulong *srcPtr, dslStatusStruct *status); ++ ++#define FlattenBufferInit(fb,fbData,bufSize,itemSize) \ ++ StretchBufferInit(fb, fbData, bufSize, itemSize) ++ ++extern int SM_DECL FlattenBufferStatusWrite(stretchBufferStruct *fBuf, dslStatusStruct *status); ++extern int SM_DECL FlattenBufferStatusRead(stretchBufferStruct *fBuf, dslStatusStruct *status); ++ ++extern int SM_DECL FlattenBufferCommandWrite(stretchBufferStruct *fBuf, dslCommandStruct *cmd); ++extern int SM_DECL FlattenBufferCommandRead(stretchBufferStruct *fBuf, dslCommandStruct *cmd); ++ ++#define FlattenBufferReadComplete(fb,nBytes) \ ++ StretchBufferReadUpdate (fb, nBytes) ++ ++#endif /* _Flatten_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,110 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G992p3OvhMsg.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the G992p3 overhead ++ * channel messages global variable structure. ++ * ++ * ++ * Copyright (c) 1999-2003 BroadCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: G992p3OvhMsg.gh,v 1.5 2004/09/11 03:52:25 ilyas Exp $ ++ * ++ * $Log: G992p3OvhMsg.gh,v $ ++ * Revision 1.5 2004/09/11 03:52:25 ilyas ++ * Added support for overhead message segmentation ++ * ++ * Revision 1.4 2004/07/07 01:27:20 ilyas ++ * Fixed OHC message stuck problem on L2 entry/exit ++ * ++ * Revision 1.3 2004/06/10 00:13:31 ilyas ++ * Added L2/L3 and SRA ++ * ++ * Revision 1.2 2004/04/12 23:34:52 ilyas ++ * Merged the latest ADSL driver chnages for ADSL2+ ++ * ++ * Revision 1.1 2003/07/18 19:39:18 ilyas ++ * Initial G.992.3 overhead channel message implementation (from ADSL driver) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G992p3OvhMsgFramerGlobals ++#define G992p3OvhMsgFramerGlobals ++ ++#define kG992p3OvhMsgMaxCmdSize (16 + 16) ++#define kG992p3OvhMsgMaxRspSize (16 + 2*512) ++ ++typedef struct ++ { ++ dslFrame *segFrame; ++ dslFrameBuffer *segFrBufCur; ++ dslFrameBuffer segFrBuf; ++ ulong timeSegOut; ++ uchar tryCnt; ++ uchar segTotal; ++ uchar segId; ++ } ++ g992p3SegFrameCtlStruct; ++ ++typedef struct ++ { ++ bitMap setup; ++ dslFrameHandlerType rxReturnFramePtr; ++ dslFrameHandlerType txSendFramePtr; ++ dslCommandHandlerType cmdHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ ++ dslFrame txRspFrame; ++ dslFrameBuffer txRspFrBuf; ++ dslFrameBuffer txRspFrBuf1; ++ uchar txRspBuf[kG992p3OvhMsgMaxRspSize]; ++ dslFrame txPwrRspFrame; ++ dslFrameBuffer txPwrRspFrBuf0; ++ dslFrameBuffer txPwrRspFrBuf0a; ++ dslFrameBuffer txPwrRspFrBuf1; ++ uchar txPwrRspBuf0[8]; ++ dslFrame txCmdFrame; ++ dslFrameBuffer txCmdFrBuf0; ++ dslFrameBuffer txCmdFrBuf0a; ++ dslFrameBuffer txCmdFrBuf1; ++ uchar txCmdBuf[kG992p3OvhMsgMaxCmdSize]; ++ g992p3SegFrameCtlStruct txSegFrameCtl; ++ ulong txFlags; ++ uchar txL0Rq; ++ uchar txL3Rq; ++ ++ ulong timeMs; ++ ulong timeCmdOut; ++ ulong cmdTryCnt; ++ ulong cmdNum; ++ ulong timeRspOut; ++ uchar *txPmdCmd; ++ ++ uchar rxCmdMsgNum; ++ uchar rxRspMsgNum; ++ uchar txCmdMsgNum; ++ uchar txRspMsgNum; ++ } ++ g992p3OvhMsgVarsStruct; ++ ++#endif /* G992p3OvhMsgFramerGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G992p3OvhMsg.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,64 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G992p3OvhMsg.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for G992p3 ++ * overhead channel messages ++ * ++ * ++ * Copyright (c) 1999-2003 BroadCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.1 $ ++ * ++ * $Id: G992p3OvhMsg.h,v 1.1 2003/07/18 19:39:18 ilyas Exp $ ++ * ++ * $Log: G992p3OvhMsg.h,v $ ++ * Revision 1.1 2003/07/18 19:39:18 ilyas ++ * Initial G.992.3 overhead channel message implementation (from ADSL driver) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G992p3OvhMsgFramerHeader ++#define G992p3OvhMsgFramerHeader ++ ++#define kG992p3OvhMsgFrameBufCnt -1 ++ ++extern Boolean G992p3OvhMsgInit( ++ void *gDslVars, ++ bitMap setup, ++ dslFrameHandlerType rxReturnFramePtr, ++ dslFrameHandlerType txSendFramePtr, ++ dslCommandHandlerType commandHandler, ++ dslStatusHandlerType statusHandler); ++ ++extern void G992p3OvhMsgReset(void *gDslVars); ++extern void G992p3OvhMsgClose(void *gDslVars); ++extern void G992p3OvhMsgTimer(void *gDslVars, long timeQ24ms); ++extern Boolean G992p3OvhMsgCommandHandler (void *gDslVars, dslCommandStruct *cmd); ++extern void G992p3OvhMsgStatusSnooper (void *gDslVars, dslStatusStruct *status); ++ ++extern int G992p3OvhMsgSendCompleteFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++extern int G992p3OvhMsgIndicateRcvFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++ ++extern void G992p3OvhMsgSetL3(void *gDslVars); ++extern void G992p3OvhMsgSetL0(void *gDslVars); ++ ++#endif /* G992p3OvhMsgFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,66 @@ ++/**************************************************************************** ++ * ++ * G997.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the G997 Framer ++ * global variable structure. ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: G997.gh,v 1.5 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: G997.gh,v $ ++ * Revision 1.5 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.4 2004/04/27 00:27:16 ilyas ++ * Implemented double buffering to ensure G.997 HDLC frame is continuous ++ * ++ * Revision 1.3 2003/07/18 18:56:59 ilyas ++ * Added support for shared TX buffer (for ADSL driver) ++ * ++ * Revision 1.2 2002/01/11 06:48:27 ilyas ++ * Added command handler pointer ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G997FramerGlobals ++#define G997FramerGlobals ++ ++#include "DslFramer.h" ++#include "HdlcFramer.h" ++ ++#define kG997MsgBufSize 64 ++ ++typedef struct ++ { ++ bitMap setup; ++ dslFramerControl dslFramer; ++ hdlcByteControl hdlcByte; ++ dslCommandHandlerType commandHandler; ++ ++ ulong timeMs; ++ ulong timeCmdOut; ++ ++ uchar rxMsgNum; ++ uchar txMsgNum; ++ Boolean txIdle; ++ uchar txMsgBuf[kG997MsgBufSize]; ++ ulong txMsgBufLen; ++ uchar *txMsgBufPtr; ++ ulong txMsgLen; ++ ulong txMsgBufs; ++ ulong txMsgBufNum; ++ } ++ g997VarsStruct; ++ ++#endif /* G997FramerGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/G997.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,68 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * G997.h ++ * ++ * Description: ++ * This file contains the exported functions and definitions for G97Framer ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: G997.h,v 1.3 2003/07/18 18:56:59 ilyas Exp $ ++ * ++ * $Log: G997.h,v $ ++ * Revision 1.3 2003/07/18 18:56:59 ilyas ++ * Added support for shared TX buffer (for ADSL driver) ++ * ++ * Revision 1.2 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef G997FramerHeader ++#define G997FramerHeader ++ ++extern Boolean G997Init( ++ void *gDslVars, ++ bitMap setup, ++ ulong rxBufNum, ++ ulong rxBufSize, ++ ulong rxPacketNum, ++ upperLayerFunctions *pUpperLayerFunctions, ++ dslCommandHandlerType g997PhyCommandHandler); ++ ++extern void G997Close(void *gDslVars); ++extern void G997Timer(void *gDslVars, long timeQ24ms); ++extern Boolean G997CommandHandler (void *gDslVars, dslCommandStruct *cmd); ++extern void G997StatusSnooper (void *gDslVars, dslStatusStruct *status); ++ ++extern int G997SendFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++extern int G997ReturnFrame(void *gDslVars, void *pVc, ulong mid, dslFrame *pFrame); ++ ++extern Boolean G997SetTxBuffer(void *gDslVars, ulong len, void *bufPtr); ++extern void * G997GetFramePoolHandler(void *gDslVars); ++ ++#endif /* G997FramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/HdlcFramer.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/HdlcFramer.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/HdlcFramer.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/HdlcFramer.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,237 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * HdlcFramer.h ++ * ++ * Description: ++ * This file contains common HDLC definitions for bit/byte stuffing ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.3 $ ++ * ++ * $Id: HdlcFramer.h,v 1.3 2004/07/21 01:39:41 ilyas Exp $ ++ * ++ * $Log: HdlcFramer.h,v $ ++ * Revision 1.3 2004/07/21 01:39:41 ilyas ++ * Reset entire G.997 state on retrain. Timeout in G.997 if no ACK ++ * ++ * Revision 1.2 2003/07/18 18:51:05 ilyas ++ * Added mode (default) to pass address and control field ++ * ++ * Revision 1.1 2001/12/13 02:28:27 ilyas ++ * Added common framer (DslPacket and G997) and G997 module ++ * ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef HdlcFramerHeader ++#define HdlcFramerHeader ++ ++/* setup bitmap definitions */ ++ ++#define kHdlcSetupShift 16 ++#define kHdlcSetupMask ((long)0xFFFF << kHdlcSetupShift) ++ ++#define kHdlcCrcMask 0x00030000 ++#define kHdlcCrcNone 0x00000000 ++#define kHdlcCrc16 0x00010000 ++#define kHdlcCrc32 0x00020000 ++ ++#define kHdlcTxIdleStop 0x00040000 ++#define kHdlcSpecialAddrCtrl 0x00080000 ++ ++extern ushort HdlcCrc16Table[]; ++ ++#define HDLC16_CRC_INIT 0xFFFF ++#define HDLC16_CRC_FINAL(crc) ((crc) ^ 0xFFFF) ++#define HDLC16_GOOD_CRC 0xF0B8 ++#define Hdlc16UpdateCrc(crc,b) ((crc) >> 8) ^ HdlcCrc16Table[((crc) ^ (b)) & 0xFF] ++ ++extern ulong HdlcCrc32Table[]; ++ ++#define HDLC32_CRC_INIT 0xFFFFFFFF ++#define HDLC32_CRC_FINAL(crc) ((crc) ^ 0xFFFFFFFF) ++#define HDLC32_GOOD_CRC 0xDEBB20E3 ++#define Hdlc32UpdateCrc(crc,b) ((crc) >> 8) ^ HdlcCrc32Table[((crc) ^ (b)) & 0xFF] ++ ++extern ulong HdlcCrc32Table[]; ++ ++/* HDLC common fields */ ++ ++#define HDLC_ADDR 0xFF ++#define HDLC_CTRL 0x3 ++ ++#define HDLC_BYTE_FLAG 0x7E ++#define HDLC_BYTE_ESC 0x7D ++ ++/* HDLC frame assembly states */ ++ ++#define HDLC_STATE_START_FLAG 0 ++#define HDLC_STATE_ADDRESS (HDLC_STATE_START_FLAG + 1) ++#define HDLC_STATE_CONTROL (HDLC_STATE_START_FLAG + 2) ++#define HDLC_STATE_DATA (HDLC_STATE_START_FLAG + 3) ++#define HDLC_STATE_FCS1 (HDLC_STATE_START_FLAG + 4) ++#define HDLC_STATE_FCS2 (HDLC_STATE_START_FLAG + 5) ++#define HDLC_STATE_END_FLAG (HDLC_STATE_START_FLAG + 6) ++ ++ ++/* HDLC common types */ ++ ++typedef struct _hdlcByteControl { ++ bitMap setup; ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ ++ /* RX working data set */ ++ ++ uchar rxFrameState; ++ int rxFrameLen; ++ ulong rxCrc; ++ Boolean rxEscChar; ++ ++ uchar *pRxData; ++ uchar *pRxDataEnd; ++ long rxDataLen; ++ ++ /* TX working data set */ ++ ++ uchar txFrameState; ++ int txFrameLen; ++ ulong txCrc; ++ int txCharPending; ++ ++ uchar *pTxData; ++ uchar *pTxDataEnd; ++ long txDataLen; ++} hdlcByteControl; ++ ++typedef struct _hdlcBitControl { ++ bitMap setup; ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ ++ /* RX working data set */ ++ ++ uchar rxFrameState; ++ int rxFrameLen; ++ ulong rxCrc; ++ int rxNibblePending; ++ int rxOutVal; ++ uchar rxOutBits; ++ uchar rxRem1Bits; ++ Boolean rxEscChar; /* ???? */ ++ ++ uchar *pRxData; ++ uchar *pRxDataEnd; ++ long rxDataLen; ++ ++ /* TX working data set */ ++ ++ uchar txFrameState; ++ int txFrameLen; ++ ulong txCrc; ++ int txOutVal; ++ uchar txOutBits; ++ uchar txLast1Bits; ++ int txCharPending; /* ???? */ ++ ++ uchar *pTxData; ++ uchar *pTxDataEnd; ++ long txDataLen; ++} hdlcBitControl; ++ ++/* HDLC common functions */ ++ ++#define HdlcFramerTxFrameInit(ctrl) do { \ ++ ctrl->txFrameState = HDLC_STATE_START_FLAG; \ ++ ctrl->txFrameLen = 0; \ ++ ctrl->txCrc = HDLC16_CRC_INIT; \ ++ ctrl->txCharPending= -1; \ ++} while (0) ++ ++#define HdlcFramerRxFrameInit(ctrl) do { \ ++ ctrl->rxFrameState = HDLC_STATE_START_FLAG; \ ++ ctrl->rxFrameLen = 0; \ ++ ctrl->rxCrc = HDLC16_CRC_INIT; \ ++ ctrl->rxEscChar = false; \ ++} while (0) ++ ++#define HdlcFramerTxGetData(ctrl) do { \ ++ dslFramerBufDesc bufDesc; \ ++ \ ++ if ((ctrl->txDataGetPtrHandler) (gDslVars, &bufDesc)) { \ ++ ctrl->pTxData = bufDesc.bufPtr; \ ++ ctrl->pTxDataEnd = (uchar*)bufDesc.bufPtr + bufDesc.bufLen; \ ++ ctrl->txDataLen = bufDesc.bufLen; \ ++ if (bufDesc.bufFlags & kDslFramerStartNewFrame) \ ++ HdlcFramerTxFrameInit(ctrl); \ ++ } \ ++ else { \ ++ HdlcFramerTxFrameInit(ctrl); \ ++ } \ ++} while (0); ++ ++#define HdlcFramerRxGetData(ctrl, frFlag) do { \ ++ dslFramerBufDesc bufDesc; \ ++ \ ++ bufDesc.bufFlags = frFlag; \ ++ if ((ctrl->rxDataGetPtrHandler) (gDslVars, &bufDesc)) { \ ++ ctrl->pRxData = bufDesc.bufPtr; \ ++ ctrl->pRxDataEnd = (uchar*)bufDesc.bufPtr + bufDesc.bufLen; \ ++ ctrl->rxDataLen = bufDesc.bufLen; \ ++ } \ ++} while (0); ++ ++/* HDLC functions headers */ ++ ++extern Boolean HdlcByteInit( ++ void *gDslVars, ++ hdlcByteControl *hbyCtrl, ++ bitMap setup, ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler, ++ dslFramerDataDoneHandlerType rxDataDoneHandler, ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler, ++ dslFramerDataDoneHandlerType txDataDoneHandler); ++ ++extern void HdlcByteReset(void *gDslVars, hdlcByteControl *hbyCtrl); ++extern void HdlcByteRxFlush(void *gDslVars, hdlcByteControl *hbyCtrl); ++extern int HdlcByteRx(void *gDslVars, hdlcByteControl *hbyCtrl, int nBytes, uchar *srcPtr) FAST_TEXT; ++extern int HdlcByteTx(void *gDslVars, hdlcByteControl *hbyCtrl, int nBytes, uchar *dstPtr) FAST_TEXT; ++extern Boolean HdlcByteTxIdle(void *gDslVars, hdlcByteControl *hbyCtrl); ++ ++extern Boolean HdlcBitInit( ++ void *gDslVars, ++ hdlcBitControl *hbiCtrl, ++ bitMap setup, ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler, ++ dslFramerDataDoneHandlerType rxDataDoneHandler, ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler, ++ dslFramerDataDoneHandlerType txDataDoneHandler); ++ ++extern void HdlcBitReset(void *gDslVars, hdlcByteControl *hbiCtrl); ++extern int HdlcBitRx(void *gDslVars, hdlcBitControl *hbiCtrl, int nBytes, uchar *srcPtr) FAST_TEXT; ++extern int HdlcBitTx(void *gDslVars, hdlcBitControl *hbiCtrl, int nBytes, uchar *dstPtr) FAST_TEXT; ++ ++#endif /* HdlcFramerHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MathUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MathUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MathUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MathUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,135 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/************************************************************************ ++ * ++ * MathUtil.h: ++ * ++ * Description: ++ * This file contains the exported interface for MathUtil.c module. ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.6 $ ++ * ++ * $Id: MathUtil.h,v 1.6 2004/04/13 00:21:13 ilyas Exp $ ++ * ++ * $Log: MathUtil.h,v $ ++ * Revision 1.6 2004/04/13 00:21:13 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.5 2001/08/16 02:18:08 khp ++ * - mark functions with FAST_TEXT to reduce cycle counts for QPROC targets ++ * (replaces use of LMEM_INSN) ++ * ++ * Revision 1.4 1999/10/06 04:55:22 liang ++ * Added function to multiply two long values to save result as VeryLong. ++ * ++ * Revision 1.3 1999/08/05 19:42:52 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.2 1999/03/26 03:29:59 liang ++ * Export CosSin table. ++ * ++ * Revision 1.1 1998/10/28 01:28:07 liang ++ * *** empty log message *** ++ * ++ * Revision 1.12 1998/02/10 17:19:49 scott ++ * Changed MathVL routines to return arguments using pointers ++ * ++ * Revision 1.11 1997/12/13 06:12:07 mwg ++ * Added more Atan2 flavors ++ * ++ * Revision 1.10 1997/11/18 01:11:48 mwg ++ * Removed symbols which accidently slipped in. ++ * ++ * Revision 1.9 1997/11/03 19:07:52 scott ++ * No longer redefine max() and min() if already defined ++ * ++ * Revision 1.8 1997/07/30 01:35:20 liang ++ * Add more accurate atan2 function UtilLongLongAtan2. ++ * ++ * Revision 1.7 1997/07/21 20:23:19 mwg ++ * Added new function: UtilBlockCos() ++ * ++ * Revision 1.6 1997/03/21 23:50:10 liang ++ * Added initial version of V8bis module to CVS tree. ++ * ++ * Revision 1.5 1997/03/19 18:35:34 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.4 1997/01/21 00:36:15 mwg ++ * Added new function: UtilBlockCosSin() ++ * ++ * Revision 1.3 1996/06/18 21:14:45 mwg ++ * Modified VLDivVL by allowing to specify the result scaling. ++ * ++ * Revision 1.2 1996/06/12 02:31:59 mwg ++ * Added 64bit arithmetic functions. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:15 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.4 1995/12/04 23:08:15 liang ++ * Add file Math/LinearToLog.c. ++ * ++ ************************************************************************/ ++#ifndef MathUtilPh ++#define MathUtilPh ++ ++/* Exported tables */ ++extern const short UtilCosTable[]; ++ ++/* Exported functions */ ++extern ComplexShort UtilCosSin(ushort angle); ++extern long UtilBlockCosSin (int nValues, long angle, long delta, ComplexShort *dstPtr); ++extern long UtilBlockCos (int nValues, long angle, long delta, short *dstPtr); ++extern ushort UtilShortShortAtan2(ComplexShort point); ++extern ushort UtilLongShortAtan2(ComplexLong point); ++extern ulong UtilShortLongAtan2(ComplexShort point) FAST_TEXT; ++extern ulong UtilLongLongAtan2(ComplexLong point) FAST_TEXT; ++extern ushort UtilSqrt(ulong y); ++extern ushort UtilMaxMagnitude(int blkSize, ComplexShort *dataPtr); ++extern short UtilQ0LinearToQ4dB (ulong x); ++extern ulong UtilQ4dBToQ12Linear (short x); ++extern void UtilAdjustComplexMagnitude(ComplexShort *srcPtr, short mag, short adjustment); ++ ++extern void VLMultLongByLong(long x, long y, VeryLong *dst); ++extern void VLMultShort (VeryLong x, short y, VeryLong *dst); ++extern void VLAddVL (VeryLong x, VeryLong y, VeryLong *dst); ++extern void VLAddLong (VeryLong x, long y, VeryLong *dst); ++extern void VLSubVL (VeryLong x, VeryLong y, VeryLong *dst); ++extern void VLSubLong (VeryLong x, long y, VeryLong *dst); ++extern void VLDivVL (VeryLong x, VeryLong y, int scale, long *dst); ++extern void VLShiftLeft(VeryLong x, int shift, VeryLong *dst); ++extern void VLShiftRight(VeryLong x, int shift, VeryLong *dst); ++ ++ ++#define UtilAtan2 UtilShortShortAtan2 ++#define UtilLongAtan2 UtilLongShortAtan2 ++ ++/* Standard Macros */ ++#undef abs ++#define abs(x) ((x) >= 0 ? (x) : -(x)) ++ ++#undef max ++#define max(x, y) ((x) >= (y) ? (x) : (y)) ++ ++#undef min ++#define min(x, y) ((x) <= (y) ? (x) : (y)) ++ ++#endif /* MathUtilPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MipsAsm.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MipsAsm.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MipsAsm.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MipsAsm.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,264 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/************************************************************************ ++ * ++ * MipsAsm.h: ++ * ++ * Description: ++ * This file contains definitions specific to MIPS assembly ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.5 $ ++ * ++ * $Id: MipsAsm.h,v 1.5 2004/04/13 00:16:59 ilyas Exp $ ++ * ++ * $Log: MipsAsm.h,v $ ++ * Revision 1.5 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.4 2002/09/12 04:08:50 ilyas ++ * Added macros for BCM MIPS specific instructions ++ * ++ * Revision 1.3 2000/11/18 21:28:19 mprahlad ++ * ifdef bcm47xx - ++ * define MSUB(src1,src2) msub src1, src2 ++ * change Mult(dst, src1, src2) to use "mul" instead of "mult; mflo" ++ * define Mul(src1, src2) mult src1, src2 ++ * ++ * Revision 1.2 2000/07/28 21:05:05 mprahlad ++ * Macros specific to bcm47xx added. ++ * ++ * Revision 1.1 1999/08/05 19:52:57 liang ++ * Copied from the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.5 1999/04/02 23:16:21 mwg ++ * Fixed a minor comatibility issue with mult ++ * ++ * Revision 1.4 1999/02/03 20:25:43 mwg ++ * Added an option for R4010 ++ * ++ * Revision 1.3 1998/10/30 02:21:34 mwg ++ * Added targets for 4640 ++ * ++ * Revision 1.2 1998/10/16 18:52:09 ilyas ++ * Added ASM_PROLOG[5-7] macros to save on stores ++ * ++ * Revision 1.1 1998/06/03 23:28:39 mwg ++ * Renamed from DinoDefs.h ++ * ++ * Revision 1.6 1998/02/09 18:23:11 scott ++ * Added EMBEDDED_CALLING_CONVENTION (GreenHill) and R3900/R4102 ++ * ++ * Revision 1.5 1997/03/19 18:35:02 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.4 1996/10/02 20:28:41 liang ++ * Remove parameter "acc" from the non-DINO version of MAD. ++ * ++ * Revision 1.3 1996/10/02 19:44:36 liang ++ * Separated MultAdd into MAD and MADW, added NO_DINO_WRITEBACK option. ++ * ++ * Revision 1.2 1996/08/14 03:06:07 liang ++ * Modified macro MultAdd so that the assembly code build works. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1994/11/04 22:41:29 mwg ++ * Added #ifdefs for different targets. ++ * ++ ************************************************************************/ ++ ++#ifndef _MIPS_ASM_H_ ++#define _MIPS_ASM_H_ ++ ++#define zero $0 ++#define v0 $2 ++#define v1 $3 ++#define a0 $4 ++#define a1 $5 ++#define a2 $6 ++#define a3 $7 ++#define t0 $8 ++#define t1 $9 ++#define t2 $10 ++#define t3 $11 ++#define t4 $12 ++#define t5 $13 ++#define t6 $14 ++#define t7 $15 ++#define s0 $16 ++#define s1 $17 ++#define s2 $18 ++#define s3 $19 ++#define s4 $20 ++#define s5 $21 ++#define s6 $22 ++#define s7 $23 ++#define t8 $24 ++#define t9 $25 ++#define k0 $26 ++#define k1 $27 ++#define gp $28 ++#define sp $29 ++#define fp $30 ++#define s8 $30 ++#define ra $31 ++ ++#ifdef EMBEDDED_CALLING_CONVENTION ++ ++/* Support for GreenHills embedded calling convention */ ++ ++#define ASM_PROLOG subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); \ ++ sw $10, 24(sp); \ ++ sw $11, 28(sp); ++ ++#define ASM_PROLOG5 subu sp, 32; \ ++ sw $8, 16(sp); ++ ++#define ASM_PROLOG6 subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); ++ ++#define ASM_PROLOG7 subu sp, 32; \ ++ sw $8, 16(sp); \ ++ sw $9, 20(sp); \ ++ sw $10, 24(sp); ++ ++#define ASM_EPILOG addu sp, 32 ++ ++#else ++#define ASM_PROLOG ++#define ASM_PROLOG5 ++#define ASM_PROLOG6 ++#define ASM_PROLOG7 ++#define ASM_EPILOG ++#endif ++ ++#ifdef DINO /* Special DSP extensions to MIPS core */ ++ ++#ifndef NO_DINO_WRITEBACK /* DSP extensions with writeback register */ ++ ++#define MAD(src1, src2) .set noreorder ; mad $0, src1, src2 ; .set reorder ++#define MADW(acc, src1, src2) .set noreorder ; mad acc, src1, src2 ; .set reorder ++#define Mult(dst, src1, src2) .set noreorder ; mult dst, src1, src2 ; .set reorder ++#define MultU(dst, src1, src2) .set noreorder ; multu dst, src1, src2 ; .set reorder ++ ++#else /* NO_DINO_WRITEBACK */ ++ ++#define MAD(src1, src2) .set noreorder ; mad $0, src1, src2 ; .set reorder ++#define MADW(acc, src1, src2) .set noreorder ; mad $0, src1, src2 ; mflo acc ; .set reorder ++#define Mult(dst, src1, src2) multu src1, src2 ; mflo dst ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#endif /* NO_DINO_WRITEBACK */ ++ ++#else /* DINO */ ++ ++#if defined(R3900) ++ ++#define MAD(src1, src2) madd $0, src1, src2 ++#define MADW(acc, src1, src2) madd acc, src1, src2 ++#define Mult(dst, src1, src2) mult dst, src1, src2 ++#define MultU(dst, src1, src2) multu dst, src1, src2 ++ ++#elif defined(bcm47xx_INSTR_MACROS) && defined(bcm47xx) ++ ++#define mips_froo(s1,s2,s3) s1##s2##s3 ++#define MSUB(s1,s2) .set noreorder ; mips_froo(msub_,s1,s2) ; .set reorder ++#define MAD(s1,s2) .set noreorder ; mips_froo(mad_,s1,s2) ; .set reorder ++#define MADW(acc, s1,s2) .set noreorder ; mips_froo(mad_,s1,s2) ; mflo acc ; .set reorder ++ ++#include "BCM4710.h" ++ ++#define Mult(dst, src1, src2) mul dst, src1, src2 ++#define Mul( src1, src2) mult src1, src2 ; ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#elif defined(bcm47xx) ++#define MSUB(src1, src2) msub src1, src2 ++#define MAD(src1, src2) madd src1, src2 ++#define MADW(acc, src1, src2) .set noreorder ; madd src1, src2; mflo acc ; .set reorder ++/* ++#define Mult(dst, src1, src2) mult src1, src2 ; mflo dst ++*/ ++#define Mult(dst, src1, src2) mul dst , src1, src2 ; ++#define Mul( src1, src2) mult src1, src2 ; ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#else ++ ++#ifdef R4102 ++#define MAD(src1, src2) madd16 src1, src2 ++#define MADW(acc, src1, src2) madd16 src1, src2 ; mflo acc ++#else /* R4102 */ ++ ++#ifdef R4640 ++ ++#define MAD(src1, src2) madd $0, src1, src2 ++#define MADW(acc, src1, src2) madd src1, src2; mflo acc ++ ++#else /* R4640 */ ++ ++#ifdef R4010 ++ ++#define MAD(src1, src2) madd src1, src2 ++#define MADW(acc, src1, src2) madd src1, src2; mflo acc ++ ++#else ++#define MAD(src1, src2) .set noat ;\ ++ mflo $at ;\ ++ sw $2, -4(sp) ;\ ++ multu src1, src2 ;\ ++ mflo $2 ;\ ++ addu $at, $2, $at ;\ ++ lw $2, -4(sp) ;\ ++ mtlo $at ;\ ++ .set at ++ ++#define MADW(acc, src1, src2) .set noat ;\ ++ mflo $at ;\ ++ sw $2, -4(sp) ;\ ++ multu src1, src2 ;\ ++ mflo $2 ;\ ++ addu $at, $2, $at ;\ ++ lw $2, -4(sp) ;\ ++ move acc, $at ;\ ++ mtlo $at ;\ ++ .set at ++#endif /* R4010 */ ++#endif /* R4102 */ ++#endif /* R4640 */ ++ ++#define Mult(dst, src1, src2) mul dst, src1, src2 ++#define MultU(dst, src1, src2) multu src1, src2 ; mflo dst ++ ++#endif /* !3900 */ ++#endif /* DINO */ ++ ++ ++ ++ ++ ++ ++ ++ ++#endif /* _MIPS_ASM_H_ */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MiscUtil.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MiscUtil.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MiscUtil.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/MiscUtil.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,65 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * MiscUtil.h -- Miscellaneous utilities ++ * ++ * Description: ++ * ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg Haixiang Liang ++ * ++ * $Revision: 1.4 $ ++ * ++ * $Id: MiscUtil.h,v 1.4 2004/04/13 00:21:46 ilyas Exp $ ++ * ++ * $Log: MiscUtil.h,v $ ++ * Revision 1.4 2004/04/13 00:21:46 ilyas ++ * Added standard header for shared ADSL driver files ++ * ++ * Revision 1.3 2001/07/21 01:21:06 ilyas ++ * Added more functions for int to string conversion used by log file ++ * ++ * Revision 1.2 1999/08/05 19:42:56 liang ++ * Merged with the softmodem top of the tree on 08/04/99 for assembly files. ++ * ++ * Revision 1.1 1999/01/27 22:10:12 liang ++ * Initial version. ++ * ++ * Revision 1.1 1997/07/10 01:18:45 mwg ++ * Initial revision. ++ * ++ * ++ * ++ *****************************************************************************/ ++#ifndef _MISC_UTIL_H_ ++#define _MISC_UTIL_H_ ++ ++extern long SM_DECL GetRateValue(dataRateMap rate); ++extern int SM_DECL DecToString(ulong value, uchar *dstPtr, uint nDigits); ++extern int SM_DECL HexToString(ulong value, uchar *dstPtr, uint nDigits); ++extern char * SM_DECL DecToStr(char *s, ulong num); ++extern char * SM_DECL SignedToStr(char *s, long num); ++extern char * SM_DECL HexToStr(char *s, ulong num); ++ ++#define EvenParityBit(x) ((z = (y = x ^ (x >> 4)) ^ (y >> 2)) ^ (z >> 1)) ++#define OddParityBit(x) (EvenParityBit(x) ^ 1) ++ ++extern void ParityApply(int nBytes, int nDataBits, int parity, uchar *srcPtr, uchar *dstPtr); ++extern void ParityStrip(int nBytes, int nDataBits, int parity, uchar *srcPtr, uchar *dstPtr, statusHandlerType statusHandler); ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Que.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Que.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Que.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/Que.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,106 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * Que.h ++ * ++ * Description: ++ * Definition and implementation (via macros and inline functions) ++ * of a simple queue ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ *****************************************************************************/ ++ ++#ifndef QueHeader_H_ ++#define QueHeader_H_ ++ ++typedef void * _QueItem; ++ ++typedef struct _QueHeader ++ { ++ _QueItem *head; /* first item in the queue */ ++ _QueItem *tail; /* last item in the queue */ ++ } QueHeader; ++ ++/* Queue management macros */ ++ ++#define QueInit(pqHdr) (((QueHeader *)(pqHdr))->head = ((QueHeader *)(pqHdr))->tail = NULL) ++#define QueEmpty(pqHdr) (NULL == ((QueHeader *)(pqHdr))->head) ++ ++#define QueFirst(pqHdr) ((QueHeader *)(pqHdr))->head ++#define QueLast(pqHdr) ((QueHeader *)(pqHdr))->tail ++#define QueNext(pqItem) (*((void **)(pqItem))) ++ ++ ++#define QueRemoveFirst(pqHdr) do { \ ++ if (!QueEmpty(pqHdr)) { \ ++ ((QueHeader *)(pqHdr))->head = *((QueHeader *)(pqHdr))->head; \ ++ if (QueEmpty(pqHdr)) \ ++ ((QueHeader *)(pqHdr))->tail = NULL; \ ++ } \ ++} while (0) ++#define QueRemove(pqHdr) QueRemoveFirst(pqHdr) ++ ++ ++#define QueAddLast(pqHdr,pqItem) do { \ ++ QueNext(pqItem) = NULL; \ ++ if (NULL != ((QueHeader *)(pqHdr))->tail) \ ++ *((QueHeader *)(pqHdr))->tail = (pqItem); \ ++ else \ ++ ((QueHeader *)(pqHdr))->head = (_QueItem *)(pqItem); \ ++ ((QueHeader *)(pqHdr))->tail = (_QueItem *)(pqItem); \ ++} while (0) ++#define QueAdd(pqHdr,pItem) QueAddLast(pqHdr,pItem) ++ ++#define QueAddFirst(pqHdr,pqItem) do { \ ++ if (NULL == ((QueHeader *)(pqHdr))->tail) \ ++ ((QueHeader *)(pqHdr))->tail = (_QueItem *)(pqItem); \ ++ QueNext(pqItem) = ((QueHeader *)(pqHdr))->head; \ ++ ((QueHeader *)(pqHdr))->head = (_QueItem *)(pqItem); \ ++} while (0) ++ ++ ++#define QueGet(pqHdr) \ ++ (void *) QueFirst(pqHdr); \ ++ QueRemove(pqHdr); ++ ++#define QueMerge(pqHdr1,pqHdr2) do { \ ++ if (NULL == ((QueHeader *)(pqHdr1))->tail) \ ++ ((QueHeader *)(pqHdr1))->head = ((QueHeader *)(pqHdr2))->head; \ ++ else \ ++ QueNext(((QueHeader *)(pqHdr1))->tail) = ((QueHeader *)(pqHdr2))->head; \ ++ if (NULL != ((QueHeader *)(pqHdr2))->tail) \ ++ ((QueHeader *)(pqHdr1))->tail = ((QueHeader *)(pqHdr2))->tail; \ ++} while (0) ++ ++#define QueCopy(pqHdr1,pqHdr2) do { \ ++ ((QueHeader *)(pqHdr1))->head = ((QueHeader *)(pqHdr2))->head; \ ++ ((QueHeader *)(pqHdr1))->tail = ((QueHeader *)(pqHdr2))->tail; \ ++} while (0) ++ ++#define QueForEach(pqHdr,f,ref) do { \ ++ _QueItem *p = ((QueHeader *)(pqHdr))->head; \ ++ \ ++ while (NULL != p) { \ ++ if ( (f)((void *)p, ref) ) break; \ ++ p = QueNext(p); \ ++ } \ ++} while (0) ++ ++#endif /* QueHeader_H_ */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftAtmVc.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftAtmVc.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftAtmVc.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftAtmVc.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,569 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftAtmVc.h ++ * ++ * Description: ++ * This file contains ATM VC definitions ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.27 $ ++ * ++ * $Id: SoftAtmVc.h,v 1.27 2004/06/02 22:26:17 ilyas Exp $ ++ * ++ * $Log: SoftAtmVc.h,v $ ++ * Revision 1.27 2004/06/02 22:26:17 ilyas ++ * Added ATM counters for G.992.3 ++ * ++ * Revision 1.26 2004/03/10 22:57:20 ilyas ++ * Added I.432 scramling control ++ * ++ * Revision 1.25 2003/09/23 00:21:59 ilyas ++ * Added status to indicate ATM header compression ++ * ++ * Revision 1.24 2003/08/27 02:00:50 ilyas ++ * Original implementation of ATM header compression ++ * ++ * Revision 1.23 2003/02/25 04:13:15 ilyas ++ * Added standard Broadcom header ++ * ++ * Revision 1.22 2003/01/10 23:25:48 ilyas ++ * Added ATM status definition ++ * ++ * Revision 1.21 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.20 2002/04/02 09:58:00 ilyas ++ * Initial implementatoin of BERT ++ * ++ * Revision 1.19 2001/10/09 22:35:14 ilyas ++ * Added more ATM statistics and OAM support ++ * ++ * Revision 1.18 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.17 2001/02/23 05:49:57 ilyas ++ * Added routed 1483 encapsulation ++ * ++ * Revision 1.16 2001/02/09 04:18:18 ilyas ++ * Added framer for bridged ethernet PDUs ++ * ++ * Revision 1.15 2001/02/09 01:55:27 ilyas ++ * Added status codes and macros to support printing of AAL packets ++ * ++ * Revision 1.14 2000/09/21 17:28:35 ilyas ++ * Added VBR support to traffic management code, separated UBR to a different ++ * Tx list, changed some of the algorithms ++ * ++ * Revision 1.13 2000/08/23 18:42:13 ilyas ++ * Added AAL2, added VcConfigure functions, moved commonly used look-up ++ * tables for CRC calculation to AtmLayer ++ * ++ * Revision 1.12 2000/08/02 03:06:22 ilyas ++ * Added support for reserving space in RX packets for ATm protocols ++ * ++ * Revision 1.11 2000/07/28 17:23:39 ilyas ++ * Added ATM connect/disconnect statuses ++ * ++ * Revision 1.10 2000/07/25 02:16:12 ilyas ++ * Added EClip (with Eth to ATM ARP translation) implementation ++ * ++ * Revision 1.9 2000/07/23 20:57:14 ilyas ++ * Added ATM framer and protocol layers ++ * ++ * Revision 1.8 2000/07/17 21:08:16 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.7 2000/06/09 18:33:04 liang ++ * Fixed Irix compiler warnings. ++ * ++ * Revision 1.6 2000/05/18 21:47:31 ilyas ++ * Added detection of preassigned cells such as OAM F4, F5 ++ * ++ * Revision 1.5 2000/05/14 01:50:11 ilyas ++ * Added more statuses to ATM code ++ * ++ * Revision 1.4 2000/05/10 02:41:28 liang ++ * Added status report for no cell memory ++ * ++ * Revision 1.3 2000/05/09 23:00:27 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.2 2000/05/03 03:53:00 ilyas ++ * Added support for pVc to vcID translation needed for LOG file and other ++ * definitions for ATM data in LOG file ++ * ++ * Revision 1.1 2000/04/19 00:21:35 ilyas ++ * Fixed some problems and added Out Of Band (OOB) support to ATM packets ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftAtmVcHeader ++#define SoftAtmVcHeader ++ ++/* ++** ++** ATM UNI types ++** ++*/ ++ ++#define AtmLinkFlags(bMap,name) (((bMap) >> name##Shift) & name##Mask) ++ ++/* ATM service category types */ ++ ++#define kAtmSrvcCBR 1 /* Constant Bit Rate */ ++#define kAtmSrvcVBR 2 /* Variable Bit Rate */ ++#define kAtmSrvcUBR 4 /* Unspecified Bit Rate */ ++#define kAtmSrvcABR 8 /* Available Bit Rate */ ++#define kAtmSrvcUnknown 0xFF ++ ++/* ATM AAL types (as encoded at UNI) */ ++ ++#define kAtmAalIE 0x58 ++ ++#define kAtmRaw 0 ++#define kAtmAal1 1 ++#define kAtmAal2 2 ++#define kAtmAal34 3 ++#define kAtmAal5 5 ++#define kAtmAalUser 16 ++#define kAtmAalUnknown 0xFF ++ ++/* ATM AAL1 parameters */ ++ ++#define kAal1SubTypeId 0x85 ++ ++#define kAal1TransportShift 0 ++#define kAal1TransportMask 0x7 ++ ++#define kAal1NullTransport 0 ++#define kAal1VoiceTransport 1 ++#define kAal1CircuitTransport 2 ++#define kAal1AudioTransport 4 ++#define kAal1VideoTransport 5 ++ ++ ++#define kAal1CBRId 0x86 ++ ++#define kAal1CBRShift 24 ++#define kAal1CBRMask 0xFF ++ ++#define kAal1CBR64 1 ++#define kAal1CBR1544 4 /* DS1 */ ++#define kAal1CBR6312 5 /* DS2 */ ++#define kAal1CBR32064 6 ++#define kAal1CBR44736 7 /* DS3 */ ++#define kAal1CBR97728 8 ++#define kAal1CBR2048 0x10 /* E1 */ ++#define kAal1CBR8448 0x11 /* E2 */ ++#define kAal1CBR34368 0x12 /* E3 */ ++#define kAal1CBR139264 0x13 ++#define kAal1CBR64xN 0x40 ++#define kAal1CBR8xN 0x41 ++ ++ ++#define kAal1MultiplierId 0x87 ++ ++#define kAal1ClockRecoveryId 0x88 ++ ++#define kAal1ClockRecoveryShift 3 ++#define kAal1ClockRecoveryMask 0x3 ++ ++#define kAal1ClockRecoveryNull 1 /* synchronous transport */ ++#define kAal1ClockRecoverySRTS 1 /* asynchronous transport */ ++#define kAal1ClockRecoveryAdaptive 2 ++ ++ ++#define kAal1ECMId 0x89 /* Error correction method */ ++ ++#define kAal1ECMShift (kAal1ClockRecoveryShift + 2) ++#define kAal1ECMMask 0x3 ++ ++#define kAal1ECMNull 0 ++#define kAal1ECMLossSensitive 1 ++#define kAal1ECMDelaySensitive 2 ++ ++ ++#define kAal1SDTBlockSizeId 0x8A ++ ++#define kAal1CellFillId 0x8B ++ ++/* ATM AAL34 and AAL5 parameters */ ++ ++#define kAalFwdMaxSDUSizeId 0x8C ++#define kAalBacMaxkSDUSizeId 0x81 ++ ++#define kAal34MidRangeId 0x82 ++ ++#define kAalSSCSTypeId 0x84 ++ ++#define kAalSSCSAssured 1 ++#define kAalSSCSNonAssured 2 ++#define kAalSSCSFrameRelay 4 ++ ++/* ATM AAL2 parameters */ ++ ++#define kAal2SSNone 0 ++#define kAal2SSSAR 1 ++#define kAal2SSTED 2 ++#define kAal2SSSARMask 3 ++#define kAal2SSType1 4 ++#define kAal2SSType3 5 ++ ++typedef struct { ++ uchar aalType; ++ union { ++ struct { ++ bitMap aal1Flags; ++ ulong cbrRate; ++ ushort blkSize; ++ uchar sarUsed; ++ } aal1Params; ++ struct { ++ ushort fwdMaxCpSize; /* Max "common part" packet size */ ++ ushort backMaxCpSize; ++ ushort cidLow; ++ ushort cidHigh; ++ ushort fwdMaxSsSize; /* Max "service specific" packet size */ ++ ushort backMaxSsSize; ++ uchar sscsType; ++ } aal2Params; ++ struct { ++ ushort fwdMaxSDUSize; ++ ushort backMaxSDUSize; ++ ushort midLow; ++ ushort midHigh; ++ uchar sscsType; ++ } aal34Params; ++ struct { ++ ushort fwdMaxSDUSize; ++ ushort backMaxSDUSize; ++ uchar sscsType; ++ } aal5Params; ++ } param; ++} atmAalParams; ++ ++/* ATM Traffic Descriptor types (as encoded at UNI) */ ++ ++#define kAtmTrafficIE 0x59 ++ ++#define kTrafficFwdPeakCellRateId0 0x82 ++#define kTrafficBackPeakCellRateId0 0x83 ++#define kTrafficFwdPeakCellRateId 0x84 ++#define kTrafficBackPeakCellRateId 0x85 ++ ++#define kTrafficFwdSustainCellRateId0 0x88 ++#define kTrafficBackSustainCellRateId0 0x89 ++#define kTrafficFwdSustainCellRateId 0x90 ++#define kTrafficBackSustainCellRateId 0x91 ++ ++#define kTrafficFwdMaxBurstSizeId0 0xA0 ++#define kTrafficBackMaxBurstSizeId0 0xA1 ++#define kTrafficFwdMaxBurstSizeId 0xB0 ++#define kTrafficBackMaxBurstSizeId 0xB1 ++ ++#define kTrafficBestEffortId 0xBE ++#define kTrafficMgrOptionsId 0xBF ++ ++#define kTrafficMaxTolerance 0x7FFFFFFF ++ ++/* trafficFlags coding */ ++ ++#define kTrafficTagFwd 1 ++#define kTrafficTagBack 2 ++#define kTrafficBestEffort 4 ++ ++typedef struct { ++ ulong tPCR0; /* CLP = 0, time between cells in us */ ++ ulong tPCR; /* CLP = 0+1 */ ++ ulong tolPCR; /* tolerance for PCR in us */ ++ ++ ulong tSCR0; /* CLP = 0 */ ++ ulong tSCR; /* CLP = 0+1 */ ++ ulong tolSCR; /* tolerance for SCR in us */ ++ ++ uchar atmServiceType; /* CBR, VBR, UBR, etc. */ ++ uchar trafficFlags; ++} atmTrafficParams; ++ ++/* ATM Broadband Bearer Capabilty (BBC) types (as encoded at UNI) */ ++ ++#define kAtmBBCIE 0x5E ++ ++#define kBBCClassShift 0 ++#define kBBCClassMask 0x1F ++ ++#define kBBCClassA 0x1 ++#define kBBCClassC 0x3 ++#define kBBCClassX 0x10 ++ ++ ++#define kBBCTrafficShift (kBBCClassShift + 5) ++#define kBBCTrafficMask 0x7 ++ ++#define kBBCTrafficNull 0 ++#define kBBCTrafficCBR 1 ++#define kBBCTrafficVBR 2 ++ ++ ++#define kBBCTimingShift (kBBCTrafficShift + 3) ++#define kBBCTimingMask 0x3 ++ ++#define kBBCTimingNull 0 ++#define kBBCTimingRequired 1 ++#define kBBCTimingNotRequired 2 ++ ++ ++#define kBBCClippingShift (kBBCTimingShift + 2) ++#define kBBCClippingMask 0x3 ++ ++#define kBBCNoClipping 0 ++#define kBBCClippingOk 1 ++ ++#define kBBCConnectionShift (kBBCClippingShift + 2) ++#define kBBCConnectionMask 0x3 ++ ++#define kBBCPoint2Point 0 ++#define kBBCPoint2MPoint 1 ++ ++/* ATM Broadband High/Low Layer Information (BHLI/BLLI) types (as encoded at UNI) */ ++ ++#define kAtmBHLIIE 0x5D ++#define kAtmBLLIIE 0x5F ++ ++/* ATM QoS types (as encoded at UNI) */ ++ ++#define kAtmQoSIE 0x5C ++ ++#define kQoSNull 0 ++#define kQoSClass1 1 ++#define kQoSClass2 2 ++#define kQoSClass3 3 ++#define kQoSClass4 4 ++#define kQoSReserved 0xFF ++ ++typedef struct { ++ uchar fwdQoSClass; ++ uchar backQoSClass; ++} atmQoSParams; ++ ++/* ATM MID definitions (ConfigureHandler) */ ++ ++#define kAtmMidEntireVc ((ulong) -1) ++ ++typedef struct { ++ void *pUserVc; /* VC id from the caller: has to be 1st !!! */ ++ ulong vci; ++ uchar defaultCLP; /* default CLP for tx packets on this VC */ ++ uchar framerId; ++ uchar protoId; ++ uchar protoRxBytesReserved; /* # bytes reserved by protocol in the beginning of Rx packet */ ++ uchar protoTxBytesReserved; /* # bytes reserved by protocol in the beginning of Tx packet */ ++ ++ atmAalParams aalParams; ++ atmTrafficParams rxTrafficParams; ++ atmTrafficParams txTrafficParams; ++ bitMap bbcFlags; ++ atmQoSParams qosParams; ++} atmVcParams; ++ ++/* ++** ++** ATM Out of Band (OOB) packet information ++** ++*/ ++ ++typedef struct { ++ Boolean clp; /* Cell Loss Prioroty */ ++ uchar aalType; ++ union { ++ struct { ++ uchar payloadType; ++ } aalRawParams; ++ struct { ++ uchar payloadType; ++ ushort mid; ++ } aal34Params; ++ struct { ++ uchar uui; /* Uses to user indicator */ ++ uchar cpi; /* common part indicator */ ++ } aal5Params; ++ } aalParam; ++} atmOobPacketInfo; ++ ++/* ++** ++** ATM setup bit definition ++** ++*/ ++ ++#define kAtmCorrectHecErrors 1 ++#define kCorrectHecErrors kAtmCorrectHecErrors ++#define kAtmPhyHeaderCompression 2 ++#define kAtmPhyNoDataScrambling 4 ++ ++#define kAtmTxIdleTimeoutMask 0x6 ++#define kAtmTxIdleNoTimeout 0 ++#define kAtmTxIdleTimeout10s 2 ++#define kAtmTxIdleTimeout30s 4 ++#define kAtmTxIdleTimeout60s 6 ++ ++/* ++** ++** ATM framer modes and protocol definitions ++** ++*/ ++ ++#define kAtmFramerNone 0 ++#define kAtmFramerISO 1 ++#define kAtmFramerIP 2 ++#define kAtmFramerEth 3 ++#define kAtmFramerEthWithCRC 4 ++ ++#define kAtmProtoNone 0 ++#define kAtmProtoEClip 1 ++#define kAtmProtoERouted1483 2 ++#define kAtmProtoPPP 3 ++ ++ ++/* ++** ++** ATM status codes ++** ++*/ ++ ++typedef void (*atmStatusHandler) (void *gDslVars, ulong statusCode, ...); ++ ++/* physical layer I.432 */ ++ ++#define kAtmStatRxHunt 1 ++#define kAtmStatRxPreSync 2 ++#define kAtmStatRxSync 3 ++#define kAtmStatRxPlOamCell 4 ++#define kAtmStatBertResult 5 ++#define kAtmStatHec 6 ++#define kAtmStatHdrCompr 7 ++#define kAtmStatCounters 8 ++ ++/* ATM layer */ ++ ++#define kAtmLayerStatFirst 100 ++#define kAtmStatRxDiscarded 100 ++#define kAtmStatTxDelayed 101 ++ ++#define kAtmStatVcCreated 102 ++#define kAtmStatVcStarted 103 ++#define kAtmStatVcStopped 104 ++#define kAtmStatVcDeleted 105 ++ ++#define kAtmStatTimeout 106 ++#define kAtmStatNoCellMemory 107 ++#define kAtmStatPrintCell 108 ++#define kAtmStatInvalidCell 109 ++#define kAtmStatUnassignedCell 110 ++#define kAtmStatOamF4SegmentCell 111 ++#define kAtmStatOamF4End2EndCell 112 ++#define kAtmStatOamI371Cell 113 ++#define kAtmStatOamF5SegmentCell 114 ++#define kAtmStatOamF5End2EndCell 115 ++#define kAtmStatReservedCell 116 ++ ++#define kAtmStatConnected 117 ++#define kAtmStatDisconnected 118 ++ ++#define kAtmStatRxPacket 119 ++#define kAtmStatTxPacket 120 ++ ++#define kAtmStatOamLoopback 121 ++ ++ ++typedef struct _atmPhyCounters { ++ ushort id; ++ ushort bertStatus; ++ ulong bertCellTotal; ++ ulong bertCellCnt; ++ ulong bertBitErrors; ++ ++ ulong rxHecCnt; ++ ulong rxCellTotal; ++ ulong rxCellData; ++ ulong rxCellDrop; ++} atmPhyCounters; ++ ++/* AAL layer */ ++ ++ ++ ++/* ++** ++** ATM log file definitions ++** ++*/ ++ ++/* ATM log file flags */ ++ ++#define kAtmLogFrameFlagMask 3 /* mask */ ++ ++#define kAtmLogFrameFlagNone 0 /* nothing */ ++#define kAtmLogFrameFlagNoData 1 /* no data only frame size */ ++#define kAtmLogFrameFlagBinData 2 /* data in binary form */ ++#define kAtmLogFrameFlagTextData 3 /* data in text form */ ++ ++#define kAtmLogSendFrameShift 0 ++#define kAtmLogSendFrameNoData (kAtmLogFrameFlagNoData << kAtmLogSendFrameShift) ++#define kAtmLogSendFrameBinData (kAtmLogFrameFlagBinData << kAtmLogSendFrameShift) ++#define kAtmLogSendFrameTextData (kAtmLogFrameFlagTextData << kAtmLogSendFrameShift) ++ ++#define kAtmLogRcvFrameShift 2 ++#define kAtmLogRcvFrameNone (kAtmLogFrameFlagNone << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameNoData (kAtmLogFrameFlagNoData << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameBinData (kAtmLogFrameFlagBinData << kAtmLogRcvFrameShift) ++#define kAtmLogRcvFrameTextData (kAtmLogFrameFlagTextData << kAtmLogRcvFrameShift) ++ ++#define kAtmLogSendCompleteFrameShift 4 ++#define kAtmLogSendCompleteFrameNone (kAtmLogFrameFlagNone << kAtmLogSendCompleteFrameShift) ++#define kAtmLogSendCompleteFrameNoData (kAtmLogFrameFlagNoData << kAtmLogSendCompleteFrameShift) ++ ++#define kAtmLogReturnFrameShift 6 ++#define kAtmLogReturnFrameNoData (kAtmLogFrameFlagNoData << kAtmLogReturnFrameShift) ++ ++#define kAtmLogCellFlag (1 << 8) ++ ++/* ATM log codes */ ++ ++#define kAtmLogSendFrame 1 ++#define kAtmLogRcvFrame 2 ++#define kAtmLogSendFrameComplete 3 ++#define kAtmLogReturnFrame 4 ++#define kAtmLogVcAllocate 5 ++#define kAtmLogVcFree 6 ++#define kAtmLogVcActivate 7 ++#define kAtmLogVcDeactivate 8 ++#define kAtmLogTimer 9 ++#define kAtmLogCell 10 ++#define kAtmLogVcConfigure 11 ++ ++#define kAtmLogRxCellHeader 12 ++#define kAtmLogRxCellData 13 ++#define kAtmLogTxCell 14 ++ ++#endif /* SoftAtmVcHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.gh linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.gh +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.gh 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.gh 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,675 @@ ++/**************************************************************************** ++ * ++ * SoftDsl.gh ++ * ++ * Description: ++ * This is a header file which defines the type for the DSL ++ * global variable structure. ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.72 $ ++ * ++ * $Id: SoftDsl.gh,v 1.72 2004/04/30 23:05:19 kdu Exp $ ++ * ++ * $Log: SoftDsl.gh,v $ ++ * Revision 1.72 2004/04/30 23:05:19 kdu ++ * Fixed interop issues in TDC lab for TMM. ++ * ++ * Revision 1.70 2004/04/10 23:30:48 ilyas ++ * Defined gloval structure for slow (SDRAM) data ++ * ++ * Revision 1.69 2004/04/02 18:33:45 gsyu ++ * Share MuxFramer buffers with scratch memory ++ * ++ * Revision 1.68 2004/02/04 20:12:38 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.67 2004/02/03 19:10:37 gsyu ++ * Added separated carrierInfo structures for G992P5 ++ * ++ * Revision 1.66 2004/01/26 04:21:06 yongbing ++ * Merge changes in ADSL2 branch into Annex A branch ++ * ++ * Revision 1.65 2004/01/13 19:12:07 gsyu ++ * Added two more variables for Double upstream ++ * ++ * Revision 1.64 2003/12/04 02:10:37 linyin ++ * Add a variable for FbmsOL mode ++ * ++ * Revision 1.63 2003/11/20 00:57:50 yongbing ++ * Merge ADSL2 functionalities into Annex A branch ++ * ++ * Revision 1.62 2003/11/05 01:59:12 liang ++ * Add vendor ID code for Infineon. ++ * ++ * Revision 1.61 2003/08/12 22:59:41 khp ++ * - for Haixiang: added support for ADSL_MARGIN_TWEAK_TEST ++ * ++ * Revision 1.60 2003/08/01 00:08:19 liang ++ * Added firmware ID for Samsung ADI 930 DSLAM. ++ * ++ * Revision 1.59 2003/07/14 14:40:08 khp ++ * - AnnexB: added bad SNR2 retrain counter to connectin setup ++ * ++ * Revision 1.58 2003/06/25 02:40:22 liang ++ * Added firmware ID for Annex A UE9000 ADI918 (from Aliant, Canada). ++ * ++ * Revision 1.57 2003/06/25 00:00:40 ilyas ++ * -added firmware IDs for TI 4000C and AC5 (Annex B) ++ * ++ * Revision 1.56 2003/05/31 01:50:38 khp ++ * -add firmware IDs for ECI16 and ECI16A ++ * ++ * Revision 1.55 2003/03/27 19:30:52 liang ++ * Add and initialize new connectionSetup field coVendorFirmwareID under module ADSL_IDENTIFY_VENDOR_FIRMWARE. ++ * ++ * Revision 1.54 2002/12/13 18:35:48 yongbing ++ * Add support for G.992.2 Annex C in start up ++ * ++ * Revision 1.53 2002/12/06 02:06:33 liang ++ * Moved the T1.413 RAck1/RAck2 switching variables to connection setup structure. ++ * ++ * Revision 1.52 2002/11/26 02:49:46 liang ++ * Added variable codingGainDecrement to the connectionSetup structure to solve the C-Rates-RA option failure problem. ++ * ++ * Revision 1.51 2002/10/20 18:56:16 khp ++ * - for linyin: ++ * - #ifdef NEC_NSIF_WORKAROUND: ++ * - add status and fail counter for NSIF ++ * ++ * Revision 1.50 2002/09/28 02:36:50 yongbing ++ * Add retrain in T1.413 with R-Ack1 tone ++ * ++ * Revision 1.49 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.48 2002/07/19 01:51:35 liang ++ * Added vendor ID constant for Alcatel. ++ * ++ * Revision 1.47 2002/06/27 21:51:08 liang ++ * Added xmt and rcv tone selection bitmap in connection setup. ++ * ++ * Revision 1.46 2002/06/11 20:48:06 liang ++ * Added CO vendor ID field to connectionSetup structure. ++ * ++ * Revision 1.45 2002/06/06 03:05:43 khp ++ * -use boolean in connectup setup instead of localCapabilities.features to indicate FBM mode ++ * ++ * Revision 1.44 2002/03/22 19:38:58 yongbing ++ * Modify for co-exist of G994P1 and T1P413 ++ * ++ * Revision 1.43 2002/03/02 00:52:40 ilyas ++ * AnnexC delay needs to be long for prototype ++ * ++ * Revision 1.42 2002/01/19 23:59:17 ilyas ++ * Added support for LOG and eye data to ADSL core target ++ * ++ * Revision 1.41 2002/01/16 19:03:59 ilyas ++ * Added HOST_ONLY ifdefs around ADSL core data ++ * ++ * Revision 1.40 2002/01/14 17:41:04 liang ++ * Move xmt & rcv sample buffers to top level. ++ * ++ * Revision 1.39 2001/12/21 22:45:34 ilyas ++ * Added support for ADSL MIB data object ++ * ++ * Revision 1.38 2001/12/13 02:24:22 ilyas ++ * Added G997 (Clear EOC and G997 framer) support ++ * ++ * Revision 1.37 2001/11/30 05:56:31 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.36 2001/10/19 00:12:07 ilyas ++ * Added support for frame oriented (no ATM) data link layer ++ * ++ * Revision 1.29.2.5 2001/10/03 01:44:00 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.29.2.4 2001/08/18 00:00:36 georgep ++ * Add variable to store annexC pathDelay ++ * ++ * Revision 1.29.2.3 2001/08/08 17:33:27 yongbing ++ * Merge with tag SoftDsl_2_17 ++ * ++ * Revision 1.35 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.34 2001/08/28 03:26:32 ilyas ++ * Added support for running host and adsl core parts separately ("dual" mode) ++ * ++ * Revision 1.33 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.32 2001/05/18 21:21:44 liang ++ * Save the current number of rcv samples to line handler for QProc test. ++ * ++ * Revision 1.31 2001/04/25 01:20:11 ilyas ++ * ++ * Don't use DSL frame functions if ATM_LAYER is not defined ++ * ++ * Revision 1.30 2001/03/25 06:11:20 liang ++ * Combined separate loop attenuation status for ATUR & ATUC into one status. ++ * Replace separate hardware AGC info status for ATUR & ATUC into hardware AGC ++ * request status and hardware AGC obtained status. ++ * Use store AGC command to save hardware AGC value instead of returning value ++ * from status report. ++ * ++ * Revision 1.29 2001/03/17 03:00:46 georgep ++ * Added agcInfo to connectionSetupStruct ++ * ++ * Revision 1.28 2001/02/10 03:03:09 ilyas ++ * Added one more DslFrame function ++ * ++ * Revision 1.27 2000/08/31 19:04:24 liang ++ * Added scratch buffer structure definition. ++ * ++ * Revision 1.26 2000/07/23 20:52:52 ilyas ++ * Added xxxFrameBufSetAddress() function for ATM framer layers ++ * Rearranged linkLayer functions in one structure which is passed as a ++ * parameter to xxxLinkLayerInit() function to be set there ++ * ++ * Revision 1.25 2000/07/18 21:42:25 ilyas ++ * Fixed compiler warning about pointer casting ++ * ++ * Revision 1.24 2000/07/18 21:18:45 ilyas ++ * Added GLOBAL_PTR_BIAS feature to utilize full 64K MIPS relative addressing space ++ * ++ * Revision 1.23 2000/07/18 20:03:24 ilyas ++ * Changed DslFrame functions definitions to macros, ++ * Removed gDslVars from their parameter list ++ * ++ * Revision 1.22 2000/07/17 21:08:15 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.21 2000/05/09 23:00:26 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.20 2000/05/03 03:57:04 ilyas ++ * Added LOG file support for writing ATM data ++ * ++ * Revision 1.19 2000/04/19 00:31:47 ilyas ++ * Added global SoftDsl functions for Vc, added OOB info functions ++ * ++ * Revision 1.18 2000/04/13 08:36:22 yura ++ * Added SoftDslSetRefData, SoftDslGetRefData functions ++ * ++ * Revision 1.17 2000/04/13 05:38:54 georgep ++ * Added T1p413 "Activation and Acknowledgement" which can substitute G994P1 ++ * ++ * Revision 1.16 2000/04/05 22:30:42 liang ++ * Changed function & constant names from G992p2 to G992 for the Main module. ++ * ++ * Revision 1.15 2000/04/04 04:16:06 liang ++ * Merged with SoftDsl_0_03 from old tree. ++ * ++ * Revision 1.15 2000/04/04 01:47:21 ilyas ++ * Implemented abstract dslFrame and dslFrameBuffer objects ++ * ++ * Revision 1.14 2000/04/01 02:53:33 georgep ++ * Added pointer to G992p2Profile inside connectionSetup ++ * ++ * Revision 1.13 2000/03/18 01:27:56 georgep ++ * Changed connectionSetup to include G992p1 Capabilities ++ * ++ * Revision 1.12 2000/02/29 01:39:05 georgep ++ * put variable haveRemoteCapabilities inside connectionSetupStruct ++ * ++ * Revision 1.11 2000/02/08 00:44:36 liang ++ * Fix the gDslVars definition for Irix environment. ++ * ++ * Revision 1.10 1999/11/19 00:59:29 george ++ * Define physicalLayerVars as a union ++ * ++ * Revision 1.9 1999/11/11 19:19:42 george ++ * Porting to 16Bit Compiler ++ * ++ * Revision 1.8 1999/11/09 20:26:17 george ++ * Added G992P2_PROFILE to modules list ++ * ++ * Revision 1.7 1999/10/27 23:01:54 wan ++ * Add G.994.1 setup in dslConnectionSetupStruct for setting up Initiation side ++ * ++ * Revision 1.6 1999/08/12 21:16:27 george ++ * Move profileVars definition to G992p2/G992p2Profile.gh ++ * ++ * Revision 1.5 1999/08/10 18:20:43 george ++ * Define fastRetrainVars ++ * ++ * Revision 1.4 1999/07/16 02:03:02 liang ++ * Added Tx & Rx data handler function pointers. ++ * ++ * Revision 1.3 1999/07/03 01:40:15 liang ++ * Redefined dsl command parameter list and added connection setup struct. ++ * ++ * Revision 1.2 1999/02/10 01:56:37 liang ++ * Added hooks for G994.1 and G992.2. ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftDslGlobals ++#define SoftDslGlobals ++ ++#include "SoftDsl.h" ++ ++#ifdef G992P2_PROFILE ++#include "G992p2Profile.gh" ++#endif ++ ++typedef enum ++ { ++ kVendorUnknown = 0, ++ kVendorBroadcom, ++ kVendorGlobespan, ++ kVendorADI, ++ kVendorTI, ++ kVendorCentillium, ++ kVendorAlcatel, ++ kVendorInfineon ++ } VendorIDType; ++ ++#define kDslVendorFirwareUnknown 0 ++typedef enum ++ { ++ kVendorADI_Anaconda = 1, ++ kVendorADI_ECI918, ++ kVendorADI_ECI930, ++ kVendorADI_Cisco, ++ kVendorADI_UE9000_918, ++ kVendorADI_Samsung_930, ++ kVendorTI_4000C_ERICSSON_350, ++ kVendorTI_4000C_SEIMENS, ++ kVendorADI_ECI16_AnnexB = 50, /* leave space for more Annex A types */ ++ kVendorADI_ECI16A_AnnexB, ++ kVendorTI_4000C_AnnexB, ++ kVendorTI_AC5_AnnexB ++ } VendorFirmwareIDType; ++ ++#define kDslXmtToneSelectionStartTone 0 ++#ifdef G992P1_ANNEX_B ++#define kDslXmtToneSelectionEndTone 63 ++#else ++#define kDslXmtToneSelectionEndTone 31 ++#endif ++#define kDslXmtToneSelectionNumOfTones (kDslXmtToneSelectionEndTone-kDslXmtToneSelectionStartTone+1) ++#define kDslXmtToneSelectionNumOfBytes ((kDslXmtToneSelectionNumOfTones+7)/8) ++#define kDslRcvToneSelectionStartTone 32 ++#define kDslRcvToneSelectionEndTone 255 ++#define kDslRcvToneSelectionNumOfTones (kDslRcvToneSelectionEndTone-kDslRcvToneSelectionStartTone+1) ++#define kDslRcvToneSelectionNumOfBytes ((kDslRcvToneSelectionNumOfTones+7)/8) ++ ++#define kDslT1p413RAckModeTryRAck1 0x01 ++#define kDslT1p413RAckModeTryRAck2 0x02 ++#define kDslT1p413RAckModeTrialMask 0x0F ++#define kDslT1p413RAckModeSelected 0x10 ++#define kDslT1p413RAckModeTrialCount 10 /* when in trial mode */ ++#define kDslT1p413RAckModeSwitchCount 20 /* when mode is selected */ ++ ++#ifdef ADSL_MARGIN_TWEAK_TEST ++#define kDslMarginTweakNumOfTones 256 ++#endif ++ ++typedef struct ++ { ++ Boolean haveRemoteCapabilities; ++ dslModulationType selectedModulation; ++ dslModulationType startupModulation; ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++ ushort downstreamMinCarr, downstreamMaxCarr; ++#else ++ uchar downstreamMinCarr, downstreamMaxCarr; ++#endif ++ uchar upstreamMinCarr, upstreamMaxCarr; ++#if defined(DOUBLE_UP_STREAM) ++ Boolean isDoubleUsEnabled; ++ short selectedPilotTone; ++#endif ++ dslDataPumpCapabilities localCapabilities, remoteCapabilities; ++#ifdef G992P3 ++ g992p3DataPumpCapabilities localCarrierInfoG992p3AnnexA; ++ g992p3DataPumpCapabilities remoteCarrierInfoG992p3AnnexA; ++ g992p3DataPumpCapabilities selectedCarrierInfoG992p3AnnexA; ++ uchar xmtG992p3State; ++#ifdef G992P5 ++ g992p3DataPumpCapabilities localCarrierInfoG992p5AnnexA; ++ g992p3DataPumpCapabilities remoteCarrierInfoG992p5AnnexA; ++ g992p3DataPumpCapabilities selectedCarrierInfoG992p5AnnexA; ++#endif /* G992P5 */ ++#endif /* G992P3 */ ++ uchar handshakingDuplexMode; ++ Boolean handshakingClientInitiation; ++ short handshakingXmtPowerLevel; ++ uchar handshakingXmtCarrierSet; ++ short hwAgcQ4dB; /* for loop attenuation calculation */ ++ uchar coVendorID; ++#ifdef ADSL_IDENTIFY_VENDOR_FIRMWARE ++ uchar coVendorFirmwareID; ++#endif ++ uchar codingGainDecrement; /* coding gain decrement in Q4dB for initial rate calculation */ ++ uchar xmtToneSelection[kDslXmtToneSelectionNumOfBytes]; ++ uchar rcvToneSelection[kDslRcvToneSelectionNumOfBytes]; ++#ifdef G992_ANNEXC ++ Boolean isFbmMode; ++ Boolean isFbmsOLMode; ++ long xmtToRcvPathDelay; ++#endif ++#if defined(T1P413) && defined(XMT_RACT2_FOR_ADI_COMPATIBILITY) ++ uchar t1p413RAckModeUsed; ++ uchar t1p413RAckModeCounter; ++#endif ++#ifdef G992P1_ANNEX_B ++ uchar badSNR2RetrainCounter; ++#endif ++#ifdef ADSL_MARGIN_TWEAK_TEST ++ short marginTweakExtraPowerQ4dB; ++ char marginTweakTableQ4dB[kDslMarginTweakNumOfTones]; ++#endif ++#ifdef G992P2_PROFILE ++ G992p2ProfileVarsStruct* profileVarsPtr; ++#endif ++#ifdef TDC_IOP_FIX_SEIMENS_TI ++ char t1p413RetrainCounter; /* 0: no retrain needed; 1: force to T1.413 mode and retrain after R-MSG1; 2: 2nd T1.413 session, go to showtime */ ++#endif ++#ifdef ANSI_CACT12_PING_PONG ++ char t1p413SkipToneIndex; /* to alternate between CAct1 and CAct2 detection */ ++#endif ++ } dslConnectionSetupStruct; ++ ++#ifdef ADSL_FRAMER ++#include "MuxFramer.gh" ++#endif ++ ++#ifdef ATM ++#include "SoftAtm.gh" ++#endif ++ ++#ifdef DSL_PACKET ++#include "DslPacket.gh" ++#endif ++ ++#ifdef G997_1_FRAMER ++#include "G997.gh" ++#ifdef G992P3 ++#include "G992p3OvhMsg.gh" ++#endif ++#endif ++ ++#ifdef ADSL_MIB ++#include "AdslMib.gh" ++#endif ++ ++#ifndef HOST_ONLY ++#ifdef T1P413 ++#include "T1p413Main.gh" ++#endif ++ ++#ifdef G994P1 ++#include "G994p1Main.gh" ++#endif ++ ++#ifdef G992 ++#include "G992Main.gh" ++#endif ++ ++#include "SoftDslSampleBuffers.gh" ++#endif ++ ++typedef struct __dslSlowVarsStruct ++ { ++ int tmp; ++ } ++ dslSlowVarsStruct; ++ ++typedef struct __dslVarsStruct ++ { ++ bitMap setup; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++ dslDriverCallbackType driverCallback; ++ ++ rcvHandlerType rcvHandlerPtr; ++ xmtHandlerType xmtHandlerPtr; ++ ++#ifndef ADSLCORE_ONLY ++ dslCommandHandlerType adslCoreCommandHandlerPtr; ++#endif ++ dslCommandHandlerType dataPumpCommandHandlerPtr; ++ ++ dslStatusHandlerType internalStatusHandlerPtr; ++ dslStatusHandlerType externalStatusHandlerPtr; ++#ifndef ADSLCORE_ONLY ++ dslStatusHandlerType externalLinkLayerStatusHandlerPtr; ++#endif ++ ++ dslDirectionType direction; ++ dslConnectionSetupStruct connectionSetup; ++ ++#ifdef NEC_NSIF_WORKAROUND ++ uchar G994NsStatus; ++ uchar G994NsFailCounter; ++#endif ++ ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ ++ linkLayerFunctions LinkLayerFunctions; ++ dslSlowVarsStruct *dslSlowVars; ++ ++#ifdef DSL_FRAME_FUNCTIONS ++ dslFrameFunctions DslFrameFunctions; ++#endif ++ ulong refData; ++ ulong execTime; ++ int currRcvNSamps; ++ ++#ifndef HOST_ONLY ++ DslSampleBuffersStruct sampleBuffersVars; ++ ++#ifdef G992P2_PROFILE ++ G992p2ProfileVarsStruct G992p2ProfileVars; ++#endif ++ ++#ifdef ADSL_FRAMER ++ muxFramerVarsStruct muxFramerVars; ++#endif ++#endif /* HOST_ONLY */ ++ ++#ifdef DSL_LINKLAYER ++ union ++ { ++#ifdef ATM ++ atmVarsStruct atmVars; ++#endif ++#ifdef DSL_PACKET ++ dslPacketVarsStruct dslPacketVars; ++#endif ++ } linkLayerVars; ++#endif ++ ++#ifdef G997_1_FRAMER ++ g997VarsStruct G997Vars; ++#ifdef G992P3 ++ g992p3OvhMsgVarsStruct G992p3OvhMsgVars; ++#endif ++#endif ++ ++#ifdef ADSL_MIB ++ adslMibVarsStruct adslMibVars; ++#endif ++ ++#ifndef HOST_ONLY ++ union ++ { ++#ifdef T1P413 ++ T1p413VarsStruct T1p413Vars; ++#endif ++#ifdef G994P1 ++ G994p1VarsStruct G994p1Vars; ++#endif ++#ifdef G992 ++ G992VarsStruct G992Vars; ++#endif ++ } physicalLayerVars; ++ union ++ { ++#ifdef G992 ++ G992ScratchVarsStruct G992ScratchVars; ++#endif ++#if defined(ADSL_FRAMER) && defined(SHARE_MUX_FRAMER_VARS) ++ muxFramerSharedVarsStruct muxFramerSharedVars; ++#endif ++ } scratchVars; ++#endif /* HOST_ONLY */ ++ ++ } ++ dslVarsStruct; ++ ++#ifndef GLOBAL_PTR_BIAS ++#define gDslGlobalVarPtr ((struct __dslVarsStruct *)gDslVars) ++#define gDslGlobalSlowVarPtr (gDslGlobalVarPtr->dslSlowVars) ++#else ++#define gDslGlobalVarPtr ((struct __dslVarsStruct *) (void*)((uchar*)(gDslVars) - GLOBAL_PTR_BIAS)) ++#define gDslGlobalSlowVarPtr ((struct __dslSlowVarsStruct *) (void*)((uchar*)(gDslGlobalVarPtr->dslSlowVars) - GLOBAL_PTR_BIAS)) ++#endif ++ ++#define gDslSampleBuffersVars (gDslGlobalVarPtr->sampleBuffersVars) ++ ++#define gDslMuxFramerVars (gDslGlobalVarPtr->muxFramerVars) ++#define gDslMuxFramerSharedVars (gDslGlobalVarPtr->scratchVars.muxFramerSharedVars) ++#define gDslLinkLayerVars (gDslGlobalVarPtr->linkLayerVars) ++#define gDslAtmVars (gDslGlobalVarPtr->linkLayerVars.atmVars) ++#define gDslPacketVars (gDslGlobalVarPtr->linkLayerVars.dslPacketVars) ++#define gG997Vars (gDslGlobalVarPtr->G997Vars) ++ ++#ifdef G992P3 ++#define gG992p3OvhMsgVars (gDslGlobalVarPtr->G992p3OvhMsgVars) ++#endif ++ ++#define gAdslMibVars (gDslGlobalVarPtr->adslMibVars) ++ ++#define gT1p413Vars (gDslGlobalVarPtr->physicalLayerVars.T1p413Vars) ++#define gG994p1Vars (gDslGlobalVarPtr->physicalLayerVars.G994p1Vars) ++#define gG992Vars (gDslGlobalVarPtr->physicalLayerVars.G992Vars) ++#define gG992p2ProfileVars (gDslGlobalVarPtr->G992p2ProfileVars) ++ ++#define gG992ScratchVars (gDslGlobalVarPtr->scratchVars.G992ScratchVars) ++ ++#ifndef gEyeHandlerPtr ++#define gEyeHandlerPtr (gDslGlobalVarPtr->eyeHandlerPtr) ++#endif ++ ++#ifndef gLogHandlerPtr ++#define gLogHandlerPtr (gDslGlobalVarPtr->logHandlerPtr) ++#endif ++ ++#ifdef VP_SIMULATOR ++#define gDriverCallback(x) (gDslGlobalVarPtr->driverCallback)(x) ++#else ++#define gDriverCallback(x) ++#endif ++ ++/* ++** ++** Frame functions callouts ++** ++*/ ++ ++#define gDslFrameFunc (gDslGlobalVarPtr->DslFrameFunctions) ++ ++#define DslFrameBufferGetLength(gDslVars, fb) \ ++ gDslFrameFunc.__DslFrameBufferGetLength(fb) ++ ++#define DslFrameBufferGetAddress(gDslVars, fb) \ ++ gDslFrameFunc.__DslFrameBufferGetAddress(fb) ++ ++#define DslFrameBufferSetLength(gDslVars, fb, l) \ ++ gDslFrameFunc.__DslFrameBufferSetLength(fb, l) ++ ++#define DslFrameBufferSetAddress(gDslVars, fb, p) \ ++ gDslFrameFunc.__DslFrameBufferSetAddress(fb, p) ++ ++#define DslFrameInit(gDslVars, f) \ ++ gDslFrameFunc.__DslFrameInit(f) ++ ++#define DslFrameGetLength(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetLength(pFrame) ++ ++#define DslFrameGetBufCnt(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetBufCnt(pFrame) ++ ++#define DslFrameGetFirstBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetFirstBuffer(pFrame) ++ ++#define DslFrameGetNextBuffer(gDslVars, pFrBuffer) \ ++ gDslFrameFunc.__DslFrameGetNextBuffer(pFrBuffer) ++ ++#define DslFrameSetNextBuffer(gDslVars, pFrBuf, pFrBufNext) \ ++ gDslFrameFunc.__DslFrameSetNextBuffer(pFrBuf, pFrBufNext) ++ ++#define DslFrameGetLastBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameGetLastBuffer(pFrame) ++ ++#define DslFrameGetLinkFieldAddress(gDslVars, f) \ ++ gDslFrameFunc.__DslFrameGetLinkFieldAddress(f) ++ ++#define DslFrameGetFrameAddressFromLink(gDslVars, lnk) \ ++ gDslFrameFunc.__DslFrameGetFrameAddressFromLink(lnk) ++ ++ ++#define DslFrameGetOobInfo(gDslVars, f, pOobInfo) \ ++ gDslFrameFunc.__DslFrameGetOobInfo(f, pOobInfo) ++ ++#define DslFrameSetOobInfo(gDslVars, f, pOobInfo) \ ++ gDslFrameFunc.__DslFrameSetOobInfo(f, pOobInfo) ++ ++ ++#define DslFrameEnqueBufferAtBack(gDslVars, f, b) \ ++ gDslFrameFunc.__DslFrameEnqueBufferAtBack(f, b) ++ ++#define DslFrameEnqueFrameAtBack(gDslVars, fMain, f) \ ++ gDslFrameFunc.__DslFrameEnqueFrameAtBack(fMain, f) ++ ++#define DslFrameEnqueBufferAtFront(gDslVars, f, b) \ ++ gDslFrameFunc.__DslFrameEnqueBufferAtFront(f, b) ++ ++#define DslFrameEnqueFrameAtFront(gDslVars, fMain, f) \ ++ gDslFrameFunc.__DslFrameEnqueFrameAtFront(fMain, f) ++ ++#define DslFrameDequeBuffer(gDslVars, pFrame) \ ++ gDslFrameFunc.__DslFrameDequeBuffer(pFrame) ++ ++#define DslFrameAllocMemForFrames(gDslVars, frameNum) \ ++ gDslFrameFunc.__DslFrameAllocMemForFrames(frameNum) ++ ++#define DslFrameFreeMemForFrames(gDslVars, hMem) \ ++ gDslFrameFunc.__DslFrameFreeMemForFrames(hMem) ++ ++#define DslFrameAllocFrame(gDslVars, handle) \ ++ gDslFrameFunc.__DslFrameAllocFrame(handle) ++ ++#define DslFrameFreeFrame(gDslVars, handle, pFrame) \ ++ gDslFrameFunc.__DslFrameFreeFrame(handle, pFrame) ++ ++#define DslFrameAllocMemForBuffers(gDslVars, ppMemPool, bufNum, memSize) \ ++ gDslFrameFunc.__DslFrameAllocMemForBuffers(ppMemPool, bufNum, memSize) ++ ++#define DslFrameFreeMemForBuffers(gDslVars, hMem, memSize, pMemPool) \ ++ gDslFrameFunc.__DslFrameFreeMemForBuffers(hMem, memSize, pMemPool) ++ ++#define DslFrameAllocBuffer(gDslVars, handle, pMem, length) \ ++ gDslFrameFunc.__DslFrameAllocBuffer(handle, pMem, length) ++ ++#define DslFrameFreeBuffer(gDslVars, handle, pBuf) \ ++ gDslFrameFunc.__DslFrameFreeBuffer(handle, pBuf) ++ ++#define DslFrame2Id(gDslVars, handle, pFrame) \ ++ gDslFrameFunc.__DslFrame2Id(handle, pFrame) ++ ++#define DslFrameId2Frame(gDslVars, handle, frameId) \ ++ gDslFrameFunc.__DslFrameId2Frame (handle, frameId) ++ ++ ++#endif /* SoftDslGlobals */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftDsl.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,2920 @@ ++/**************************************************************************** ++ * ++ * SoftDsl.h ++ * ++ * ++ * Description: ++ * This file contains the exported interface for SoftDsl.c ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.275 $ ++ * ++ * $Id: SoftDsl.h,v 1.275 2005/04/28 22:55:36 ilyas Exp $ ++ * ++ * $Log: SoftDsl.h,v $ ++ * Revision 1.275 2005/04/28 22:55:36 ilyas ++ * Cleaned up kDslG992RunAnnexaP3ModeInAnnexaP5, kG992EnableAnnexM and kDslAtuChangeTxFilterRequest definitions ++ * ++ * Revision 1.274 2005/04/27 20:57:32 yongbing ++ * Implement 32 frequency break points for TSSI, PR 30211 ++ * ++ * Revision 1.273 2005/04/02 03:27:52 kdu ++ * PR30236: Define kDslEnableRoundUpDSLoopAttn, this is shared with kDslCentilliumCRCWorkAroundEnabled. ++ * ++ * Revision 1.272 2005/04/01 21:56:39 ilyas ++ * Added more test commands definitions ++ * ++ * Revision 1.271 2005/02/11 05:03:57 ilyas ++ * Added support for DslOs ++ * ++ * Revision 1.270 2005/02/11 03:33:22 lke ++ * Support 2X, 4X, and 8X spectrum in ANNEX_I DS ++ * ++ * Revision 1.269 2005/01/08 00:11:58 ilyas ++ * Added definition for AnnexL status ++ * ++ * Revision 1.268 2004/12/18 00:52:35 mprahlad ++ * Add Dig US Pwr cutback status ++ * ++ * Revision 1.267 2004/11/08 22:21:38 ytan ++ * init swap state after retrain ++ * ++ * Revision 1.266 2004/11/05 21:16:50 ilyas ++ * Added support for pwmSyncClock ++ * ++ * Revision 1.265 2004/10/28 20:05:17 gsyu ++ * Fixed compilation errors for simulation targets ++ * ++ * Revision 1.264 2004/10/23 00:16:35 nino ++ * Added kDslHardwareSetRcvAGC status to set absolute rcv agc gain. ++ * ++ * Revision 1.263 2004/10/22 21:21:06 ilyas ++ * Fixed bit definition overlap in demodCapabilities ++ * ++ * Revision 1.262 2004/10/20 00:43:20 gsyu ++ * Added constants to support new xmt sample buffer control scheme ++ * ++ * Revision 1.261 2004/10/12 01:09:28 nino ++ * Remove kDslHardwareEnablePwmSyncClk and kDslHardwareSetPwmSyncClkFreq ++ * status definitions. Add kDslEnablePwmSyncClk and kDslSetPwmSyncClkFreq ++ * command definitions. ++ * ++ * Revision 1.260 2004/10/11 20:21:26 nino ++ * Added kDslHardwareEnablePwmSyncClk and kDslHardwareSetPwmSynClkFreq hardware statuses. ++ * ++ * Revision 1.259 2004/10/07 19:17:29 nino ++ * Added kDslHardwareGetRcvAGC status. ++ * ++ * Revision 1.258 2004/10/02 00:17:14 nino ++ * Added kDslHardwareAGCSetPga2 and kDslSetPilotEyeDisplay status definitions. ++ * ++ * Revision 1.257 2004/08/27 01:00:30 mprahlad ++ * ++ * Keep kDslAtuChangeTxFilterRequest defined by default so ADSL1 only targets can ++ * build ++ * ++ * Revision 1.256 2004/08/20 19:00:34 ilyas ++ * Added power management code for 2+ ++ * ++ * Revision 1.255 2004/08/17 23:18:25 kdu ++ * Merged interop changes for TDC lab from a023e9. ++ * ++ * Revision 1.254 2004/07/22 00:56:03 yongbing ++ * Add ADSL2 Annex B modulation definition ++ * ++ * Revision 1.253 2004/07/16 22:23:28 nino ++ * - Defined macros to extract subcarrier and supported set information ++ * for tssi. Subcarrier and suported set indicator is packed into ++ * dsSubcarrier index array. ++ * ++ * Revision 1.252 2004/07/01 00:11:22 nino ++ * Added preliminary code for debugDataHandler (inside of #if DEBUG_DATA_HANDLER). ++ * ++ * Revision 1.251 2004/06/24 03:08:39 ilyas ++ * Added GFC mapping control for ATM bonding ++ * ++ * Revision 1.250 2004/06/23 00:03:20 khp ++ * - shorten self test result register length to 1 (satisfied requirement ++ * at DT, no known requirement anywhere else) ++ * ++ * Revision 1.249 2004/06/15 20:18:33 ilyas ++ * Made D uchar again for compatibility with older ADSl drivers that use this structure. ADSL driver will rely on G992p3 parameters for large D ++ * ++ * Revision 1.248 2004/06/12 00:26:03 gsyu ++ * Added constants for AnnexM ++ * ++ * Revision 1.247 2004/06/10 18:53:24 yjchen ++ * add large D support ++ * ++ * Revision 1.246 2004/06/04 01:55:00 linyin ++ * Add a constant for SRA enable/disable ++ * ++ * Revision 1.245 2004/05/19 23:22:23 linyin ++ * Support L2 ++ * ++ * Revision 1.244 2004/05/15 03:04:58 ilyas ++ * Added L3 test definition ++ * ++ * Revision 1.243 2004/05/14 03:04:38 ilyas ++ * Fixed structure name typo ++ * ++ * Revision 1.242 2004/05/14 02:01:01 ilyas ++ * Fixed structure name typo ++ * ++ * Revision 1.241 2004/05/14 01:21:49 nino ++ * Added kDslSignalAttenuation, kDslAttainableNetDataRate kDslHLinScale constant definitions. ++ * ++ * Revision 1.240 2004/05/13 19:07:58 ilyas ++ * Added new statuses for ADSL2 ++ * ++ * Revision 1.239 2004/05/01 01:09:51 ilyas ++ * Added power management command and statuses ++ * ++ * Revision 1.238 2004/04/23 22:50:38 ilyas ++ * Implemented double buffering to ensure G.997 HDLC frame (OvhMsg) is continuous ++ * ++ * Revision 1.237 2004/03/31 18:57:39 ilyas ++ * Added drop on data error capability control ++ * ++ * Revision 1.236 2004/03/30 03:11:30 ilyas ++ * Added #ifdef for CFE build ++ * ++ * Revision 1.235 2004/03/29 23:06:39 ilyas ++ * Added status for BG table update ++ * ++ * Revision 1.234 2004/03/17 02:49:49 ilyas ++ * Turn off ATM bit reversal for Alcatel DSLAM only ++ * ++ * Revision 1.233 2004/03/11 03:09:48 mprahlad ++ * Add test mode for afeloopback test ++ * ++ * Revision 1.232 2004/03/10 23:15:53 ilyas ++ * Added ETSI modem support ++ * ++ * Revision 1.231 2004/03/04 19:28:14 linyin ++ * Support adsl2plus ++ * ++ * Revision 1.230 2004/02/28 00:06:21 ilyas ++ * Added OLR message definitions for ADSL2+ ++ * ++ * Revision 1.229 2004/02/13 03:21:15 mprahlad ++ * define kDslAturHwAgcMaxGain correctly for 6348 ++ * ++ * Revision 1.228 2004/02/09 05:06:17 yongbing ++ * Add ADSL2 bit swap function ++ * ++ * Revision 1.227 2004/02/04 02:08:19 linyin ++ * remove the redefined kG992p5AnnexA ++ * ++ * Revision 1.226 2004/02/04 01:41:48 linyin ++ * Add some variables for G992P5 ++ * ++ * Revision 1.225 2004/02/03 19:12:22 gsyu ++ * Added a dedicate structure and constants for G992P5 ++ * ++ * Revision 1.224 2004/01/24 01:18:34 ytan ++ * add multi-section swapping flag ++ * ++ * Revision 1.223 2004/01/17 00:21:48 ilyas ++ * Added commands and statuses for OLR ++ * ++ * Revision 1.222 2004/01/13 19:12:37 gsyu ++ * Added more constants for Double upstream ++ * ++ * Revision 1.221 2003/12/23 21:19:04 mprahlad ++ * Define BCM6348_TEMP_MOVE_TO_LMEM to FAST_TEXT for 6348 targets - this is for ++ * ADSL2/AnnexA multimode builds - move a few functions to Lmem for now to avoid ++ * changes for swap on 6348. ++ * ++ * Revision 1.220 2003/12/19 21:21:53 ilyas ++ * Added dying gasp support for ADSL2 ++ * ++ * Revision 1.219 2003/12/05 02:09:51 mprahlad ++ * Leave the AnalogEC defs in - saves ifdef-ing all uses of these defines. ++ * Include Bcm6345_To_Bcm6348.h - to be able to pick up macros for the ++ * transition ++ * ++ * Revision 1.218 2003/12/04 02:10:58 linyin ++ * Redefine some constants for supporting different pilot and TTR ++ * ++ * Revision 1.217 2003/12/03 02:24:39 gsyu ++ * Reverse previous check in for Double Upstream demo ++ * ++ * Revision 1.215 2003/11/20 00:58:47 yongbing ++ * Merge ADSL2 functionalities into Annex A branch ++ * ++ * Revision 1.214 2003/11/06 00:35:06 nino ++ * Added kDslWriteAfeRegCmd and kDslReadAfeRegCmd commands. ++ * ++ * Revision 1.213 2003/11/05 21:04:23 ilyas ++ * Added more codes for LOG data ++ * ++ * Revision 1.212 2003/10/22 00:51:52 yjchen ++ * define constant for quiet line noise ++ * ++ * Revision 1.211 2003/10/20 22:08:57 nino ++ * Added kDslSetRcvGainCmd and kDslBypassRcvHpfCmd debug commands. ++ * ++ * Revision 1.210 2003/10/18 00:04:59 yjchen ++ * define constants for G992P3 diagnostic mode channel response ++ * ++ * Revision 1.209 2003/10/17 22:41:29 yongbing ++ * Add INP message support ++ * ++ * Revision 1.208 2003/10/16 00:06:09 uid1249 ++ * Moved G.994 definitions from G.994p1MainTypes.h ++ * ++ * Revision 1.207 2003/10/15 20:45:11 linyin ++ * Add some constants for support Revision 2 ++ * ++ * Revision 1.206 2003/10/14 22:04:02 ilyas ++ * Added Nino's AFE statuses for 6348 ++ * ++ * Revision 1.205 2003/10/10 18:49:26 gsyu ++ * Added test modes to workaround the clock domain crossing bug, PR18038 ++ * ++ * Revision 1.204 2003/09/30 19:27:46 mprahlad ++ * ifdef AnalogEC definies with #ifndef BCM6348_SRC ++ * ++ * Revision 1.203 2003/09/26 19:36:34 linyin ++ * Add annexi constant and vars ++ * ++ * Revision 1.202 2003/09/25 20:16:13 yjchen ++ * remove featureNTR definition ++ * ++ * Revision 1.201 2003/09/08 20:29:51 ilyas ++ * Added test commands for chip regression tests ++ * ++ * Revision 1.200 2003/08/26 00:58:14 ilyas ++ * Added I432 reset command (for header compression) ++ * Fixed SoftDsl time (for I432 header compression) ++ * ++ * Revision 1.199 2003/08/26 00:37:29 ilyas ++ * #ifdef'ed DslFrameFunctions in dslCommand structure to save space ++ * ++ * Revision 1.198 2003/08/22 22:45:00 liang ++ * Change the NF field in G992CodingParams from uchar to ushort to support K=256 (dataRate=255*32kbps) in fast path. ++ * ++ * Revision 1.197 2003/08/21 21:19:05 ilyas ++ * Changed dataPumpCapabilities structure for G992P3 ++ * ++ * Revision 1.196 2003/08/12 22:44:28 khp ++ * - for Haixiang: added kDslTestMarginTweak command and marginTweakSpec ++ * ++ * Revision 1.195 2003/07/24 17:28:16 ovandewi ++ * added Tx filter change request code ++ * ++ * Revision 1.194 2003/07/24 15:48:55 yongbing ++ * Reduce TSSI buffer size to avoid crash at the beginning of G.994.1. Need to find out why ++ * ++ * Revision 1.193 2003/07/19 07:11:47 nino ++ * Revert back to version 1.191. ++ * ++ * Revision 1.191 2003/07/17 21:25:25 yongbing ++ * Add support for READSL2 and TSSI ++ * ++ * Revision 1.190 2003/07/14 19:42:33 yjchen ++ * add constants for G992P3 ++ * ++ * Revision 1.189 2003/07/10 23:07:11 liang ++ * Add demodCapability bit to minimize showtime ATUC xmt power through b&g table. ++ * ++ * Revision 1.188 2003/07/08 22:18:50 liang ++ * Added demodCapability bit for G.994.1 Annex A multimode operation. ++ * ++ * Revision 1.187 2003/07/07 23:24:43 ilyas ++ * Added G.dmt.bis definitions ++ * ++ * Revision 1.186 2003/06/25 02:44:02 liang ++ * Added demod capability bit kDslUE9000ADI918FECFixEnabled. ++ * Added back kDslHWEnableAnalogECUpdate & kDslHWEnableAnalogEC for backward compatibility (annex A). ++ * ++ * Revision 1.185 2003/06/18 01:39:19 ilyas ++ * Added AFE test commands. Add #defines for driver's builds ++ * ++ * Revision 1.184 2003/06/06 23:58:09 ilyas ++ * Added command and status for standalone AFE tests ++ * ++ * Revision 1.183 2003/05/29 21:09:32 nino ++ * - kDslHWEnableAnalogECUpdate define replaced with kDslHWSetDigitalEcUpdateMode ++ * - kDslHWEnableAnalogEC define replaced with kDslHWDisableDigitalECUpdate ++ * ++ * Revision 1.182 2003/04/15 22:08:15 liang ++ * Changed one of the demodCapability bit name from last checkin. ++ * ++ * Revision 1.181 2003/04/13 19:25:54 liang ++ * Added three more demodCapability bits. ++ * ++ * Revision 1.180 2003/04/02 02:09:17 liang ++ * Added demodCapability bit for ADI low rate option fix disable. ++ * ++ * Revision 1.179 2003/03/18 18:22:06 yongbing ++ * Use 32 tap TEQ for Annex I ++ * ++ * Revision 1.178 2003/03/06 00:58:07 ilyas ++ * Added SetStausBuffer command ++ * ++ * Revision 1.177 2003/02/25 00:46:26 ilyas ++ * Added T1.413 EOC vendor ID ++ * ++ * Revision 1.176 2003/02/21 23:30:54 ilyas ++ * Added Xmtgain command framing mode status and T1413VendorId parameters ++ * ++ * Revision 1.175 2003/02/07 22:13:55 liang ++ * Add demodCapabilities bits for sub-sample alignment and higher T1.413 level (used internally only). ++ * ++ * Revision 1.174 2003/01/23 02:54:07 liang ++ * Added demod capability bit for bitswap enable. ++ * ++ * Revision 1.173 2002/12/13 18:36:33 yongbing ++ * Add support for G.992.2 Annex C ++ * ++ * Revision 1.172 2002/12/10 23:27:12 ilyas ++ * Extended dslException parameter structure to allow printout from DslDiags ++ * ++ * Revision 1.171 2002/12/06 02:10:19 liang ++ * Moved the T1.413 RAck1/RAck2 switching variables to connection setup structure. ++ * Added/Modified the training progress codes for T1.413 RAck1/RAck2 and upstream 2x IFFT disable. ++ * ++ * Revision 1.170 2002/11/11 00:20:05 liang ++ * Add demod capability constant for internally disabling upstream 2x IFFT in T1.413 mode. ++ * ++ * Revision 1.169 2002/11/06 03:46:19 liang ++ * Add training progress code for upstream 2x IFFT disable. ++ * ++ * Revision 1.168 2002/11/01 01:41:06 ilyas ++ * Added flags for Centillium 4103 workarround ++ * ++ * Revision 1.167 2002/10/26 01:26:11 gsyu ++ * Move SoftDslLineHandler from SDRAM to LMEM ++ * ++ * Revision 1.166 2002/10/20 18:56:20 khp ++ * - for linyin ++ * - #ifdef NEC_NSIF_WORKAROUND: ++ * - add macros to extract NSIF status and fail counter vars ++ * ++ * Revision 1.165 2002/10/14 05:24:35 liang ++ * Add training status code to request alternate xmt filter (for Samsung 6-port ADI918 DSLAMs) to meet KT 2km spec. ++ * ++ * Revision 1.164 2002/10/08 21:44:50 ilyas ++ * Fixed EOC stuffing byte to indicate "no synchronization" action ++ * ++ * Revision 1.163 2002/10/03 19:34:24 ilyas ++ * Added size for EOC serial number register ++ * ++ * Revision 1.162 2002/09/28 02:42:27 yongbing ++ * Add retrain in T1.413 with R-Ack1 tone ++ * ++ * Revision 1.161 2002/09/28 01:23:35 gsyu ++ * Reverse us2xifft change so that we can install new us2xifft on the tree ++ * ++ * Revision 1.160 2002/09/26 23:30:48 yongbing ++ * Add synch symbol detection in Showtime ++ * ++ * Revision 1.159 2002/09/20 23:47:52 khp ++ * - for gsyu: enable 2X IFFT for Annex A (XMT_FFT_SIZE_2X) ++ * ++ * Revision 1.158 2002/09/14 03:26:39 ilyas ++ * Changed far-end RDI reporting ++ * ++ * Revision 1.157 2002/09/13 21:10:54 ilyas ++ * Added reporting of remote modem LOS and RDI. ++ * Moved G992CodingParams definition to SoftDsl.h ++ * ++ * Revision 1.156 2002/09/12 21:07:19 ilyas ++ * Added HEC, OCD and LCD counters ++ * ++ * Revision 1.155 2002/09/09 21:31:30 linyin ++ * Add two constant to support long reach ++ * ++ * Revision 1.154 2002/09/07 01:31:51 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.153 2002/09/04 22:36:14 mprahlad ++ * defines for non standard info added ++ * ++ * Revision 1.152 2002/08/02 21:59:09 liang ++ * Enable G.992.2 carrierInfo in capabitilities when G.992.1 annex A is used for G.992.2. ++ * ++ * Revision 1.151 2002/07/29 20:01:03 ilyas ++ * Added command for Atm VC map table change ++ * ++ * Revision 1.150 2002/07/18 22:30:47 liang ++ * Add xmt power and power cutback related constants. ++ * ++ * Revision 1.149 2002/07/11 01:30:58 ilyas ++ * Changed status for ShowtimeMargin reporting ++ * ++ * Revision 1.148 2002/07/09 19:19:09 ilyas ++ * Added status parameters for ShowtimeSNRMargin info and command to filter ++ * out SNR margin data ++ * ++ * Revision 1.147 2002/06/27 21:50:24 liang ++ * Added test command related demodCapabilities bits. ++ * ++ * Revision 1.146 2002/06/26 21:29:00 liang ++ * Added dsl test cmd structure and showtime margin connection info status. ++ * ++ * Revision 1.145 2002/06/15 05:15:51 ilyas ++ * Added definitions for Ping, Dying Gasp and other test commands ++ * ++ * Revision 1.144 2002/05/30 19:55:15 ilyas ++ * Added status for ADSL PHY MIPS exception ++ * Changed conflicting definition for higher rates (S=1/2) ++ * ++ * Revision 1.143 2002/05/21 23:41:07 yongbing ++ * First check-in of Annex C S=1/2 codes ++ * ++ * Revision 1.142 2002/04/29 22:25:09 georgep ++ * Merge from branch annexC_demo - add status message constants ++ * ++ * Revision 1.141 2002/04/18 19:00:35 ilyas ++ * Added include file for builds in CommEngine environment ++ * ++ * Revision 1.140 2002/04/18 00:18:36 yongbing ++ * Add detailed timeout error messages ++ * ++ * Revision 1.139 2002/04/02 10:03:18 ilyas ++ * Merged BERT from AnnexA branch ++ * ++ * Revision 1.138 2002/03/26 01:42:29 ilyas ++ * Added timeout message constants for annex C ++ * ++ * Revision 1.137 2002/03/22 19:39:22 yongbing ++ * Modify for co-exist of G994P1 and T1P413 ++ * ++ * Revision 1.136 2002/03/22 01:19:40 ilyas ++ * Add status message constants for total FEXT Bits, NEXT bits ++ * ++ * Revision 1.135 2002/03/10 22:32:24 liang ++ * Added report constants for LOS recovery and timing tone index. ++ * ++ * Revision 1.134 2002/03/07 22:06:32 georgep ++ * Replace ifdef G992P1 with G992P1_ANNEX_A for annex A variables ++ * ++ * Revision 1.133 2002/02/16 01:08:18 georgep ++ * Add log constant for showtime mse ++ * ++ * Revision 1.132 2002/02/08 04:36:27 ilyas ++ * Added commands for LOG file and fixed Idle mode pointer update ++ * ++ * Revision 1.131 2002/01/24 20:21:30 georgep ++ * Add logging defines, remove fast retrain defines ++ * ++ * Revision 1.130 2002/01/19 23:59:17 ilyas ++ * Added support for LOG and eye data to ADSL core target ++ * ++ * Revision 1.129 2002/01/16 23:43:54 liang ++ * Remove the carriage return character from last checkin. ++ * ++ * Revision 1.128 2002/01/15 22:27:13 ilyas ++ * Added command for ADSL loopback ++ * ++ * Revision 1.127 2002/01/10 07:18:22 ilyas ++ * Added status for printf (mainly for ADSL core debugging) ++ * ++ * Revision 1.126 2001/12/21 22:45:34 ilyas ++ * Added support for ADSL MIB data object ++ * ++ * Revision 1.125 2001/12/13 02:24:22 ilyas ++ * Added G997 (Clear EOC and G997 framer) support ++ * ++ * Revision 1.124 2001/11/30 05:56:31 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.123 2001/11/15 19:01:07 yongbing ++ * Modify only T1.413 part to the top of tree based on AnnexBDevelopment branch ++ * ++ * Revision 1.122 2001/10/19 00:12:07 ilyas ++ * Added support for frame oriented (no ATM) data link layer ++ * ++ * Revision 1.121 2001/10/09 22:35:13 ilyas ++ * Added more ATM statistics and OAM support ++ * ++ * Revision 1.105.2.20 2001/11/27 02:32:03 liang ++ * Combine vendor ID, serial #, and version number into SoftModemVersionNumber.c. ++ * ++ * Revision 1.105.2.19 2001/11/21 01:29:14 georgep ++ * Add a status message define for annexC ++ * ++ * Revision 1.105.2.18 2001/11/08 23:26:28 yongbing ++ * Add carrier selection function for Annex A and B ++ * ++ * Revision 1.105.2.17 2001/11/07 22:55:30 liang ++ * Report G992 rcv msg CRC error as what it is instead of time out. ++ * ++ * Revision 1.105.2.16 2001/11/05 19:56:21 liang ++ * Add DC offset info code. ++ * ++ * Revision 1.105.2.15 2001/10/16 00:47:16 yongbing ++ * Add return-to-T1p413 starting point if in error ++ * ++ * Revision 1.105.2.14 2001/10/15 23:14:01 yjchen ++ * remove ADSL_SINGLE_SYMBOL_BLOCK ++ * ++ * Revision 1.105.2.13 2001/10/12 18:07:16 yongbing ++ * Add support for T1.413 ++ * ++ * Revision 1.105.2.12 2001/10/04 00:23:52 liang ++ * Add connection info constants for TEQ coef and PSD. ++ * ++ * Revision 1.105.2.11 2001/10/03 01:44:01 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.105.2.10 2001/09/28 22:10:04 liang ++ * Add G994 exchange message status reports. ++ * ++ * Revision 1.105.2.9 2001/09/26 18:08:21 georgep ++ * Send status error message in case features field is not setup properly ++ * ++ * Revision 1.105.2.8 2001/09/05 01:58:13 georgep ++ * Added status message for annexC measured delay ++ * ++ * Revision 1.105.2.7 2001/08/29 00:37:52 georgep ++ * Add log constants for annexC ++ * ++ * Revision 1.105.2.6 2001/08/18 00:01:34 georgep ++ * Add constants for annexC ++ * ++ * Revision 1.105.2.5 2001/08/08 17:33:28 yongbing ++ * Merge with tag SoftDsl_2_17 ++ * ++ * Revision 1.120 2001/08/29 02:56:01 ilyas ++ * Added tests for flattening/unflatenning command and statuses (dual mode) ++ * ++ * Revision 1.119 2001/08/28 03:26:32 ilyas ++ * Added support for running host and adsl core parts separately ("dual" mode) ++ * ++ * Revision 1.118 2001/08/16 02:16:10 khp ++ * - mark functions with FAST_TEXT to reduce cycle counts for QPROC targets ++ * (replaces use of LMEM_INSN) ++ * ++ * Revision 1.117 2001/06/18 20:06:35 ilyas ++ * Added forward declaration of dslCommandStruc to avoid gcc warnings ++ * ++ * Revision 1.116 2001/06/18 19:49:36 ilyas ++ * Changes to include support for HOST_ONLY mode ++ * ++ * Revision 1.115 2001/06/01 22:00:33 ilyas ++ * Changed ATM PHY interface to accomodate UTOPIA needs ++ * ++ * Revision 1.114 2001/05/16 06:22:24 liang ++ * Added status reports for xmt & rcv prefix enable position. ++ * ++ * Revision 1.113 2001/05/02 20:34:32 georgep ++ * Added log constants for snr1 calculation ++ * ++ * Revision 1.112 2001/04/25 01:20:11 ilyas ++ * ++ * Don't use DSL frame functions if ATM_LAYER is not defined ++ * ++ * Revision 1.111 2001/04/17 21:13:00 georgep ++ * Define status constant kDslHWSetDigitalEcUpdateShift ++ * ++ * Revision 1.110 2001/04/16 23:38:36 georgep ++ * Add HW AGC constants for ATUR ++ * ++ * Revision 1.109 2001/04/06 23:44:53 georgep ++ * Added status constant for setting up digitalEcGainShift ++ * ++ * Revision 1.108 2001/03/29 05:58:34 liang ++ * Replaced the Aware compatibility codes with automatic detection codes. ++ * ++ * Revision 1.107 2001/03/25 06:11:22 liang ++ * Combined separate loop attenuation status for ATUR & ATUC into one status. ++ * Replace separate hardware AGC info status for ATUR & ATUC into hardware AGC ++ * request status and hardware AGC obtained status. ++ * Use store AGC command to save hardware AGC value instead of returning value ++ * from status report. ++ * ++ * Revision 1.106 2001/03/24 00:43:22 liang ++ * Report more checksum results (NumOfCalls, txSignal, rxSignal & eyeData). ++ * ++ * Revision 1.105 2001/03/16 23:57:31 georgep ++ * Added more loop attenuation reporting status constants ++ * ++ * Revision 1.104 2001/03/15 00:22:07 liang ++ * Back to version 1.101. ++ * ++ * Revision 1.103 2001/03/15 00:03:44 yjchen ++ * use kDslATURHardwareAGCInfo for AltoE14 AGC as well ++ * ++ * Revision 1.102 2001/03/14 23:10:56 yjchen ++ * add defns for AltoE14 AGC ++ * ++ * Revision 1.101 2001/03/08 23:31:34 georgep ++ * Added R, S, D, coding parameters to dslDataPumpCapabilities ++ * ++ * Revision 1.100 2001/02/10 03:03:09 ilyas ++ * Added one more DslFrame function ++ * ++ * Revision 1.99 2001/02/09 01:55:27 ilyas ++ * Added status codes and macros to support printing of AAL packets ++ * ++ * Revision 1.98 2001/01/30 23:28:10 georgep ++ * Added kDslDspControlStatus for handling changes to dsp params ++ * ++ * Revision 1.97 2001/01/12 01:17:18 georgep ++ * Added bit in demodCapabilities for analog echo cancellor ++ * ++ * Revision 1.96 2001/01/04 05:51:03 ilyas ++ * Added more dslStatuses ++ * ++ * Revision 1.95 2000/12/21 05:46:07 ilyas ++ * Added name for struct _dslFrame ++ * ++ * Revision 1.94 2000/12/13 22:04:39 liang ++ * Add Reed-Solomon coding enable bit in demodCapabilities. ++ * ++ * Revision 1.93 2000/11/29 20:42:02 liang ++ * Add defines for SNR & max achivable rate status and DEC enable demodCapabilities bit. ++ * ++ * Revision 1.92 2000/09/22 21:55:13 ilyas ++ * Added support for DSL + Atm physical layer only (I.432) simulations ++ * ++ * Revision 1.91 2000/09/10 09:20:53 lkaplan ++ * Improve interface for sending Eoc messages ++ * ++ * Revision 1.90 2000/09/08 19:37:58 lkaplan ++ * Added code for handling EOC messages ++ * ++ * Revision 1.89 2000/09/07 23:02:27 georgep ++ * Add HarwareAGC Bit to demod Capabilities ++ * ++ * Revision 1.88 2000/09/01 00:57:34 georgep ++ * Added Hardware AGC status defines ++ * ++ * Revision 1.87 2000/08/31 19:04:26 liang ++ * Added external reference for stack size requirement test functions. ++ * ++ * Revision 1.86 2000/08/24 23:16:46 liang ++ * Increased sample block size for noBlock. ++ * ++ * Revision 1.85 2000/08/23 18:34:39 ilyas ++ * Added XxxVcConfigure function ++ * ++ * Revision 1.84 2000/08/05 00:25:04 georgep ++ * Redefine sampling freq constants ++ * ++ * Revision 1.83 2000/08/03 14:04:00 liang ++ * Add hardware time tracking clock error reset code. ++ * ++ * Revision 1.82 2000/07/23 20:52:52 ilyas ++ * Added xxxFrameBufSetAddress() function for ATM framer layers ++ * Rearranged linkLayer functions in one structure which is passed as a ++ * parameter to xxxLinkLayerInit() function to be set there ++ * ++ * Revision 1.81 2000/07/18 20:03:24 ilyas ++ * Changed DslFrame functions definitions to macros, ++ * Removed gDslVars from their parameter list ++ * ++ * Revision 1.80 2000/07/17 21:08:15 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.79 2000/06/21 20:38:44 georgep ++ * Added bit to demodCapabilities for HW_TIME_TRACKING ++ * ++ * Revision 1.78 2000/06/19 19:57:55 georgep ++ * Added constants for logging of HWResampler data ++ * ++ * Revision 1.77 2000/06/02 18:57:21 ilyas ++ * Added support for DSL buffers consisting of many ATM cells ++ * ++ * Revision 1.76 2000/05/27 02:19:28 liang ++ * G992MonitorParams structure is moved here, and Tx/Rx data handler type definitions changed. ++ * ++ * Revision 1.75 2000/05/15 18:17:21 liang ++ * Added statuses for sent and received frames ++ * ++ * Revision 1.74 2000/05/14 01:56:38 ilyas ++ * Added ATM cell printouts ++ * ++ * Revision 1.73 2000/05/09 23:00:26 ilyas ++ * Added ATM status messages, ATM timer, Tx frames flush on timeout ++ * Fixed a bug - adding flushed Tx frames to the list of free Rx frames ++ * ++ * Revision 1.72 2000/05/03 18:01:18 georgep ++ * Removed old function declarations for Eoc/Aoc ++ * ++ * Revision 1.71 2000/05/03 03:57:04 ilyas ++ * Added LOG file support for writing ATM data ++ * ++ * Revision 1.70 2000/05/02 00:04:36 liang ++ * Add showtime monitoring and message exchange info constants. ++ * ++ * Revision 1.69 2000/04/28 23:34:20 yongbing ++ * Add constants for reporting error events in performance monitoring ++ * ++ * Revision 1.68 2000/04/21 23:09:04 liang ++ * Added G992 time out training progress constant. ++ * ++ * Revision 1.67 2000/04/19 00:31:47 ilyas ++ * Added global SoftDsl functions for Vc, added OOB info functions ++ * ++ * Revision 1.66 2000/04/18 00:45:31 yongbing ++ * Add G.DMT new frame structure, define G992P1_NEWFRAME to enable, need ATM layer to work ++ * ++ * Revision 1.65 2000/04/15 01:48:34 georgep ++ * Added T1p413 status constants ++ * ++ * Revision 1.64 2000/04/13 08:36:22 yura ++ * Added SoftDslSetRefData, SoftDslGetRefData functions ++ * ++ * Revision 1.63 2000/04/13 05:42:35 georgep ++ * Added constant for T1p413 ++ * ++ * Revision 1.62 2000/04/05 21:49:54 liang ++ * minor change. ++ * ++ * Revision 1.61 2000/04/04 04:16:06 liang ++ * Merged with SoftDsl_0_03 from old tree. ++ * ++ * Revision 1.65 2000/04/04 01:47:21 ilyas ++ * Implemented abstract dslFrame and dslFrameBuffer objects ++ * ++ * Revision 1.64 2000/04/01 08:12:10 yura ++ * Added preliminary revision of the SoftDsl driver architecture ++ * ++ * Revision 1.63 2000/04/01 02:55:33 georgep ++ * New defines for G992p2Profile Structure ++ * ++ * Revision 1.62 2000/04/01 00:50:36 yongbing ++ * Add initial version of new frame structure for full-rate ++ * ++ * Revision 1.61 2000/03/24 03:30:45 georgep ++ * Define new constant kDslUpstreamSamplingFreq ++ * ++ * Revision 1.60 2000/03/23 19:51:30 georgep ++ * Define new features bits for G992p1 ++ * ++ * Revision 1.59 2000/03/18 01:28:41 georgep ++ * Changed connectionSetup to include G992p1 Capabilities ++ * ++ * Revision 1.58 2000/02/29 01:40:03 georgep ++ * Changed modulationtype defines to be the same as SPAR1 in G994p1 ++ * ++ * Revision 1.57 1999/11/19 01:03:19 george ++ * Use Block Size 256 for single symbol Mode ++ * ++ * Revision 1.56 1999/11/18 02:37:43 george ++ * Porting to 16Bit ++ * ++ * Revision 1.55 1999/11/12 02:12:55 george ++ * Added status constant for reporting of profile channel matching calculation ++ * ++ * Revision 1.54 1999/11/11 19:19:42 george ++ * Porting to 16Bit Compiler ++ * ++ * Revision 1.53 1999/11/05 01:27:06 liang ++ * Add recovery-from-inpulse-noise progress report. ++ * ++ * Revision 1.52 1999/11/02 02:06:27 george ++ * Added SNRMargin training status value ++ * ++ * Revision 1.51 1999/10/27 23:02:03 wan ++ * Add G.994.1 setup in dslConnectionSetupStruct for setting up Initiation side ++ * ++ * Revision 1.50 1999/10/25 21:55:36 liang ++ * Renamed the constant for FEQ output error. ++ * ++ * Revision 1.49 1999/10/23 02:20:55 george ++ * Add debug data codes ++ * ++ * Revision 1.48 1999/10/19 23:59:06 liang ++ * Change line handler interface to work with nonsymmetric sampling freq. ++ * ++ * Revision 1.47 1999/10/09 01:38:04 george ++ * Define maxProfileNumber ++ * ++ * Revision 1.46 1999/10/07 23:30:51 wan ++ * Add G.994.1 Tone and Fast Retrain Recov detections in G.992p2 SHOWTIME and Fast Retrain ++ * ++ * Revision 1.45 1999/10/06 13:59:27 liang ++ * Escape to G994.1 should be done through status instead of command. ++ * ++ * Revision 1.44 1999/10/06 02:01:28 george ++ * Add kDslReturnToG994p1Cmd ++ * ++ * Revision 1.43 1999/09/30 19:29:58 george ++ * Add reporting constant for Fast Retrain ++ * ++ * Revision 1.42 1999/09/16 23:41:56 liang ++ * Added command for host forced retrain. ++ * ++ * Revision 1.41 1999/08/20 00:47:25 wan ++ * Add constants for Fast Retrain progress status ++ * ++ * Revision 1.40 1999/08/16 18:06:01 wan ++ * Add more reporting constants for Fast Retrain ++ * ++ * Revision 1.39 1999/08/12 00:18:10 wan ++ * Add several Fast Retrain Status constants ++ * ++ * Revision 1.38 1999/08/10 18:25:38 george ++ * Define constants used for Fast Retrain ++ * ++ * Revision 1.37 1999/07/31 01:47:43 george ++ * Add status constants for eoc/aoc ++ * ++ * Revision 1.36 1999/07/27 18:19:52 george ++ * declare aoc/eoc functions ++ * ++ * Revision 1.35 1999/07/19 22:44:47 george ++ * Add constants for G994p1 Message Exchange ++ * ++ * Revision 1.34 1999/07/16 02:03:03 liang ++ * Modified Dsl link layer command spec structure. ++ * ++ * Revision 1.33 1999/07/14 22:53:16 george ++ * Add Constants for G994p1 ++ * ++ * Revision 1.32 1999/07/13 00:02:26 liang ++ * Added more feature bits. ++ * ++ * Revision 1.31 1999/07/09 01:58:14 wan ++ * Added more constants G.994.1 testing reports ++ * ++ * Revision 1.30 1999/07/07 23:51:04 liang ++ * Added rcv power and loop attenuation reports. ++ * ++ * Revision 1.29 1999/07/06 21:32:01 liang ++ * Added some aux. feature bits, and field performanceMargin was changed to noiseMargin in Capabilities. ++ * ++ * Revision 1.28 1999/07/03 01:40:17 liang ++ * Redefined dsl command parameter list and added connection setup struct. ++ * ++ * Revision 1.27 1999/07/02 00:41:18 liang ++ * Add bit and gain logging as well as rcv carrier range status. ++ * ++ * Revision 1.26 1999/06/25 21:37:10 wan ++ * Work in progress for G994.1. ++ * ++ * Revision 1.25 1999/06/16 00:54:36 liang ++ * Added Tx/Rx SHOWTIME active training progress codes. ++ * ++ * Revision 1.24 1999/06/11 21:59:37 wan ++ * Added G994.1 fail status constant. ++ * ++ * Revision 1.23 1999/06/11 21:29:01 liang ++ * Constants for C/R-Msgs was changed to C/R-Msg. ++ * ++ * Revision 1.22 1999/06/08 02:49:42 liang ++ * Added SNR data logging. ++ * ++ * Revision 1.21 1999/06/07 21:05:08 liang ++ * Added more training status values. ++ * ++ * Revision 1.20 1999/05/22 02:18:26 liang ++ * More constant defines. ++ * ++ * Revision 1.19 1999/05/14 22:49:35 liang ++ * Added more status codes and debug data codes. ++ * ++ * Revision 1.18 1999/04/12 22:41:39 liang ++ * Work in progress. ++ * ++ * Revision 1.17 1999/04/01 20:28:07 liang ++ * Added RReverb detect event status. ++ * ++ * Revision 1.16 1999/03/26 03:29:54 liang ++ * Add DSL debug data constants. ++ * ++ * Revision 1.15 1999/03/08 21:58:00 liang ++ * Added more constant definitions. ++ * ++ * Revision 1.14 1999/03/02 01:49:36 liang ++ * Added more connection info codes. ++ * ++ * Revision 1.13 1999/03/02 00:25:55 liang ++ * Added DSL tx and rx data handler type definitions. ++ * ++ * Revision 1.12 1999/02/27 01:16:55 liang ++ * Increase allowable static memory size to a VERY large number for now. ++ * ++ * Revision 1.11 1999/02/25 00:24:06 liang ++ * Increased symbol block size to 16. ++ * ++ * Revision 1.10 1999/02/23 22:03:26 liang ++ * Increased maximal static memory size allowed. ++ * ++ * Revision 1.9 1999/02/17 02:39:21 ilyas ++ * Changes for NDIS ++ * ++ * Revision 1.8 1999/02/11 22:44:30 ilyas ++ * More definitions for ATM ++ * ++ * Revision 1.7 1999/02/10 01:56:38 liang ++ * Added hooks for G994.1 and G992.2. ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef SoftDslHeader ++#define SoftDslHeader ++ ++/* for builds in Linux/VxWorks CommEngine environment */ ++#if (defined(__KERNEL__) && !defined(LINUX_DRIVER)) || defined(VXWORKS) || defined(_WIN32_WCE) || defined(TARG_OS_RTEMS) || defined(_CFE_) ++#include "AdslCoreDefs.h" ++#else ++#include "Bcm6345_To_Bcm6348.h" /* File for 45->48 changes */ ++#endif ++ ++#ifndef SoftModemPh ++#include "SoftModem.h" ++#endif ++ ++#ifdef DSL_OS ++#include "DslOs.h" ++#endif ++ ++/* ++** ++** Type definitions ++** ++*/ ++ ++#if defined(ATM) || defined(DSL_PACKET) ++#define DSL_LINKLAYER ++#endif ++ ++#if defined(ATM_LAYER) || defined(DSL_PACKET_LAYER) || defined(G997_1_FRAMER) ++#define DSL_FRAME_FUNCTIONS ++#endif ++ ++#define FLD_OFFSET(type,fld) ((int)(void *)&(((type *)0)->fld)) ++ ++#include "Que.h" ++#include "SoftAtmVc.h" ++ ++typedef struct _dslFrameBuffer ++ { ++ struct _dslFrameBuffer *next; /* link to the next buffer in the frame */ ++ void *pData; /* pointer to data */ ++ ulong length; /* size (in bytes) of data */ ++ } dslFrameBuffer; ++ ++typedef struct _dslFrame ++ { ++ ulong Reserved[3]; ++ ++ ulong totalLength; /* total amount of data in the packet */ ++ int bufCnt; /* buffer counter */ ++ struct _dslFrameBuffer *head; /* first buffer in the chain */ ++ struct _dslFrameBuffer *tail; /* last buffer in the chain */ ++ } dslFrame; ++ ++ ++/* VC types and parameters */ ++ ++#define kDslVcAtm 1 ++ ++typedef struct ++ { ++ ulong vcType; ++ union ++ { ++ atmVcParams atmParams; ++ } params; ++ } dslVcParams; ++ ++/* ++** Assuming that dslVcParams.params is the first field in VC ++** and RefData is the first field in dslVcParams.params ++*/ ++ ++#define DslVcGetRefData(pVc) (*(void **) (pVc)) ++ ++/* Frame OOB types */ ++ ++#define kDslFrameAtm 1 ++ ++typedef struct ++ { ++ ulong frameType; ++ union ++ { ++ atmOobPacketInfo atmInfo; ++ } param; ++ } dslOobFrameInfo; ++ ++ ++typedef struct ++ { ++ ulong (SM_DECL *__DslFrameBufferGetLength) (dslFrameBuffer *fb); ++ void * (SM_DECL *__DslFrameBufferGetAddress) (dslFrameBuffer *fb); ++ void (SM_DECL *__DslFrameBufferSetLength) (dslFrameBuffer *fb, ulong l); ++ void (SM_DECL *__DslFrameBufferSetAddress) (dslFrameBuffer *fb, void *p); ++ ++ void (SM_DECL *__DslFrameInit) (dslFrame *f); ++ ulong (SM_DECL *__DslFrameGetLength) (dslFrame *pFrame); ++ ulong (SM_DECL *__DslFrameGetBufCnt) (dslFrame *pFrame); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetFirstBuffer) (dslFrame *pFrame); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetNextBuffer) (dslFrameBuffer *pFrBuffer); ++ void (SM_DECL *__DslFrameSetNextBuffer) (dslFrameBuffer *pFrBuf, dslFrameBuffer *pFrBufNext); ++ dslFrameBuffer * (SM_DECL *__DslFrameGetLastBuffer) (dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameGetLinkFieldAddress) (dslFrame *f); ++ dslFrame * (SM_DECL *__DslFrameGetFrameAddressFromLink) (void *lnk); ++ ++ Boolean (SM_DECL *__DslFrameGetOobInfo) (dslFrame *f, dslOobFrameInfo *pOobInfo); ++ Boolean (SM_DECL *__DslFrameSetOobInfo) (dslFrame *f, dslOobFrameInfo *pOobInfo); ++ ++ void (SM_DECL *__DslFrameEnqueBufferAtBack) (dslFrame *f, dslFrameBuffer *b); ++ void (SM_DECL *__DslFrameEnqueFrameAtBack) (dslFrame *fMain, dslFrame *f); ++ void (SM_DECL *__DslFrameEnqueBufferAtFront) (dslFrame *f, dslFrameBuffer *b); ++ void (SM_DECL *__DslFrameEnqueFrameAtFront) (dslFrame *fMain, dslFrame *f); ++ dslFrameBuffer * (SM_DECL *__DslFrameDequeBuffer) (dslFrame *pFrame); ++ ++ void * (SM_DECL *__DslFrameAllocMemForFrames) (ulong frameNum); ++ void (SM_DECL *__DslFrameFreeMemForFrames) (void *hMem); ++ dslFrame * (SM_DECL *__DslFrameAllocFrame) (void *handle); ++ void (SM_DECL *__DslFrameFreeFrame) (void *handle, dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameAllocMemForBuffers) (void **ppMemPool, ulong bufNum, ulong memSize); ++ void (SM_DECL *__DslFrameFreeMemForBuffers) (void *hMem, ulong memSize, void *pMemPool); ++ dslFrameBuffer * (SM_DECL *__DslFrameAllocBuffer) (void *handle, void *pMem, ulong length); ++ void (SM_DECL *__DslFrameFreeBuffer) (void *handle, dslFrameBuffer *pBuf); ++ ++ /* for LOG file support */ ++ ++ ulong (SM_DECL *__DslFrame2Id)(void *handle, dslFrame *pFrame); ++ void * (SM_DECL *__DslFrameId2Frame)(void *handle, ulong frameId); ++ } dslFrameFunctions; ++ ++#define DslFrameDeclareFunctions( name_prefix ) \ ++extern ulong SM_DECL name_prefix##BufferGetLength(dslFrameBuffer *fb); \ ++extern void * SM_DECL name_prefix##BufferGetAddress(dslFrameBuffer *fb); \ ++extern void SM_DECL name_prefix##BufferSetLength(dslFrameBuffer *fb, ulong l); \ ++extern void SM_DECL name_prefix##BufferSetAddress(dslFrameBuffer *fb, void *p); \ ++ \ ++extern void SM_DECL name_prefix##Init(dslFrame *f); \ ++extern ulong SM_DECL name_prefix##GetLength (dslFrame *pFrame); \ ++extern ulong SM_DECL name_prefix##GetBufCnt(dslFrame *pFrame); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetFirstBuffer(dslFrame *pFrame); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetNextBuffer(dslFrameBuffer *pFrBuffer); \ ++extern void SM_DECL name_prefix##SetNextBuffer(dslFrameBuffer *pFrBuf, dslFrameBuffer *pFrBufNext); \ ++extern dslFrameBuffer * SM_DECL name_prefix##GetLastBuffer(dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##GetLinkFieldAddress(dslFrame *f); \ ++extern Boolean SM_DECL name_prefix##GetOobInfo(dslFrame *f, dslOobFrameInfo *pOobInfo); \ ++extern Boolean SM_DECL name_prefix##SetOobInfo(dslFrame *f, dslOobFrameInfo *pOobInfo); \ ++extern dslFrame* SM_DECL name_prefix##GetFrameAddressFromLink(void *lnk); \ ++extern void SM_DECL name_prefix##EnqueBufferAtBack(dslFrame *f, dslFrameBuffer *b); \ ++extern void SM_DECL name_prefix##EnqueFrameAtBack(dslFrame *fMain, dslFrame *f); \ ++extern void SM_DECL name_prefix##EnqueBufferAtFront(dslFrame *f, dslFrameBuffer *b); \ ++extern void SM_DECL name_prefix##EnqueFrameAtFront(dslFrame *fMain, dslFrame *f); \ ++extern dslFrameBuffer * SM_DECL name_prefix##DequeBuffer(dslFrame *pFrame); \ ++ \ ++extern void * SM_DECL name_prefix##AllocMemForFrames(ulong frameNum); \ ++extern void SM_DECL name_prefix##FreeMemForFrames(void *hMem); \ ++extern dslFrame * SM_DECL name_prefix##AllocFrame(void *handle); \ ++extern void SM_DECL name_prefix##FreeFrame(void *handle, dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##AllocMemForBuffers(void **ppMemPool, ulong bufNum, ulong memSize); \ ++extern void SM_DECL name_prefix##FreeMemForBuffers(void *hMem, ulong memSize, void *pMemPool); \ ++extern dslFrameBuffer * SM_DECL name_prefix##AllocBuffer(void *handle, void *pMem, ulong length); \ ++extern void SM_DECL name_prefix##FreeBuffer(void *handle, dslFrameBuffer *pBuf); \ ++extern ulong SM_DECL name_prefix##2Id(void *handle, dslFrame *pFrame); \ ++extern void * SM_DECL name_prefix##Id2Frame(void *handle, ulong frameId); ++ ++ ++#define DslFrameAssignFunctions( var, name_prefix ) do { \ ++ (var).__DslFrameBufferGetLength = name_prefix##BufferGetLength; \ ++ (var).__DslFrameBufferGetAddress= name_prefix##BufferGetAddress; \ ++ (var).__DslFrameBufferSetLength = name_prefix##BufferSetLength; \ ++ (var).__DslFrameBufferSetAddress= name_prefix##BufferSetAddress; \ ++ \ ++ (var).__DslFrameInit = name_prefix##Init; \ ++ (var).__DslFrameGetLength = name_prefix##GetLength; \ ++ (var).__DslFrameGetBufCnt = name_prefix##GetBufCnt; \ ++ (var).__DslFrameGetFirstBuffer = name_prefix##GetFirstBuffer; \ ++ (var).__DslFrameGetNextBuffer = name_prefix##GetNextBuffer; \ ++ (var).__DslFrameSetNextBuffer = name_prefix##SetNextBuffer; \ ++ (var).__DslFrameGetLastBuffer = name_prefix##GetLastBuffer; \ ++ (var).__DslFrameGetLinkFieldAddress = name_prefix##GetLinkFieldAddress; \ ++ (var).__DslFrameGetFrameAddressFromLink = name_prefix##GetFrameAddressFromLink; \ ++ \ ++ (var).__DslFrameGetOobInfo = name_prefix##GetOobInfo; \ ++ (var).__DslFrameSetOobInfo = name_prefix##SetOobInfo; \ ++ \ ++ (var).__DslFrameEnqueBufferAtBack = name_prefix##EnqueBufferAtBack; \ ++ (var).__DslFrameEnqueFrameAtBack = name_prefix##EnqueFrameAtBack; \ ++ (var).__DslFrameEnqueBufferAtFront= name_prefix##EnqueBufferAtFront; \ ++ (var).__DslFrameEnqueFrameAtFront = name_prefix##EnqueFrameAtFront; \ ++ (var).__DslFrameDequeBuffer = name_prefix##DequeBuffer; \ ++ \ ++ (var).__DslFrameAllocMemForFrames = name_prefix##AllocMemForFrames; \ ++ (var).__DslFrameFreeMemForFrames = name_prefix##FreeMemForFrames; \ ++ (var).__DslFrameAllocFrame = name_prefix##AllocFrame; \ ++ (var).__DslFrameFreeFrame = name_prefix##FreeFrame; \ ++ (var).__DslFrameAllocMemForBuffers= name_prefix##AllocMemForBuffers; \ ++ (var).__DslFrameFreeMemForBuffers = name_prefix##FreeMemForBuffers; \ ++ (var).__DslFrameAllocBuffer = name_prefix##AllocBuffer; \ ++ (var).__DslFrameFreeBuffer = name_prefix##FreeBuffer; \ ++ \ ++ (var).__DslFrame2Id = name_prefix##2Id; \ ++ (var).__DslFrameId2Frame = name_prefix##Id2Frame; \ ++} while (0) ++ ++typedef struct ++ { ++ Boolean febe_I; ++ Boolean fecc_I; ++ Boolean los, rdi; ++ Boolean ncd_I; ++ Boolean hec_I; ++#ifdef G992P3 ++ Boolean lpr; ++#endif ++ ++#ifdef G992P1_NEWFRAME ++ ++ Boolean febe_F; ++ Boolean fecc_F; ++ Boolean ncd_F; ++ Boolean hec_F; ++ ++#endif ++ } G992MonitorParams; ++ ++typedef struct ++ { ++ ushort K; ++ uchar S, R; ++ uchar D; ++#ifdef G992P3 ++ uchar T, SEQ; ++#endif ++ directionType direction; ++ ++#ifdef G992P1_NEWFRAME ++ ++ ushort N; ++ ushort NF; ++ uchar RSF; ++ ++ uchar AS0BF, AS1BF, AS2BF, AS3BF, AEXAF; ++ ushort AS0BI; ++ uchar AS1BI, AS2BI, AS3BI, AEXAI; ++ ++ uchar LS0CF, LS1BF, LS2BF, LEXLF; ++ uchar LS0CI, LS1BI, LS2BI, LEXLI; ++ ++ uchar mergedModeEnabled; ++ ++#endif ++ ++ } G992CodingParams; ++ ++typedef struct ++ { ++ uchar Nlp; ++ uchar Nbc; ++ uchar MSGlp; ++ ushort MSGc; ++ ++ ulong L; ++ ushort M; ++ ushort T; ++ ushort D; ++ ushort R; ++ ushort B; ++ } G992p3CodingParams; ++ ++/* Power Management Message definitions (used in command and status) */ ++ ++typedef struct ++ { ++ long msgType; ++ union ++ { ++ long value; ++ struct ++ { ++ long msgLen; ++ void *msgData; ++ } msg; ++ } param; ++ } dslPwrMessage; ++ ++/* Power Management commands and responses */ ++ ++#define kPwrSimpleRequest 1 ++#define kPwrL2Request 2 ++#define kPwrL2TrimRequest 3 ++ ++#define kPwrGrant 0x80 ++#define kPwrReject 0x81 ++#define kPwrL2Grant 0x82 ++#define kPwrL2Reject 0x83 ++#define kPwrL2TrimGrant 0x84 ++#define kPwrL2TrimReject 0x85 ++#define kPwrL2Grant2p 0x86 ++ ++#define kPwrBusy 0x01 ++#define kPwrInvalid 0x02 ++#define kPwrNotDesired 0x03 ++#define kPwrInfeasibleParam 0x04 ++ ++/* Power Management reason codes */ ++ ++/* OLR definitions (used in command and status) */ ++ ++typedef struct ++ { ++ ushort msgType; ++ ushort nCarrs; ++ ushort L[4]; ++ uchar B[4]; ++ void *carrParamPtr; ++ } dslOLRMessage; ++ ++typedef struct ++ { ++ uchar ind; ++ uchar gain; ++ uchar gb; ++ } dslOLRCarrParam; ++ ++typedef struct ++ { ++ ushort ind; ++ uchar gain; ++ uchar gb; ++ } dslOLRCarrParam2p; ++ ++/* OLR messages */ ++ ++#define kOLRRequestType1 1 ++#define kOLRRequestType2 2 ++#define kOLRRequestType3 3 ++#define kOLRRequestType4 4 ++#define kOLRRequestType5 5 ++#define kOLRRequestType6 6 ++ ++#define kOLRDeferType1 0x81 ++#define kOLRRejectType2 0x82 ++#define kOLRRejectType3 0x83 ++ ++/* OLR reason codes */ ++ ++#define kOLRBusy 1 ++#define kOLRInvalidParam 2 ++#define kOLRNotEnabled 3 ++#define kOLRNotSupported 4 ++ ++/* common EOC definitions */ ++#define kG992EocStuffingByte 0x0C ++ ++/* showtime monitor counters */ ++#define kG992ShowtimeRSCodewordsRcved 0 /* number of Reed-Solomon codewords received */ ++#define kG992ShowtimeRSCodewordsRcvedOK 1 /* number of Reed-Solomon codewords received with all symdromes zero */ ++#define kG992ShowtimeRSCodewordsRcvedCorrectable 2 /* number of Reed-Solomon codewords received with correctable errors */ ++#define kG992ShowtimeRSCodewordsRcvedUncorrectable 3 /* number of Reed-Solomon codewords received with un-correctable errors */ ++#define kG992ShowtimeSuperFramesRcvd 4 /* number of super frames received */ ++#define kG992ShowtimeSuperFramesRcvdWrong 5 /* number of super frames received with CRC error */ ++#define kG992ShowtimeLastUncorrectableRSCount 6 /* last recorded value for kG992ShowtimeRSCodewordsRcvedUncorrectable */ ++#define kG992ShowtimeLastWrongSuperFrameCount 7 /* last recorded value for kG992ShowtimeSuperFramesRcvdWrong */ ++#define kG992ShowtimeNumOfShortResync 8 /* number of short interrupt recoveries by FEQ */ ++ ++#define kG992ShowtimeNumOfFEBE 9 /* number of other side superframe errors */ ++#define kG992ShowtimeNumOfFECC 10 /* number of other side superframe FEC errors */ ++#define kG992ShowtimeNumOfFHEC 11 /* number of far-end ATM header CRC errors */ ++#define kG992ShowtimeNumOfFOCD 12 /* number of far-end OCD events */ ++#define kG992ShowtimeNumOfFLCD 13 /* number of far-end LCD events */ ++#define kG992ShowtimeNumOfHEC 14 /* number of ATM header CRC errors */ ++#define kG992ShowtimeNumOfOCD 15 /* number of OCD events */ ++#define kG992ShowtimeNumOfLCD 16 /* number of LCD events */ ++ ++#define kG992ShowtimeNumOfMonitorCounters (kG992ShowtimeNumOfLCD+1) /* always last number + 1 */ ++#define kG992ShowtimeMonitorReportNumber 9 ++ ++#define kG992ShowtimeLCDNumShift 1 ++#define kG992ShowtimeLCDFlag 1 ++ ++typedef int (SM_DECL *dslFrameHandlerType) (void *gDslVars, void *pVc, ulong mid, dslFrame *); ++ ++typedef void* (SM_DECL *dslHeaderHandlerType) (void *gDslVars, ulong hdr, uchar hdrHec); ++typedef void* (SM_DECL *dslTxFrameBufferHandlerType) (void *gDslVars, int*, void*); ++typedef void* (SM_DECL *dslRxFrameBufferHandlerType) (void *gDslVars, int, void*); ++ ++typedef void* (SM_DECL *dslVcAllocateHandlerType) (void *gDslVars, void *); ++typedef void (SM_DECL *dslVcFreeHandlerType) (void *gDslVars, void *); ++typedef Boolean (SM_DECL *dslVcActivateHandlerType) (void *gDslVars, void *); ++typedef void (SM_DECL *dslVcDeactivateHandlerType) (void *gDslVars, void *); ++typedef Boolean (SM_DECL *dslVcConfigureHandlerType) (void *gDslVars, void *pVc, ulong mid, void *); ++ ++typedef ulong (SM_DECL *dslLinkVc2IdHandlerType) (void *gDslVars, void *); ++typedef void* (SM_DECL *dslLinkVcId2VcHandlerType) (void *gDslVars, ulong); ++typedef void* (SM_DECL *dslGetFramePoolHandlerType) (void *gDslVars); ++ ++typedef void (SM_DECL *dslLinkCloseHandlerType) (void *gDslVars); ++typedef int (SM_DECL *dslTxDataHandlerType)(void *gDslVars, int, int, uchar*, G992MonitorParams*); ++typedef int (SM_DECL *dslRxDataHandlerType)(void *gDslVars, int, uchar*, G992MonitorParams*); ++ ++typedef void (SM_DECL *dslLinkStatusHandler) (void *gDslVars, ulong statusCode, ...); ++ ++typedef Boolean (SM_DECL *dslPhyInitType) ( ++ void *gDslVars, ++ bitMap setupMap, ++ dslHeaderHandlerType rxCellHeaderHandlerPtr, ++ dslRxFrameBufferHandlerType rxFrameHandlerPtr, ++ dslTxFrameBufferHandlerType txFrameHandlerPtr, ++ atmStatusHandler statusHandlerPtr); ++ ++struct _dslFramerBufDesc; ++ ++typedef Boolean (SM_DECL *dslFramerDataGetPtrHandlerType) (void *gDslVars, struct _dslFramerBufDesc *pBufDesc); ++typedef void (SM_DECL *dslFramerDataDoneHandlerType) (void *gDslVars, struct _dslFramerBufDesc *pBufDesc); ++ ++typedef void (SM_DECL *dslDriverCallbackType) (void *gDslVars); ++ ++#ifdef DSL_PACKET ++ ++typedef struct ++ { ++ dslFramerDataGetPtrHandlerType rxDataGetPtrHandler; ++ dslFramerDataDoneHandlerType rxDataDoneHandler; ++ dslFramerDataGetPtrHandlerType txDataGetPtrHandler; ++ dslFramerDataDoneHandlerType txDataDoneHandler; ++ } dslPacketPhyFunctions; ++ ++typedef Boolean (SM_DECL *dslPacketPhyInitType) ( ++ void *gDslVars, ++ bitMap setupMap, ++ dslPacketPhyFunctions dslPhyFunctions, ++ dslLinkStatusHandler statusHandlerPtr); ++ ++ ++#endif /* DSL_PACKET */ ++ ++ ++typedef int dslDirectionType; ++typedef bitMap dslModulationType; ++typedef bitMap dslLinkLayerType; ++ ++/* ++** ++** Log data codes ++** ++*/ ++ ++#define kDslEyeData eyeData ++ ++#define kDslLogComplete (inputSignalData - 1) ++#define kDslLogInputData inputSignalData ++#define kDslLogInputData1 (inputSignalData + 1) ++#define kDslLogInputData2 (inputSignalData + 2) ++#define kDslLogInputData3 (inputSignalData + 3) ++ ++/* ++** ++** Status codes ++** ++*/ ++ ++typedef long dslStatusCode; ++#define kFirstDslStatusCode 256 ++#define kDslError (kFirstDslStatusCode + 0) ++#define kAtmStatus (kFirstDslStatusCode + 1) ++#define kDslTrainingStatus (kFirstDslStatusCode + 2) ++#define kDslConnectInfoStatus (kFirstDslStatusCode + 3) ++#define kDslEscapeToG994p1Status (kFirstDslStatusCode + 4) ++#define kDslFrameStatus (kFirstDslStatusCode + 5) ++#define kDslReceivedEocCommand (kFirstDslStatusCode + 6) ++#define kDslSendEocCommandDone (kFirstDslStatusCode + 7) ++#define kDslSendEocCommandFailed (kFirstDslStatusCode + 8) ++#define kDslWriteRemoteRegisterDone (kFirstDslStatusCode + 9) ++#define kDslReadRemoteRegisterDone (kFirstDslStatusCode + 10) ++#define kDslExternalError (kFirstDslStatusCode + 11) ++#define kDslDspControlStatus (kFirstDslStatusCode + 12) ++#define kDslATUHardwareAGCRequest (kFirstDslStatusCode + 13) ++#define kDslPacketStatus (kFirstDslStatusCode + 14) ++#define kDslG997Status (kFirstDslStatusCode + 15) ++#define kDslPrintfStatus (kFirstDslStatusCode + 16) ++#define kDslPrintfStatus1 (kFirstDslStatusCode + 17) ++#define kDslExceptionStatus (kFirstDslStatusCode + 18) ++#define kDslPingResponse (kFirstDslStatusCode + 19) ++#define kDslShowtimeSNRMarginInfo (kFirstDslStatusCode + 20) ++#define kDslGetOemParameter (kFirstDslStatusCode + 21) ++#define kDslOemDataAddrStatus (kFirstDslStatusCode + 22) ++#define kDslDataAvailStatus (kFirstDslStatusCode + 23) ++/* #define kDslAtuChangeTxFilterRequest (kFirstDslStatusCode + 24) */ ++#define kDslTestPllPhaseResult (kFirstDslStatusCode + 25) ++#ifdef BCM6348_SRC ++#define kDslHardwareAGCSetPga1 (kFirstDslStatusCode + 26) ++#define kDslHardwareAGCDecPga1 (kFirstDslStatusCode + 27) ++#define kDslHardwareAGCIncPga1 (kFirstDslStatusCode + 28) ++#define kDslHardwareAGCSetPga2Delta (kFirstDslStatusCode + 29) ++#endif ++#define kDslOLRRequestStatus (kFirstDslStatusCode + 30) ++#define kDslOLRResponseStatus (kFirstDslStatusCode + 31) ++#define kDslOLRBitGainUpdateStatus (kFirstDslStatusCode + 32) ++#define kDslPwrMgrStatus (kFirstDslStatusCode + 33) ++#define kDslEscapeToT1p413Status (kFirstDslStatusCode + 34) ++#ifdef BCM6348_SRC ++#define kDslHardwareAGCSetPga2 (kFirstDslStatusCode + 35) ++#define kDslHardwareGetRcvAGC (kFirstDslStatusCode + 36) ++#endif ++#define kDslUpdateXmtReadPtr (kFirstDslStatusCode + 37) ++#define kDslHardwareSetRcvAGC (kFirstDslStatusCode + 38) ++#ifdef BCM6348_SRC ++#define kDslSetDigUsPwrCutback (kFirstDslStatusCode + 39) ++#endif ++ ++#define kClientSideInitiation 0 ++#define kClientSideRespond 1 ++#define kCentralSideInitiation 2 ++#define kCentralSideRespond 3 ++ ++/* OEM parameter ID definition */ ++ ++#define kDslOemG994VendorId 1 ++#define kDslOemG994XmtNSInfo 2 ++#define kDslOemG994RcvNSInfo 3 ++#define kDslOemEocVendorId 4 ++#define kDslOemEocVersion 5 ++#define kDslOemEocSerNum 6 ++#define kDslOemT1413VendorId 7 ++#define kDslOemT1413EocVendorId 8 ++ ++typedef long dslErrorCode; ++ ++typedef long atmStatusCode; ++typedef long dslFramerStatusCode; ++ ++typedef long atmErrorCode; ++ ++typedef long dslTrainingStatusCode; ++ ++#define kDslStartedG994p1 0 ++#define kDslStartedT1p413HS 1 ++ ++/* reserved for G.994.1: 1 ~ 8 */ ++ ++#define kDslG994p1MessageDet 100 ++#define kDslG994p1ToneDet 101 ++#define kDslG994p1RToneDet 102 ++#define kDslG994p1FlagDet 103 ++#define kDslG994p1GalfDet 104 ++#define kDslG994p1ErrorFrameDet 105 ++#define kDslG994p1BadFrameDet 106 ++#define kDslG994p1SilenceDet 107 ++#define kDslG994p1RcvTimeout 108 ++#define kDslG994p1XmtFinished 109 ++#define kDslG994p1ReturntoStartup 110 ++#define kDslG994p1InitiateCleardown 111 ++#define kDslG994p1StartupFinished 112 ++#define kDslG994p1RcvNonStandardInfo 113 ++#define kDslG994p1XmtNonStandardInfo 114 ++ ++#define kG994p1MaxNonstdMessageLength 64 ++ ++#define kDslFinishedT1p413 1100 ++#define kDslT1p413DetectedCTone 1101 ++#define kDslT1p413DetectedCAct 1102 ++#define kDslT1p413DetectedCReveille 1103 ++#define kDslT1p413DetectedRActReq 1104 ++#define kDslT1p413DetectedRQuiet1 1105 ++#define kDslT1p413DetectedRAct 1106 ++#define kDslT1p413TimeoutCReveille 1107 ++#define kDslT1p413ReturntoStartup 1108 ++ ++#define kDslG994p1Timeout 8 ++#define kDslFinishedG994p1 9 ++#define kDslStartedG992p2Training 10 ++#define kDslG992p2DetectedPilotSymbol 11 ++#define kDslG992p2DetectedReverbSymbol 12 ++#define kDslG992p2TEQCalculationDone 13 ++#define kDslG992p2TrainingFEQ 14 ++#define kDslG992p2Phase3Started 15 ++#define kDslG992p2ReceivedRates1 16 ++#define kDslG992p2ReceivedMsg1 17 ++#define kDslG992p2Phase4Started 18 ++#define kDslG992p2ReceivedRatesRA 19 ++#define kDslG992p2ReceivedMsgRA 20 ++#define kDslG992p2ReceivedRates2 21 ++#define kDslG992p2ReceivedMsg2 22 ++#define kDslG992p2ReceivedBitGainTable 23 ++#define kDslG992p2TxShowtimeActive 24 ++#define kDslG992p2RxShowtimeActive 25 ++#define kDslG992p2TxAocMessage 26 ++#define kDslG992p2RxAocMessage 27 ++#define kDslG992p2TxEocMessage 28 ++#define kDslG992p2RxEocMessage 29 ++#define kDslFinishedG992p2Training 30 ++#define kDslRecoveredFromImpulseNoise 31 ++#define kDslG992Timeout 32 ++#define kDslT1p413Isu1SglByteSymDetected 33 /* detected T1.413 Issue 1 single byte per symbol mode */ ++#define kDslG992RxPrefixOnInAFewSymbols 34 ++#define kDslG992TxPrefixOnInAFewSymbols 35 ++#define kDslAnnexCXmtCPilot1Starting 36 ++#define kDslXmtToRcvPathDelay 37 ++#define kDslFeaturesUnsupported 38 ++#define kDslG992RcvMsgCrcError 39 ++#define kDslAnnexCDetectedStartHyperframe 40 ++ ++#define kDslG992AnnexCTimeoutCPilot1Detection 41 ++#define kDslG992AnnexCTimeoutCReverb1Detection 42 ++#define kDslG992AnnexCTimeoutECTraining 43 ++#define kDslG992AnnexCTimeoutHyperframeDetector 44 ++#define kDslG992AnnexCTimeoutSendRSegue2 45 ++#define kDslG992AnnexCTimeoutDetectCSegue1 46 ++#define kDslG992AnnexCAlignmentErrDetected 47 ++#define kDslG992AnnexCTimeoutSendRSegueRA 48 ++#define kDslG992AnnexCTimeoutSendRSegue4 49 ++#define kDslG992AnnexCTimeoutCSegue2Detection 50 ++#define kDslG992AnnexCTimeoutCSegue3Detection 51 ++/* Progress report for fast retrain */ ++ ++#define kG994p1EventToneDetected 54 ++#define kDslG992p2RcvVerifiedBitAndGain 55 ++#define kDslG992p2ProfileChannelResponseCalc 56 ++#define kDslG992AnnexCTotalFEXTBits 57 ++#define kDslG992AnnexCTotalNEXTBits 58 ++#define kDslG992AnnexCTotalFEXTCarrs 59 ++#define kDslG992AnnexCTotalNEXTCarrs 60 ++ ++#define kDslG992p3ReceivedMsgFmt 61 ++#define kDslG992p3ReceivedMsgPcb 62 ++ ++#define kDslG992p3AnnexLMode 63 ++ ++/* performance monitoring report */ ++ ++#define kG992DataRcvDetectFastRSCorrection 70 ++#define kG992DataRcvDetectInterleaveRSCorrection 71 ++#define kG992DataRcvDetectFastCRCError 72 ++#define kG992DataRcvDetectInterleaveCRCError 73 ++#define kG992DataRcvDetectFastRSError 74 ++#define kG992DataRcvDetectInterleaveRSError 75 ++#define kG992DataRcvDetectLOS 76 ++#define kG992DecoderDetectRDI 77 ++#define kG992DataRcvDetectLOSRecovery 78 ++#define kG992AtmDetectHEC 79 ++#define kG992AtmDetectOCD 180 ++#define kG992AtmDetectCD 181 ++#define kG992DecoderDetectRemoteLOS 182 ++#define kG992DecoderDetectRemoteLOSRecovery 183 ++#define kG992DecoderDetectRemoteRDI 184 ++#define kG992DecoderDetectRemoteRDIRecovery 185 ++#define kG992RcvDetectSyncSymbolOffset 186 ++#define kG992Upstream2xIfftDisabled 187 ++#if defined(G992P5) ++#define kDslG992RunAnnexaP3ModeInAnnexaP5 188 /* run Annex C mode in Annex I compiled codes */ ++#else ++#define kDslG992RunAnnexCModeInAnnexI 188 /* run Annex C mode in Annex I compiled codes */ ++#endif ++ ++/* OLR PHY status */ ++ ++#define kG992EventSynchSymbolDetected 189 ++#define kG992EventReverseSynchSymbolDetected 190 ++#define kG992EventL2CReverbSymbolDetected 191 ++#define kG992EventL2CSegueSymbolDetected 192 ++ ++/* ANNEX_M */ ++#define kG992EnableAnnexM 191 ++ ++#define kDslAtuChangeTxFilterRequest 192 ++ ++/* detailed error messages reports */ ++ ++#define kDslG992XmtRReverbRAOver4000 80 ++#define kDslG992XmtRReverb5Over4000 81 ++#define kDslG992RcvCSegue2Failed 82 ++#define kDslG992RcvCSegueRAFailed 83 ++#define kDslG992RcvCSegue3Failed 84 ++#define kDslG992RcvShowtimeStartedTooLate 85 ++#define kDslG992XmtRReverb3Over4000 86 ++#define kDslG992RcvFailDetCSegue1InWindow 87 ++#define kDslG992RcvCPilot1Failed 88 ++#define kDslG992RcvCReverb1Failed 89 ++#define kG992ControlAllRateOptionsFailedErr 90 ++#define kG992ControlInvalidRateOptionErr 91 ++#define kDslG992XmtInvalidXmtDErr 92 ++#define kDslG992BitAndGainCalcFailed 93 ++#define kDslG992BitAndGainVerifyFailed 94 ++ ++#define kDslT1p413RetrainToUseCorrectRAck 95 ++#define kDslUseAlternateTxFilter 96 ++#define kDslT1p413RetrainToUseCorrectIFFT 97 ++ ++typedef long dslConnectInfoStatusCode; ++#define kG992p2XmtToneOrderingInfo 0 ++#define kG992p2RcvToneOrderingInfo 1 ++#define kG992p2XmtCodingParamsInfo 2 ++#define kG992p2RcvCodingParamsInfo 3 ++#define kG992p2TrainingRcvCarrEdgeInfo 4 ++#define kG992ShowtimeMonitoringStatus 5 ++#define kG992MessageExchangeRcvInfo 6 ++#define kG992MessageExchangeXmtInfo 7 ++#define kG994MessageExchangeRcvInfo 8 ++#define kG994MessageExchangeXmtInfo 9 ++ ++#define kDslATURClockErrorInfo 10 ++#define kDslATURcvPowerInfo 11 ++#define kDslATUAvgLoopAttenuationInfo 12 ++#define kDslHWTimeTrackingResetClockError 13 ++#define kDslHWTimeTrackingClockTweak 14 ++#define kDslATUHardwareAGCObtained 15 ++#define kDslTEQCoefInfo 16 ++#define kDslRcvCarrierSNRInfo 17 ++#define kDslMaxReceivableBitRateInfo 18 ++#define kDslHWSetDigitalEcUpdateMode 19 ++#define kDslHWEnableDigitalECUpdate 20 ++#define kDslHWDisableDigitalECUpdate 21 ++#define kDslHWEnableDigitalEC 22 ++#define kDslHWSetDigitalEcGainShift 23 ++#define kDslHWSetDigitalEcUpdateShift 24 ++#define kDslRcvPsdInfo 25 ++#define kDslHWdcOffsetInfo 26 ++#define kG994SelectedG994p1CarrierIndex 27 ++#define kDslSelectedTimingTone 28 ++ ++#define kDslHWEnableAnalogECUpdate kDslHWSetDigitalEcUpdateMode ++#define kDslHWEnableAnalogEC kDslHWDisableDigitalECUpdate ++ ++#define kG992AocMessageExchangeRcvInfo 29 ++#define kG992AocMessageExchangeXmtInfo 30 ++#define kG992AocBitswapTxStarted 31 ++#define kG992AocBitswapRxStarted 32 ++#define kG992AocBitswapTxCompleted 33 ++#define kG992AocBitswapRxCompleted 34 ++#define kDslChannelResponseLog 35 ++#define kDslChannelResponseLinear 36 ++#define kDslChannelQuietLineNoise 37 ++ ++#define kDslATUCXmtPowerCutbackInfo 40 ++#define kDslATURXmtPowerCutbackInfo 41 ++#define kDslATUCXmtPowerInfo 42 ++#define kDslATURXmtPowerInfo 43 ++ ++#define kDslFramingModeInfo 50 ++#define kDslG992VendorID 51 ++ ++#ifdef BCM6348_SRC ++#define kDslHWSetRcvFir2OutputScale 52 ++#endif ++ ++#define kDslSignalAttenuation 53 ++#define kDslAttainableNetDataRate 54 ++#define kDslHLinScale 55 ++ ++#define kG992p3XmtCodingParamsInfo 60 ++#define kG992p3RcvCodingParamsInfo 61 ++#define kG992p3PwrStateInfo 62 ++#define kG992PilotToneInfo 63 ++ ++#define kDslSetPilotEyeDisplay 64 ++ ++#define kDslAturHwAgcResolutionMask (0xFFFFFFF8) ++#define kDslAturHwAgcMinGain ((-12)<<4) ++#ifndef BCM6348_SRC ++#define kDslAturHwAgcMaxGain (30<<4) ++#else ++#define kDslAturHwAgcMaxGain (36<<4) ++#endif ++ ++#define kDslFrameStatusSend 1 ++#define kDslFrameStatusSendComplete 2 ++#define kDslFrameStatusRcv 3 ++#define kDslFrameStatusReturn 4 ++ ++typedef struct _dslFramerStatus ++ { ++ dslFramerStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nRxFrameTotal; ++ long nRxFrameError; ++ long nTxFrameTotal; ++ } statistic; ++ } param; ++ } dslFramerStatus; ++ ++typedef struct ++ { ++ dslStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ atmStatusCode code; ++ union ++ { ++ long value; ++ dslErrorCode error; ++ struct ++ { ++ long vci; ++ long mid; ++ long aalType; ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long vcId; ++ long vci; ++ long aalType; ++ ulong fwdPeakCellTime; ++ ulong backPeakCellTime; ++ } vcInfo; ++ struct ++ { ++ long cellHdr; ++ long oamCmd; ++ } oamInfo; ++ struct ++ { ++ void *pVc; ++ char *pHdr; ++ void *cellHdr; ++ void *cellData; ++ } cellInfo; ++ struct ++ { ++ long totalBits; ++ long errBits; ++ } bertInfo; ++ } param; ++ } atmStatus; ++#ifdef DSL_PACKET ++ dslFramerStatus dslPacketStatus; ++#endif ++#ifdef G997_1_FRAMER ++ dslFramerStatus g997Status; ++#endif ++ struct ++ { ++ dslTrainingStatusCode code; ++ long value; ++ } dslTrainingInfo; ++ struct ++ { ++ dslConnectInfoStatusCode code; ++ long value; ++ void *buffPtr; ++ } dslConnectInfo; ++ struct ++ { ++ long maxMarginCarrier; ++ long maxSNRMargin; ++ long minMarginCarrier; ++ long minSNRMargin; ++ long avgSNRMargin; ++ long nCarriers; ++ void *buffPtr; ++ } dslShowtimeSNRMarginInfo; ++ struct ++ { ++ long code; ++ long vcId; ++ long timeStamp; ++ } dslFrameInfo; ++#ifdef G997_1 ++ struct ++ { ++ long msgId; ++ long msgType; ++ char *dataPtr; ++ } dslClearEocMsg; ++#endif ++ struct ++ { ++ char *fmt; ++ long argNum; ++ void *argPtr; ++ } dslPrintfMsg; ++ struct ++ { ++ ulong nBits; ++ ulong nBlocks; ++ ulong nBitErrors; ++ ulong nBlockErrors; ++ ++ ulong nAudioBits; ++ ulong nAudioBlocks; ++ ulong nAudioSyncErrors; ++ ulong nAudioBlockErrors; ++ } testResults; ++ struct ++ { ++ ulong code; ++ uchar *valuePtr; ++ ulong length; ++ } dslDataRegister; ++ struct ++ { ++ ulong code; ++ char *desc; ++ } dslExternalError; ++ struct ++ { ++ ulong numberOfCalls; ++ ulong txSignalChecksum; ++ ulong rxSignalChecksum; ++ ulong eyeDataChecksum; ++ } checksums; ++ struct ++ { ++ int sp; ++ int argc; ++ int *argv; ++ int *stackPtr; ++ int stackLen; ++ } dslException; ++ struct ++ { ++ ulong paramId; ++ void *dataPtr; ++ ulong dataLen; ++ } dslOemParameter; ++ struct ++ { ++ void *dataPtr; ++ ulong dataLen; ++ } dslDataAvail; ++ dslOLRMessage dslOLRRequest; ++ dslPwrMessage dslPwrMsg; ++ } param; ++ } dslStatusStruct; ++ ++typedef void (SM_DECL *dslStatusHandlerType) (void *gDslVars, dslStatusStruct*); ++ ++ ++/* ++** ++** Command codes ++** ++*/ ++ ++typedef long dslCommandCode; ++#define kFirstDslCommandCode 256 ++#define kDslIdleCmd (kFirstDslCommandCode + 0) ++#define kDslIdleRcvCmd (kFirstDslCommandCode + 1) ++#define kDslIdleXmtCmd (kFirstDslCommandCode + 2) ++#define kDslStartPhysicalLayerCmd (kFirstDslCommandCode + 3) ++#define kDslStartRetrainCmd (kFirstDslCommandCode + 4) ++#define kDslSetFrameFunctions (kFirstDslCommandCode + 5) ++#define kDslSendEocCommand (kFirstDslCommandCode + 6) ++#define kDslWriteRemoteRegister (kFirstDslCommandCode + 7) ++#define kDslReadRemoteRegister (kFirstDslCommandCode + 8) ++#define kDslWriteLocalRegister (kFirstDslCommandCode + 9) ++#define kDslReadLocalRegister (kFirstDslCommandCode + 10) ++#define kDslStoreHardwareAGCCmd (kFirstDslCommandCode + 11) ++#define kDslSetCommandHandlerCmd (kFirstDslCommandCode + 12) ++#define kSetLinkLayerStatusHandlerCmd (kFirstDslCommandCode + 13) ++#define kDslSetG997Cmd (kFirstDslCommandCode + 14) ++#define kDslLoopbackCmd (kFirstDslCommandCode + 15) ++#define kDslDiagSetupCmd (kFirstDslCommandCode + 16) ++#define kDslSetDriverCallbackCmd (kFirstDslCommandCode + 17) ++#define kDslDiagStopLogCmd (kFirstDslCommandCode + 18) ++#define kDslDiagStartBERT (kFirstDslCommandCode + 19) ++#define kDslDiagStopBERT (kFirstDslCommandCode + 20) ++#define kDslPingCmd (kFirstDslCommandCode + 21) ++#define kDslDyingGaspCmd (kFirstDslCommandCode + 22) ++#define kDslTestCmd (kFirstDslCommandCode + 23) ++#define kDslFilterSNRMarginCmd (kFirstDslCommandCode + 24) ++#define kDslAtmVcMapTableChanged (kFirstDslCommandCode + 25) ++#define kDslGetOemDataAddrCmd (kFirstDslCommandCode + 26) ++#define kDslAtmReportHEC (kFirstDslCommandCode + 27) ++#define kDslAtmReportCD (kFirstDslCommandCode + 28) ++#define kDslSetXmtGainCmd (kFirstDslCommandCode + 29) ++#define kDslSetStatusBufferCmd (kFirstDslCommandCode + 30) ++#define kDslAfeTestCmd (kFirstDslCommandCode + 31) ++#define kDslI432ResetCmd (kFirstDslCommandCode + 32) ++#define kDslSetRcvGainCmd (kFirstDslCommandCode + 33) ++#define kDslBypassRcvHpfCmd (kFirstDslCommandCode + 34) ++#define kDslWriteAfeRegCmd (kFirstDslCommandCode + 35) ++#define kDslReadAfeRegCmd (kFirstDslCommandCode + 36) ++#define kDslOLRRequestCmd (kFirstDslCommandCode + 37) ++#define kDslOLRResponseCmd (kFirstDslCommandCode + 38) ++#define kDslI432SetScrambleCmd (kFirstDslCommandCode + 39) ++#define kDslPwrMgrCmd (kFirstDslCommandCode + 40) ++#define kDslAtmGfcMappingCmd (kFirstDslCommandCode + 41) ++ ++#ifdef BCM6348_SRC ++#define kDslEnablePwmSyncClk (kFirstDslCommandCode + 42) ++#define kDslSetPwmSyncClkFreq (kFirstDslCommandCode + 43) ++#endif ++ ++#define kG994p1Duplex 1 ++#define kG994p1HalfDuplex 2 ++ ++/* Eoc Messages from ATU-C to ATU-R */ ++#define kDslEocHoldStateCmd 1 ++#define kDslEocReturnToNormalCmd 2 ++#define kDslEocPerformSelfTestCmd 3 ++#define kDslEocRequestCorruptCRCCmd 4 ++#define kDslEocRequestEndCorruptCRCCmd 5 ++#define kDslEocNotifyCorruptCRCCmd 6 ++#define kDslEocNotifyEndCorruptCRCCmd 7 ++#define kDslEocRequestTestParametersUpdateCmd 8 ++#define kDslEocGrantPowerDownCmd 9 ++#define kDslEocRejectPowerDownCmd 10 ++ ++/* Eoc Messages from ATU-R to ATU-C */ ++#define kDslEocRequestPowerDownCmd 11 ++#define kDslEocDyingGaspCmd 12 ++ ++/* Clear Eoc Messages */ ++#define kDslClearEocFirstCmd 100 ++#define kDslClearEocSendFrame 100 ++#define kDslClearEocSendComplete 101 ++#define kDslClearEocRcvedFrame 102 ++#define kDslClearEocSendComplete2 103 ++ ++#define kDslClearEocMsgLengthMask 0xFFFF ++#define kDslClearEocMsgNumMask 0xFF0000 ++#define kDslClearEocMsgDataVolatileMask 0x1000000 ++#define kDslClearEocMsgDataVolatile kDslClearEocMsgDataVolatileMask ++#define kDslClearEocMsgExtraSendComplete 0x2000000 ++ ++/* ADSL Link Power States */ ++#define kDslPowerFullOn 0 ++#define kDslPowerLow 1 ++#define kDslPowerIdle 3 ++ ++/* ATU-R Data Registers */ ++#define kDslVendorIDRegister 1 ++#define kDslRevisionNumberRegister 2 ++#define kDslSerialNumberRegister 3 ++#define kDslSelfTestResultsRegister 4 ++#define kDslLineAttenuationRegister 5 ++#define kDslSnrMarginRegister 6 ++#define kDslAturConfigurationRegister 7 ++#define kDslLinkStateRegister 8 ++ ++#define kDslVendorIDRegisterLength 8 ++#define kDslRevisionNumberRegisterLength 32 ++#define kDslSerialNumberRegisterLength 32 ++#define kDslSelfTestResultsRegisterLength 1 ++#define kDslLineAttenuationRegisterLength 1 ++#define kDslSnrMarginRegisterLength 1 ++#define kDslAturConfigurationRegisterLength 30 ++#define kDslLinkStateRegisterLength 1 ++ ++/* Dsl Diags setup flags */ ++#define kDslDiagEnableEyeData 1 ++#define kDslDiagEnableLogData 2 ++ ++/* Dsl test commands */ ++typedef long dslTestCmdType; ++#define kDslTestBackToNormal 0 ++#define kDslTestReverb 1 ++#define kDslTestMedley 2 ++#define kDslTestToneSelection 3 ++#define kDslTestNoAutoRetrain 4 ++#define kDslTestMarginTweak 5 ++#define kDslTestEstimatePllPhase 6 ++#define kDslTestReportPllPhaseStatus 7 ++#define kDslTestAfeLoopback 8 ++#define kDslTestL3 9 ++#define kDslTestAdsl2DiagMode 10 ++#define kDslTestRetL0 11 ++ ++/* Xmt gain default setting */ ++#define kDslXmtGainAuto 0x80000000 ++ ++/* Unit (AFE) test commands */ ++#define kDslAfeTestLoadImage 0 ++#define kDslAfeTestPatternSend 1 ++#define kDslAfeTestLoadImageOnly 2 ++#define kDslAfeTestPhyRun 3 ++#define kDslAfeTestLoadBuffer 4 ++ ++typedef struct ++ { ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++ ushort downstreamMinCarr, downstreamMaxCarr; ++#else ++ uchar downstreamMinCarr, downstreamMaxCarr; ++#endif ++ uchar upstreamMinCarr, upstreamMaxCarr; ++ }carrierInfo; ++ ++#if defined(G992P3) && !defined(BCM6348_SRC) ++#define FAST_TEXT_TYPE ++#else ++#define FAST_TEXT_TYPE FAST_TEXT ++#endif ++ ++#if defined(BCM6348_SRC) ++#define BCM6348_TEMP_MOVE_TO_LMEM ++#else ++#define BCM6348_TEMP_MOVE_TO_LMEM ++#endif ++ ++#ifdef G992P3 ++#define PRINT_DEBUG_INFO ++#else ++#define PRINT_DEBUG_INFO ++#endif ++ ++#ifdef G992P3 ++ ++#define kG992p3MaxSpectBoundsUpSize 16 ++#define kG992p3MaxSpectBoundsDownSize 16 ++ ++/* G.994 definitions */ ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 1 ***/ ++ ++#define kG994p1G992p3AnnexASpectrumBoundsUpstream 0x01 ++#define kG994p1G992p3AnnexASpectrumShapingUpstream 0x02 ++#define kG994p1G992p3AnnexASpectrumBoundsDownstream 0x04 ++#define kG994p1G992p3AnnexASpectrumShapingDownstream 0x08 ++#define kG994p1G992p3AnnexATxImageAboveNyquistFreq 0x10 ++#define kG994p1G992p3AnnexLReachExtended 0x20 ++#define kG994p1G992p3AnnexMSubModePSDMasks 0x20 ++ ++#define kG994p1G992p3AnnexLUpNarrowband 0x02 ++#define kG994p1G992p3AnnexLUpWideband 0x01 ++#define kG994p1G992p3AnnexLDownNonoverlap 0x01 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 2 ***/ ++ ++#define kG994p1G992p3AnnexADownOverheadDataRate 0x01 ++#define kG994p1G992p3AnnexAUpOverheadDataRate 0x02 ++#define kG994p1G992p3AnnexAMaxNumberDownTPSTC 0x04 ++#define kG994p1G992p3AnnexAMaxNumberUpTPSTC 0x08 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 3,5,7,9 ***/ ++ ++#define kG994p1G992p3AnnexADownSTM_TPS_TC 0x01 ++#define kG994p1G992p3AnnexAUpSTM_TPS_TC 0x02 ++#define kG994p1G992p3AnnexADownATM_TPS_TC 0x04 ++#define kG994p1G992p3AnnexAUpATM_TPS_TC 0x08 ++#define kG994p1G992p3AnnexADownPTM_TPS_TC 0x10 ++#define kG994p1G992p3AnnexAUpPTM_TPS_TC 0x20 ++ ++/*** Standard Info SPar2: G.992.3 Annex A Octet 4,6,8,10 ***/ ++ ++#define kG994p1G992p3AnnexADownPMS_TC_Latency 0x01 ++#define kG994p1G992p3AnnexAUpPMS_TC_Latency 0x02 ++ ++/*** ++ * TSSI ++ * ++ * TSSI information is specified in 2 parts: subcarrier index, ++ * tssi value, and an indication of whether or no the tone specified ++ * is part of the supported set. ++ * ++ * The subcarrier index information is currently stored in the ++ * dsSubcarrierIndex array defined below. The tssi value are stored ++ * in the dsLog_tss array. ++ * ++ * The subcarrier index information only occupies the lower 12 bits ++ * of the available 16 bits (short type). Therefore, we will pack the ++ * supported set information in bit 15. ++ */ ++#define kG992DsSubCarrierIndexMask (0x0fff) /* AND mask to ectract ds subcarrier index */ ++#define kG992DsSubCarrierSuppSetMask (0x8000) /* AND mask to extract supported set indication */ ++ ++#define G992GetDsSubCarrierIndex(arg) ((arg) & kG992DsSubCarrierIndexMask) ++#define G992GetDsSubCarrierSuppSetIndication(arg) (((arg) & kG992DsSubCarrierSuppSetMask) >> 15) ++ ++/* Caution: Do not change anything in this structure definition, including associated constant */ ++/* This structure definition is used only by the driver and any change impose incompatibility issue in driver */ ++/* The structure following this structure (g992p3PhyDataPumpCapabilities) can be changed in PHY application */ ++ ++typedef struct ++ { ++ Boolean rcvNTREnabled, shortInitEnabled, diagnosticsModeEnabled; ++ ++ char featureSpectrum, featureOverhead; ++ char featureTPS_TC[4], featurePMS_TC[4]; ++ ++ short rcvNOMPSDus, rcvMAXNOMPSDus, rcvMAXNOMATPus; ++ short usSubcarrierIndex[kG992p3MaxSpectBoundsUpSize], ++ usLog_tss[kG992p3MaxSpectBoundsUpSize]; ++ short numUsSubcarrier; ++ short rcvNOMPSDds, rcvMAXNOMPSDds, rcvMAXNOMATPds; ++ short dsSubcarrierIndex[kG992p3MaxSpectBoundsDownSize], ++ dsLog_tss[kG992p3MaxSpectBoundsDownSize]; ++ short numDsSubcarrier; ++ uchar sizeIDFT, fillIFFT; ++ uchar readsl2Upstream, readsl2Downstream; ++ uchar minDownOverheadDataRate, minUpOverheadDataRate; ++ uchar maxDownSTM_TPSTC, maxDownATM_TPSTC, maxDownPTM_TPSTC; ++ uchar maxUpSTM_TPSTC, maxUpATM_TPSTC, maxUpPTM_TPSTC; ++ ++ short minDownSTM_TPS_TC[4], maxDownSTM_TPS_TC[4], ++ minRevDownSTM_TPS_TC[4], maxDelayDownSTM_TPS_TC[4]; ++ uchar maxErrorDownSTM_TPS_TC[4], minINPDownSTM_TPS_TC[4]; ++ short minUpSTM_TPS_TC[4], maxUpSTM_TPS_TC[4], ++ minRevUpSTM_TPS_TC[4], maxDelayUpSTM_TPS_TC[4]; ++ uchar maxErrorUpSTM_TPS_TC[4], minINPUpSTM_TPS_TC[4]; ++ ++ short maxDownPMS_TC_Latency[4], maxUpPMS_TC_Latency[4]; ++ short maxDownR_PMS_TC_Latency[4], maxDownD_PMS_TC_Latency[4]; ++ short maxUpR_PMS_TC_Latency[4], maxUpD_PMS_TC_Latency[4]; ++ ++ short minDownATM_TPS_TC[4], maxDownATM_TPS_TC[4], ++ minRevDownATM_TPS_TC[4], maxDelayDownATM_TPS_TC[4]; ++ uchar maxErrorDownATM_TPS_TC[4], minINPDownATM_TPS_TC[4]; ++ short minUpATM_TPS_TC[4], maxUpATM_TPS_TC[4], ++ minRevUpATM_TPS_TC[4], maxDelayUpATM_TPS_TC[4]; ++ uchar maxErrorUpATM_TPS_TC[4], minINPUpATM_TPS_TC[4]; ++ ++ short minDownPTM_TPS_TC[4], maxDownPTM_TPS_TC[4], ++ minRevDownPTM_TPS_TC[4], maxDelayDownPTM_TPS_TC[4]; ++ uchar maxErrorDownPTM_TPS_TC[4], minINPDownPTM_TPS_TC[4]; ++ short minUpPTM_TPS_TC[4], maxUpPTM_TPS_TC[4], ++ minRevUpPTM_TPS_TC[4], maxDelayUpPTM_TPS_TC[4]; ++ uchar maxErrorUpPTM_TPS_TC[4], minINPUpPTM_TPS_TC[4]; ++ ++ ushort subModePSDMasks; ++ } g992p3DataPumpCapabilities; ++ ++#define kG992p3p5MaxSpectBoundsUpSize 16 ++#define kG992p3p5MaxSpectBoundsDownSize 32 ++ ++typedef struct ++ { ++ Boolean rcvNTREnabled, shortInitEnabled, diagnosticsModeEnabled; ++ ++ char featureSpectrum, featureOverhead; ++ char featureTPS_TC[4], featurePMS_TC[4]; ++ ++ short rcvNOMPSDus, rcvMAXNOMPSDus, rcvMAXNOMATPus; ++ short usSubcarrierIndex[kG992p3p5MaxSpectBoundsUpSize], ++ usLog_tss[kG992p3p5MaxSpectBoundsUpSize]; ++ short numUsSubcarrier; ++ short rcvNOMPSDds, rcvMAXNOMPSDds, rcvMAXNOMATPds; ++ short dsSubcarrierIndex[kG992p3p5MaxSpectBoundsDownSize], ++ dsLog_tss[kG992p3p5MaxSpectBoundsDownSize]; ++ short numDsSubcarrier; ++ uchar sizeIDFT, fillIFFT; ++ uchar readsl2Upstream, readsl2Downstream; ++ uchar minDownOverheadDataRate, minUpOverheadDataRate; ++ uchar maxDownSTM_TPSTC, maxDownATM_TPSTC, maxDownPTM_TPSTC; ++ uchar maxUpSTM_TPSTC, maxUpATM_TPSTC, maxUpPTM_TPSTC; ++ ++ short minDownSTM_TPS_TC[4], maxDownSTM_TPS_TC[4], ++ minRevDownSTM_TPS_TC[4], maxDelayDownSTM_TPS_TC[4]; ++ uchar maxErrorDownSTM_TPS_TC[4], minINPDownSTM_TPS_TC[4]; ++ short minUpSTM_TPS_TC[4], maxUpSTM_TPS_TC[4], ++ minRevUpSTM_TPS_TC[4], maxDelayUpSTM_TPS_TC[4]; ++ uchar maxErrorUpSTM_TPS_TC[4], minINPUpSTM_TPS_TC[4]; ++ ++ short maxDownPMS_TC_Latency[4], maxUpPMS_TC_Latency[4]; ++ short maxDownR_PMS_TC_Latency[4], maxDownD_PMS_TC_Latency[4]; ++ short maxUpR_PMS_TC_Latency[4], maxUpD_PMS_TC_Latency[4]; ++ ++ short minDownATM_TPS_TC[4], maxDownATM_TPS_TC[4], ++ minRevDownATM_TPS_TC[4], maxDelayDownATM_TPS_TC[4]; ++ uchar maxErrorDownATM_TPS_TC[4], minINPDownATM_TPS_TC[4]; ++ short minUpATM_TPS_TC[4], maxUpATM_TPS_TC[4], ++ minRevUpATM_TPS_TC[4], maxDelayUpATM_TPS_TC[4]; ++ uchar maxErrorUpATM_TPS_TC[4], minINPUpATM_TPS_TC[4]; ++ ++ short minDownPTM_TPS_TC[4], maxDownPTM_TPS_TC[4], ++ minRevDownPTM_TPS_TC[4], maxDelayDownPTM_TPS_TC[4]; ++ uchar maxErrorDownPTM_TPS_TC[4], minINPDownPTM_TPS_TC[4]; ++ short minUpPTM_TPS_TC[4], maxUpPTM_TPS_TC[4], ++ minRevUpPTM_TPS_TC[4], maxDelayUpPTM_TPS_TC[4]; ++ uchar maxErrorUpPTM_TPS_TC[4], minINPUpPTM_TPS_TC[4]; ++ ++ ushort subModePSDMasks; ++ } g992p3PhyDataPumpCapabilities; ++#endif ++ ++typedef struct ++ { ++ dslModulationType modulations; ++ bitMap auxFeatures; ++ bitMap features; ++ bitMap demodCapabilities; ++ bitMap demodCapabilities2; ++ ushort noiseMargin; /* Q4 dB */ ++#ifdef G992_ATUC ++ short xmtRSf, xmtRS, xmtS, xmtD; ++ short rcvRSf, rcvRS, rcvS, rcvD; ++#endif ++#ifdef G992P1_ANNEX_A ++ bitMap subChannelInfo; ++ carrierInfo carrierInfoG992p1; ++#endif ++#ifdef G992P1_ANNEX_B ++ bitMap subChannelInfoAnnexB; ++ carrierInfo carrierInfoG992p1AnnexB; ++#endif ++#ifdef G992_ANNEXC ++ bitMap subChannelInfoAnnexC; ++ carrierInfo carrierInfoG992p1AnnexC; ++#endif ++#if defined(G992P1_ANNEX_I) ++ bitMap subChannelInfoAnnexI; ++ carrierInfo carrierInfoG992p1AnnexI; ++#endif ++#ifdef G992P5 ++ bitMap subChannelInfop5; ++ carrierInfo carrierInfoG992p5; ++#endif ++#if defined(G992P2) || (defined(G992P1_ANNEX_A) && defined(G992P1_ANNEX_A_USED_FOR_G992P2)) ++ carrierInfo carrierInfoG992p2; ++#endif ++ ushort maxDataRate; ++ uchar minDataRate; ++#ifdef G992P3 ++ g992p3DataPumpCapabilities *carrierInfoG992p3AnnexA; ++#endif ++#ifdef G992P5 ++ g992p3DataPumpCapabilities *carrierInfoG992p5AnnexA; ++#endif ++ } dslDataPumpCapabilities; ++ ++struct __dslCommandStruct; ++typedef Boolean (*dslCommandHandlerType) (void *gDslVars, struct __dslCommandStruct*); ++typedef struct __dslCommandStruct ++ { ++ dslCommandCode command; ++ union ++ { ++ long value; ++ Boolean flag; ++ struct ++ { ++ dslTestCmdType type; ++ union ++ { ++ struct ++ { ++ ulong xmtStartTone, xmtNumOfTones; ++ ulong rcvStartTone, rcvNumOfTones; ++ uchar *xmtMap, *rcvMap; ++ } toneSelectSpec; ++ struct ++ { ++ long extraPowerRequestQ4dB; ++ long numOfCarriers; ++ char *marginTweakTableQ4dB; ++ } marginTweakSpec; ++ } param; ++ } dslTestSpec; ++ struct ++ { ++ dslDirectionType direction; ++ dslDataPumpCapabilities capabilities; ++ } dslModeSpec; ++ struct ++ { ++ bitMap setup; ++ ulong eyeConstIndex1; ++ ulong eyeConstIndex2; ++ ulong logTime; ++ } dslDiagSpec; ++ struct ++ { ++ void *pBuf; ++ ulong bufSize; ++ } dslStatusBufSpec; ++ struct ++ { ++ ulong type; ++ void *afeParamPtr; ++ ulong afeParamSize; ++ void *imagePtr; ++ ulong imageSize; ++ } dslAfeTestSpec; ++ struct ++ { ++ dslLinkLayerType type; ++ bitMap setup; ++ union ++ { ++ struct ++ { ++ dataRateMap rxDataRate; ++ dataRateMap txDataRate; ++ long rtDelayQ4ms; ++ ulong rxBufNum; ++ ulong rxCellsInBuf; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslPhyInitType atmPhyInitPtr; ++ } atmLinkSpec; ++ struct ++ { ++ dslHeaderHandlerType rxHeaderHandlerPtr; ++ dslRxFrameBufferHandlerType rxDataHandlerPtr; ++ dslTxFrameBufferHandlerType txHandlerPtr; ++ } atmPhyLinkSpec; ++#ifdef DSL_PACKET ++ struct ++ { ++ ulong rxBufNum; ++ ulong rxBufSize; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslPacketPhyInitType dslPhyInitPtr; ++ } dslPacketLinkSpec; ++ dslPacketPhyFunctions dslPacketPhyLinkSpec; ++#endif ++ struct ++ { ++ txDataHandlerType txDataHandlerPtr; ++ rxDataHandlerType rxDataHandlerPtr; ++ } nullLinkSpec; ++ } param; ++ } dslLinkLayerSpec; ++#ifdef G997_1 ++#ifdef G997_1_FRAMER ++ struct ++ { ++ bitMap setup; ++ ulong rxBufNum; ++ ulong rxBufSize; ++ ulong rxPacketNum; ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ } dslG997Cmd; ++#endif ++ struct ++ { ++ long msgId; ++ long msgType; ++ char *dataPtr; ++ } dslClearEocMsg; ++#endif ++ struct ++ { ++ ulong code; ++ uchar *valuePtr; ++ ulong length; ++ } dslDataRegister; ++ union ++ { ++ dslStatusHandlerType statusHandlerPtr; ++ dslCommandHandlerType commandHandlerPtr; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++#if defined(DEBUG_DATA_HANDLER) ++ debugDataHandlerType debugDataHandlerPtr; ++#endif ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslDriverCallbackType driverCallback; ++ } handlerSpec; ++#if !defined(CHIP_SRC) || defined(DSL_FRAME_FUNCTIONS) ++ dslFrameFunctions DslFunctions; ++#endif ++ dslOLRMessage dslOLRRequest; ++ dslPwrMessage dslPwrMsg; ++ } param; ++ } dslCommandStruct; ++ ++ ++ ++ ++typedef struct ++ { ++ dslCommandHandlerType linkCommandHandlerPtr; ++ timerHandlerType linkTimerHandlerPtr; ++ dslLinkCloseHandlerType linkCloseHandlerPtr; ++ ++ dslFrameHandlerType linkSendHandlerPtr; ++ dslFrameHandlerType linkReturnHandlerPtr; ++ ++ dslVcAllocateHandlerType linkVcAllocateHandlerPtr; ++ dslVcFreeHandlerType linkVcFreeHandlerPtr; ++ dslVcActivateHandlerType linkVcActivateHandlerPtr; ++ dslVcDeactivateHandlerType linkVcDeactivateHandlerPtr; ++ dslVcConfigureHandlerType linkVcConfigureHandlerPtr; ++ ++ dslLinkVc2IdHandlerType linkVc2IdHandlerPtr; ++ dslLinkVcId2VcHandlerType linkVcId2VcHandlerPtr; ++ dslGetFramePoolHandlerType linkGetFramePoolHandlerPtr; ++ ++#ifndef ADSLCORE_ONLY ++ dslHeaderHandlerType linkRxCellHeaderHandlerPtr; ++ dslRxFrameBufferHandlerType linkRxCellDataHandlerPtr; ++ dslTxFrameBufferHandlerType linkTxCellHandlerPtr; ++#endif ++ ++ txDataHandlerType linkTxDataHandlerPtr; ++ rxDataHandlerType linkRxDataHandlerPtr; ++ } linkLayerFunctions; ++ ++#ifndef ADSLCORE_ONLY ++ ++#define LinkLayerAssignFunctions( var, name_prefix ) do { \ ++ (var).linkCommandHandlerPtr = name_prefix##CommandHandler; \ ++ (var).linkTimerHandlerPtr = name_prefix##TimerHandler; \ ++ (var).linkCloseHandlerPtr = name_prefix##CloseHandler; \ ++ \ ++ (var).linkSendHandlerPtr = name_prefix##SendFrameHandler; \ ++ (var).linkReturnHandlerPtr = name_prefix##ReturnFrameHandler; \ ++ \ ++ (var).linkVcAllocateHandlerPtr = name_prefix##VcAllocateHandler; \ ++ (var).linkVcFreeHandlerPtr = name_prefix##VcFreeHandler; \ ++ (var).linkVcActivateHandlerPtr = name_prefix##VcActivateHandler; \ ++ (var).linkVcDeactivateHandlerPtr = name_prefix##VcDeactivateHandler; \ ++ (var).linkVcConfigureHandlerPtr = name_prefix##VcConfigureHandler; \ ++ \ ++ (var).linkVc2IdHandlerPtr = name_prefix##Vc2IdHandler; \ ++ (var).linkVcId2VcHandlerPtr = name_prefix##VcId2VcHandler; \ ++ (var).linkGetFramePoolHandlerPtr = name_prefix##GetFramePoolHandler; \ ++ \ ++ (var).linkRxCellHeaderHandlerPtr = name_prefix##RxCellHeaderHandler; \ ++ (var).linkRxCellDataHandlerPtr = name_prefix##RxCellDataHandler; \ ++ (var).linkTxCellHandlerPtr = name_prefix##TxCellHandler; \ ++ \ ++ (var).linkTxDataHandlerPtr = name_prefix##TxDataHandler; \ ++ (var).linkRxDataHandlerPtr = name_prefix##RxDataHandler; \ ++} while (0) ++ ++#else ++ ++#define LinkLayerAssignFunctions( var, name_prefix ) do { \ ++ (var).linkCommandHandlerPtr = name_prefix##CommandHandler; \ ++ (var).linkTimerHandlerPtr = name_prefix##TimerHandler; \ ++ (var).linkCloseHandlerPtr = name_prefix##CloseHandler; \ ++ \ ++ (var).linkSendHandlerPtr = name_prefix##SendFrameHandler; \ ++ (var).linkReturnHandlerPtr = name_prefix##ReturnFrameHandler; \ ++ \ ++ (var).linkVcAllocateHandlerPtr = name_prefix##VcAllocateHandler; \ ++ (var).linkVcFreeHandlerPtr = name_prefix##VcFreeHandler; \ ++ (var).linkVcActivateHandlerPtr = name_prefix##VcActivateHandler; \ ++ (var).linkVcDeactivateHandlerPtr = name_prefix##VcDeactivateHandler; \ ++ (var).linkVcConfigureHandlerPtr = name_prefix##VcConfigureHandler; \ ++ \ ++ (var).linkVc2IdHandlerPtr = name_prefix##Vc2IdHandler; \ ++ (var).linkVcId2VcHandlerPtr = name_prefix##VcId2VcHandler; \ ++ (var).linkGetFramePoolHandlerPtr = name_prefix##GetFramePoolHandler; \ ++ \ ++ (var).linkTxDataHandlerPtr = name_prefix##TxDataHandler; \ ++ (var).linkRxDataHandlerPtr = name_prefix##RxDataHandler; \ ++} while (0) ++ ++#endif ++ ++typedef struct ++ { ++ dslFrameHandlerType rxIndicateHandlerPtr; ++ dslFrameHandlerType txCompleteHandlerPtr; ++ dslStatusHandlerType statusHandlerPtr; ++ } upperLayerFunctions; ++ ++ ++/* ++ * Debug data ++ */ ++#define kDslFirstDebugData 1000 ++#define kDslXmtPerSymTimeCompData (kDslFirstDebugData + 0) ++#define kDslRcvPerSymTimeCompData (kDslFirstDebugData + 1) ++#define kDslXmtAccTimeCompData (kDslFirstDebugData + 2) ++#define kDslRcvAccTimeCompData (kDslFirstDebugData + 3) ++#define kDslRcvPilotToneData (kDslFirstDebugData + 4) ++#define kDslTEQCoefData (kDslFirstDebugData + 5) ++#define kDslTEQInputData (kDslFirstDebugData + 6) ++#define kDslTEQOutputData (kDslFirstDebugData + 7) ++#define kDslRcvFFTInputData (kDslFirstDebugData + 8) ++#define kDslRcvFFTOutputData (kDslFirstDebugData + 9) ++#define kDslRcvCarrierSNRData (kDslFirstDebugData + 10) ++#define kDslXmtToneOrderingData (kDslFirstDebugData + 11) ++#define kDslRcvToneOrderingData (kDslFirstDebugData + 12) ++#define kDslXmtGainData (kDslFirstDebugData + 13) ++#define kDslRcvGainData (kDslFirstDebugData + 14) ++#define kDslMseData (kDslFirstDebugData + 15) ++#define kDslFEQOutErrData (kDslFirstDebugData + 16) ++#define kDslFEQCoefData (kDslFirstDebugData + 17) ++#define kDslShowtimeMseData (kDslFirstDebugData + 18) ++#define kDslTimeEstimationHWPhaseTweak (kDslFirstDebugData + 24) ++#define kDslSlicerInput (kDslFirstDebugData + 40) ++#define kDslXmtConstellations (kDslFirstDebugData + 41) ++#define kDslSnr1ShiftData (kDslFirstDebugData + 50) ++#define kDslSnr1InputData (kDslFirstDebugData + 51) ++#define kDslSnr1ReverbAvgData (kDslFirstDebugData + 52) ++#define kDslAnnexCFextSnrData (kDslFirstDebugData + 53) ++#define kDslAnnexCNextSnrData (kDslFirstDebugData + 54) ++#define kG994p1OutputXmtSample (kDslFirstDebugData + 100) ++#define kG994p1OutputMicroBit (kDslFirstDebugData + 101) ++#define kG994p1OutputBit (kDslFirstDebugData + 102) ++#define kG994p1OutputTimer (kDslFirstDebugData + 103) ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.1 Defininitive constants */ ++/****************************************************************************/ ++ ++/* dslDirectionType */ ++ ++#define kATU_C 0 ++#define kATU_R 1 ++ ++/* ATM setup maps */ ++ ++#define kAtmCallMgrEnabled 0x00000001 /* Bit 0 */ ++#define kAtmAAL1FecEnabledMask 0x00000006 /* Bit 1 */ ++#define kAtmAAL1HiDelayFecEnabled 0x00000002 /* Bit 2 */ ++#define kAtmAAL1LoDelayFecEnabled 0x00000004 /* Bit 3 */ ++ ++/* dslLinkLayerType */ ++ ++#define kNoDataLink 0 ++#define kAtmLink 0x00000001 ++#define kAtmPhyLink 0x00000002 ++#define kDslPacketLink 0x00000003 ++#define kDslPacketPhyLink 0x00000004 ++ ++/* dslModulationType */ ++#define kNoCommonModulation 0x00000000 ++#define kG994p1 0x00000020 /* G.994.1 or G.hs */ ++#define kT1p413 0x00000040 /* T1.413 handshaking */ ++#define kG992p1AnnexA 0x00000001 /* G.992.1 or G.dmt Annex A */ ++#define kG992p1AnnexB 0x00000002 /* G.992.1 or G.dmt Annex B */ ++#define kG992p1AnnexC 0x00000004 /* G.992.1 or G.dmt Annex C */ ++#define kG992p2AnnexAB 0x00000008 /* G.992.2 or G.lite Annex A/B */ ++#define kG992p2AnnexC 0x00000010 /* G.992.2 or G.lite Annex C */ ++#define kG992p3AnnexA 0x00000100 /* G.992.3 or G.DMTbis Annex A */ ++#define kG992p3AnnexB 0x00000200 /* G.992.3 or G.DMTbis Annex A */ ++#define kG992p1AnnexI 0x00000400 /* G.992.1 Annex I */ ++#define kG992p5AnnexA 0x00010000 /* G.992.5 Annex A */ ++#define kG992p5AnnexB 0x00020000 /* G.992.5 Annex B */ ++#define kG992p5AnnexI 0x00040000 /* G.992.5 Annex I */ ++#define kG992p3AnnexM 0x00080000 /* G.992.3 Annex M */ ++#define kG992p5AnnexM 0x01000000 /* G.992.5 Annex M */ ++ ++/* demodCapabilities bitmap */ ++#define kEchoCancellorEnabled 0x00000001 ++#define kSoftwareTimeErrorDetectionEnabled 0x00000002 ++#define kSoftwareTimeTrackingEnabled 0x00000004 ++#define kDslTrellisEnabled 0x00000008 ++#define kHardwareTimeTrackingEnabled 0x00000010 ++#define kHardwareAGCEnabled 0x00000020 ++#define kDigitalEchoCancellorEnabled 0x00000040 ++#define kReedSolomonCodingEnabled 0x00000080 ++#define kAnalogEchoCancellorEnabled 0x00000100 ++#define kT1p413Issue1SingleByteSymMode 0x00000200 ++#define kDslAturXmtPowerCutbackEnabled 0x00000400 ++#ifdef G992_ANNEXC_LONG_REACH ++#define kDslAnnexCPilot48 0x00000800 ++#define kDslAnnexCReverb33_63 0x00001000 ++#endif ++#ifdef G992_ANNEXC ++#define kDslCentilliumCRCWorkAroundEnabled 0x00002000 ++#else ++#define kDslEnableRoundUpDSLoopAttn 0x00002000 ++#endif ++#define kDslBitSwapEnabled 0x00004000 ++#define kDslADILowRateOptionFixDisabled 0x00008000 ++#define kDslAnymediaGSPNCrcFixEnabled 0x00010000 ++#define kDslMultiModesPreferT1p413 0x00020000 ++#define kDslT1p413UseRAck1Only 0x00040000 ++#define kDslUE9000ADI918FECFixEnabled 0x00080000 ++#define kDslG994AnnexAMultimodeEnabled 0x00100000 ++#define kDslATUCXmtPowerMinimizeEnabled 0x00200000 ++#define kDropOnDataErrorsDisabled 0x00400000 ++#define kDslSRAEnabled 0x00800000 ++ ++#define kDslT1p413HigherToneLevelNeeded 0x01000000 ++#define kDslT1p413SubsampleAlignmentEnabled 0x02000000 ++#define kDslT1p413DisableUpstream2xIfftMode 0x04000000 ++ ++/* test mode related demodCapabilities, for internal use only */ ++#define kDslTestDemodCapMask 0xF8000000 ++#define kDslSendReverbModeEnabled 0x10000000 ++#define kDslSendMedleyModeEnabled 0x20000000 ++#define kDslAutoRetrainDisabled 0x40000000 ++#define kDslPllWorkaroundEnabled 0x80000000 ++#define kDslAfeLoopbackModeEnabled 0x08000000 ++ ++/* demodCapabilities bitmap2 */ ++ ++#define kDslAnnexCProfile1 0x00000001 ++#define kDslAnnexCProfile2 0x00000002 ++#define kDslAnnexCProfile3 0x00000004 ++#define kDslAnnexCProfile4 0x00000008 ++#define kDslAnnexCProfile5 0x00000010 ++#define kDslAnnexCProfile6 0x00000020 ++#define kDslAnnexCPilot64 0x00000040 ++#define kDslAnnexCPilot48 0x00000080 ++#define kDslAnnexCPilot32 0x00000100 ++#define kDslAnnexCPilot16 0x00000200 ++#define kDslAnnexCA48B48 0x00000400 ++#define kDslAnnexCA24B24 0x00000800 ++#define kDslAnnexCReverb33_63 0x00001000 ++#define kDslAnnexCCReverb6_31 0x00002000 ++ ++#define kDslAnnexIShapedSSVI 0x00004000 ++#define kDslAnnexIFlatSSVI 0x00008000 ++ ++#define kDslAnnexIPilot64 0x00010000 ++#define kDslAnnexIA48B48 0x00020000 ++#define kDslAnnexIPilot128 0x00040000 ++#define kDslAnnexIPilot96 0x00080000 ++ ++/* Features bitmap */ ++#define kG992p2RACK1 0x00000001 ++#define kG992p2RACK2 0x00000002 ++#define kG992p2DBM 0x00000004 ++#define kG992p2FastRetrain 0x00000008 ++#define kG992p2RS16 0x00000010 ++#define kG992p2ClearEOCOAM 0x00000020 ++#define kG992NTREnabled 0x00000040 ++#define kG992p2EraseAllStoredProfiles 0x00000080 ++#define kG992p2FeaturesNPar2Mask 0x0000003B ++#define kG992p2FeaturesNPar2Shift 0 ++ ++#define kG992p1RACK1 0x00000100 ++#define kG992p1RACK2 0x00000200 ++#define kG992p1STM 0x00000800 ++#define kG992p1ATM 0x00001000 ++#define kG992p1ClearEOCOAM 0x00002000 ++#define kG992p1FeaturesNPar2Mask 0x00003B00 ++#define kG992p1FeaturesNPar2Shift 8 ++#define kG992p1DualLatencyUpstream 0x00004000 ++#define kG992p1DualLatencyDownstream 0x00008000 ++#define kG992p1HigherBitRates 0x40000000 ++ ++#if defined(G992P1_ANNEX_I) ++#define kG992p1HigherBitRates1over3 0x80000000 ++#define kG992p1AnnexIShapedSSVI 0x00000001 ++#define kG992p1AnnexIFlatSSVI 0x00000002 ++#define kG992p1AnnexIPilotFlag 0x00000008 ++#define kG992p1AnnexIPilot64 0x00000001 ++#define kG992p1AnnexIPilot128 0x00000004 ++#define kG992p1AnnexIPilot96 0x00000008 ++#define kG992p1AnnexIPilotA48B48 0x00000010 ++#endif ++ ++#define kG992p1AnnexBRACK1 0x00010000 ++#define kG992p1AnnexBRACK2 0x00020000 ++#define kG992p1AnnexBUpstreamTones1to32 0x00040000 ++#define kG992p1AnnexBSTM 0x00080000 ++#define kG992p1AnnexBATM 0x00100000 ++#define kG992p1AnnexBClearEOCOAM 0x00200000 ++#define kG992p1AnnexBFeaturesNPar2Mask 0x003F0000 ++#define kG992p1AnnexBFeaturesNPar2Shift 16 ++ ++#define kG992p1AnnexCRACK1 0x01000000 ++#define kG992p1AnnexCRACK2 0x02000000 ++#define kG992p1AnnexCDBM 0x04000000 ++#define kG992p1AnnexCSTM 0x08000000 ++#define kG992p1AnnexCATM 0x10000000 ++#define kG992p1AnnexCClearEOCOAM 0x20000000 ++#define kG992p1AnnexCFeaturesNPar2Mask 0x3F000000 ++#define kG992p1AnnexCFeaturesNPar2Shift 24 ++ ++#define kG992p1HigherBitRates1over3 0x80000000 ++ ++/* auxFeatures bitmap */ ++#define kG994p1PreferToExchangeCaps 0x00000001 ++#define kG994p1PreferToDecideMode 0x00000002 ++#define kG994p1PreferToMPMode 0x00000004 ++#define kAfePwmSyncClockShift 3 ++#define kAfePwmSyncClockMask (0xF << kAfePwmSyncClockShift) ++#define AfePwmSyncClockEnabled(val) (((val) & kAfePwmSyncClockMask) != 0) ++#define AfePwmGetSyncClockFreq(val) ((((val) & kAfePwmSyncClockMask) >> kAfePwmSyncClockShift) - 1) ++#define AfePwmSetSyncClockFreq(val,freq) ((val) |= ((((freq)+1) << kAfePwmSyncClockShift) & kAfePwmSyncClockMask)) ++ ++/* SubChannel Info bitMap for G992p1 */ ++#define kSubChannelASODownstream 0x00000001 ++#define kSubChannelAS1Downstream 0x00000002 ++#define kSubChannelAS2Downstream 0x00000004 ++#define kSubChannelAS3Downstream 0x00000008 ++#define kSubChannelLSODownstream 0x00000010 ++#define kSubChannelLS1Downstream 0x00000020 ++#define kSubChannelLS2Downstream 0x00000040 ++#define kSubChannelLS0Upstream 0x00000080 ++#define kSubChannelLS1Upstream 0x00000100 ++#define kSubChannelLS2Upstream 0x00000200 ++#define kSubChannelInfoOctet1Mask 0x0000001F ++#define kSubChannelInfoOctet2Mask 0x000003E0 ++#define kSubChannelInfoOctet1Shift 0 ++#define kSubChannelInfoOctet2Shift 5 ++ ++/****************************************************************************/ ++/* 3. Interface functions. */ ++/* */ ++/****************************************************************************/ ++ ++#ifdef G992P1 ++#if defined(G992P1_ANNEX_I2X) || defined(G992P5) ++/* lke */ ++#define kDslSamplingFreq 4416000 ++#define kDslMaxFFTSize 1024 ++#define kDslMaxFFTSizeShift 10 ++#elif defined(G992P1_ANNEX_I4X) ++#define kDslSamplingFreq 8832000 ++#define kDslMaxFFTSize 2048 ++#define kDslMaxFFTSizeShift 11 ++#elif defined(G992P1_ANNEX_I8X) ++#define kDslSamplingFreq 17664000 ++#define kDslMaxFFTSize 4096 ++#define kDslMaxFFTSizeShift 12 ++#else ++#define kDslSamplingFreq 2208000 ++#define kDslMaxFFTSize 512 ++#define kDslMaxFFTSizeShift 9 ++#endif ++#else ++#define kDslSamplingFreq 1104000 ++#define kDslMaxFFTSize 256 ++#define kDslMaxFFTSizeShift 8 ++#endif ++ ++#if defined(G992_ATUR_UPSTREAM_SAMPLING_FREQ_276KHZ) ++#define kDslATURUpstreamSamplingFreq 276000 ++#define kDslATURFFTSizeShiftUpstream 6 ++#elif defined(G992_ATUR_UPSTREAM_SAMPLING_FREQ_552KHZ) ++#define kDslATURUpstreamSamplingFreq 552000 ++#define kDslATURFFTSizeShiftUpstream 7 ++#else ++#define kDslATURUpstreamSamplingFreq kDslSamplingFreq ++#define kDslATURFFTSizeShiftUpstream kDslMaxFFTSizeShift ++#endif ++ ++#if defined(G992_ATUC_UPSTREAM_SAMPLING_FREQ_276KHZ) ++#define kDslATUCUpstreamSamplingFreq 276000 ++#define kDslATUCFFTSizeShiftUpstream 6 ++#elif defined(G992_ATUC_UPSTREAM_SAMPLING_FREQ_552KHZ) ++#define kDslATUCUpstreamSamplingFreq 552000 ++#define kDslATUCFFTSizeShiftUpstream 7 ++#else ++#define kDslATUCUpstreamSamplingFreq kDslSamplingFreq ++#define kDslATUCFFTSizeShiftUpstream kDslMaxFFTSizeShift ++#endif ++ ++#define kDslMaxSamplesPerSymbol (kDslMaxFFTSize+kDslMaxFFTSize/16) ++ ++#if defined(G992P1_ANNEX_I) || defined(G992P5) ++#define kDslMaxTEQLength 32 ++#else ++#define kDslMaxTEQLength 16 ++#endif ++ ++#define kDslMaxSymbolBlockSize 1 ++#define kDslMaxSampleBlockSize (kDslMaxSymbolBlockSize*kDslMaxSamplesPerSymbol) ++ ++#ifdef G992_ANNEXC ++#define kG992AnnexCXmtToRcvPathDelay 512 /* In samples at kDslSamplingFreq */ ++#endif ++ ++/*** For compatibility with existing test codes ***/ ++#if !defined(TARG_OS_RTEMS) ++typedef dslStatusCode modemStatusCode; ++typedef dslStatusStruct modemStatusStruct; ++typedef dslStatusHandlerType statusHandlerType; ++typedef dslCommandCode modemCommandCode; ++typedef dslCommandStruct modemCommandStruct; ++typedef dslCommandHandlerType commandHandlerType; ++#endif ++ ++extern void SM_DECL SoftDslSetRefData (void *gDslVars, ulong refData); ++extern ulong SM_DECL SoftDslGetRefData (void *gDslVars); ++extern int SM_DECL SoftDslGetMemorySize(void); ++extern void SM_DECL SoftDslInit (void *gDslVars); ++extern void SM_DECL SoftDslReset (void *gDslVars); ++extern void SM_DECL SoftDslLineHandler (void *gDslVars, int rxNSamps, int txNSamps, short *rcvPtr, short *xmtPtr) FAST_TEXT; ++extern Boolean SM_DECL SoftDslCommandHandler (void *gDslVars, dslCommandStruct *cmdPtr); ++ ++/* swap Lmem functions */ ++#if defined(bcm47xx) && defined(SWAP_LMEM) ++extern int SoftDslSwapLmem(void *gDslVars, int sectionN, int imageN); ++extern void init_SoftDslSwapLmem(void); ++#endif ++ ++/* SoftDsl time functions */ ++ ++extern ulong SM_DECL SoftDslGetTime(void *gDslVars); ++#define __SoftDslGetTime(gv) gDslGlobalVarPtr->execTime ++ ++extern void SM_DECL SoftDslTimer(void *gDslVars, ulong timeMs); ++ ++/* SoftDsl IO functions */ ++ ++extern void SM_DECL SoftDslClose (void *gDslVars); ++extern int SM_DECL SoftDslSendFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++extern int SM_DECL SoftDslReturnFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++ ++/* SoftDsl connection functions */ ++ ++extern void* SM_DECL SoftDslVcAllocate(void *gDslVars, dslVcParams *pVcParams); ++extern void SM_DECL SoftDslVcFree(void *gDslVars, void *pVc); ++extern Boolean SM_DECL SoftDslVcActivate(void *gDslVars, void *pVc); ++extern void SM_DECL SoftDslVcDeactivate(void *gDslVars, void *pVc); ++extern Boolean SM_DECL SoftDslVcConfigure(void *gDslVars, void *pVc, ulong mid, dslVcParams *pVcParams); ++ ++/* Special functions for LOG support */ ++ ++extern ulong SM_DECL SoftDslVc2Id(void *gDslVars, void *pVc); ++extern void* SM_DECL SoftDslVcId2Vc(void *gDslVars, ulong vcId); ++extern void* SM_DECL SoftDslGetFramePool(void *gDslVars); ++ ++/* Functions for host mode execution */ ++ ++extern void* SM_DECL SoftDslRxCellHeaderHandler (void *gDslVars, ulong hdr, uchar hdrHec); ++extern void* SM_DECL SoftDslRxCellDataHandler (void *gDslVars, int, void*); ++extern void* SM_DECL SoftDslTxCellHandler (void *gDslVars, int*, void*); ++extern Boolean SM_DECL SoftDslPhyCommandHandler (void *gDslVars, dslCommandStruct *cmdPtr); ++ ++/* Functions getting OEM parameters including G994 non standard info management */ ++ ++extern char* SM_DECL SoftDslGetTrainingVendorIDString(void *gDslVars); ++extern char* SM_DECL SoftDslGetVendorIDString(void *gDslVars); ++extern char* SM_DECL SoftDslGetSerialNumberString(void *gDslVars); ++extern char* SM_DECL SoftDslGetRevString(void *gDslVars); ++extern int SM_DECL SoftDslRevStringSize(void *gDslVars); ++extern int SM_DECL SoftDslSerNumStringSize(void *gDslVars); ++ ++extern void* SM_DECL SoftDslGetG994p1RcvNonStdInfo(void *gDslVars, ulong *pLen); ++extern void* SM_DECL SoftDslGetG994p1XmtNonStdInfo(void *gDslVars, ulong *pLen); ++ ++#ifdef G997_1_FRAMER ++ ++/* G997 functions */ ++ ++extern int SM_DECL SoftDslG997SendFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++extern int SM_DECL SoftDslG997ReturnFrame (void *gDslVars, void *pVc, ulong mid, dslFrame * pFrame); ++ ++#endif ++ ++#ifdef ADSL_MIB ++extern void * SM_DECL SoftDslMibGetData (void *gDslVars, int dataId, void *pAdslMibData); ++#endif ++ ++#define SoftDsl SoftDslLineHandler ++#define kSoftDslMaxMemorySize (32768*16384) ++ ++/* ++ * Internal functions ++ */ ++ ++extern void SoftDslStatusHandler (void *gDslVars, dslStatusStruct *status) FAST_TEXT; ++extern void SoftDslInternalStatusHandler (void *gDslVars, dslStatusStruct *status); ++ ++/* ++ * DSL OS functions ++ */ ++ ++#ifdef DSL_OS ++ ++#define SoftDslIsBgAvailable(gDslVars) (DSLOS_THREAD_INACTIVE == DslOsGetThreadState(&(gDslGlobalVarPtr->tcbDslBg))) ++#define SoftDslGetBgThread(gDslVars) \ ++ ((DSLOS_THREAD_INACTIVE != DslOsGetThreadState(&(gDslGlobalVarPtr->tcbDslBg))) ? &gDslGlobalVarPtr->tcbDslBg : NULL) ++#define SoftDslBgStart(gDslVars, pFunc) \ ++ DslOsCreateThread(&gDslGlobalVarPtr->tcbDslBg, DSLOS_PRIO_HIGHEST - 10, pFunc, gDslVars, \ ++ WB_ADDR(gDslGlobalVarPtr->bgStack), sizeof(gDslGlobalVarPtr->bgStack)) ++#define SoftDslBgStop(gDslVars) DslOsDeleteThread(&gDslGlobalVarPtr->tcbDslBg) ++ ++#define SoftDslEnterCritical() DslOsEnterCritical() ++#define SoftDslLeaveCritical(id) DslOsLeaveCritical(id) ++ ++#else ++ ++#define SoftDslIsBgAvailable(gDslVars) 1 ++#define SoftDslGetBgThread(gDslVars) 1 ++#define SoftDslBgStart(gDslVars, pFunc) (*pFunc)(gDslVars) ++#define SoftDslBgStop(gDslVars) ++ ++#define SoftDslEnterCritical() 0 ++#define SoftDslLeaveCritical(id) ++ ++#endif ++ ++/* ++ * DSL frames and native frame functions ++ */ ++ ++DslFrameDeclareFunctions (DslFrameNative) ++ ++/* ++ * These functions are for testing purpose, they are defined outside. ++ */ ++#ifdef STACK_SIZE_REQUIREMENT_TEST ++extern void StackSizeTestInitializeStackBeforeEntry(void); ++extern void StackSizeTestCheckStackAfterExit(void); ++extern void StackSizeTestBackupStack(void); ++extern void StackSizeTestRestoreStack(void); ++#endif /* STACK_SIZE_REQUIREMENT_TEST */ ++ ++#ifdef NEC_NSIF_WORKAROUND ++#define SoftDslGetG994NsStatus(gDslVars) (gDslGlobalVarPtr->G994NsStatus) ++#define SoftDslGetG994NsFailCounter(gDslVars) (gDslGlobalVarPtr->G994NsFailCounter) ++#endif ++ ++#endif /* SoftDslHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModem.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModem.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModem.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModem.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,3128 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftModem.h ++ * ++ * ++ * Description: ++ * This file contains the exported interface for SoftModem.c ++ * ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.16 $ ++ * ++ * $Id: SoftModem.h,v 1.16 2004/04/14 21:16:51 ilyas Exp $ ++ * ++ * $Log: SoftModem.h,v $ ++ * Revision 1.16 2004/04/14 21:16:51 ilyas ++ * Merged with the latest changes in ADSL driver ++ * ++ * Revision 1.15 2004/04/13 00:56:10 ilyas ++ * Merged the latest ADSL driver changes for RTEMS ++ * ++ * Revision 1.14 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.13 2003/02/22 05:07:11 ilyas ++ * Added VendorID for T1.413 mode ++ * ++ * Revision 1.12 2002/10/03 19:34:24 ilyas ++ * Added size for EOC serial number register ++ * ++ * Revision 1.11 2002/09/07 01:37:22 ilyas ++ * Added support for OEM parameters ++ * ++ * Revision 1.10 2001/12/13 02:25:34 ilyas ++ * Added definitions for G997 ++ * ++ * Revision 1.9 2001/11/30 05:56:34 liang ++ * Merged top of the branch AnnexBDevelopment onto top of the tree. ++ * ++ * Revision 1.7.2.2 2001/11/27 02:32:05 liang ++ * Combine vendor ID, serial #, and version number into SoftModemVersionNumber.c. ++ * ++ * Revision 1.7.2.1 2001/10/03 01:44:10 liang ++ * Merged with codes from main tree (tag SoftDsl_2_18). ++ * ++ * Revision 1.8 2001/09/21 19:19:01 ilyas ++ * Minor fixes for VxWorks build ++ * ++ * Revision 1.7 2000/07/17 21:08:16 lkaplan ++ * removed global pointer ++ * ++ * Revision 1.6 2000/05/03 04:09:11 ilyas ++ * Added ID for ATM log data ++ * ++ * Revision 1.5 2000/04/01 01:07:44 liang ++ * Changed file names and some module names. ++ * ++ * Revision 1.4 2000/03/02 20:18:12 ilyas ++ * Added test status code for ATM VC finished ++ * ++ * Revision 1.3 1999/08/05 20:02:11 liang ++ * Merged with the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.2 1999/01/27 22:19:08 liang ++ * Merge with SoftModem_3_1_02. ++ * Include SoftDsl.h conditionlly so that the test utilities from SoftModem ++ * can be used without major change. It can be merged easily to SoftModem. ++ * ++ * Revision 1.170 1998/12/22 00:52:52 liang ++ * Added auxFeatures bit kV8HoldANSamUntilDetCI. When it is set, ANSam won't be ++ * sent until CI is detected (normally ANSam will be sent after 200ms). This is ++ * useful in V34 half duplex fax mode. ++ * ++ * Revision 1.169 1998/12/19 04:46:52 mwg ++ * Added bits for fax/data calling tones ++ * ++ * Revision 1.168 1998/12/17 02:46:10 scott ++ * Removed overlay-related commands/statuses and added ++ * kSetTrainingDelayReductionCmd ++ * ++ * Revision 1.167 1998/12/12 03:17:42 scott ++ * Added overlay commands and statuses ++ * ++ * Revision 1.166 1998/12/02 05:34:23 mwg ++ * Fixed a problem with bong tone detection ++ * ++ * Revision 1.165 1998/11/26 00:22:44 yura ++ * Added two more log data types: modulatorInputData & modulatorOutputData ++ * ++ * Revision 1.164 1998/11/19 03:08:04 mwg ++ * Added kSetCallProgressParamsCmd ++ * ++ * Revision 1.163 1998/11/18 23:00:03 liang ++ * Added a separate command kLoopbackTestAutoRespEnableCmd to enable or disable ++ * the loopback test auto respond feature when the modem is already on-line. ++ * ++ * Revision 1.162 1998/11/13 20:50:21 scott ++ * SoftModemInternalStatusHandler is now SM_DECL as well ++ * ++ * Revision 1.161 1998/11/13 20:42:25 scott ++ * Added SM_DECL type to entrypoint functions ++ * ++ * Revision 1.160 1998/11/13 03:02:54 scott ++ * Added SoftModemTimer prototype. ++ * Also include V.8bis types if AT_COMMANDS_V8BIS is defined. ++ * ++ * Revision 1.159 1998/11/12 01:22:46 scott ++ * Increased number of AT registers to 46 ++ * ++ * Revision 1.158 1998/11/05 22:35:18 yura ++ * Added two more S-registers ++ * ++ * Revision 1.157 1998/11/05 03:09:54 mwg ++ * Added kLapmRetryFailed to the list of LAPM errors ++ * ++ * Revision 1.156 1998/11/05 00:13:20 liang ++ * Add new connectionInfo status kLoopbackSelfTestNewErrs to report ++ * new bit errors whenever it happens. ++ * ++ * Revision 1.155 1998/11/04 07:11:33 mwg ++ * Moved declaration for SoftModemATPrintf() to SoftModem.h ++ * ++ * Revision 1.154 1998/10/29 07:24:49 mwg ++ * *** empty log message *** ++ * ++ * Revision 1.153 1998/10/15 02:09:37 luisgm ++ * added separate data rate mask for Flex to dataPumpCapabilities structure ++ * ++ * Revision 1.152 1998/10/14 00:12:15 scott ++ * Added kMnpOOBFrameCmd and command.frameSpec ++ * ++ * Revision 1.151 1998/10/09 02:19:22 luisgm ++ * added FlexV8bisStruct member to dataPumpCapabilities struc to store flex v8bis info, added define for kFlexSkipV8bis ++ * ++ * Revision 1.150 1998/10/06 19:36:33 mwg ++ * Limited 56K rates to 53K ++ * ++ * Revision 1.149 1998/10/03 03:43:38 ilyas ++ * Added status codes for Audio ++ * ++ * Revision 1.148 1998/10/01 02:03:17 mwg ++ * Added external pulse dialer option ++ * ++ * Revision 1.147 1998/09/30 01:44:26 mwg ++ * Added new functions SoftModemGetWriteBufferSize() & SoftModemGetReadBufferSize() ++ * ++ * Revision 1.146 1998/09/22 03:44:38 scott ++ * Added ALWAYS_LONG_ALIGN() macro ++ * ++ * Revision 1.145 1998/09/21 21:49:22 scott ++ * Added logDataCodes for mnpDecoder(Input/Output)Data ++ * ++ * Revision 1.144 1998/08/31 22:57:21 luisgm ++ * added constants for Flex data rates + kFlexEventTRN2AFinished ++ * ++ * Revision 1.143 1998/08/18 05:09:53 mwg ++ * Increased AT command buffer size to 128 ++ * ++ * Revision 1.142 1998/08/18 03:45:54 ilyas ++ * Integrated Audio into V70 test ++ * ++ * Revision 1.141 1998/08/14 17:46:04 ilyas ++ * Integrated Audio and G729a ++ * ++ * Revision 1.140 1998/08/10 21:42:19 mwg ++ * Added space and mark parity ++ * ++ * Revision 1.139 1998/08/08 03:39:33 scott ++ * Moved the C6xDefs and PentiumDefs includes before the internal function ++ * prototypes (to permit their redefinitions) ++ * ++ * Revision 1.138 1998/08/07 20:37:27 yura ++ * Added new S-register for &T commands ++ * ++ * Revision 1.137 1998/08/01 05:22:09 mwg ++ * Implemented split memory model ++ * ++ * Revision 1.136 1998/07/22 02:12:22 liang ++ * Added self test mode for loopback test. ++ * ++ * Revision 1.135 1998/07/21 01:19:03 liang ++ * Changed loopback test command parameter interface to use regular modeSpec. ++ * ++ * Revision 1.134 1998/07/18 03:52:10 liang ++ * Added V54 loop 2 test for V22. ++ * ++ * Revision 1.133 1998/07/15 02:45:03 mwg ++ * Added new connection info code: kPCMSpectralShapingBits ++ * ++ * Revision 1.132 1998/07/15 00:18:48 liang ++ * Add special turn off command for V34 fax to handle different turn off procedures. ++ * ++ * Revision 1.131 1998/07/13 22:19:49 liang ++ * Add V8 CI detection status and ANSam disable aux feature. ++ * ++ * Revision 1.130 1998/07/08 17:09:13 scott ++ * Added USE_LONG_ALIGN; support for 6 and PentiumDefs.h files ++ * ++ * Revision 1.129 1998/07/03 23:28:13 mwg ++ * Added Fax Class 2 defines ++ * ++ * Revision 1.128 1998/07/03 23:17:33 mwg ++ * Insuread command/status structures are long aligned ++ * ++ * Revision 1.127 1998/06/23 16:48:01 mwg ++ * Fixed a longstanding problem typical for Win95 VxD: whenever new ++ * VxD is intalled the confuguration profile may not match the old one but ++ * since the crc is correct it is still being downloaded. To avoid the problem ++ * a crc for the version number was added to avoid confusion between profiles ++ * of different versions. ++ * ++ * Revision 1.126 1998/06/19 21:04:06 liang ++ * Add auxiliary feature bit kV90ServerNotDetSbarAfterJdbarFix. ++ * ++ * Revision 1.125 1998/06/11 22:48:14 liang ++ * Add kPCM28000bpsShift constant. ++ * ++ * Revision 1.124 1998/06/05 22:11:51 liang ++ * New V90 DIL works through data mode. ++ * ++ * Revision 1.123 1998/06/01 23:03:41 liang ++ * Add v90RcvdDilDiffData logging. ++ * ++ * Revision 1.122 1998/06/01 21:24:38 mwg ++ * Changed some of the names. ++ * ++ * Revision 1.121 1998/05/13 04:55:22 mwg ++ * Now passing the number of spectral shaping bits in aux features ++ * ++ * Revision 1.120 1998/05/13 02:53:13 liang ++ * Add field "value" to command param structure. ++ * ++ * Revision 1.119 1998/05/12 04:42:23 mwg ++ * Replaced some of the status messages ++ * ++ * Revision 1.118 1998/05/11 23:36:10 mwg ++ * Added 8000Hz symbol rate to the map ++ * ++ * Revision 1.117 1998/05/05 04:28:39 liang ++ * V90 works up to data mode first version. ++ * ++ * Revision 1.116 1998/04/21 09:36:45 mwg ++ * Fixed a few problems for 16Khz and added 32Khz. ++ * ++ * Revision 1.115 1998/04/17 22:33:54 liang ++ * Added V90 DIL for mu-law PCM. ++ * ++ * Revision 1.114 1998/04/15 22:36:39 mwg ++ * Added new parameters to kDialCmd to allow individual control of each ++ * DTMF group attenuation. ++ * ++ * Revision 1.113 1998/04/15 18:16:22 ilyas ++ * Integrated V.8bis and changed coding of LinkLayerType to bitMap ++ * ++ * Revision 1.112 1998/04/15 07:59:06 mwg ++ * Added new status codes for V.90 ++ * ++ * Revision 1.111 1998/04/11 00:29:16 mwg ++ * Fixed the warnings which appeared when Irix builds were upgraded to ++ * gcc 2.8.1 ++ * ++ * Revision 1.110 1998/04/11 00:25:01 ilyas ++ * More V.70 statuses ++ * ++ * Revision 1.109 1998/04/10 23:29:31 mwg ++ * Added new field to capabilities: dataRates56K ++ * ++ * Revision 1.108 1998/04/09 02:02:56 mwg ++ * Added status for Ja detection. ++ * ++ * Revision 1.107 1998/04/03 02:05:30 ilyas ++ * More V.70 commands added ++ * ++ * Revision 1.106 1998/04/02 06:15:39 mwg ++ * Added coding type (Mu-law/A-law) status reporting. ++ * ++ * Revision 1.105 1998/03/30 09:53:57 mwg ++ * Added definition for k56Flex modulation for future use. ++ * ++ * Revision 1.104 1998/03/27 17:56:09 ilyas ++ * Added definitions for V.70 ++ * ++ * Revision 1.103 1998/03/26 23:29:04 liang ++ * Added first version of IMD estimation. ++ * ++ * Revision 1.102 1998/03/20 04:37:26 mwg ++ * Increased the size of the nominal variance to 32 bit. ++ * ++ * Revision 1.101 1998/03/06 01:22:04 yura ++ * Improved Win95 VxD segmentation handling ++ * ++ * Revision 1.100 1998/03/06 01:06:18 liang ++ * Add initial version of V90 phase 1 and 2. ++ * ++ * Revision 1.99 1998/03/05 23:42:22 mwg ++ * (hxl) Implemented enable/disable call waiting command. ++ * ++ * Revision 1.98 1998/02/26 06:13:06 mwg ++ * Increased the number of AT S-registers to account for newly introduced ++ * S9 and S10. ++ * ++ * Revision 1.97 1998/02/25 18:18:25 scott ++ * Added v42bisCycleCount for V42BIS_THROUGHPUT_CONTROL ++ * ++ * Revision 1.96 1998/02/24 05:31:20 mwg ++ * Added stuff required by international version of AT command processor. ++ * ++ * Revision 1.95 1998/02/17 01:14:10 scott ++ * Reenabled sys/types.h for Linux builds ++ * ++ * Revision 1.94 1998/02/16 22:32:23 scott ++ * Changed copyright notice ++ * ++ * Revision 1.93 1998/02/16 22:17:44 scott ++ * Turned off include of sys/types.h for normal builds ++ * ++ * Revision 1.92 1998/02/16 21:53:28 scott ++ * Exclude sys/types.h for another compiler ++ * ++ * Revision 1.91 1998/02/09 18:24:10 scott ++ * Fixed ComplexShort type to work around bugs in MS and GreenHill compilers ++ * ++ * Revision 1.90 1998/01/27 01:37:36 mwg ++ * Added new log identifier for pcm infidelity data. ++ * ++ * Revision 1.89 1998/01/22 19:49:32 liang ++ * Add auxFeature bit kFaxV34HDXAllowAsymCtrlChan. ++ * ++ * Revision 1.88 1998/01/21 02:32:01 liang ++ * Add more V34 half duplex training progress codes. ++ * ++ * Revision 1.87 1997/12/23 03:28:25 liang ++ * Add more half duplex V34 related constants. ++ * ++ * Revision 1.86 1997/12/18 19:38:50 scott ++ * Added agcData log type. ++ * Added kDisableFaxFastClearDown demod capability ++ * ++ * Revision 1.85 1997/12/18 06:02:45 mwg ++ * Added a function to reenable DC offset tracking. ++ * ++ * Revision 1.84 1997/12/17 22:46:30 mwg ++ * Minor modifications to X2 escape status reporting. ++ * ++ * Revision 1.83 1997/12/16 06:49:45 mwg ++ * Implemented proper data rate reporting for PCM modem. ++ * ++ * Revision 1.82 1997/12/13 06:11:08 mwg ++ * Added X2 interface hooks ++ * ++ * Revision 1.81 1997/12/02 06:21:33 mwg ++ * Implemented kSetATRegister command. ++ * ++ * Revision 1.80 1997/11/27 02:11:41 liang ++ * Add code for half duplex V34 control channel. ++ * ++ * Revision 1.79 1997/11/19 19:52:48 guy ++ * Added constant to define V.34 half duplex operation ++ * ++ * Revision 1.78 1997/10/24 05:15:53 scott ++ * Added AGC and phase hit recovery to demodCapabilities ++ * ++ * Revision 1.77 1997/10/01 02:47:50 liang ++ * Add PCM interface. ++ * ++ * Revision 1.76 1997/09/29 15:48:04 yura ++ * Added #pragma statement for W95 Vxd ++ * ++ * Revision 1.75 1997/09/18 20:32:39 scott ++ * Do not include VxD support files if GENERATE_DEPENDENCIES is defined. ++ * ++ * Revision 1.74 1997/09/18 12:40:55 yura ++ * Removed #ifdef statments to be more robust ++ * ++ * Revision 1.73 1997/09/17 17:32:41 scott ++ * Do not include sys/types.h for 6 ++ * ++ * Revision 1.72 1997/08/08 00:53:48 mwg ++ * Added fields for LAP-M frames printout. ++ * Added fields in auxFeatures to pass preemphasis filter parameters ++ * to V.34 phase 3 when doing PTT testing. ++ * ++ * Revision 1.71 1997/08/06 03:41:45 yura ++ * Added a few includes and defines needed by Win 95 driver. ++ * ++ * Revision 1.70 1997/08/05 03:22:10 liang ++ * Add equalizer center tap adjustment calculation related constants. ++ * ++ * Revision 1.69 1997/07/29 02:44:19 mwg ++ * Added new field to dataPumpCapabilities structure. This field is not ++ * yet exposed to external interface and currently is only used to ++ * enable PTT testing. ++ * Added new commands: kStartDataModemPTTTestCmd & kStartDataModemLoopbackTestCmd ++ * ++ * Revision 1.68 1997/07/22 22:05:10 liang ++ * Change sample rate setup as a normal command. ++ * ++ * Revision 1.67 1997/07/21 23:23:30 liang ++ * Define SoftModemSetSampleRate as null when SAMPLE_RATE_CONVERSION is not defined. ++ * ++ * Revision 1.66 1997/07/21 22:38:36 liang ++ * Change sample rate converter structure so that sample rate can be changed ++ * on the fly (at very begining) to either 8KHz or 9600Hz. ++ * ++ * Revision 1.65 1997/07/21 20:22:01 mwg ++ * Added statusInfoData to the log identifiers. ++ * ++ * Revision 1.64 1997/07/16 20:40:07 scott ++ * Added multitone monitor fields ++ * ++ * Revision 1.63 1997/07/10 02:31:08 mwg ++ * 1. Added kRxFrameHDLCFlags detected status for the ++ * framingInfo. ++ * 2. Added kLapmMNPFrameDetected status to lapmStatusCode. ++ * 3. Increased the number of AT registers to 35 ++ * 4. Modified LinkLayerSpec structure in modemCommandStruc ++ * to provide the initial values of rxDataRate & ++ * txDataRate and RT delay for the cases when ++ * link layer is started *after* the data connection ++ * is established and the status snooper is unable ++ * to determine the rates and RT delay. ++ * 5. Added a few extra *empty* constant definitions for ++ * disabled features. ++ * ++ * Revision 1.62 1997/07/02 19:15:05 scott ++ * Added bits for Bel103 & Bel212 modulations. ++ * ++ * Revision 1.61 1997/07/02 05:15:16 mwg ++ * Added MNP code. ++ * ++ * Revision 1.60 1997/07/01 23:52:48 mwg ++ * Modified the record test setup to log and use all the commands. ++ * ++ * Revision 1.59 1997/06/25 19:11:26 mwg ++ * 1. Added new framingInfoCode values for Async framing error reporting; ++ * 2. Added a substructure to pass serial data format for kSetDTERate cmd; ++ * ++ * Revision 1.58 1997/05/28 02:05:08 liang ++ * Add PCM modem phase 2 codes. ++ * ++ * Revision 1.57 1997/05/12 21:55:08 liang ++ * Add call waiting tone detector module. ++ * ++ * Revision 1.56 1997/03/21 23:50:08 liang ++ * Added initial version of V8bis module to CVS tree. ++ * ++ * Revision 1.55 1997/03/19 18:35:05 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.54 1997/03/11 11:11:45 mwg ++ * Added code to report V42bis statistics. ++ * ++ * Revision 1.53 1997/03/04 06:21:08 mwg ++ * Added logging of most commands. ++ * ++ * Revision 1.52 1997/02/28 23:45:13 liang ++ * Added training progress status report kPhaseJitterDeactivated. ++ * ++ * Revision 1.51 1997/02/28 22:23:22 mwg ++ * Implemented the following features: ++ * - Cleardown for fax modulations V.27, V.29 V.17 ++ * - Rockwell compatible bitmap report (needed by a customer) ++ * ++ * Revision 1.50 1997/02/28 03:05:31 mwg ++ * Added more logging data types. ++ * ++ * Revision 1.49 1997/02/27 05:28:58 mwg ++ * Added RxFrameOK report. ++ * ++ * Revision 1.48 1997/02/27 01:48:53 liang ++ * Add kV8MenuDataWord1 and kV8MenuDataWord2 connectionInfo status. ++ * ++ * Revision 1.47 1997/02/24 02:30:27 mwg ++ * Added new log data: predictorErrData ++ * ++ * Revision 1.46 1997/02/22 03:00:22 liang ++ * Add echoCancelledSignalData. ++ * ++ * Revision 1.45 1997/02/21 01:26:42 liang ++ * Add six more bits for the Demodulator capabilities to deal with 2nd order ++ * time tracking & PLLs, as well as shorter NEEC & PFEEC, and front end HBF. ++ * ++ * Revision 1.44 1997/02/17 03:09:00 mwg ++ * Added LAPM statistics printout. ++ * ++ * Revision 1.43 1997/02/04 08:38:47 mwg ++ * Added dc cancelled samples printout. ++ * ++ * Revision 1.42 1997/01/29 21:40:28 mwg ++ * Changed the way timers work: now time is passed as Q4 ms instead of ticks. ++ * Completed the 8KHz front end implementation. ++ * Got rid of kSamplesPerSecond constant. ++ * ++ * Revision 1.41 1997/01/24 07:13:50 mwg ++ * Added new statuses for automoder. ++ * ++ * Revision 1.40 1997/01/23 02:03:08 mwg ++ * Replaced old sample rate conversion with the newer one. ++ * Still has to resolve the automoding issue. ++ * ++ * Revision 1.39 1997/01/21 00:55:04 mwg ++ * Added 8KHz front end functionality. ++ * ++ * Revision 1.38 1996/11/13 00:30:55 liang ++ * Add kAutoLoadReductionEnabled to demodCapabilities so that PFEEC, FEEC, IEEC ++ * can be disabled automatically, but for worst processor loading test they ++ * won't be disabled when this bit is not set. ++ * ++ * Revision 1.37 1996/11/07 23:07:18 mwg ++ * Rearranged global variables to allow V.17 short training. ++ * ++ * Revision 1.36 1996/09/17 23:55:05 liang ++ * Change kMaxDataBlockSize from 16 to 24 to handle high data rates. ++ * ++ * Revision 1.35 1996/09/05 19:43:39 liang ++ * Removed caller ID error status code kCallerIDUnknownMessageType, and ++ * added caller ID status codes kCallerIDUnknownMessage & kCallerIDWholeMessage. ++ * Changed the callerIDStatus report structure. ++ * ++ * Revision 1.34 1996/08/29 00:36:57 liang ++ * Added kLapmTxFrameStatus and kLapmRxFrameStatus. ++ * ++ * Revision 1.33 1996/08/27 22:56:01 liang ++ * Added kResetHardware status code. ++ * ++ * Revision 1.32 1996/08/23 23:35:35 liang ++ * Add kATDebugStatus and function SoftModemGetHybridDelay. ++ * ++ * Revision 1.31 1996/08/22 01:13:19 yg ++ * Added AT command processor. ++ * ++ * Revision 1.30 1996/08/12 21:46:47 mwg ++ * Added code to report capabilities. ++ * ++ * Revision 1.29 1996/08/10 01:59:59 mwg ++ * Added report of the sent rate sequence; ++ * ++ * Revision 1.28 1996/08/07 22:15:02 mwg ++ * Added new status reports: ++ * kRemoteFreqOffset ++ * kIEECDeactivated ++ * kPFEECDeactivated ++ * ++ * Revision 1.27 1996/06/27 05:15:48 mwg ++ * Added V.24 circuit status. ++ * ++ * Revision 1.26 1996/06/27 02:12:43 mwg ++ * Cleaned the code. ++ * ++ * Revision 1.25 1996/06/20 23:57:30 mwg ++ * Added new training progress status. ++ * ++ * Revision 1.24 1996/06/18 21:13:50 mwg ++ * Added trellis MSE data logging. ++ * ++ * Revision 1.23 1996/06/12 02:31:10 mwg ++ * Added new type: VeryLong ++ * ++ * Revision 1.22 1996/06/08 22:15:39 mwg ++ * Added new status report: kCleardownStarted ++ * Added new field for the features: kV34bisEnabled ++ * ++ * Revision 1.21 1996/05/31 00:29:11 liang ++ * Add feature bit kV34ExtraINFOPreamble. ++ * ++ * Revision 1.20 1996/05/30 23:28:31 mwg ++ * Replaced enums with #defines ++ * ++ * Revision 1.19 1996/05/25 00:38:27 mwg ++ * Added kProjectedDataRate training progress report. ++ * ++ * Revision 1.18 1996/05/24 23:27:15 mwg ++ * Added mode status codes. ++ * ++ * Revision 1.17 1996/05/10 05:39:59 liang ++ * Move the includes for DEBUG inside "ifndef SoftModemTypes" so that ++ * cap build won't break. ++ * ++ * Revision 1.16 1996/05/08 01:49:34 mwg ++ * Added capability to setup auxiliary data channel handlers. ++ * ++ * Revision 1.15 1996/05/07 22:51:08 liang ++ * Added group delay estimation and improved symbol rate selection process. ++ * ++ * Revision 1.14 1996/05/06 06:49:09 mwg ++ * Fixed linux problems. ++ * ++ * Revision 1.13 1996/05/02 08:40:16 mwg ++ * Merged in Chromatic bug fixes. ++ * ++ * Revision 1.12 1996/05/02 02:26:21 mwg ++ * Added code to implement dozing functionality for v.34. ++ * ++ * Revision 1.11 1996/05/01 22:43:13 mwg ++ * Added new command: kDozeCmd; ++ * ++ * Revision 1.10 1996/05/01 19:20:16 liang ++ * Add command codes kInitiateRetrainCmd and kInitiateRateRenegotiationCmd. ++ * ++ * Revision 1.9 1996/04/25 01:12:37 mwg ++ * Added new flag: rapid preliminary EC training. ++ * ++ * Revision 1.8 1996/04/20 02:26:22 mwg ++ * Added preliminary far-end echo support ++ * ++ * Revision 1.7 1996/04/15 23:26:16 mwg ++ * Changed flag definitions for v34 modem. ++ * ++ * Revision 1.6 1996/04/04 02:35:50 liang ++ * Change kCid from 0x0080 to 0x0004 (0x0080 is defined as kV32). ++ * ++ * Revision 1.5 1996/03/08 23:07:01 mwg ++ * Added name for the struct. ++ * ++ * Revision 1.4 1996/03/02 00:59:27 liang ++ * Added typedef for V34CodingParameters structure. ++ * ++ * Revision 1.3 1996/02/27 02:28:31 mwg ++ * Fixed a bug in kLapmLongADPEnabled definition. ++ * ++ * Revision 1.2 1996/02/19 23:50:59 liang ++ * Removed compressionSetup parameter from the link layer command structure. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.5 1996/01/15 23:26:04 liang ++ * Change the softmodem command structure name from SoftwareModemCommand ++ * to SoftwareModemCommandParameters. ++ * ++ *****************************************************************************/ ++#ifndef SoftModemPh ++#define SoftModemPh ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.1 General types */ ++/****************************************************************************/ ++ ++#ifndef SM_DECL ++#define SM_DECL ++#endif ++ ++#ifdef __VxWORKS__ ++#include ++#endif ++ ++#ifdef DEBUG ++/* We have to define __wchar_t for Linux */ ++#if defined __linux__ && !defined _NO_WHCAR_DEF_ ++typedef long int __wchar_t; ++#endif ++#if !defined(__KERNEL__) && !defined(_CFE_) ++#include ++#include ++#endif ++ ++#if defined(__linux__) || defined (__unix__) || defined (__unix) || (defined (__mips__) && !defined(_CFE_) && !defined(VXWORKS) && !defined(TARG_OS_RTEMS))/* enable if necessary, but not for dos-based builds */ ++#include ++#endif ++ ++ ++#endif /* DEBUG */ ++ ++#if defined(W95_DRIVER) ++#pragma code_seg("_LTEXT", "LCODE") ++#pragma data_seg("_LDATA", "LCODE") ++#pragma const_seg("_LDATA", "LCODE") ++#pragma bss_seg("_LDATA", "LCODE") ++#pragma pack(1) ++#endif /* W95_DRIVER */ ++ ++#ifndef SoftModemTypes ++#include "SoftModemTypes.h" ++#endif /* SoftModemTypes */ ++ ++ ++typedef struct ++ { ++ schar x, y; ++ } ComplexByte; ++ ++typedef struct ++ { ++ uchar numerator; ++ uchar denominator; ++ } Ratio; ++ ++#ifdef PEGASUS ++typedef union ++ { ++ struct ++ { ++ short x, y; ++ }; ++ ++ long foo; ++ } ComplexShort; ++#else ++typedef struct ++ { ++ short x, y; ++#ifdef GREENHILL ++ long a[0]; ++#endif ++ } ComplexShort; ++#endif ++ ++typedef struct ++ { ++ long x, y; ++ } ComplexLong; ++ ++typedef struct ++ { ++ ushort x0, x1, x2; ++ short x3; ++ } VeryLong; ++ ++typedef union ++ { ++ struct ++ { ++ uchar number; ++ uchar defaultValue; /* default value */ ++ uchar maxValue; /* max allowed value */ ++ uchar minValue; /* should be greater then maxValue to make reg readonly */ ++ } param; ++ long alignment; ++ } SRegisterDefinition; ++ ++#define MacroPaste2(a,b) a##b ++#define MacroPaste(a,b) MacroPaste2(a,b) ++#define ALWAYS_LONG_ALIGN() long MacroPaste(ALIGNMENT,__LINE__); ++ ++#ifdef USE_LONG_ALIGN ++#define LONG_ALIGN() ALWAYS_LONG_ALIGN() ++#else ++#define LONG_ALIGN() ++#endif ++ ++typedef ulong bitMap; ++ ++typedef int pace; ++#define kStop 0 ++#define kVerySlow 1 ++#define kSlow 2 ++#define kMedium 3 ++#define kFast 4 ++ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.2 Modem specific types */ ++/****************************************************************************/ ++ ++typedef long directionType; ++#define kXmt 0 ++#define kRcv 1 ++#define kXmtRcv 2 ++ ++ ++#define originating kXmt ++#define answering kRcv ++#define kOrg kXmt ++#define kAns kRcv ++#define kOrgAns kXmtRcv ++ ++#define ORIGINATING originating ++#define ANSWERING answering ++ ++typedef int pcmCodingType; ++#define kMuLawPCM 0 ++#define kALawPCM 1 ++ ++#define kMuLawPCMScaleShift 2 ++#define kALawPCMScaleShift 3 ++ ++/* link layer and framer share defines */ ++typedef bitMap framerType; ++typedef bitMap linkLayerType; ++#define kNoFramer 0 ++#define kSync 0x00000001 ++#define kAsync 0x00000002 ++#define kHDLC 0x00000004 ++#define kLapm 0x00000008 ++#define kMnp 0x00000010 ++#define kV70 0x00000020 ++#define kSAM 0x00000040 ++ ++ ++typedef bitMap modulationMap; ++typedef bitMap symbolRateMap; ++typedef bitMap dataRateMap; ++typedef bitMap featureMap; ++typedef bitMap breakType; ++ ++typedef bitMap audioType; ++#define kRawAudio 0 ++#define kAudioG729A 1 ++#define kAudioG729 2 ++#define kAudioG723 3 ++ ++ ++#ifndef ADSL_MODEM ++typedef long modemStatusCode; ++#endif ++ /* Information status Codes: 1-31 */ ++#define kSetSampleRate 1 ++#define kModulationKnown 2 ++#define kRxSymbolRate 3 ++#define kTxSymbolRate 4 ++#define kRxCarrierFreq 5 ++#define kTxCarrierFreq 6 ++#define kTxPreemphasisFilter 7 ++#define kTxPowerAdjustment 8 ++#define kRemoteTxPreemphasisFilter 9 ++#define kRemoteTxPowerAdjustment 10 ++#define kRxRateKnown 11 ++#define kTxRateKnown 12 ++#define kRxDataModeActive 13 ++#define kTxDataModeActive 14 ++#define kTxSignalCompleted 15 ++#define kDTMFSignalDetected 16 ++#define kModemSignalDetected 17 ++#define kCallProgressSignalDetected 18 ++#define kCustomSignalDetected 19 ++#define kFaxPreambleDetected 20 ++#define kV24CircuitStatusChange 21 ++#define kHookStateChange 22 ++#define kCallWaitingToneDetected 23 ++#define kMultiToneSignalDetected 24 ++#define kPulseShuntStateChange 25 ++#define kRingFrequency 26 ++ ++ ++ /* Warning status Codes: 32-64 */ ++#define kError 32 ++#define kV34Exception 33 ++#define kClearDownLocal 34 ++#define kClearDownRemote 35 ++#define kCarrierPresent 36 ++#define kCarrierLost 37 ++#define kRetrainingLocal 38 ++#define kRetrainingRemote 39 ++#define kRateRenegotiationLocal 40 ++#define kRateRenegotiationRemote 41 ++#define kFallbackStarted 42 ++#define kFallForwardStarted 43 ++#define kCleardownStarted 44 ++#define kIllegalCommand 45 ++ ++ /* Auxiliary status Codes: 64-.. */ ++#define kTrainingProgress 64 ++#define kConnectionInfo 65 ++#define kDialerStatus 66 ++#define kFramingInfo 67 ++#define kBreakReceived 68 ++#define kLapmStatus 69 ++#define kLapmParameter 70 ++#define kV42bisStatus 71 ++#define kCallerIDStatus 72 ++#define kIOStatus 73 ++#define kCapabilitiesStatus 74 ++#define kSpeakerStatus 75 ++#define kATProfileChanged 76 ++#define kATDebugStatus 77 ++#define kResetHardware 78 ++#define kV8bisStatus 79 ++#define kMnpStatus 80 ++#define kMnpParameter 81 ++#define kV70Status 82 ++#define kV70Parameter 83 ++#define kFaxClass2Status 84 ++#define kAudioStatus 85 ++#define kAudioParameter 86 ++#define kOverlayStatus 87 ++#define kCallerIDCircuitStatus 88 ++#define kV80Status 89 ++#define kV80Parameter 90 ++#define kLocalCountryChanged 91 ++#define kDTERateChanged 92 ++#define kATResponse 93 ++#define kFramerConfigured 94 ++#define kA8RStatus 95 ++#define kA8TStatus 96 ++#define kVersionStatus 97 ++ ++ /* Testing status codes: 128-... */ ++ /* These statuses are generated by modem test suit */ ++#define kTestFinished 128 ++#define kConnectivityTestFinished 129 ++#define kTestCheckSum 130 ++#define kLogFileControl 131 ++#define kTestAtmVcFinished 132 ++#define kTestClearEocFinished 133 ++#define kTestG997Finished 134 ++ ++typedef long modemErrorCode; ++#define kNoError 0 ++#define kErrorTimerExpired 1 ++#define kErrorNoSReceived 2 ++#define kErrorNoSbarReceived 3 ++ ++ ++typedef long dialerStatusCode; ++#define kDialCompleted 0 ++#define kNoDialToneDetected 1 ++#define kBongToneDetected 2 ++#define kNoBongToneDetected 3 ++#define kErrorIllegalDialModifier 5 ++#define kDialStarted 6 ++#define kExternalPulseDialDigit 7 ++ ++ ++typedef long framingInfoCode; ++#define kRxFrameOK 0 ++#define kRxFrameTooLong 1 ++#define kRxFrameCRCError 2 ++#define kTxFrameUnderrun 3 ++#define kRxFrameOverrun 4 ++#define kRxFrameAborted 5 ++#define kRxFrameParityError 6 ++#define kRxFrameFormatError 7 ++#define kRxFrameHDLCFlagsDetected 8 ++ ++ ++typedef long IOStatusCode; ++#define kRxDataReady 0 ++#define kRxBufferOverflow 1 ++#define kTxSpaceAvailable 2 ++#define kTxBufferEmpty 3 ++ ++typedef long capabilitiesStatusCode; ++#define kSymbolRates 0 ++#define kDataRates 1 ++#define kFeatures 2 ++#define kDemodCapabilities 3 ++#define kRateThresholdAdjustment 4 ++#define kXmtLevel 5 ++#define kHybridDelay 6 ++#define kAuxFeatures 7 ++ ++ ++typedef long A8TStatusCode; ++#define kA8TFinished 0 ++ ++typedef long callerIDStatusCode; ++#define kCallerIDError 0 ++#define kCallerIDChannelSeizureReceived 1 ++#define kCallerIDMarkSignalReceived 2 ++#define kCallerIDTime 3 ++#define kCallerIDTelnum 4 ++#define kCallerIDName 5 ++#define kCallerIDEnd 6 ++#define kCallerIDUnknownMessage 7 ++#define kCallerIDWholeMessage 8 ++ ++ ++typedef long callerIDErrorCode; ++#define kCallerIDNoError 0 ++#define kCallerIDMarkSignalError 1 ++#define kCallerIDTooManyMarkBits 2 ++#define kCallerIDMessageTooLong 3 ++#define kCallerIDChecksumError 4 ++ ++ ++typedef long connectionInfoCode; ++#define kRTDelay 1 ++#define kRxSignalLevel 2 ++#define kTimingOffset 3 ++#define kFreqOffset 4 ++#define kPhaseJitter 5 ++#define kSNR 6 ++#define kNearEchoLevel 7 ++#define kSER 8 ++#define kNearEndDelay 9 ++#define kFarEchoLevel 10 ++#define kL1L2SNRDifference 11 ++#define kDCOffset 12 ++#define kTotalRxPower 13 ++#define kRemoteFreqOffset 14 ++/* obsolete #define kV8MenuDataWord1 15 */ ++/* obsolete #define kV8MenuDataWord2 16 */ ++#define kPCMP2AnalogDetSNR 17 ++#define kPCMP2DigitalDetSNR 18 ++#define kPCMP2RBSDetSNR 19 ++#define kEqCenterTapOffset 20 ++#define kPCMPadValue 21 ++#define kPCMRBSMap 22 ++#define kPCMCodingType 23 ++#define kPCMSpectralShapingBits 24 ++#define kLoopbackSelfTestResult 25 ++#define kEyeQuality 26 ++#define kLoopbackSelfTestNewErrs 27 ++#define kV34EqlLengthStatus 28 ++#define kV34EqlOffsetStatus 29 ++#define kV8CallMenuData 30 ++#define kV8JointMenuData 31 ++#define kPCMClientIeecLengthStatus 32 ++#define kPCMClientIeecOffsetStatus 33 ++#define kSeamlessRateChange 34 ++ ++typedef long trainingProgressCode; ++#define kPeriodicalSignalDetected 0 ++#define kPhaseReversalDetected 1 ++#define kSignalStartDetected 2 ++#define kSignalEndDetected 3 ++#define kSSignalDetected 4 ++#define kSbarSignalDetected 5 ++#define kJ4SignalDetected 6 ++#define kJ16SignalDetected 7 ++#define kJprimeSignalDetected 8 ++#define kMPSignalDetected 9 ++#define kMPprimeSignalDetected 10 ++#define kMPSignalSent 11 ++#define kMPprimeSignalSent 12 ++#define kRateSignalDetected 13 ++#define kESignalDetected 14 ++#define kRateSignalSent 15 ++ ++#define kAutomodingTryModulation 16 ++#define kAutomodingCompleted 17 ++#define kRCFaxBitMapStatus 18 ++ ++#define kV8CIDetected 19 ++#define kV8ANSToneDetected 20 ++#define kV8ANSamDetected 21 ++#define kV8CMDetected 22 ++#define kV8JMDetected 23 ++#define kV8CJDetected 24 ++#define kV8Finished 25 ++ ++#define kV34Phase2Started 26 ++#define kV34Phase2INFOSequenceDetected 27 ++#define kV34Phase2NearEndEchoDetected 28 ++#define kV34Phase2L1Receiving 29 ++#define kV34Phase2L2Receiving 30 ++#define kV34Phase2Finished 31 ++#define kV34Phase3Started 32 ++#define kV34Phase3Finished 33 ++#define kV34Phase4Started 34 ++#define kV34Phase4Finished 35 ++#define kV34DecoderParameters 36 ++#define kV34EncoderParameters 37 ++ ++#define kMaxLocalRxDataRate 38 ++#define kMaxLocalTxDataRate 39 ++#define kMaxRemoteRxDataRate 40 ++#define kMaxRemoteTxDataRate 41 ++#define kProjectedDataRate 42 ++#define kFEECDeactivated 43 ++#define kIEECDeactivated 44 ++#define kPFEECDeactivated 45 ++#define kPhaseJitterDeactivated 46 ++ ++#define kPCMP2DetectedDigitalConnection 47 ++#define kPCMP2DetectedRBS 48 ++#define kX2DetectedPhase1Escape 49 ++ ++#define kStarted1200BpsTraining 50 ++#define kStarted2400BpsTraining 51 ++#define kUnscrambledOneDetected 52 ++#define kScrambled1200BpsOneDetected 53 ++#define kScrambled2400BpsOneDetected 54 ++#define kV22BisS1Detected 55 ++#define kV22InitiateLoop2Test 56 ++#define kV22RespondLoop2Test 57 ++#define kV22Loop2TestAlt01Detected 58 ++ ++#define kDataModemLoop1TestStarted 59 ++#define kDataModemLoop1TestFinished 60 ++#define kDataModemLoop2TestStarted 61 ++#define kDataModemLoop2TestFinished 62 ++#define kDataModemLoop3TestStarted 63 ++#define kDataModemLoop3TestFinished 64 ++#define kDataModemSelfLoopTestEnabled 65 ++ ++#define kPCMPhase3Started 70 ++#define kPCMPhase3Finished 71 ++#define kPCMPhase4Started 72 ++#define kPCMPhase4Finished 73 ++ ++#define kV90JaSignalDetected 74 ++#define kV90JdSignalDetected 75 ++#define kV90JdPrimeSignalDetected 76 ++#define kV90RSignalDetected 77 ++#define kV90RBarSignalDetected 78 ++#define kV90CPSignalDetected 79 ++ ++#define kV90CPtSignalSent 80 ++#define kV90CPSignalSent 81 ++#define kV90CPprimeSignalSent 82 ++ ++ ++#define kV34SeamlessRateChangeRequestSent 83 ++#define kV34SeamlessRateChangeUpdateSent 84 ++#define kV34SeamlessRateChangeRequestReceived 85 ++#define kV34SeamlessRateChangeUpdateReceived 86 ++#define kV34SeamlessRateChangeUpdateTimeout 87 ++ ++#define kV90JaSignalAcknowledged 88 ++ ++#define kV34HCtrlChanPPhDetected 100 ++#define kV34HCtrlChanMPhDetected 101 ++#define kV34HCtrlChanRatesKnown 102 ++#define kV34HDXCtrlChanBinary1Detected 103 ++#define kV34HDXPhase3Started 104 ++#define kV34HDXPhase3Finished 105 ++#define kV34HDXPrimChanBinary1Detected 106 ++#define kFlexEventTRN2AFinished 107 ++ ++#define kV32RanginigStarted 108 ++#define kV32RangingStarted 108 ++#define kV32RanginigFinished 109 ++#define kV32RangingFinished 109 ++ ++ ++typedef long lapmStatusCode; ++#define kLapmDisconnected 0 /* LAPM disconnected */ ++#define kLapmConnected 1 /* LAPM is connected */ ++#define kLapmV42ODPDetected 2 /* LAPM ODP is detected */ ++#define kLapmV42ADPDetected 3 /* LAPM V.42 ADP is detected */ ++#define kLapmUnknownADPDetected 4 /* LAPM Unsupported ADP is detected */ ++#define kLapmTimeout 5 /* LAPM Timeout */ ++#define kLapmMNPFrameDetected 6 /* LAPM detected MNP frame */ ++#define kLapmDPDetectionTimedOut 7 /* LAPM Unsupported ADP is detected */ ++#define kLapmError 8 /* LAPM Error */ ++#define kLapmTestResult 9 /* LAPM loopback test result */ ++#define kLapmTxFrameStatus 10 ++#define kLapmRxFrameStatus 11 ++#define kLapmTxStatistics 12 ++#define kLapmRxStatistics 13 ++ ++typedef long lapmTakedownReason; ++#define kLapmRemoteDisconnect 0 ++#define kLapmLocalDisconnect 1 ++#define kLapmCannotConnect 2 ++#define kLapmProtocolError 3 ++#define kLapmCompressionError 4 ++#define kLapmInactivityTimer 5 ++#define kLapmRetryFailed 6 ++ ++ ++typedef long lapmParameterCode; ++#define kLapmXmtK 0 ++#define kLapmRcvK 1 ++#define kLapmXmtN401 2 ++#define kLapmRcvN401 3 ++#define kLapmTESTSupport 4 ++#define kLapmSREJSupport 5 ++#define kLapmCompDir 6 ++#define kLapmCompDictSize 7 ++#define kLapmCompStringSize 8 ++ ++ ++typedef long lapmErrorCode; ++#define kLapmNoError 0 ++#define kLapmBufferOverflow 1 ++#define kLapmFrameTooLong 2 ++#define kLapmBadFrame 3 ++#define kLapmUnknownEvent 4 ++/* 6 is reserved for kLapmRetryFailed defined above */ ++ ++ ++typedef long lapmTestResultCode; ++#define kLapmTestPassed 0 ++#define kLapmTestRequestIgnored 1 ++#define kLapmTestAlreadyInProgress 2 ++#define kLapmTestNotSupported 3 ++#define kLapmTestFailed 4 ++ ++ ++typedef long v42bisStatusCode; ++#define kV42bisEncoderTransparentMode 0 /* V.42bis encoder transparent mode active */ ++#define kV42bisEncoderCompressedMode 1 /* V.42bis encoder compressed mode active */ ++#define kV42bisDecoderTransparentMode 2 /* V.42bis decoder transparent mode active */ ++#define kV42bisDecoderCompressedMode 3 /* V.42bis decoder compressed mode active */ ++#define kV42bisError 4 /* V.42bis error */ ++#define kV42bisEncoderStatistics 5 ++#define kV42bisDecoderStatistics 6 ++ ++ ++typedef long v42bisErrorCode; ++#define kV42bisUndefinedEscSequence 0 /* V.42bis undefined escape sequence */ ++#define kV42bisCodewordSizeOverflow 1 /* V.42bis codeword size overflow */ ++#define kV42bisUndefinedCodeword 2 /* V.42bis undefined codeword */ ++ ++typedef long mnpStatusCode; ++#define kMnpDisconnected 0 /* Mnp disconnected */ ++#define kMnpConnected 1 /* Mnp is connected */ ++#define kMnpFallback 2 /* Mnp is falling back to buffer mode */ ++#define kMnpError 3 /* Mnp Error */ ++#define kMnpTimeout 4 /* Mnp Timeout */ ++#define kMnpInvalidLT 5 /* Invalid LT received */ ++#define kMnpRetransmitFrame 6 ++#define kMnpNack 7 ++#define kMnpTxFrameStatus 8 ++#define kMnpRxFrameStatus 9 ++#define kMnpTxStatistics 10 ++#define kMnpRxStatistics 11 ++ ++typedef long mnpTakedownReason; ++#define kMnpRemoteDisconnect 0 ++#define kMnpLocalDisconnect 1 ++#define kMnpCannotConnect 2 ++#define kMnpProtocolError 3 ++#define kMnpCompressionError 4 ++#define kMnpInactivityTimer 5 ++#define kMnpRetryFailed 6 ++ ++ ++typedef long mnpParameterCode; ++#define kMnpProtocolLevel 0 ++#define kMnpServiceClass 1 ++#define kMnpOptimizationSupport 2 ++#define kMnpCompressionSupport 3 ++#define kMnpN401 4 ++#define kMnpK 5 ++ ++ ++typedef long mnpErrorCode; ++#define kMnpNoError 0 ++#define kMnpBufferOverflow 1 ++#define kMnpFrameTooLong 2 ++#define kMnpBadFrame 3 ++#define kMnpUnknownEvent 4 ++ ++ ++typedef long v70StatusCode; ++#define kV70Disconnected 0 /* V70 disconnected */ ++#define kV70Connected 1 /* V70 is connected */ ++#define kV70Error 2 /* V70 Error */ ++#define kV70Timeout 3 /* V70 Timeout */ ++#define kV70ChannelDown 4 /* V70 channel released */ ++#define kV70ChannelUp 5 /* V70 channel established */ ++#define kV70AudioChannelDown 6 /* V70 audio channel released */ ++#define kV70AudioChannelUp 7 /* V70 audio channel established */ ++#define kV70DataChannelDown 8 /* V70 data channel released */ ++#define kV70DataChannelUp 9 /* V70 data channel established */ ++#define kV70OOBChannelDown 10 /* V70 out-of-band channel released */ ++#define kV70OOBChannelUp 11 /* V70 out-of-band channel established */ ++#define kV70TxFrameStatus 12 ++#define kV70RxFrameStatus 13 ++#define kV70TxStatistics 14 ++#define kV70RxStatistics 15 ++#define kV70StateTransition 16 ++ ++typedef long v70TakedownReason; ++#define kV70RemoteDisconnect 0 ++#define kV70LocalDisconnect 1 ++#define kV70CannotConnect 2 ++#define kV70ProtocolError 3 ++#define kV70CompressionError 4 ++#define kV70InactivityTimer 5 ++#define kV70RetryFailed 6 ++ ++ ++typedef long v70ParameterCode; ++#define kV70SuspendResume 0 ++#define kV70CrcLength 1 ++#define kV70NumberOfDLCs 2 ++#define kV70uIH 3 ++ ++#define kV70LapmXmtK 10 ++#define kV70LapmRcvK 11 ++#define kV70LapmXmtN401 12 ++#define kV70LapmRcvN401 13 ++#define kV70LapmTESTSupport 14 ++#define kV70LapmSREJSupport 15 ++#define kV70LapmCompDir 16 ++#define kV70LapmCompDictSize 17 ++#define kV70LapmCompStringSize 18 ++ ++#define kV70AudioHeader 20 /* if audio header is present in audio frames */ ++#define kV70BlockingFactor 21 /* audio blocking factor (default 1) */ ++#define kV70SilenceSuppression 22 /* audio silence suppression */ ++ ++ ++ ++typedef long v70ErrorCode; ++#define kV70NoError 0 ++#define kV70BadFrame 1 ++ ++typedef long audioStatusCode; ++#define kAudioFramesLost 0 /* One or more audio frames were lost */ ++#define kAudioTxBufferOverflow 1 ++#define kAudioRxBufferOverflow 2 ++#define kAudioRxBufferUnderflow 3 ++ ++ ++typedef long v80StatusCode; ++#define kV80Disconnected 0 /* V80 disconnected */ ++#define kV80Connected 1 /* V80 is connected */ ++#define kV80Error 2 /* V80 Error */ ++#define kV80InBandStatus 3 /* V80 in-band SAM status */ ++#define kV80TxFrameStatus 12 ++#define kV80RxFrameStatus 13 ++#define kV80TxStatistics 14 ++#define kV80RxStatistics 15 ++ ++typedef long v80TakedownReason; ++#define kV80RemoteDisconnect 0 ++#define kV80LocalDisconnect 1 ++ ++typedef long v80ErrorCode; ++#define kV80NoError 0 ++#define kV80BadFrame 1 ++ ++typedef long overlayStatusCode; ++#define kOverlayBegin 0 /* DSP has halted */ ++#define kOverlayEnd 1 /* DSP has received entire overlay */ ++#define kOverlayElapsedTime 2 /* time elapsed(as viewed by datapump) during overlay */ ++#define kOverlayRecordingData 3 /* ms of data that we are recording */ ++#define kOverlayReplayingData 4 /* ms of data that we have replayed so far */ ++#define kOverlayReplayDone 5 /* playback is done */ ++ ++/* types for kOverlayRecording/ReplayingData */ ++#define kOverlayTxData 0 ++#define kOverlayRxData 1 ++ ++/* ++ * Rockwell faxmodem compatible bitmap (kRCFaxBitMapStatus) ++ */ ++#define kRCFaxFCD 0x01 ++#define kRCFaxP2 0x02 ++#define kRCFaxPN 0x04 ++#define kRCFaxDCD 0x08 ++#define kRCFaxTX 0x10 ++#define kRCFaxCTS 0x20 ++ ++ ++#ifndef ADSL_MODEM ++typedef long modemCommandCode; ++#endif ++ /* Basic Action commands 00-63 */ ++#define kIdleCmd 0 ++#define kStartFaxModemCmd 1 ++#define kStartDataModemCmd 2 ++#define kStartCallProgressMonitorCmd 3 ++#define kSendTonesCmd 4 ++#define kStartCallerIDRcvCmd 5 ++#define kSetLinkLayerCmd 6 ++#define kSetFramerCmd 7 ++#define kTestLinkLayerCmd 8 ++#define kIdleRcvCmd 9 ++#define kIdleXmtCmd 10 ++#define kSetStatusHandlerCmd 11 ++#define kSetEyeHandlerCmd 12 ++#define kSetLogHandlerCmd 13 ++#define kSendBreakCmd 14 ++#define kSendTestCmd 15 ++#define kDisconnectLinkCmd 16 ++#define kSetXmtGainCmd 17 ++#define kStartADSICmd 18 ++#define kSetHybridDelayCmd 19 ++#define kCleardownCmd 20 ++#define kInitiateRetrainCmd 21 ++#define kInitiateRateRenegotiationCmd 22 ++#define kDialToneIndicator 23 ++#define kSetRxDataHandler 24 /* not used yet */ ++#define kSetTxDataHandler 25 /* not used yet */ ++#define kSetAuxRxDataHandler 26 ++#define kSetAuxTxDataHandler 27 ++#define kRingIndicatorCmd 28 ++#define kDTERateIndicatorCmd 29 ++#define kStartV8bisCmd 30 ++#define kSendMultiTonesCmd 31 ++#define kSetMultiToneParamsCmd 32 ++#define kSetModemSampleRateCmd 33 ++#define kStartDataModemPTTTestCmd 34 ++#define kStartDataModemLoopbackTestCmd 35 ++#define kRingFrequencyCmd 36 ++#define kSetCallWaitingDetectorStateCmd 37 ++#define kV34HDXTurnOffCurrentModeCmd 38 ++#define kSetAudioCmd 39 ++#define kLoopbackTestAutoRespEnableCmd 40 ++#define kSetCallProgressParamsCmd 41 ++#define kSetTrainingDelayReductionCmd 42 ++#define kSetFaxECMPageBufferPtrCmd 43 ++#define kSetLineCurrentStateCmd 44 ++#define kSetFramerParameterCmd 45 ++#define kStartDozeCmd 46 ++#define kEndDozeCmd 47 ++#define kStartRingFrequencyDetectorCmd 48 ++#define kSetBufferingDelayAdjustmentCmd 49 ++ ++ /* Composite action commands 64-127 */ ++#define kDialCmd 64 ++#define kSendCallingToneCmd 65 ++#define kV24CircuitChangeCmd 66 ++#define kStartATModeCmd 67 ++#define kStopATModeCmd 68 ++#define kSetATRegister 69 ++#define kSetATRegisterLimits 70 ++#define kSetATIResponse 71 ++#define kEnableATDebugMode 72 ++#define kSetWhiteListEntry 73 ++#define kSetBlackListEntry 74 ++ ++#define kV70Setup 75 /* additional V70 configuration */ ++#define kEstablishChannel 76 /* Establish new link layer channel (V70) */ ++#define kReleaseChannel 77 /* Release link layer channel (V70) */ ++#define kWaitChannelEstablished 78 /* Wait for establishment of the new link layer channel (V70) */ ++ ++/* unused 79 */ ++#define kMnpOOBFrameCmd 80 ++#define kV80InBandCmd 81 /* V80 In-band commands */ ++#define kSetV250IdString 82 ++#define kSetInternationalTablesCmd 83 ++#define kConfigureCountryCmd 84 ++#define kConigureCountryCmd 84 ++#define kV8ControlCmd 85 ++#define kV8bisSendMessage 86 ++#define kSetHWIdCmd 87 ++#define kSetCodecIdCmd 88 ++#define kOverCurrentDetected 89 ++ ++ ++ ++typedef long v8ControlType; ++#define kEnableDTEControl 1 ++#define kSetV8ControlTimeout 2 ++#define kSetCIValue 3 ++#define kSetCMValue 4 ++#define kSetJMValue 5 ++#define kSendCJ 6 ++#define kSetCallFunctionCategory 7 ++ ++typedef long v250IdStringCode; ++#define kGMIString 1 ++#define kGMMString 2 ++#define kGMRString 3 ++#define kGSNString 4 ++#define kGOIString 5 ++ ++typedef long kCallProgressParameterCode; ++#define kModemSignalPowerThreshold 1 ++#define kDialtonePowerThreshold 2 ++#define kRingBackPowerThreshold 3 ++#define kBusyPowerThreshold 4 ++#define kReorderPowerThreshold 5 ++#define k2ndDTnPowerThreshold 6 ++#define kMinDialtoneTime 7 ++#define kDialtoneFreqRange 8 ++#define kRingBackFreqRange 9 ++#define kBusyFreqRange 10 ++#define kReorderFreqRange 11 ++#define k2ndDTnFreqRange 12 ++ ++ ++typedef long framerParameterCode; ++#define kSetHDLCLeadingFlags 0 ++#define kHDLCResetFlagDetection 1 ++#define kSyncFramerSetup 2 ++#define kHDLCSendCRC 3 ++#define kHDLCSendFlags 4 ++#define kHDLCSendAborts 5 ++ ++ ++typedef long logDataCode; ++#define eyeData 0 ++#define mseData 1 ++#define rxData 2 ++#define txData 3 ++#define neecData 4 ++#define eqlData 5 ++#define ieecData 6 ++#define feecData 7 ++#define eqlPllData 8 ++#define feecPllData 9 ++#define timingData 10 ++#define pjPhaseErrData 11 ++#define pjEstimateData 12 ++#define pjEstDiffData 13 ++#define pjCoefData 14 ++#define inputSignalData 15 ++#define outputSignalData 16 ++#define agcGainData 17 ++#define automoderData 18 ++#define v8CMData 19 ++#define v8JMData 20 ++#define inputAfterNeecData 21 ++#define eqlErrData 22 ++#define dpskMicrobitsData 23 ++#define v34P2LSamplesData 24 ++#define phaseSplittedLData 25 ++#define fftedLData 26 ++#define channelSNRData 27 ++#define noiseEstimateData 28 ++#define signalEstimateData 29 ++#define v34INFOData 30 ++#define v34ChanProbData 31 ++#define v34P2OutputData 32 ++#define v8ANSamDetectData 33 ++#define pFeecData 34 ++#define channelDelayData 35 ++#define timingOffsetData 36 ++#define trellisMSEData 37 ++#define interpolatedSignalData 38 ++#define dcCancelledSignalData 39 ++#define echoCancelledSignalData 40 ++#define predictorErrData 41 ++#define commandInfoData 42 ++#define unusedInfoData 43 ++#define atCommandInfoData 44 ++#define atResponseInfoData 45 ++#define hwTerminalTxData 46 ++#define hwTerminalRxData 47 ++#define statusInfoData 48 ++#define channelResponseData 49 ++#define channelImpulseRespData 50 ++#define x2PcmP1DetectorInData 51 ++#define x2PcmP1DetectorOutData 52 ++#define eqlRealData 53 ++#define ieecRealData 54 ++#define neecOutputData 55 ++#define precodedEqlOutputData 56 ++#define eqlRealErrData 57 ++#define idealEqlOutputData 58 ++#define agcData 59 ++#define pcmInfidelityData 60 ++#define v42bisCycleCount 61 ++#define pcmImdOffsetCoefData 62 ++#define pcmImdOffsetData 63 ++#define v90RcvdDilLongData 64 ++#define v90RcvdDilShortData 65 ++#define v90DilProducedData 66 ++#define pcmEncoderKbitsData 67 ++#define pcmEncoderMbitsData 68 ++#define pcmEncoderSbitsData 69 ++#define pcmDecoderKbitsData 70 ++#define pcmDecoderMbitsData 71 ++#define pcmDecoderSbitsData 72 ++#define v90CPorCPtData 73 ++#define mnpDecoderInputData 74 ++#define mnpDecoderOutputData 75 ++#define v42bisEncoderInputData 76 ++#define v42bisDecoderInputData 77 ++#define modulatorInputData 78 ++#define modulatorOutputData 79 ++#define encodedStatusData 80 ++#define blockFramerTxData 81 ++#define blockFramerRxData 82 ++#define framerTxData 83 ++#define framerRxData 84 ++#define dpskBasebandData 85 ++#define dpskBasebandLPFedData 86 ++#define dpskRealData 87 ++#define bandEdgeCorrectedSignalData 88 ++#define atmLogData 89 ++#define clearEocLogData 90 ++#define g997LogData 91 ++ ++ ++#define kLogDataDelimiter 0xFEFEFEFE ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.3 Handlers */ ++/****************************************************************************/ ++ ++typedef void (SM_DECL *rcvHandlerType) (void *gDslVars, int, short*); ++typedef void (SM_DECL *xmtHandlerType) (void *gDslVars, int, short*); ++typedef int (SM_DECL *xmtHandlerWithRtnValType) (void *gDslVars, int, short*); ++typedef void (SM_DECL *timerHandlerType) (void *gDslVars, long); ++typedef int (SM_DECL *interpolatorHandlerType) (void *gDslVars, int, short*, short*); ++typedef void (SM_DECL *controlHandlerType) (void *gDslVars, int); ++ ++typedef int (SM_DECL *txDataHandlerType) (void *gDslVars, int, uchar*); ++typedef int (SM_DECL *rxDataHandlerType) (void *gDslVars, int, uchar*); ++ ++typedef bitMap (SM_DECL *signalDetectorType) (void *gDslVars, int, long, long*); ++ ++ ++typedef void (SM_DECL *hookHandlerType) (void *gDslVars, Boolean); ++ ++typedef short* (SM_DECL *sampBuffPtrType) (void *gDslVars, int); ++ ++typedef void (SM_DECL *eyeHandlerType) (void *gDslVars, int, ComplexShort*); ++typedef void (SM_DECL *logHandlerType) (void *gDslVars, logDataCode, ...); ++ ++typedef void (SM_DECL *voidFuncType) (void *gDslVars); ++ ++typedef int (SM_DECL *txAudioHandlerType) (void *gDslVars, int, short*); ++typedef int (SM_DECL *rxAudioHandlerType) (void *gDslVars, int, short*); ++ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.4 Structures */ ++/****************************************************************************/ ++ ++/* ++ * AT command processor definitions ++ */ ++#define kATRegistersNumber 56 ++#define kFirstConfigurationRegister 500 ++#define kLastConfigurationRegister 515 ++#define kFirstInternationalRegister 516 ++#define kLastInternationalRegister 595 ++ ++ ++ ++#define kATMaxDialStringSize 128 ++typedef struct ++ { ++ struct ++ { ++ uchar loadNumber; /* Which profile to load upon powerup/reset */ ++ uchar countryCode; /* T.35 Country Code */ ++ uchar profile[2][kATRegistersNumber]; ++ uchar dialString[4][kATMaxDialStringSize + 1]; ++ } config; ++ ulong versionCode; ++ ulong crcCheckSum; ++ } NVRAMConfiguration; ++ ++/* Structure to hold international settings */ ++typedef struct ++ { ++ char *name; ++ int countryCode; ++ const SRegisterDefinition *userRegisters; ++ const ulong *configRegisters; ++ } CountryDescriptor; ++ ++/* ++ * V.34 coding parameters structure ++ */ ++ ++typedef struct ++ { ++ /* DO NOT CHANGE THE ORDER OF FIELDS IN THIS STRUCTURE! ++ * (Some assembly code depends on it!) If you ++ * must add fields, please do so at the bottom. ++ */ ++ ++ int symbolRateIndex, ++ dataRateIndex, ++ userSNRAdjustment; ++ Boolean auxChannel, ++ expConstellation, ++ precoding, ++ nonlinearCoding; ++ schar J, /* number of data frames in superframe */ ++ P, /* number of mapping frames in a data frame */ ++ r, /* number of high mapping frames in a data frame */ ++ b, /* number of data bits in a mapping frame */ ++ W, /* number of aux bits in a data frame */ ++ K, /* number of S bits in a mapping frame */ ++ q, /* number of Q bits in a 2D symbol */ ++ M; /* number of rings in shell mapping */ ++ long nominalVariance; /* the signal variance which gives 1e-2 BLER Q10 */ ++ int bitsPerDataFrame; ++ short quantRoundOff, ++ quantMask; ++ uchar nTrellisStates, ++ log2NTrellisStates; ++ short gain1xmt, ++ gain2xmt, ++ gain1rcv, ++ gain2rcv; ++ ushort bitInversionPattern; ++ } V34CodingParams; ++ ++typedef long v8bisStatusCode; ++typedef bitMap v8bisConnectionSetup; ++#if defined(V8BIS) || defined(AT_COMMANDS_V8BIS) ++#include "V8bisMainTypes.h" ++#endif ++ ++#define kMaxMultiTones 4 /* MultiTone: search for up to this many tones at once */ ++ ++#ifndef ADSL_MODEM ++typedef struct ++ { ++ modemStatusCode code; ++ union ++ { ++ long value; ++ long freq; ++ modemErrorCode error; ++ modulationMap modulation; ++ modulationMap modemSignal; ++ dataRateMap dataRate; ++ long dtmfSignal; ++ bitMap callProgressSignal; ++ bitMap customSignal; ++ void *ptr; ++ struct ++ { ++ long detected; ++ long numTones; ++ long tones[kMaxMultiTones]; ++ } multiToneInfo; ++ struct ++ { ++ v8bisStatusCode code; ++ long value; ++ } v8bisStatus; ++ struct ++ { ++ trainingProgressCode code; ++ long value; ++ } trainingInfo; ++ struct ++ { ++ long code; ++ long value; ++ } v24Circuit; ++ struct ++ { ++ trainingProgressCode code; ++ void* ptr; ++ } advancedTrainingInfo; ++ struct ++ { ++ capabilitiesStatusCode code; ++ long value; ++ } capabilitiesStatusInfo; ++ struct ++ { ++ connectionInfoCode code; ++ long value; ++ } connectionInfo; ++ struct ++ { ++ connectionInfoCode code; ++ int length; ++ uchar *ptr; ++ } advancedConnectionInfo; ++ struct ++ { ++ dialerStatusCode code; ++ long value; ++ long makeTime; ++ long breakTime; ++ } dialerStatus; ++ struct ++ { ++ long enabled; ++ long volume; ++ } speakerStatus; ++ framingInfoCode framingInfo; ++ IOStatusCode ioStatus; ++ struct ++ { ++ lapmStatusCode code; ++ union ++ { ++ long value; ++ lapmTakedownReason reason; ++ lapmErrorCode error; ++ lapmTestResultCode testResult; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ } param; ++ } lapmStatus; ++ struct ++ { ++ lapmParameterCode code; ++ long value; ++ } lapmParameter; ++ struct ++ { ++ v42bisStatusCode code; ++ union ++ { ++ long value; ++ v42bisErrorCode error; ++ struct ++ { ++ long nBytesIn; ++ long nBytesOut; ++ } statistic; ++ } param; ++ } v42bisStatus; ++ struct ++ { ++ mnpStatusCode code; ++ union ++ { ++ long value; ++ mnpTakedownReason reason; ++ mnpErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ ulong nSize; ++ uchar *Buffer; ++ } fallback; ++ struct ++ { ++ char *header; ++ void *frame; ++ } frame; ++ struct ++ { ++ long nack; ++ long rFrameNo; ++ } timeout; ++ struct ++ { ++ long frameNo; ++ long framesPending; ++ } retrFrame; ++ } param; ++ } mnpStatus; ++ struct ++ { ++ mnpParameterCode code; ++ long value; ++ } mnpParameter; ++ struct ++ { ++ v70StatusCode code; ++ union ++ { ++ long value; ++ v70TakedownReason reason; ++ v70ErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long nack; ++ long rFrameNo; ++ } timeout; ++ struct ++ { ++ long frameNo; ++ long framesPending; ++ } retrFrame; ++ struct ++ { ++ long ChannelId; ++ long DLCI; ++ ulong LcNum; ++ v70TakedownReason reason; ++ } channelInfo; ++ struct ++ { ++ long ChannelId; ++ long stateOld; ++ long stateNew; ++ } stateInfo; ++ } param; ++ ulong v70Time; ++ } v70Status; ++ struct ++ { ++ audioStatusCode code; ++ union ++ { ++ long value; ++ struct ++ { ++ long nReq; ++ long nAvail; ++ } buffer; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ } param; ++ } audioStatus; ++ struct ++ { ++ v80StatusCode code; ++ union ++ { ++ long value; ++ v80TakedownReason reason; ++ v80ErrorCode error; ++ struct ++ { ++ long nFrames; ++ long nFrameErrors; ++ } statistic; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frame; ++ struct ++ { ++ long code; ++ long value; ++ } inBand; ++ } param; ++ ulong v80Time; ++ } v80Status; ++ struct ++ { ++ v70ParameterCode code; ++ long value; ++ } v70Parameter; ++ struct ++ { ++ breakType type; ++ long length; ++ } breakStatus; ++ struct ++ { ++ callerIDStatusCode code; ++ union ++ { ++ long value; ++ struct ++ { ++ callerIDErrorCode code; ++ long value; ++ } callerIDError; ++ struct ++ { ++ long length; ++ char* ptr; ++ } message; ++ } param; ++ } callerIDStatus; ++ struct ++ { ++ ulong signal; ++ uchar *msg1; ++ long msg1Length; ++ uchar *msg2; ++ long msg2Length; ++ } A8RStatus; ++ struct ++ { ++ overlayStatusCode code; ++ long value; ++ long value2; ++ } overlayStatus; ++ struct ++ { ++ ulong nBits; ++ ulong nBlocks; ++ ulong nBitErrors; ++ ulong nBlockErrors; ++ ++ ulong nAudioBits; ++ ulong nAudioBlocks; ++ ulong nAudioSyncErrors; ++ ulong nAudioBlockErrors; ++ } testResults; ++ ulong checksum; ++ struct ++ { ++ ulong sizeM; ++ uchar *filename; ++ } logFileControlStatus; ++ struct ++ { ++ long direction; ++ long module; ++ long message; ++ long data; ++ } ++ faxClass2Status; ++ ++ } param; ++ } modemStatusStruct; ++ ++typedef void (SM_DECL *statusHandlerType) (void *gDslVars, modemStatusStruct*); ++#endif /* ADSL_MODEM */ ++ ++/****************************************************************************/ ++/* 1. Type definitions. */ ++/* */ ++/* 1.5 Command structure */ ++/****************************************************************************/ ++ ++typedef struct ++ { ++ Boolean remoteModemIsFlex; ++ uchar countryCode; ++ ushort manufacturerId; ++ uchar licenseeId; ++ uchar productCapabilities; ++ Boolean digitalModeFlag; ++ Boolean prototypeFlag; ++ uchar version; ++ } ++FlexV8bisStruct; ++ ++typedef struct ++ { ++ symbolRateMap symbolRates; ++ dataRateMap dataRates; ++ dataRateMap dataRates56k; ++ dataRateMap dataRatesFlex; ++ featureMap features; ++ bitMap auxFeatures; ++ bitMap demodCapabilities; ++ long rateThresholdAdjustment; /* dB Q4 */ ++ FlexV8bisStruct flexRemoteV8bisInfo; ++ } dataPumpCapabilities; ++ ++#ifndef ADSL_MODEM ++typedef struct SoftwareModemCommandParameters ++ { ++ modemCommandCode command; ++ union ++ { ++ long xmtGain; ++ ulong hybridDelayQ4ms; ++ long modemSampleRate; ++ long timeInMs; ++ long state; ++ long freq; ++ NVRAMConfiguration *nvramConfigurationPtr; ++ long enabled; ++ long value; ++ uchar *phoneNumber; ++ uchar *faxECMPageBufferPtr; ++ CountryDescriptor *countryDescriptorTable; ++ struct ++ { ++ dataRateMap dteRate; ++ bitMap format; ++ } dteRateSpec; ++ struct ++ { ++ v8ControlType code; ++ long value; ++ uchar *buffer; ++ } v8ControlSpec; ++ struct ++ { ++ directionType direction; ++ v8bisConnectionSetup setup; ++ void *capPtr; ++ voidFuncType confirmMsFunc; ++ voidFuncType genMsFunc; ++ xmtHandlerWithRtnValType ogmFunc; ++ } v8bisSpec; ++ struct ++ { ++ directionType direction; ++ } ADSISpec; ++ struct ++ { ++ directionType direction; ++ modulationMap modulations; ++ dataPumpCapabilities capabilities; ++ } modeSpec; ++ struct ++ { ++ long time, ++ freq1, ++ freq2, ++ freq3, ++ freq4, ++ mag1, ++ mag2, ++ mag3, ++ mag4; ++ } toneSpec; ++ struct ++ { ++ long signal; ++ uchar *msg1; ++ long msg1Length; ++ uchar *msg2; ++ long msg2Length; ++ long sig_en; ++ long msg_en; ++ long supp_delay; ++ } ++ v8bisMessageSpec; ++ struct ++ { ++ linkLayerType type; ++ bitMap setup; ++ dataRateMap rxDataRate; ++ dataRateMap txDataRate; ++ long rtDelayQ4ms; ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } linkLayerSpec; ++ struct ++ { ++ framerType type; ++ bitMap setup; ++ directionType direction; ++ long fill[2]; /* need to match linkLayerSpec */ ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } framerSpec; ++ struct ++ { ++ framerParameterCode code; ++ long value; ++ } framerParameterSpec; ++ struct ++ { ++ bitMap callProgressDetectorSetup; ++ signalDetectorType callProgressDetectorPtr; /* if nil, use defaults */ ++ signalDetectorType customDetectorPtr; /* if nil, no custom detector */ ++ } callProgressMonitorSpec; ++ struct ++ { ++ ulong maxTones; /* maximum number of simultaneous tones to detect */ ++ ulong allowableVariance; /* maximum cumulative variance in the eight interpolated frequencies */ ++ ulong totalPowerThreshold; /* ignore complete block if power less than this */ ++ ulong powerShiftThreshold; /* ignore a bin if its power is less than (totalPowerValue >> powerShiftThreshold) */ ++ ulong toneMatchThresholdHz; /* tones within +/- this many Hz of original tone are considered the same tone */ ++ ulong binSeparation; /* ignore tones with a spacing of less than this */ ++ ulong outsideFreqDeviation; /* an individual value in the interpolated array can be up to this many Hz outside of the expected angle range */ ++ } multiToneSpec; ++ struct ++ { ++ uchar *dialString; /* nil limited string for DTMF dialing sequence */ ++ long pulseBreakTime, ++ pulseMakeTime, ++ pulseInterDigitTime, ++ toneDigitTime, ++ toneInterDigitTime, ++ toneLoGroupMag, ++ toneHiGroupMag, ++ flashTime, ++ pauseTime, ++ signalWaitTimeout, ++ blindDialingTimeout; ++ bitMap dialerSetup; ++ bitMap callProgressDetectorSetup; ++ signalDetectorType callProgressDetectorPtr; /* if nil, use defaults */ ++ signalDetectorType customDetectorPtr; /* if nil, no custom detector */ ++ hookHandlerType hookHandlerPtr; /* nil if DTMF dialing specified*/ ++ } dialSpec; ++ struct ++ { ++ long timeOn, ++ timeOff, ++ freq; ++ } callingToneSpec; ++ union ++ { ++ statusHandlerType statusHandlerPtr; ++ eyeHandlerType eyeHandlerPtr; ++ logHandlerType logHandlerPtr; ++ rxDataHandlerType rxDataHandlerPtr; ++ txDataHandlerType txDataHandlerPtr; ++ } handlerSpec; ++ struct ++ { ++ breakType type; ++ long length; ++ } breakSpec; ++ struct ++ { ++ long length; ++ uchar *dataPtr; ++ } lapmTestSpec; ++ struct ++ { ++ bitMap setupLapm; ++ rxDataHandlerType rxAudioHandlerPtr; ++ txDataHandlerType txAudioHandlerPtr; ++ } v70SetupSpec; ++ struct ++ { ++ ulong ChannelId; ++ ulong LogChannelNum; ++ ulong PortNum; ++ } EstChannelSpec; ++ struct ++ { ++ ulong ChannelId; ++ } WaitChannelSpec; ++ struct ++ { ++ ulong ChannelId; ++ ulong LogChannelNum; ++ ulong PortNum; ++ ulong DLCI; ++ } RelChannelSpec; ++ struct ++ { ++ audioType type; ++ bitMap setup; ++ dataRateMap rxAudioRate; ++ dataRateMap txAudioRate; ++ rxAudioHandlerType rxAudioHandlerPtr; ++ txAudioHandlerType txAudioHandlerPtr; ++ } audioSpec; ++ struct ++ { ++ long code; ++ long value; ++ } v24Circuit; ++ struct ++ { ++ ulong code; ++ ulong value; ++ ulong minValue; ++ ulong maxValue; ++ } atRegister; ++ struct ++ { ++ long code; ++ uchar *response; ++ } atiSpec; ++ struct ++ { ++ long length; ++ uchar *framePtr; ++ } frameSpec; ++ struct ++ { ++ long code; ++ union ++ { ++ long value; ++ struct ++ { ++ long loFreq1; ++ long hiFreq1; ++ long loFreq2; ++ long hiFreq2; ++ } freqRange; ++ } params; ++ } callProgressParamSpec; ++ struct ++ { ++ v250IdStringCode v250IdCode; ++ uchar *v250IdString; ++ } v250IdSpec; ++ ++ } param; ++ } modemCommandStruct; ++ ++typedef Boolean (*commandHandlerType) (modemCommandStruct*); ++#endif /* ADSL_MODEM */ ++ ++ ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.1 Definitive constants */ ++/****************************************************************************/ ++ ++#define kMaxSampleBlockSize 48 ++#define kMaxDataBlockSize 48 ++ ++#define kMaxDialStringLength 127 ++#define kCallProgressSampleRate 7200 ++ ++#define kMaxCallerIDMessageLength 80 ++ ++/****************************************************************************/ ++/* 2. Constant definitions. */ ++/* */ ++/* 2.2 Bit maps */ ++/****************************************************************************/ ++ ++/* modulationMap */ ++ ++#define kIdle 0x00000000 ++#define kV25 0x00000001 ++#define kV8 0x00000002 ++#define kCid 0x00000004 ++#define kV8bis 0x00000008 ++#define kV21 0x00000010 ++#define kV22 0x00000020 ++#define kV23 0x00000040 ++#define kV32 0x00000080 ++#define kV34 0x00000100 ++#define kX2 0x00000200 ++#define kV90 0x00000400 ++#define k56Flex 0x00000800 ++#define kV27 0x00001000 ++#define kV29 0x00002000 ++#define kV17 0x00004000 ++#define kV34HDX 0x00008000 ++#define kV34HDXC 0x00010000 ++#define kBell103 0x00100000 ++#define kBell212 0x00200000 ++#define kDataCallingTone 0x01000000 ++#define kFaxCallingTone 0x02000000 ++ ++#define kV22FastNZConnect 0x04000000 ++#define kV22FastNNZConnect 0x08000000 ++#define kV22FastConnect (kV22FastNZConnect|kV22FastNNZConnect) ++#define kV22bisFastConnect 0x10000000 ++ ++ ++#define kDataModulations (kV25 | kV8 | kV21 | kV22FastConnect | kV22bisFastConnect | kV22 | kV23 | kV32 | kV34 | kBell103 | kBell212) ++#define kDataOnlyModulations (kV21 | kV22 | kV23 | kV32 | kBell103 | kBell212) ++#define kPCMModulations (kV90 | kX2 | k56Flex) ++ ++#define kFaxModulations (kV25 | kV21 | kV27 | kV29 | kV17) ++#define kFaxOnlyModulations (kV27 | kV29 | kV17) ++#define kFaxModulationShift 12 ++ ++/* symbolRateMap */ ++ ++#define k1200Hz 0x00000001 ++#define k1600Hz 0x00000002 ++#define k2400Hz 0x00000004 ++#define k2743Hz 0x00000008 ++#define k2800Hz 0x00000010 ++#define k3000Hz 0x00000020 ++#define k3200Hz 0x00000040 ++#define k3429Hz 0x00000080 ++#define k8000Hz 0x00000100 ++ ++#define kAllSymbolRates ( k1200Hz | k1600Hz | k2400Hz | k2743Hz | \ ++ k2800Hz | k3000Hz | k3429Hz | k8000Hz ) ++ ++/* dataRateMap */ ++ ++#define k75bps 0x00000002 ++#define k300bps 0x00000004 ++#define k600bps 0x00000008 ++#define k1200bps 0x00000010 ++#define k2400bps 0x00000020 ++#define k4800bps 0x00000040 ++#define k7200bps 0x00000080 ++#define k9600bps 0x00000100 ++#define k12000bps 0x00000200 ++#define k14400bps 0x00000400 ++#define k16800bps 0x00000800 ++#define k19200bps 0x00001000 ++#define k21600bps 0x00002000 ++#define k24000bps 0x00004000 ++#define k26400bps 0x00008000 ++#define k28800bps 0x00010000 ++#define k31200bps 0x00020000 ++#define k33600bps 0x00040000 ++#define k36000bps 0x00080000 ++#define k38400bps 0x00100000 ++#define k57600bps 0x00200000 ++#define k115200bps 0x00400000 ++#define k230400bps 0x00800000 ++#define k460800bps 0x01000000 ++#define k921600bps 0x02000000 ++/* ++ * kPCMRate is used to identify that the reported rate is ++ * PCM modulation rate, and is only used for PCM modulation while ++ * reporting rate !!!! ++ */ ++#define kPCMRate 0x40000000 ++#define kPCMFlexRate 0x80000000 ++#define kAllDataRates 0x0FFFFFFF ++ ++/* rates specific for X2 and V.90 */ ++#define kPCM25333bps 0x00000001 ++#define kPCM26666bps 0x00000002 ++#define kPCM28000bps 0x00000004 ++#define kPCM29333bps 0x00000008 ++#define kPCM30666bps 0x00000010 ++#define kPCM32000bps 0x00000020 ++#define kPCM33333bps 0x00000040 ++#define kPCM34666bps 0x00000080 ++#define kPCM36000bps 0x00000100 ++#define kPCM37333bps 0x00000200 ++#define kPCM38666bps 0x00000400 ++#define kPCM40000bps 0x00000800 ++#define kPCM41333bps 0x00001000 ++#define kPCM42666bps 0x00002000 ++#define kPCM44000bps 0x00004000 ++#define kPCM45333bps 0x00008000 ++#define kPCM46666bps 0x00010000 ++#define kPCM48000bps 0x00020000 ++#define kPCM49333bps 0x00040000 ++#define kPCM50666bps 0x00080000 ++#define kPCM52000bps 0x00100000 ++#define kPCM53333bps 0x00200000 ++#define kPCM54666bps 0x00400000 ++#define kPCM56000bps 0x00800000 ++#define kPCM57333bps 0x01000000 ++ ++#define kV90ServerToClientDataRates \ ++ ( kPCM28000bps | kPCM29333bps | kPCM30666bps | \ ++ kPCM32000bps | kPCM33333bps | kPCM34666bps | \ ++ kPCM36000bps | kPCM37333bps | kPCM38666bps | \ ++ kPCM40000bps | kPCM41333bps | kPCM42666bps | \ ++ kPCM44000bps | kPCM45333bps | kPCM46666bps | \ ++ kPCM48000bps | kPCM49333bps | kPCM50666bps | \ ++ kPCM52000bps | kPCM53333bps | kPCM54666bps | \ ++ kPCM56000bps | kPCM57333bps ) ++ ++#define kV90ClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | \ ++ k14400bps | k16800bps | k19200bps | k21600bps | \ ++ k24000bps | k26400bps | k28800bps | k31200bps | \ ++ k33600bps ) ++ ++ ++ ++#define kX2ServerToClientDataRates \ ++ ( kPCM25333bps | kPCM26666bps | kPCM28000bps | \ ++ kPCM29333bps | kPCM30666bps | kPCM32000bps | \ ++ kPCM33333bps | \ ++ kPCM34666bps | kPCM36000bps | kPCM37333bps | \ ++ kPCM38666bps | kPCM40000bps | kPCM41333bps | \ ++ kPCM42666bps | kPCM44000bps | kPCM45333bps | \ ++ kPCM46666bps | kPCM48000bps | kPCM49333bps | \ ++ kPCM50666bps | kPCM52000bps | kPCM53333bps | \ ++ kPCM54666bps | kPCM56000bps | kPCM57333bps ) ++#define kX2ClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | k14400bps | \ ++ k16800bps | k19200bps | k21600bps | k24000bps | k26400bps | k28800bps | \ ++ k31200bps ) ++ ++ /* ++ Rates specific for Flex ++ */ ++#define kPCMFlex32000bps 0x00000001 ++#define kPCMFlex34000bps 0x00000002 ++#define kPCMFlex36000bps 0x00000004 ++#define kPCMFlex38000bps 0x00000008 ++#define kPCMFlex40000bps 0x00000010 ++#define kPCMFlex42000bps 0x00000020 ++#define kPCMFlex44000bps 0x00000040 ++#define kPCMFlex46000bps 0x00000080 ++#define kPCMFlex48000bps 0x00000100 ++#define kPCMFlex50000bps 0x00000200 ++#define kPCMFlex52000bps 0x00000400 ++#define kPCMFlex54000bps 0x00000800 ++#define kPCMFlex56000bps 0x00001000 ++#define kPCMFlex58000bps 0x00002000 ++#define kPCMFlex60000bps 0x00004000 ++ ++#define kFlexServerToClientDataRates \ ++ ( kPCMFlex32000bps | kPCMFlex34000bps | kPCMFlex36000bps | kPCMFlex38000bps | \ ++ kPCMFlex40000bps | kPCMFlex42000bps | kPCMFlex44000bps | kPCMFlex46000bps | \ ++ kPCMFlex48000bps | kPCMFlex50000bps | kPCMFlex52000bps | kPCMFlex52000bps | \ ++ kPCMFlex54000bps | kPCMFlex56000bps | kPCMFlex58000bps | kPCMFlex60000bps ) ++ ++#define kFlexClientToServerDataRates \ ++ ( k4800bps | k7200bps | k9600bps | k12000bps | \ ++ k14400bps | k16800bps | k19200bps | k21600bps | \ ++ k24000bps | k26400bps | k28800bps | k31200bps ) ++ ++ ++#define k2400BitShift 5 ++#define k4800BitShift 6 ++ ++#define kPCM28000bpsShift 2 ++ ++#define kV21Rates k300bps ++#define kV22Rates k1200bps ++#define kV22bisRates (k1200bps | k2400bps) ++#define kV23Rates (k75bps | k1200bps) ++#define kCidRates (k1200bps) ++#define kV32Rates (k4800bps | k9600bps) ++#define kV32bisRates (kV32Rates | k7200bps | k12000bps | k14400bps) ++#define kV32terboRates (kV32bisRates | k16800bps | k19200bps) ++#define kV34Rates ( k2400bps | k4800bps | k7200bps | k9600bps | k12000bps | k14400bps | \ ++ k16800bps | k19200bps | k21600bps | k24000bps | k26400bps | k28800bps | \ ++ k31200bps | k33600bps ) ++ ++#define kV27Rates (k2400bps | k4800bps) ++#define kV29Rates (k4800bps | k7200bps | k9600bps) ++#define kBell103Rates k300bps ++#define kBell212Rates k1200bps ++ ++ ++/* Demodulator capabilities */ ++#define kNeecEnabled 0x00000001 ++#define kPFeecEnabled 0x00000002 ++#define kIeecEnabled 0x00000004 ++#define kFeecEnabled 0x00000008 ++ ++#define kRapidEqualizerTraining 0x00000010 ++#define kRapidPECTraining 0x00000020 ++#define kRapidECTraining 0x00000040 ++#define kAutoLoadReductionEnabled 0x00000080 ++ ++#define kTimingTrackingEnabled 0x00000100 ++#define kPhaseLockedLoopEnabled 0x00000200 ++#define kFeecPhaseLockedLoopEnabled 0x00000400 ++#define kPhaseJitterTrackingEnabled 0x00000800 ++ ++#define kClockErrorTrackingEnabled 0x00001000 ++#define kFreqOffsetTrackingEnabled 0x00002000 ++#define kFeecFreqOffsetTrackingEnabled 0x00004000 ++ ++#define kShorterNeecEnabled 0x00008000 ++#define kShorterPFeecEnabled 0x00010000 ++#define kFrondEndHPFilterEnabled 0x00020000 ++#define kGainControlEnabled 0x00040000 ++#define kPhaseHitControlEnabled 0x00080000 ++#define kBandEdgeCorrectorEnabled 0x00100000 ++#define kDisableFaxFastClearDown 0x00200000 ++ ++#define kImdOffsetCompensationEnabled 0x00400000 ++ ++#define kV34ShortEqlLengthExtShift 23 ++#define kV34ShortEqlLengthExtMask (0x3< */ ++#define kSAM8bitSYNHuntDisabled 0 ++#define kSAM8bitSYNHuntEnabled ((ulong)1 << kSAMTransparentIdleTypeShift) ++#define kSAM16bitSYNHuntEnabled ((ulong)2 << kSAMTransparentIdleTypeShift) ++ ++/* */ ++#define kSAMSendFlagsOnIdle 0 ++#define kSAMSendMarksOnIdle ((ulong)1 << kSAMFramedIdleTypeShift) ++ ++/* */ ++#define kSAMAbortOnUnderrun 0 ++#define kSAMFlagsOnUnderrun ((ulong)1 << kSAMFramedOverrunActionShift) ++ ++/* */ ++#define kSAMHalfDuplexNoAuto 0 ++#define kSAMHalfDuplexAuto ((ulong)1 << kSAMHalfDuplexModeShift) ++ ++ ++/* */ ++#define kSAMNoCRC 0 ++#define kSAM16bitCRC ((ulong)1 << kSAMCRCTypeShift) ++#define kSAM32bitCRC ((ulong)2 << kSAMCRCTypeShift) ++ ++/* */ ++#define kSAMNRZIDisabled 0 ++#define kSAMNRZIEnabled ((ulong)1 << kSAMNRZIEnabledShift) ++ ++ ++/* LAPM setup maps */ ++#define kLapmDirection 0x00000001 /* Bit 0 */ ++#define kLapmSREJEnabled 0x00000002 /* Bit 1 */ ++#define kLapmDetectionEnabled 0x00000004 /* Bit 2 */ ++#define kLapmLongADPEnabled 0x00000008 /* Bit 3 */ ++ ++#define kLapmCompressionEnabledMask 0x00000030 ++#define kLapmTxCompressionEnabled 0x00000010 /* Bit 4 */ ++#define kLapmRxCompressionEnabled 0x00000020 /* Bit 5 */ ++#define kLapmCompressionEnabledShift 4 ++ ++#define kLapmRetryLimitMask 0x000000C0 /* Bits 6,7 */ ++ ++#define kLapmNoRetryLimit 0x00000000 ++#define kLapm4Retries 0x00000040 ++#define kLapm8Retries 0x00000080 ++#define kLapm20Retries 0x000000C0 ++ ++#define kLapmWindowSizeMask 0x00001F00 /* Bits 8-12 */ ++#define kLapmWindowSizeShift 8 ++ ++#define kLapmWindowSize8 0x00000800 ++#define kLapmWindowSize15 0x00000F00 ++ ++ ++#define kLapmInfoFieldSizeMask 0x0000E000 /* Bits 13-15 */ ++#define kLapmInfoField8Bytes 0x00000000 ++#define kLapmInfoField16Bytes 0x00002000 ++#define kLapmInfoField32Bytes 0x00004000 ++#define kLapmInfoField64Bytes 0x00006000 ++#define kLapmInfoField128Bytes 0x00008000 ++#define kLapmInfoField192Bytes 0x0000A000 ++#define kLapmInfoField256Bytes 0x0000C000 ++#define kLapmInfoField512Bytes 0x0000E000 ++#define kLapmInfoFieldSizeShift 13 ++ ++#define kLapmT400Mask 0x00030000 /* Bits 16-17 */ ++#define kLapmAutoT400 0x00000000 ++#define kLapm750msT400 0x00010000 ++#define kLapm3secT400 0x00020000 ++#define kLapm30secT400 0x00030000 ++ ++#define kLapmT401Mask 0x000C0000 /* Bits 18-19 */ ++#define kLapmAutoT401 0x00000000 ++#define kLapm750msT401 0x00040000 ++#define kLapm3secT401 0x00080000 ++#define kLapm6secT401 0x000C0000 ++ ++#define kLapmT403Mask 0x00300000 /* Bits 20-21 */ ++#define kLapmAutoT403 0x00000000 ++#define kLapm750msT403 0x00100000 ++#define kLapm2secT403 0x00200000 ++#define kLapm4secT403 0x00300000 ++ ++ ++ ++#define kLapmDictSizeMask 0x00C00000 /* Bits 22-23 */ ++#define kLapmDictSize512 0x00000000 ++#define kLapmDictSize1024 0x00400000 ++#define kLapmDictSize2048 0x00800000 ++#define kLapmDictSize4096 0x00C00000 ++ ++#define kLapmStringSizeMask 0xFF000000 /* Bits 24-31 */ ++#define kLapmStringSizeShift 24 ++ ++/* MNP setup maps */ ++ ++#define kMnpMinPLevel 0x00000001 /* Bit 0: 1 - Minimal, 0 - Standard */ ++#define kMnpStdPLevel 0x00000000 /* Bit 0: 1 - Minimal, 0 - Standard */ ++ ++#define kMnpOptimizationEnabled 0x00000002 /* Bit 1 */ ++#define kMnpOptimizationDisabled 0x00000000 /* Bit 1 */ ++ ++#define kMnpCompressionEnabled 0x00000004 /* Bit 2 */ ++#define kMnpCompressionDisabled 0x00000000 /* Bit 2 */ ++ ++#define kMnpClassMask 0x00000018 ++#define kMnpClassShift 3 ++#define kMnpClass1 0x00000008 ++#define kMnpClass2 0x00000010 ++#define kMnpClass3 0x00000018 /* Bits 3,4 */ ++ ++#define kMnpMaxRetryMask 0x00000060 /* Bits 5,6 */ ++#define kMnpMaxRetryShift 5 ++#define kMnpNoRetryLimit 0x00000000 ++#define kMnp4Retries 0x00000020 ++#define kMnp8Retries 0x00000040 ++#define kMnp20Retries 0x00000060 ++ ++#define kMnpInfoFieldSizeMask 0x00000380 /* Bits 7-9 */ ++#define kMnpInfoFieldSizeShift 7 ++#define kMnpInfoField8Bytes 0x00000000 ++#define kMnpInfoField16Bytes 0x00000080 ++#define kMnpInfoField32Bytes 0x00000100 ++#define kMnpInfoField64Bytes 0x00000180 ++#define kMnpInfoField128Bytes 0x00000200 ++#define kMnpInfoField192Bytes 0x00000280 ++#define kMnpInfoField256Bytes 0x00000300 ++#define kMnpInfoField260Bytes 0x00000380 ++ ++#define kMnpT400Mask 0x00003000 /* Bits 12,13 */ ++#define kMnpT400Shift 12 ++#define kMnpAutoT400 0x00000000 ++#define kMnp750msT400 0x00001000 ++#define kMnp3secT400 0x00002000 ++#define kMnp6secT400 0x00003000 ++ ++#define kMnpT401Mask 0x0000C000 /* Bits 14,15 */ ++#define kMnpT401Shift 14 ++#define kMnpAutoT401 0x00000000 ++#define kMnp750msT401 0x00004000 ++#define kMnp3secT401 0x00008000 ++#define kMnp6secT401 0x0000C000 ++ ++#define kMnpT403Mask 0x00030000 /* Bits 16,17 */ ++#define kMnpT403Shift 16 ++#define kMnpAutoT403 0x00000000 ++#define kMnp60secT403 0x00010000 ++#define kMnp600secT403 0x00020000 ++#define kMnp3600secT403 0x00030000 ++ ++#define kMnpFallbackTypeMask 0x000C0000 /* Bits 18,19 */ ++#define kMnpFallbackTypeShift 18 ++#define kMnpNoFallback 0x00000000 ++#define kMnpFallbackTime 0x00040000 ++#define kMnpFallback200 0x00080000 ++#define kMnpFallbackChar 0x000C0000 ++ ++#define kMnpWindowSizeMask 0x00300000 /* Bits 20,21 */ ++#define kMnpWindowSizeShift 20 ++#define kMnp1Frame 0x00000000 ++#define kMnp4Frames 0x00100000 ++#define kMnp8Frames 0x00200000 ++#define kMnp16Frames 0x00300000 ++ ++#define kMnpDirection 0x00800000 /* Bit 22 */ ++ ++#define kMnpFallbackCharMask 0xFF000000 /* Bit 24-31 */ ++#define kMnpFallbackCharShift 24 ++ ++/* kV34HDXTurnOffCurrentModeCmd state parameter values */ ++ ++#define kV34HDXTurnOffAsClearDown 0 ++#define kV34HDXTurnOffFromControlSource 1 ++#define kV34HDXTurnOffFromControlDestination 2 ++#define kV34HDXTurnOffFromPrimarySource 3 ++#define kV34HDXTurnOffFromPrimaryDestination 4 ++ ++/* V70 setup maps */ ++ ++#define kV70Direction 0x00000001 /* Bit 0 */ ++#define kV70uIHEnabled 0x00000002 /* Bit 1 */ ++#define kV70AudioHeaderEnabled 0x00000004 /* Bit 2 */ ++#define kV70SilenceSupprEnabled 0x00000008 /* Bit 3 */ ++ ++#define kV70SuspendResumeShift 4 ++#define kV70SuspendResumeMask (3 << kV70SuspendResumeShift) ++#define kV70SuspendResumeDisabled 0x00000000 /* Bit 4,5 */ ++#define kV70SuspendResumeWAddr 0x00000010 /* Bit 4 */ ++#define kV70SuspendResumeWoAddr 0x00000020 /* Bit 5 */ ++ ++#define kV70CrcLengthShift 6 ++#define kV70CrcLengthMask (3 << kV70CrcLengthShift) ++#define kV70CrcLength16 0x00000000 /* Bit 6,7 */ ++#define kV70CrcLength8 0x00000040 /* Bit 6 */ ++#define kV70CrcLength32 0x00000080 /* Bit 7 */ ++ ++#define kV70BlockingFactorShift 8 ++#define kV70BlockingFactorMask (3 << kV70BlockingFactorShift) ++#define kV70BlockingFactor1 0x00000000 /* Bit 8,9 */ ++#define kV70BlockingFactor2 0x00000100 /* Bit 8 */ ++#define kV70BlockingFactor3 0x00000200 /* Bit 9 */ ++#define kV70BlockingFactor4 0x00000300 /* Bit 8,9 */ ++ ++#define kV70InitChannelsShift 10 ++#define kV70InitChannelsMask (1 << kV70InitChannelsShift) ++#define kV70InitNoChannels 0x00000000 /* Bit 10,11 */ ++#define kV70InitDataChannel 0x00000400 /* Bit 10,11 */ ++#define kV70InitAudioChannel 0x00000800 /* Bit 10,11 */ ++#define kV70InitBothChannels 0x00000C00 /* Bit 10,11 */ ++ ++#define kV70OOBEnabled 0x00001000 /* Bit 12 */ ++ ++/* V80 setup maps */ ++ ++#define kV80Direction 0x00000001 /* Bit 0 */ ++ ++#define kV80ModeShift 1 ++#define kV80ModeMask (3 << kV80ModeShift) ++#define kV80SyncMode (0 << kV80ModeShift) ++#define kV80TunnellingMode (1 << kV80ModeShift) ++#define kV80SamMode (2 << kV80ModeShift) ++#define kV80SamTransparentMode (2 << kV80ModeShift) ++#define kV80SamFramedMode (3 << kV80ModeShift) ++ ++#define kV80TransIdleShift 3 ++#define kV80TransIdleMask (3 << kV80TransIdleShift) ++#define kV80TransIdleNoHunt (0 << kV80TransIdleShift) ++#define kV80TransIdleHunt8 (1 << kV80TransIdleShift) ++#define kV80TransIdleHunt16 (2 << kV80TransIdleShift) ++ ++#define kV80FrameIdleShift 5 ++#define kV80FrameIdleMask (1 << kV80FrameIdleShift) ++#define kV80FrameIdleFlags (0 << kV80FrameIdleShift) ++#define kV80FrameIdleMarks (1 << kV80FrameIdleShift) ++ ++#define kV80FrameUnOvShift 6 ++#define kV80FrameUnOvMask (1 << kV80FrameUnOvShift) ++#define kV80FrameUnOvAbort (0 << kV80FrameUnOvShift) ++#define kV80FrameUnOvFlag (1 << kV80FrameUnOvShift) ++ ++#define kV80HdAutoShift 7 ++#define kV80HdAutoMask (1 << kV80HdAutoShift) ++#define kV80HdAutoNormal (0 << kV80HdAutoShift) ++#define kV80HdAutoExtended (1 << kV80HdAutoShift) ++ ++#define kV80CrcTypeShift 8 ++#define kV80CrcTypeMask (3 << kV80CrcTypeShift) ++#define kV80NoCrc (0 << kV80CrcTypeShift) ++#define kV80Crc16 (1 << kV80CrcTypeShift) ++#define kV80Crc32 (2 << kV80CrcTypeShift) ++ ++#define kV80NrziShift 10 ++#define kV80NrziMask (1 << kV80NrziShift) ++#define kV80NrziDisabled (0 << kV80NrziShift) ++#define kV80NrziEnabled (1 << kV80NrziShift) ++ ++#define kV80Syn1Mask 0x00FF0000 /* Bit 16-23 */ ++#define kV80Syn1Shift 16 ++#define kV80Syn2Mask 0xFF000000 /* Bit 24-31 */ ++#define kV80Syn2Shift 24 ++ ++/* kStartCallProgressMonitorCmd setup masks */ ++ ++#define kDTMFDetectorDebouncerEnabled 0x0001 ++#define kModemSignalDetectorDebouncerEnabled 0x0002 ++#define kCallProgressDetectorDebouncerEnabled 0x0004 ++#define kCustomSignalDebouncerEnabled 0x0008 ++#define kFaxCallingToneSuppressionEnabled 0x0010 ++#define kDataCallingToneSuppressionEnabled 0x0020 ++#define kCISuppressionEnabled 0x0040 ++#define kAnsSuppressionEnabled 0x0080 ++ ++/* kDialCmd setup masks (dialerSetup bit fields) */ ++ ++#define kDTMFDialingEnabled 0x0001 ++#define kPulseDialingEnabled 0x0002 ++#define kModeSwitchEnabled 0x0004 ++#define kBlindDialingEnabled 0x0008 ++#define kPulseDialingMethodMask 0x0030 ++#define kDialModifierTranslationMask 0x00C0 ++#define kFlashWhilePulseDialingEnabled 0x0100 ++ ++/* Pulse dialing method */ ++#define kPulseDialingNPulsesPerDigit 0x0000 ++#define kPulseDialingNplusOnePulsesPerDigit 0x0010 ++#define kPulseDialingTenMinusNPulsesPerDigit 0x0020 ++ ++/* Dial modifier translation */ ++#define kTreatWasPause 0x0040 /* Tread 'W' modifier as pause */ ++#define kTreatCommaAsWaitForDialtone 0x0080 ++ ++#ifdef TI_C6X ++#include "C6xDefs.h" ++#endif ++#ifdef PENTIUM_MMX ++#include "PentiumDefs.h" ++#endif ++ ++ ++#if defined(DSP16K) && !defined(SoftModemGlobals) ++/* ensure that code generator does not use r5 */ ++register int *softmodem_h_should_not_be_included_after_softmodem_gh asm("r5"); ++#endif ++ ++/****************************************************************************/ ++/* 3. Interface functions. */ ++/* */ ++/****************************************************************************/ ++ ++#ifdef ADSL_MODEM ++ ++#ifndef SoftDslHeader ++#include "SoftDsl.h" ++#endif ++extern char* SM_DECL SoftModemGetRevString(void); ++extern char* SM_DECL SoftModemGetProductName(void); ++extern char* SM_DECL SoftModemGetBuildDate(void); ++extern char* SM_DECL SoftModemGetFullManufacturerName(void); ++extern char* SM_DECL SoftModemGetShortManufacturerName(void); ++extern int SM_DECL SoftModemRevStringSize(void); ++extern char* SM_DECL SoftModemGetVendorIDString(void); ++extern char* SM_DECL SoftModemGetT1413VendorIDString(void); ++extern char* SM_DECL SoftModemGetSerialNumberString(void); ++extern int SM_DECL SoftModemSerNumStringSize(void); ++#define SoftDslGetProductName SoftModemGetProductName ++#define SoftDslGetBuildDate SoftModemGetBuildDate ++#define SoftDslGetFullManufacturerName SoftModemGetFullManufacturerName ++#define SoftDslGetShortManufacturerName SoftModemGetShortManufacturerName ++ ++#else /* !ADSL_MODEM */ ++ ++extern void SM_DECL SoftModemSetMemoryPtr (void *varsPtr); ++extern void* SM_DECL SoftModemGetMemoryPtr (void); ++extern void SM_DECL SoftModemSetRefData (void *varsPtr); ++extern void* SM_DECL SoftModemGetRefData (void); ++extern int SM_DECL SoftModemGetMemorySize (void); ++extern void SM_DECL SoftModemInit (void); ++extern void SM_DECL SoftModemReset (void); ++extern void SM_DECL SoftModemLineHandler (int sampleCount, short *srcPtr, short *dstPtr); ++extern void SM_DECL SoftModemTimer (long timeQ24ms); ++extern Boolean SM_DECL SoftModemCommandHandler (modemCommandStruct *cmdPtr); ++extern int SM_DECL SoftModemGetExternalMemorySize(void); ++extern void SM_DECL SoftModemSetExternalMemoryPtr(void *varsPtr); ++ ++extern void SM_DECL SoftModemSetPcmCoding (pcmCodingType pcmCoding); ++extern void SM_DECL SoftModemPcmLineHandler (int sampleCount, uchar *srcPtr, uchar *dstPtr); ++ ++/* SoftModem IO functions */ ++extern int SM_DECL SoftModemWrite(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemRead(int nBytes, uchar* dstPtr); ++extern int SM_DECL SoftModemWriteFrame(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemReadFrame(int maxFrameSize, uchar* dstPtr); ++extern int SM_DECL SoftModemCountWritePending(void); ++extern int SM_DECL SoftModemCountReadPending(void); ++extern int SM_DECL SoftModemWriteSpaceAvailable(void); ++extern void SM_DECL SoftModemWriteFlush(void); ++extern void SM_DECL SoftModemReadFlush(void); ++extern int SM_DECL SoftModemGetWriteBufferSize(void); ++extern int SM_DECL SoftModemGetReadBufferSize(void); ++ ++#ifdef AUDIO ++extern int SM_DECL SoftModemAudioHandler(int sampleCount, short *srcPtr, short *dstPtr); ++extern int SM_DECL SoftModemAudioRxDataHandler(int nBytes, uchar* srcPtr); ++extern int SM_DECL SoftModemAudioTxDataHandler(int nBytes, uchar* dstPtr); ++#endif ++ ++ ++#define SoftModemSetGlobalPtr SoftModemSetMemoryPtr ++#define SoftModem SoftModemLineHandler ++#ifndef LINKLAYER_V42BIS_LARGE_DICTIONARY ++#define kSoftModemMaxMemorySize (65536) ++#else ++#define kSoftModemMaxMemorySize (65536 + 8192) ++#endif ++ ++/* ++ * Internal functions ++ */ ++extern long SM_DECL SoftModemGetDCOffset(void); ++extern void SM_DECL SoftModemDisableDCOffsetTracking(void); ++extern void SM_DECL SoftModemEnableDCOffsetTracking(void); ++extern long SM_DECL SoftModemGetRcvPower(void); ++extern ulong SM_DECL SoftModemGetHybridDelay(void); ++extern void SM_DECL SoftModemStatusHandler (modemStatusStruct *status); ++extern Boolean SM_DECL SoftModemInternalCommandHandler (modemCommandStruct *cmdPtr); ++extern void SM_DECL SoftModemInternalStatusHandler (modemStatusStruct *status); ++extern void SM_DECL SoftModemSetControllerOnlyMode(commandHandlerType externalDataPumpCommandHandlerPtr); ++extern char* SM_DECL SoftModemGetRevString(void); ++extern char* SM_DECL SoftModemGetProductName(void); ++extern char* SM_DECL SoftModemGetBuildDate(void); ++extern char* SM_DECL SoftModemGetFullManufacturerName(void); ++extern char* SM_DECL SoftModemGetShortManufacturerName(void); ++extern int SM_DECL SoftModemRevStringSize(void); ++extern char* SM_DECL SoftModemGetVendorIDString(void); ++extern char* SM_DECL SoftModemGetSerialNumberString(void); ++extern void SM_DECL SoftModemAuxTxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemAuxRxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemTxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemRxDataHandler(int nBytes, uchar *dataPtr); ++extern void SM_DECL SoftModemATPrintf(uchar *format, void *arg1, void *arg2, void *arg3); ++ ++#define SoftModemSetInputSaturationLimit(limit) (gSystemVars.inputSignalLimit = limit) ++#define SoftModemResetInputSaturationLimit() (gSystemVars.inputSignalLimit = 0) ++ ++#endif /* !ADSL_MODEM */ ++ ++#endif /* SoftModemPh */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModemTypes.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModemTypes.h +--- linux-2.6.8.1/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModemTypes.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/char/adsl/impl1/softdsl/SoftModemTypes.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,292 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * SoftModemTypes.h ++ * ++ * ++ * Description: ++ * This file contains some of the type declarations for SoftModem ++ * ++ * Copyright (c) 1993-1997 AltoCom, Inc. All rights reserved. ++ * Authors: Mark Gonikberg, Haixiang Liang. ++ * ++ * $Revision: 1.9 $ ++ * ++ * $Id: SoftModemTypes.h,v 1.9 2004/04/13 00:16:59 ilyas Exp $ ++ * ++ * $Log: SoftModemTypes.h,v $ ++ * Revision 1.9 2004/04/13 00:16:59 ilyas ++ * Merged the latest ADSL driver changes ++ * ++ * Revision 1.8 2004/01/24 01:35:33 ytan ++ * add multi-section lmem swap ++ * ++ * Revision 1.7 2001/09/21 19:19:01 ilyas ++ * Minor fixes for VxWorks build ++ * ++ * Revision 1.6 2001/08/16 02:16:39 khp ++ * - added definitions for SLOW_DATA and FAST_TEXT, defined to nothing ++ * except when bcm47xx && USE_SLOW_DATA or USE_FAST_TEXT. Any function ++ * that needs to run fast should be marked with FAST_TEXT. Any data that ++ * is not referenced often should be marked with SLOW_DATA. ++ * ++ * Revision 1.5 2001/03/30 00:49:59 liang ++ * Changed warning output message. ++ * ++ * Revision 1.4 2000/06/21 22:24:40 yongbing ++ * Modify WARN micro to limit the number of same warnings printed ++ * ++ * Revision 1.3 1999/08/05 20:02:13 liang ++ * Merged with the softmodem top of the tree on 08/04/99. ++ * ++ * Revision 1.2 1999/01/27 22:14:29 liang ++ * Merge with SoftModem_3_1_02. ++ * ++ * Revision 1.19 1998/11/17 04:02:39 yura ++ * Fixed WARN and ASSERT redefinition warning for WinNT targets ++ * ++ * Revision 1.18 1998/08/26 19:20:43 scott ++ * Commented out EXCLUDE_CYGWIN32_TYPES define ++ * ++ * Revision 1.17 1998/08/13 19:03:06 scott ++ * Added BitField definition and INT_IS_LONG ++ * ++ * Revision 1.16 1998/08/08 03:39:55 scott ++ * The DEBUG_PTR_ENABLED macro can be used to enable only the DEBUG_PTR macros ++ * ++ * Revision 1.15 1998/07/28 22:21:31 mwg ++ * Fixed problems with NULL & nil being defined incorrectly ++ * ++ * Revision 1.14 1998/07/08 17:09:17 scott ++ * Define ASSERT and WARN only if not already defined ++ * ++ * Revision 1.13 1998/07/02 20:46:34 scott ++ * Added workaround for building certain builds with older SunOS ++ * ++ * Revision 1.12 1998/02/09 18:24:49 scott ++ * Defined "Private" as nothing for GreenHill (to prevent erroneous section ++ * allocations for data) ++ * ++ * Revision 1.11 1997/08/29 21:39:24 scott ++ * Added check for LONG_IS_INT define (for TI C6X support) ++ * ++ * Revision 1.10 1997/05/29 19:50:23 mwg ++ * Added code to avoid type redefintions under SunOS. ++ * ++ * Revision 1.9 1997/03/19 18:35:08 mwg ++ * Changed copyright notice. ++ * ++ * Revision 1.8 1997/02/11 00:05:53 mwg ++ * Minor adjustments for Pentium optimization. ++ * ++ * Revision 1.7 1997/01/11 01:30:47 mwg ++ * Added new macro WARN -- the same as ASSERT but without exit. ++ * ++ * Revision 1.6 1996/08/22 20:07:39 liang ++ * When ASSERT fires, only print out information, don't exit. ++ * ++ * Revision 1.5 1996/05/06 06:49:10 mwg ++ * Fixed linux problems. ++ * ++ * Revision 1.4 1996/05/02 08:40:16 mwg ++ * Merged in Chromatic bug fixes. ++ * ++ * Revision 1.3 1996/04/01 20:59:53 mwg ++ * Added macros to setup and use debug pointer. ++ * ++ * Revision 1.2 1996/02/27 01:50:04 mwg ++ * Added ASSERT() macro. ++ * ++ * Revision 1.1.1.1 1996/02/14 02:35:13 mwg ++ * Redesigned the project directory structure. Merged V.34 into the project. ++ * ++ * Revision 1.2 1995/12/03 06:59:31 mwg ++ * Fixed all gcc varnings. We are now running under Linux on a PC! ++ * ++ *****************************************************************************/ ++#ifndef SoftModemTypesh ++#define SoftModemTypesh ++ ++#ifdef LONG_SHORTS ++#define short long ++#define ushort unsigned long ++#endif ++ ++typedef signed char schar; ++typedef unsigned char uchar; ++ ++#if 0 /* This is not currently required */ ++#if defined(_CYGWIN32) && defined(DEBUG) ++#define EXCLUDE_CYGWIN32_TYPES ++#endif ++#endif ++ ++#if !defined(_SYS_TYPES_H) || !defined(TARG_OS_RTEMS) ++#if defined(_CFE_) ++ typedef unsigned int uint; ++ typedef unsigned long ulong; ++ typedef unsigned short ushort; ++#elif defined(TARG_OS_RTEMS) ++#if defined(HOST_ARCH_LINUX) ++ typedef unsigned int uint; ++#endif ++ typedef unsigned long ulong; ++#if defined(HOST_ARCH_LINUX) ++ typedef unsigned short ushort; ++#endif ++#elif defined(EXCLUDE_CYGWIN32_TYPES) || (!defined _NO_TYPE_DEFS_ && !defined _SYS_TYPES_H && !defined __SYS_TYPES_H__ && !defined _SYS_BSD_TYPES_H && !defined _LINUX_TYPES_H) || defined(__sparc__) ++#ifndef EXCLUDE_CYGWIN32_TYPES ++ typedef unsigned int uint; ++#endif ++#ifndef _LINUX_TYPES_H ++ typedef unsigned long ulong; ++#endif ++#if !defined(ushort) && !defined(EXCLUDE_CYGWIN32_TYPES) && !defined(__INCvxTypesOldh) ++ typedef unsigned short ushort; ++#endif ++#endif ++#else ++typedef unsigned long ulong; ++#endif ++ ++#if defined(GREENHILL) || defined(GNUTX39) /* GH allocates private data to incorrect section */ ++#define Private ++#else ++#define Private static ++#endif ++ ++#define Public ++ ++#ifdef NULL ++#undef NULL ++#endif ++#ifdef nil ++#undef nil ++#endif ++ ++#define NULL 0 ++#define nil 0 ++ ++#define false 0 ++#define true 1 ++typedef unsigned char Boolean; ++typedef unsigned int BitField; /* this must occur BEFORE long_is_int/int_is_long defs */ ++ ++#ifdef LONG_IS_INT ++#define long int ++#define ulong uint ++#endif ++ ++#ifdef INT_IS_LONG ++#define int long ++#define uint ulong ++#endif ++ ++#define POSTULATE(postulate) \ ++ do \ ++ { \ ++ typedef struct \ ++ { \ ++ char NegativeSizeIfPostulateFalse[((int)(postulate))*2 - 1]; \ ++ } PostulateCheckStruct; \ ++ } \ ++ while (0) ++ ++#if defined(DEBUG) && !defined(__KERNEL__) ++#ifndef WARN ++#define kDSLNumberWarnTimes 10 ++#define WARN(assertion) \ ++ { static int warnSeveralTimes=0; \ ++ if ((!(assertion))&(warnSeveralTimes ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6338_common.h */ ++/* DATE: 05/10/04 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6338 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6338_MAP_COMMON_H ++#define __BCM6338_MAP_COMMON_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#define PERF_BASE 0xfffe0000 /* chip control registers */ ++#define BB_BASE 0xfffe0100 /* bus bridge registers */ ++#define TIMR_BASE 0xfffe0200 /* timer registers */ ++#define UART_BASE 0xfffe0300 /* uart registers */ ++#define GPIO_BASE 0xfffe0400 /* gpio registers */ ++#define SPI_BASE 0xfffe0c00 /* SPI master controller registers */ ++ ++#define ADSL_BASE 0xfffe1000 /* ADSL core control registers */ ++#define ATM_BASE 0xfffe2000 /* ATM SAR control registers */ ++#define EMAC_DMA_BASE 0xfffe2400 /* EMAC DMA control registers */ ++#define USB_DMA_BASE 0xfffe2400 /* USB DMA control registers */ ++#define EMAC1_BASE 0xfffe2800 /* EMAC1 control registers */ ++#define USB_CTL_BASE 0xfffe3000 /* USB control registers */ ++#define SDRAM_BASE 0xfffe3100 /* SDRAM control registers */ ++ ++ ++/* ++##################################################################### ++# System PLL Control Register ++##################################################################### ++*/ ++ ++#define SOFT_RESET 0x00000001 ++ ++/* ++##################################################################### ++# SDRAM Control Registers ++##################################################################### ++*/ ++#define SDR_INIT_CTL 0x00 ++ /* Control Bits */ ++#define SDR_PFEN1 (1<<16) ++#define SDR_PFEN0 (1<<15) ++#define SDR_EMPRS (1<<14) ++#define SDR_2_BANKS (1<<13) ++#define SDR_1_BANK (0<<13) ++#define SDR_CS1_EN (1<<12) ++#define SDR_PEND (1<<11) ++#define SDR_32_BIT (1<<10) ++#define SDR_POWER_DOWN (1<<9) ++#define SDR_SELF_REFRESH (1<<8) ++#define SDR_11_COLS (3<<6) ++#define SDR_10_COLS (2<<6) ++#define SDR_9_COLS (1<<6) ++#define SDR_8_COLS (0<<6) ++#define SDR_13_ROWS (2<<4) ++#define SDR_12_ROWS (1<<4) ++#define SDR_11_ROWS (0<<4) ++#define SDR_MASTER_EN (1<<3) ++#define SDR_MRS_CMD (1<<2) ++#define SDR_PRE_CMD (1<<1) ++#define SDR_CBR_CMD (1<<0) ++ ++#define SDR_CFG_REG 0x04 ++ /* Control Bits */ ++#define SDR_FULL_PG 0 ++#define SDR_BURST8 1 ++#define SDR_BURST4 2 ++#define SDR_BURST2 3 ++#define SDR_FAST_MEM (1<<2) ++#define SDR_SLOW_MEM (0<<2) ++ ++#define SDR_REF_CTL 0x0C ++ /* Control Bits */ ++#define SDR_REF_EN (1<<15) ++ ++#define SDR_PRIOR ++ /* Control Bits */ ++#define SDR_EN_PRIOR (1<<31) ++ ++ ++/* ++##################################################################### ++# MPI Control Registers ++##################################################################### ++*/ ++#define CS0BASE 0x00 ++#define CS0CNTL 0x04 ++ ++/* ++# CSxBASE settings ++# Size in low 4 bits ++# Base Address for match in upper 24 bits ++*/ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ ++/* CSxCNTL settings */ ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define ZEROWT 0x00000000 /* .. 0 WS */ ++#define ONEWT 0x00000002 /* .. 1 WS */ ++#define TWOWT 0x00000004 /* .. 2 WS */ ++#define THREEWT 0x00000006 /* .. 3 WS */ ++#define FOURWT 0x00000008 /* .. 4 WS */ ++#define FIVEWT 0x0000000a /* .. 5 WS */ ++#define SIXWT 0x0000000c /* .. 6 WS */ ++#define SEVENWT 0x0000000e /* .. 7 WS */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert chip select polarity */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. enable fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++ ++/* ++##################################################################### ++# UART Control Registers ++##################################################################### ++*/ ++#define UART0CONTROL 0x01 ++#define UART0CONFIG 0x02 ++#define UART0RXTIMEOUT 0x03 ++#define UART0BAUD 0x04 ++#define UART0FIFOCFG 0x0a ++#define UART0INTMASK 0x10 ++#define UART0INTSTAT 0x12 ++#define UART0DATA 0x17 ++ ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ ++#define XMITBREAK 0x40 /* Config register */ ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ ++#define RSTTXFIFOS 0x80 /* Rx Timeout register */ ++#define RSTRXFIFOS 0x40 ++ ++#define TX4 0x40 /* FIFO config register */ ++#define RX4 0x04 ++ ++#define DELTAIP 0x0001 /* Interrupt Status and Mask registers */ ++#define TXUNDERR 0x0002 ++#define TXOVFERR 0x0004 ++#define TXFIFOTHOLD 0x0008 ++#define TXREADLATCH 0x0010 ++#define TXFIFOEMT 0x0020 ++#define RXUNDERR 0x0040 ++#define RXOVFERR 0x0080 ++#define RXTIMEOUT 0x0100 ++#define RXFIFOFULL 0x0200 ++#define RXFIFOTHOLD 0x0400 ++#define RXFIFONE 0x0800 ++#define RXFRAMERR 0x1000 ++#define RXPARERR 0x2000 ++#define RXBRK 0x4000 ++ ++#if __cplusplus ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6338_map.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6338_map.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6338_map.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6338_map.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,885 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6338_map.h */ ++/* DATE: 05/10/04 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6338 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6338_MAP_H ++#define __BCM6338_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++#include "6338_common.h" ++#include "6338_intr.h" ++ ++/* macro to convert logical data addresses to physical */ ++/* DMA hardware must see physical address */ ++#define LtoP( x ) ( (uint32)x & 0x1fffffff ) ++#define PtoL( x ) ( LtoP(x) | 0xa0000000 ) ++ ++/* ++** Interrupt Controller ++*/ ++typedef struct PerfControl { ++ uint32 RevID; /* (00) */ ++ uint16 testControl; /* (04) */ ++ uint16 blkEnables; /* (06) */ ++ ++#define ADSL_CLK_EN 0x0001 ++#define MPI_CLK_EN 0x0002 ++#define DRAM_CLK_EN 0x0004 ++#define EMAC_CLK_EN 0x0010 ++#define USBS_CLK_EN 0x0010 ++#define SAR_CLK_EN 0x0020 ++#define SPI_CLK_EN 0x0200 ++ ++ uint32 pll_control; /* (08) */ ++#define CHIP_SOFT_RESET 0x00000001 ++ ++ uint32 IrqMask; /* (0c) */ ++ uint32 IrqStatus; /* (10) */ ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 5 ++#define EI_CLEAR_SHFT 10 ++#define EI_MASK_SHFT 15 ++#define EI_INSENS_SHFT 20 ++#define EI_LEVEL_SHFT 25 ++ ++ uint32 unused[4]; /* (18) */ ++ uint32 BlockSoftReset; /* (28) */ ++#define BSR_SPI 0x00000001 ++#define BSR_EMAC 0x00000004 ++#define BSR_USBH 0x00000008 ++#define BSR_USBS 0x00000010 ++#define BSR_ADSL 0x00000020 ++#define BSR_DMAMEM 0x00000040 ++#define BSR_SAR 0x00000080 ++#define BSR_ACLC 0x00000100 ++#define BSR_ADSL_MIPS_PLL 0x00000400 ++#define BSR_ALL_BLOCKS \ ++ (BSR_SPI | BSR_EMAC | BSR_USBH | BSR_USBS | BSR_ADSL | BSR_DMAMEM | \ ++ BSR_SAR | BSR_ACLC | BSR_ADSL_MIPS_PLL) ++} PerfControl; ++ ++#define PERF ((volatile PerfControl * const) PERF_BASE) ++ ++/* ++** Bus Bridge Registers ++*/ ++typedef struct BusBridge { ++ uint16 status; ++#define BB_BUSY 0x8000 /* posted operation in progress */ ++#define BB_RD_PND 0x4000 /* read pending */ ++#define BB_RD_CMPLT 0x2000 /* read complete */ ++#define BB_ERROR 0x1000 /* posted write error */ ++#define BB_TEA 0x0800 /* transfer aborted */ ++ uint16 abortTimeoutCnt; /* abort timeout value */ ++ ++ byte writePostEnable; ++#define BB_POST_TIMR_EN 0x08 /* post writes to timer regs */ ++#define BB_POST_GPIO_EN 0x04 /* post writes to gpio regs */ ++#define BB_POST_INTC_EN 0x02 /* post writes to interrupt controller regs */ ++#define BB_POST_UART_EN 0x01 /* post writes to uart regs */ ++ byte unused1[5]; ++ uint16 postAddr; /* posted read address (lower half) */ ++ byte unused2[3]; ++ byte postData; /* posted read data */ ++} BusBridge; ++ ++/* register offsets (needed for EBI master access) */ ++#define BB_STATUS 0 ++#define BB_ABORT_TO_CNT 2 ++#define BB_WR_POST_EN 4 ++#define BB_RD_POST_ADDR 10 ++#define BB_RD_POST_DATA 12 ++ ++#define BRIDGE *bridge ((volatile BusBridge * const) BB_BASE) ++ ++/* ++** Timer ++*/ ++typedef struct Timer { ++ uint16 unused0; ++ byte TimerMask; ++#define TIMER0EN 0x01 ++#define TIMER1EN 0x02 ++#define TIMER2EN 0x04 ++ byte TimerInts; ++#define TIMER0 0x01 ++#define TIMER1 0x02 ++#define TIMER2 0x04 ++#define WATCHDOG 0x08 ++ uint32 TimerCtl0; ++ uint32 TimerCtl1; ++ uint32 TimerCtl2; ++#define TIMERENABLE 0x80000000 ++#define RSTCNTCLR 0x40000000 ++ uint32 TimerCnt0; ++ uint32 TimerCnt1; ++ uint32 TimerCnt2; ++ uint32 WatchDogDefCount; ++ ++ /* Write 0xff00 0x00ff to Start timer ++ * Write 0xee00 0x00ee to Stop and re-load default count ++ * Read from this register returns current watch dog count ++ */ ++ uint32 WatchDogCtl; ++ ++ /* Number of 40-MHz ticks for WD Reset pulse to last */ ++ uint32 WDResetCount; ++} Timer; ++ ++#define TIMER ((volatile Timer * const) TIMR_BASE) ++ ++/* ++** UART ++*/ ++typedef struct UartChannel { ++ byte unused0; ++ byte control; ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ ++ byte config; ++#define XMITBREAK 0x40 ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ /* 4-LSBS represent STOP bits/char ++ * in 1/8 bit-time intervals. Zero ++ * represents 1/8 stop bit interval. ++ * Fifteen represents 2 stop bits. ++ */ ++ byte fifoctl; ++#define RSTTXFIFOS 0x80 ++#define RSTRXFIFOS 0x40 ++ /* 5-bit TimeoutCnt is in low bits of this register. ++ * This count represents the number of characters ++ * idle times before setting receive Irq when below threshold ++ */ ++ uint32 baudword; ++ /* When divide SysClk/2/(1+baudword) we should get 32*bit-rate ++ */ ++ ++ byte txf_levl; /* Read-only fifo depth */ ++ byte rxf_levl; /* Read-only fifo depth */ ++ byte fifocfg; /* Upper 4-bits are TxThresh, Lower are ++ * RxThreshold. Irq can be asserted ++ * when rx fifo> thresh, txfifo RX_LENGTH register value */ ++#define EMAC_NO 0x0008 /* Non-Octet aligned */ ++#define EMAC_RXER 0x0004 /* RX_ERR on MII while RX_DV assereted */ ++#define EMAC_CRC_ERROR 0x0002 /* CRC error */ ++#define EMAC_OV 0x0001 /* Overflow */ ++ ++/* HDLC Descriptor Status definitions */ ++#define DMA_HDLC_TX_ABORT 0x0100 ++#define DMA_HDLC_RX_OVERRUN 0x4000 ++#define DMA_HDLC_RX_TOO_LONG 0x2000 ++#define DMA_HDLC_RX_CRC_OK 0x1000 ++#define DMA_HDLC_RX_ABORT 0x0100 ++ ++ uint32 address; /* address of data */ ++} DmaDesc; ++ ++/* ++** Sdram Controller ++*/ ++typedef struct SdramControllerRegs { ++ uint16 unused1; ++ uint16 initControl; /* 02 */ ++#define SD_POWER_DOWN 0x200 /* put sdram into power down */ ++#define SD_SELF_REFRESH 0x100 /* enable self refresh mode */ ++#define SD_SOFT_RESET 0x080 /* soft reset all sdram controller regs */ ++#define SD_EDO_SELECT 0x040 /* select EDO mode */ ++#define SD_EDO_WAIT_STATE 0x020 /* add an EDO wait state */ ++#define SD_8MEG 0x010 /* map sdram to 8 megs */ ++#define SD_MASTER_ENABLE 0x008 /* enable accesses to external sdram */ ++#define SD_MRS 0x004 /* generate a mode register select cycle */ ++#define SD_PRECHARGE 0x002 /* generate a precharge cycle */ ++#define SD_CBR 0x001 /* generate a refresh cycle */ ++ uint8 unused2[3]; ++ uint8 config; /* 07 */ ++#define SD_FAST_MEM 0x04 /* 1=CAS latency of 2, 0 = CAS latency of 3 */ ++#define SD_BURST_LEN 0x03 /* set burst length */ ++#define SD_BURST_FULL_PAGE 0x00 /* .. full page */ ++#define SD_BURST_8 0x01 /* .. 8 words */ ++#define SD_BURST_4 0x02 /* .. 4 words */ ++#define SD_BURST_2 0x03 /* .. 2 words */ ++ uint16 unused3; ++ uint16 refreshControl; /* 0a */ ++#define SD_REFRESH_ENABLE 0x8000 /* refresh enable */ ++#define SD_REFRESH_PERIOD 0x00ff /* refresh period (16 x n x clock_period) */ ++ ++ uint32 memoryBase; /* 0c */ ++#define SD_MEMBASE_MASK 0xffffe000 /* base address mask */ ++#define SD_MEMSIZE_8MEG 0x00000001 /* memory is 8 meg */ ++#define SD_MEMSIZE_2MEG 0x00000001 /* memory is 2 meg */ ++ ++} SdramControllerRegs; ++ ++/* ++** External Bus Interface ++*/ ++typedef struct EbiChipSelect { ++ uint32 base; /* base address in upper 24 bits */ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ uint32 config; ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define EBI_WTST_SHIFT 1 /* .. for shifting wait states */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_WREN 0x00000020 /* enable posted writes */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert something, ++ ** don't know what yet */ ++#define EBI_FIFO 0x00000200 /* .. use fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++} EbiChipSelect; ++ ++typedef struct MpiRegisters { ++ EbiChipSelect cs[1]; /* size chip select configuration */ ++} MpiRegisters; ++ ++#define MPI ((volatile MpiRegisters * const) MPI_BASE) ++ ++/* ++** EMAC transmit MIB counters ++*/ ++typedef struct EmacTxMib { ++ uint32 tx_good_octets; /* (200) good byte count */ ++ uint32 tx_good_pkts; /* (204) good pkt count */ ++ uint32 tx_octets; /* (208) good and bad byte count */ ++ uint32 tx_pkts; /* (20c) good and bad pkt count */ ++ uint32 tx_broadcasts_pkts; /* (210) good broadcast packets */ ++ uint32 tx_multicasts_pkts; /* (214) good mulitcast packets */ ++ uint32 tx_len_64; /* (218) RMON tx pkt size buckets */ ++ uint32 tx_len_65_to_127; /* (21c) */ ++ uint32 tx_len_128_to_255; /* (220) */ ++ uint32 tx_len_256_to_511; /* (224) */ ++ uint32 tx_len_512_to_1023; /* (228) */ ++ uint32 tx_len_1024_to_max; /* (22c) */ ++ uint32 tx_jabber_pkts; /* (230) > 1518 with bad crc */ ++ uint32 tx_oversize_pkts; /* (234) > 1518 with good crc */ ++ uint32 tx_fragment_pkts; /* (238) < 63 with bad crc */ ++ uint32 tx_underruns; /* (23c) fifo underrun */ ++ uint32 tx_total_cols; /* (240) total collisions in all tx pkts */ ++ uint32 tx_single_cols; /* (244) tx pkts with single collisions */ ++ uint32 tx_multiple_cols; /* (248) tx pkts with multiple collisions */ ++ uint32 tx_excessive_cols; /* (24c) tx pkts with excessive cols */ ++ uint32 tx_late_cols; /* (250) tx pkts with late cols */ ++ uint32 tx_defered; /* (254) tx pkts deferred */ ++ uint32 tx_carrier_lost; /* (258) tx pkts with CRS lost */ ++ uint32 tx_pause_pkts; /* (25c) tx pause pkts sent */ ++#define NumEmacTxMibVars 24 ++} EmacTxMib; ++ ++/* ++** EMAC receive MIB counters ++*/ ++typedef struct EmacRxMib { ++ uint32 rx_good_octets; /* (280) good byte count */ ++ uint32 rx_good_pkts; /* (284) good pkt count */ ++ uint32 rx_octets; /* (288) good and bad byte count */ ++ uint32 rx_pkts; /* (28c) good and bad pkt count */ ++ uint32 rx_broadcasts_pkts; /* (290) good broadcast packets */ ++ uint32 rx_multicasts_pkts; /* (294) good mulitcast packets */ ++ uint32 rx_len_64; /* (298) RMON rx pkt size buckets */ ++ uint32 rx_len_65_to_127; /* (29c) */ ++ uint32 rx_len_128_to_255; /* (2a0) */ ++ uint32 rx_len_256_to_511; /* (2a4) */ ++ uint32 rx_len_512_to_1023; /* (2a8) */ ++ uint32 rx_len_1024_to_max; /* (2ac) */ ++ uint32 rx_jabber_pkts; /* (2b0) > 1518 with bad crc */ ++ uint32 rx_oversize_pkts; /* (2b4) > 1518 with good crc */ ++ uint32 rx_fragment_pkts; /* (2b8) < 63 with bad crc */ ++ uint32 rx_missed_pkts; /* (2bc) missed packets */ ++ uint32 rx_crc_align_errs; /* (2c0) both or either */ ++ uint32 rx_undersize; /* (2c4) < 63 with good crc */ ++ uint32 rx_crc_errs; /* (2c8) crc errors (only) */ ++ uint32 rx_align_errs; /* (2cc) alignment errors (only) */ ++ uint32 rx_symbol_errs; /* (2d0) pkts with RXERR assertions (symbol errs) */ ++ uint32 rx_pause_pkts; /* (2d4) MAC control, PAUSE */ ++ uint32 rx_nonpause_pkts; /* (2d8) MAC control, not PAUSE */ ++#define NumEmacRxMibVars 23 ++} EmacRxMib; ++ ++typedef struct EmacRegisters { ++ uint32 rxControl; /* (00) receive control */ ++#define EMAC_PM_REJ 0x80 /* - reject DA match in PMx regs */ ++#define EMAC_UNIFLOW 0x40 /* - accept cam match fc */ ++#define EMAC_FC_EN 0x20 /* - enable flow control */ ++#define EMAC_LOOPBACK 0x10 /* - loopback */ ++#define EMAC_PROM 0x08 /* - promiscuous */ ++#define EMAC_RDT 0x04 /* - ignore transmissions */ ++#define EMAC_ALL_MCAST 0x02 /* - ignore transmissions */ ++#define EMAC_NO_BCAST 0x01 /* - ignore transmissions */ ++ ++ ++ uint32 rxMaxLength; /* (04) receive max length */ ++ uint32 txMaxLength; /* (08) transmit max length */ ++ uint32 unused1[1]; ++ uint32 mdioFreq; /* (10) mdio frequency */ ++#define EMAC_MII_PRE_EN 0x00000080 /* prepend preamble sequence */ ++#define EMAC_MDIO_PRE 0x00000080 /* - enable MDIO preamble */ ++#define EMAC_MDC_FREQ 0x0000007f /* - mdio frequency */ ++ ++ uint32 mdioData; /* (14) mdio data */ ++#define MDIO_WR 0x50020000 /* - write framing */ ++#define MDIO_RD 0x60020000 /* - read framing */ ++#define MDIO_PMD_SHIFT 23 ++#define MDIO_REG_SHIFT 18 ++ ++ uint32 intMask; /* (18) int mask */ ++ uint32 intStatus; /* (1c) int status */ ++#define EMAC_FLOW_INT 0x04 /* - flow control event */ ++#define EMAC_MIB_INT 0x02 /* - mib event */ ++#define EMAC_MDIO_INT 0x01 /* - mdio event */ ++ ++ uint32 unused2[3]; ++ uint32 config; /* (2c) config */ ++#define EMAC_ENABLE 0x001 /* - enable emac */ ++#define EMAC_DISABLE 0x002 /* - disable emac */ ++#define EMAC_SOFT_RST 0x004 /* - soft reset */ ++#define EMAC_SOFT_RESET 0x004 /* - emac soft reset */ ++#define EMAC_EXT_PHY 0x008 /* - external PHY select */ ++ ++ uint32 txControl; /* (30) transmit control */ ++#define EMAC_FD 0x001 /* - full duplex */ ++#define EMAC_FLOWMODE 0x002 /* - flow mode */ ++#define EMAC_NOBKOFF 0x004 /* - no backoff in */ ++#define EMAC_SMALLSLT 0x008 /* - small slot time */ ++ ++ uint32 txThreshold; /* (34) transmit threshold */ ++ uint32 mibControl; /* (38) mib control */ ++#define EMAC_NO_CLEAR 0x001 /* don't clear on read */ ++ ++ uint32 unused3[7]; ++ ++ uint32 pm0DataLo; /* (58) perfect match 0 data lo */ ++ uint32 pm0DataHi; /* (5C) perfect match 0 data hi (15:0) */ ++ uint32 pm1DataLo; /* (60) perfect match 1 data lo */ ++ uint32 pm1DataHi; /* (64) perfect match 1 data hi (15:0) */ ++ uint32 pm2DataLo; /* (68) perfect match 2 data lo */ ++ uint32 pm2DataHi; /* (6C) perfect match 2 data hi (15:0) */ ++ uint32 pm3DataLo; /* (70) perfect match 3 data lo */ ++ uint32 pm3DataHi; /* (74) perfect match 3 data hi (15:0) */ ++#define EMAC_CAM_V 0x10000 /* - cam index */ ++#define EMAC_CAM_VALID 0x00010000 ++ ++ uint32 unused4[98]; /* (78-1fc) */ ++ ++ EmacTxMib tx_mib; /* (200) emac tx mib */ ++ uint32 unused5[8]; /* (260-27c) */ ++ ++ EmacRxMib rx_mib; /* (280) rx mib */ ++ ++} EmacRegisters; ++ ++/* register offsets for subrouting access */ ++#define EMAC_RX_CONTROL 0x00 ++#define EMAC_RX_MAX_LENGTH 0x04 ++#define EMAC_TX_MAC_LENGTH 0x08 ++#define EMAC_MDIO_FREQ 0x10 ++#define EMAC_MDIO_DATA 0x14 ++#define EMAC_INT_MASK 0x18 ++#define EMAC_INT_STATUS 0x1C ++#define EMAC_CAM_DATA_LO 0x20 ++#define EMAC_CAM_DATA_HI 0x24 ++#define EMAC_CAM_CONTROL 0x28 ++#define EMAC_CONTROL 0x2C ++#define EMAC_TX_CONTROL 0x30 ++#define EMAC_TX_THRESHOLD 0x34 ++#define EMAC_MIB_CONTROL 0x38 ++ ++ ++#define EMAC1 ((volatile EmacRegisters * const) EMAC1_BASE) ++ ++/* ++** USB Registers ++*/ ++typedef struct UsbRegisters { ++ byte inttf_setting; ++ byte current_config; ++ uint16 status_frameNum; ++#define USB_LINK 0x2000 ++#define USB_BUS_RESET 0x1000 ++#define USB_SUSPENDED 0x0800 ++ byte unused1; ++ byte endpt_prnt; ++ byte endpt_dirn; ++ byte endpt_status; ++#define USB_ENDPOINT_0 0x01 ++#define USB_ENDPOINT_1 0x02 ++#define USB_ENDPOINT_2 0x04 ++#define USB_ENDPOINT_3 0x08 ++#define USB_ENDPOINT_4 0x10 ++#define USB_ENDPOINT_5 0x20 ++#define USB_ENDPOINT_6 0x40 ++#define USB_ENDPOINT_7 0x80 ++ uint32 unused2; ++ byte conf_mem_ctl; ++#define USB_CONF_MEM_RD 0x80 ++#define USB_CONF_MEM_RDY 0x40 ++ byte unused2a; ++ byte conf_mem_read_address; ++ byte conf_mem_write_address; ++ ++ byte unused3; ++ byte dev_req_bytesel; ++ uint16 ext_dev_data; ++ ++ byte unused4; ++ byte clr_fifo; ++ byte endpt_stall_reset; // use same endpoint #'s from above ++ byte usb_cntl; ++#define USB_FORCE_ERR 0x20 ++#define USB_SOFT_RESET 0x10 ++#define USB_RESUME 0x08 ++#define USB_COMMAND_ERR 0x04 ++#define USB_COMMAND_OVER 0x02 ++ byte irq_addr; ++ byte iso_out_in_addr; ++ byte blk_out_in_addr; ++ byte cntl_addr; ++ uint32 unusedx[2]; ++ uint32 tx_ram_write_port; ++ uint32 fifo_status; // (see bcm6338 data sheet for definition) ++ ++ uint32 irq_status; ++ uint32 irq_mask; ++#define USB_NEW_CONFIG 0x00000001 ++#define USB_SETUP_COMMAND_RECV 0x00000002 // non-standard setup cmd rcvd ++#define USB_OUT_FIFO_OV 0x00000004 ++#define USB_RESET_RECV 0x00000008 ++#define USB_SUSPEND_RECV 0x00000010 ++#define USB_FIFO_REWIND 0x00000020 ++#define USB_RX_BULK_FIFO_DATA_AVAIL 0x00000040 ++#define USB_RX_ISO_FIFO_DATA_AVAIL 0x00000080 ++#define USB_LINK_CHANGE 0x00010000 ++ uint32 endpt_cntl; ++#define USB_R_WK_EN 0x0100 ++#define USB_TX_EOP 0x0200 ++#define USB_TX_CNTL_DMA_EN 0x0400 ++#define USB_TX_BULK_DMA_EN 0x0800 ++#define USB_TX_ISO_DMA_EN 0x1000 ++#define USB_RX_CNTL_DMA_EN 0x2000 ++#define USB_RX_BULK_DMA_EN 0x4800 ++#define USB_RX_ISO_DMA_EN 0x8000 ++ uint32 rx_status_read_port; ++ uint32 confmem_read_port; ++ uint32 confmem_write_port; ++ uint32 fifo_ovf_count; ++ uint32 fifo_rewind_cnt; ++ uint32 terminal_count; ++} UsbRegisters; ++ ++#define USB ((volatile UsbRegisters * const) USB_CTL_BASE) ++ ++/* ++** ADSL core Registers ++*/ ++ ++#define _PADLINE(line) pad ## line ++#define _XSTR(line) _PADLINE(line) ++#define PAD _XSTR(__LINE__) ++ ++typedef struct AdslRegisters { ++ uint32 core_control; ++#define ADSL_RESET 0x01 ++ ++ uint32 core_status; ++#define ADSL_HOST_MSG 0x01 ++ ++ uint32 PAD; ++ uint32 bist_status; ++ uint32 PAD[4]; ++ uint32 int_status_i; /* 0x20 */ ++ uint32 int_mask_i; ++ uint32 int_status_f; ++ uint32 int_mask_f; ++#define ADSL_INT_HOST_MSG 0x00000020 ++#define ADSL_INT_DESC_ERR 0x00000400 ++#define ADSL_INT_DATA_ERR 0x00000800 ++#define ADSL_INT_DESC_PROTO_ERR 0x00001000 ++#define ADSL_INT_RCV_DESC_UF 0x00002000 ++#define ADSL_INT_RCV_FIFO_OF 0x00004000 ++#define ADSL_INT_XMT_FIFO_UF 0x00008000 ++#define ADSL_INT_RCV 0x00010000 ++#define ADSL_INT_XMT 0x01000000 ++ ++ uint32 PAD[116]; ++ ++ uint32 xmtcontrol_intr; /* 0x200 */ ++#define ADSL_DMA_XMT_EN 0x00000001 ++#define ADSL_DMA_XMT_LE 0x00000004 ++ uint32 xmtaddr_intr; ++#define ADSL_DMA_ADDR_MASK 0xFFFFF000 ++ uint32 xmtptr_intr; ++#define ADSL_DMA_LAST_DESC_MASK 0x00000FFF ++ uint32 xmtstatus_intr; ++#define ADSL_DMA_CURR_DESC_MASK 0x00000FFF ++#define ADSL_DMA_XMT_STATE_MASK 0x0000F000 ++#define ADSL_DMA_XMT_STATE_DIS 0x00000000 ++#define ADSL_DMA_XMT_STATE_ACT 0x00001000 ++#define ADSL_DMA_XMT_STATE_IDLE 0x00002000 ++#define ADSL_DMA_XMT_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_XMT_ERR_MASK 0x000F0000 ++#define ADSL_DMA_XMT_ERR_NONE 0x00000000 ++#define ADSL_DMA_XMT_ERR_DPE 0x00010000 ++#define ADSL_DMA_XMT_ERR_FIFO 0x00020000 ++#define ADSL_DMA_XMT_ERR_DTE 0x00030000 ++#define ADSL_DMA_XMT_ERR_DRE 0x00040000 ++ ++ uint32 rcvcontrol_intr; ++#define ADSL_DMA_RCV_EN 0x00000001 ++#define ADSL_DMA_RCV_FO 0x000000FE ++ uint32 rcvaddr_intr; ++ uint32 rcvptr_intr; ++ uint32 rcvstatus_intr; ++#define ADSL_DMA_RCV_STATE_MASK 0x0000F000 ++#define ADSL_DMA_RCV_STATE_DIS 0x00000000 ++#define ADSL_DMA_RCV_STATE_ACT 0x00001000 ++#define ADSL_DMA_RCV_STATE_IDLE 0x00002000 ++#define ADSL_DMA_RCV_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_RCV_ERR_MASK 0x000F0000 ++#define ADSL_DMA_RCV_ERR_NONE 0x00000000 ++#define ADSL_DMA_RCV_ERR_DPE 0x00010000 ++#define ADSL_DMA_RCV_ERR_FIFO 0x00020000 ++#define ADSL_DMA_RCV_ERR_DTE 0x00030000 ++#define ADSL_DMA_RCV_ERR_DRE 0x00040000 ++ ++ uint32 xmtcontrol_fast; ++ uint32 xmtaddr_fast; ++ uint32 xmtptr_fast; ++ uint32 xmtstatus_fast; ++ uint32 rcvcontrol_fast; ++ uint32 rcvaddr_fast; ++ uint32 rcvptr_fast; ++ uint32 rcvstatus_fast; ++ uint32 PAD[48]; ++ ++ uint32 host_message; /* 0x300 */ ++ uint32 PAD[805]; ++ uint32 core_reset; ++ uint32 core_error; ++ uint32 core_revision; ++ ++#define ADSL_CORE_REV 0x0000000F ++#define ADSL_CORE_TYPE 0x0000FFF0 ++} AdslRegisters; ++ ++#define ADSL ((volatile AdslRegisters * const) ADSL_BASE) ++ ++#if __cplusplus ++} ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6345_common.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6345_common.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6345_common.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6345_common.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,275 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6345_common.h */ ++/* DATE: 96/12/19 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6345 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6345_MAP_COMMON_H ++#define __BCM6345_MAP_COMMON_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++/* matches isb_decoder.v */ ++#define INTC_BASE 0xfffe0000 /* interrupts controller registers */ ++#define BB_BASE 0xfffe0100 /* bus bridge registers */ ++#define TIMR_BASE 0xfffe0200 /* timer registers */ ++#define UART_BASE 0xfffe0300 /* uart registers */ ++#define GPIO_BASE 0xfffe0400 /* gpio registers */ ++#define EMAC_BASE 0xfffe1800 /* EMAC control registers */ ++#define EBIC_BASE 0xfffe2000 /* EBI control registers */ ++#define PCMCIA_BASE 0xfffe2028 /* PCMCIA control registers */ ++#define USB_BASE 0xfffe2100 /* USB controll registers */ ++#define SDRAM_BASE 0xfffe2300 /* SDRAM control registers */ ++#define DMA_BASE 0xfffe2800 /* DMA control registers */ ++ ++/* DMA channel assignments */ ++#define EMAC_RX_CHAN 1 ++#define EMAC_TX_CHAN 2 ++#define EBI_RX_CHAN 5 ++#define EBI_TX_CHAN 6 ++#define RESERVED_RX_CHAN 9 ++#define RESERVED_TX_CHAN 10 ++#define USB_BULK_RX_CHAN 13 ++#define USB_BULK_TX_CHAN 14 ++#define USB_ISO_RX_CHAN 15 ++#define USB_ISO_TX_CHAN 16 ++#define USB_CNTL_RX_CHAN 17 ++#define USB_CNTL_TX_CHAN 18 ++ ++/* ++#-----------------------------------------------------------------------* ++# * ++#************************************************************************ ++*/ ++#define SDR_INIT_CTL 0x00 ++ /* Control Bits */ ++#define SDR_9BIT_COL (1<<11) ++#define SDR_32BIT (1<<10) ++#define SDR_PWR_DN (1<<9) ++#define SDR_SELF_REF (1<<8) ++#define SDR_SOFT_RST (1<<7) ++#define SDR_64x32 (3<<4) ++#define SDR_128MEG (2<<4) ++#define SDR_64MEG (1<<4) ++#define SDR_16MEG (0<<4) ++#define SDR_ENABLE (1<<3) ++#define SDR_MRS_CMD (1<<2) ++#define SDR_PRE_CMD (1<<1) ++#define SDR_CBR_CMD (1<<0) ++ ++#define SDR_CFG_REG 0x04 ++ /* Control Bits */ ++#define SDR_FULL_PG 0x00 ++#define SDR_BURST8 0x01 ++#define SDR_BURST4 0x02 ++#define SDR_BURST2 0x03 ++#define SDR_FAST_MEM (1<<2) ++#define SDR_SLOW_MEM 0x00 ++ ++#define SDR_REF_CTL 0x08 ++ /* Control Bits */ ++#define SDR_REF_EN (1<<15) ++ ++#define SDR_MEM_BASE 0x0c ++ /* Control Bits */ ++#define DRAM2MBSPC 0x00000000 ++#define DRAM8MBSPC 0x00000001 ++#define DRAM16MBSPC 0x00000002 ++#define DRAM32MBSPC 0x00000003 ++#define DRAM64MBSPC 0x00000004 ++ ++#define DRAM2MEG 0x00000000 /* See SDRAM config */ ++#define DRAM8MEG 0x00000001 /* See SDRAM config */ ++#define DRAM16MEG 0x00000002 /* See SDRAM config */ ++#define DRAM32MEG 0x00000003 /* See SDRAM config */ ++#define DRAM64MEG 0x00000004 /* See SDRAM config */ ++ ++/* ++#-----------------------------------------------------------------------* ++# * ++#************************************************************************ ++*/ ++#define CS0BASE 0x00 ++#define CS0CNTL 0x04 ++#define CS1BASE 0x08 ++#define CS1CNTL 0x0c ++#define CS2BASE 0x10 ++#define CS2CNTL 0x14 ++#define CS3BASE 0x18 ++#define CS3CNTL 0x1c ++#define CS4BASE 0x20 ++#define CS4CNTL 0x24 ++#define CS5BASE 0x28 ++#define CS5CNTL 0x2c ++#define CS6BASE 0x30 ++#define CS6CNTL 0x34 ++#define CS7BASE 0x38 ++#define CS7CNTL 0x3c ++#define EBICONFIG 0x40 ++ ++/* ++# CSxBASE settings ++# Size in low 4 bits ++# Base Address for match in upper 24 bits ++*/ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ ++/* CSxCNTL settings */ ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define ZEROWT 0x00000000 /* .. 0 WS */ ++#define ONEWT 0x00000002 /* .. 1 WS */ ++#define TWOWT 0x00000004 /* .. 2 WS */ ++#define THREEWT 0x00000006 /* .. 3 WS */ ++#define FOURWT 0x00000008 /* .. 4 WS */ ++#define FIVEWT 0x0000000a /* .. 5 WS */ ++#define SIXWT 0x0000000c /* .. 6 WS */ ++#define SEVENWT 0x0000000e /* .. 7 WS */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert chip select polarity */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. enable fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++ ++/* EBICONFIG settings */ ++#define EBI_MASTER_ENABLE 0x80000000 /* allow external masters */ ++#define EBI_EXT_MAST_PRIO 0x40000000 /* maximize ext master priority */ ++#define EBI_CTRL_ENABLE 0x20000000 ++#define EBI_TA_ENABLE 0x10000000 ++ ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++#define XMITBREAK 0x40 ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define BAUD115200 0x0a ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++#define TX4 0x40 ++#define RX4 0x04 ++#define RSTTXFIFOS 0x80 ++#define RSTRXFIFOS 0x40 ++#define DELTAIP 0x0001 ++#define TXUNDERR 0x0002 ++#define TXOVFERR 0x0004 ++#define TXFIFOTHOLD 0x0008 ++#define TXREADLATCH 0x0010 ++#define TXFIFOEMT 0x0020 ++#define RXUNDERR 0x0040 ++#define RXOVFERR 0x0080 ++#define RXTIMEOUT 0x0100 ++#define RXFIFOFULL 0x0200 ++#define RXFIFOTHOLD 0x0400 ++#define RXFIFONE 0x0800 ++#define RXFRAMERR 0x1000 ++#define RXPARERR 0x2000 ++#define RXBRK 0x4000 ++ ++#define RXIRQS 0x7fc0 ++#define TXIRQS 0x003e ++ ++#define CPU_CLK_EN 0x0001 ++#define UART_CLK_EN 0x0008 ++ ++#define BLKEN 06 ++ ++#define FMSEL_MASK 0xf0000000 // 31:28 ++#define FMSEL_SHFT 28 ++#define FM_HI_GEAR 0x08000000 // 27 ++#define FMCLKSEL 0x04000000 // 26 ++#define FMDIV_MASK 0x03000000 // 25:24 ++#define FMDIV_SHFT 24 ++#define FBDIV_MASK 0x00f00000 // 23:20 ++#define FBDIV_SHFT 20 ++#define FB_SEL 0x00010000 // 16 ++#define FU2SEL_MASK 0x0000f000 // 15:12 ++#define FU2SEL_SHFT 12 ++#define FU1SEL_MASK 0x00000f00 // 11:8 ++#define FU1SEL_SHFT 8 ++#define FU1PRS_MASK 0x000000e0 // 7:5 ++#define FU1PRS_SHFT 5 ++#define FU1POS_MASK 0x00000018 // 4:3 ++#define FU1POS_SHFT 3 ++#define SOFT_RESET 0x00000001 ++ ++#define FMSEL 0x08 ++ ++#define UART0CONTROL 0x01 ++#define UART0CONFIG 0x02 ++#define UART0RXTIMEOUT 0x03 ++#define UART0BAUD 0x04 ++#define UART0FIFOCFG 0x0a ++#define UART0INTMASK 0x10 ++#define UART0INTSTAT 0x12 ++#define UART0DATA 0x17 ++ ++#define GPIOTBUSSEL 0x03 ++#define GPIODIR 0x06 ++#define GPIOLED 0x09 ++#define GPIOIO 0x0a ++#define GPIOUARTCTL 0x0c ++ ++/*Defines below show which bit enables which UART signals */ ++#define RI1_EN 0x0001 ++#define CTS1_EN 0x0002 ++#define DCD1_EN 0x0004 ++#define DSR1_EN 0x0008 ++#define DTR1_EN 0x0010 ++#define RTS1_EN 0x0020 ++#define DO1_EN 0x0040 ++#define DI1_EN 0x0080 ++#define RI0_EN 0x0100 ++#define CTS0_EN 0x0200 ++#define DCD0_EN 0x0400 ++#define DSR0_EN 0x0800 ++#define DTR0_EN 0x1000 ++#define RTS0_EN 0x2000 ++ ++#if __cplusplus ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6345_map.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6345_map.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6345_map.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6345_map.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,939 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6345_map.h */ ++/* DATE: 96/12/19 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6345 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6345_MAP_H ++#define __BCM6345_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++#include "6345_common.h" ++#include "6345_intr.h" ++ ++/* macro to convert logical data addresses to physical */ ++/* DMA hardware must see physical address */ ++#define LtoP( x ) ( (uint32)x & 0x1fffffff ) ++#define PtoL( x ) ( LtoP(x) | 0xa0000000 ) ++ ++/* ++** Interrupt Controller ++*/ ++typedef struct IntControl { ++ uint32 RevID; /* (00) */ ++ uint16 testControl; /* (04) */ ++ uint16 blkEnables; /* (06) */ ++ ++#define USB_CLK_EN 0x0100 ++#define EMAC_CLK_EN 0x0080 ++#define ADSL_CLK_EN 0x0010 ++#define UART_CLK_EN 0x0008 ++#define EBI_CLK_EN 0x0004 ++#define BUS_CLK_EN 0x0002 ++#define CPU_CLK_EN 0x0001 ++ ++ uint32 pll_control; /* (08) */ ++#define FMSEL_MASK 0xf0000000 // 31:28 ++#define FMSEL_SHFT 28 ++#define FM_HI_GEAR 0x08000000 // 27 ++#define FMCLKSEL 0x04000000 // 26 ++#define FMDIV_MASK 0x03000000 // 25:24 ++#define FMDIV_SHFT 24 ++#define FBDIV_MASK 0x00f00000 // 23:20 ++#define FBDIV_SHFT 20 ++#define FB_SEL 0x00010000 // 16 ++#define FU2SEL_MASK 0x0000f000 // 15:12 ++#define FU2SEL_SHFT 12 ++#define FU1SEL_MASK 0x00000f00 // 11:8 ++#define FU1SEL_SHFT 8 ++#define FU1PRS_MASK 0x000000e0 // 7:5 ++#define FU1PRS_SHFT 5 ++#define FU1POS_MASK 0x00000018 // 4:3 ++#define FU1POS_SHFT 3 ++#define SOFT_RESET 0x00000001 ++ ++ uint32 IrqMask; /* (0c) */ ++ uint32 IrqStatus; /* (10) */ ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 4 ++#define EI_CLEAR_SHFT 8 ++#define EI_MASK_SHFT 12 ++#define EI_INSENS_SHFT 16 ++#define EI_LEVEL_SHFT 20 ++} IntControl; ++ ++#define PERF ((volatile IntControl * const) INTC_BASE) ++ ++/* ++** Bus Bridge Registers ++*/ ++typedef struct BusBridge { ++ uint16 status; ++#define BB_BUSY 0x8000 /* posted operation in progress */ ++#define BB_RD_PND 0x4000 /* read pending */ ++#define BB_RD_CMPLT 0x2000 /* read complete */ ++#define BB_ERROR 0x1000 /* posted write error */ ++#define BB_TEA 0x0800 /* transfer aborted */ ++ uint16 abortTimeoutCnt; /* abort timeout value */ ++ ++ byte writePostEnable; ++#define BB_POST_TIMR_EN 0x08 /* post writes to timer regs */ ++#define BB_POST_GPIO_EN 0x04 /* post writes to gpio regs */ ++#define BB_POST_INTC_EN 0x02 /* post writes to interrupt controller regs */ ++#define BB_POST_UART_EN 0x01 /* post writes to uart regs */ ++ byte unused1[5]; ++ uint16 postAddr; /* posted read address (lower half) */ ++ byte unused2[3]; ++ byte postData; /* posted read data */ ++} BusBridge; ++ ++/* register offsets (needed for EBI master access) */ ++#define BB_STATUS 0 ++#define BB_ABORT_TO_CNT 2 ++#define BB_WR_POST_EN 4 ++#define BB_RD_POST_ADDR 10 ++#define BB_RD_POST_DATA 12 ++ ++#define BRIDGE *bridge ((volatile BusBridge * const) BB_BASE) ++ ++/* ++** Timer ++*/ ++typedef struct Timer { ++ uint16 unused0; ++ byte TimerMask; ++#define TIMER0EN 0x01 ++#define TIMER1EN 0x02 ++#define TIMER2EN 0x04 ++ byte TimerInts; ++#define TIMER0 0x01 ++#define TIMER1 0x02 ++#define TIMER2 0x04 ++#define WATCHDOG 0x08 ++ uint32 TimerCtl0; ++ uint32 TimerCtl1; ++ uint32 TimerCtl2; ++#define TIMERENABLE 0x80000000 ++#define RSTCNTCLR 0x40000000 ++ uint32 TimerCnt0; ++ uint32 TimerCnt1; ++ uint32 TimerCnt2; ++ uint32 WatchDogDefCount; ++ ++ /* Write 0xff00 0x00ff to Start timer ++ * Write 0xee00 0x00ee to Stop and re-load default count ++ * Read from this register returns current watch dog count ++ */ ++ uint32 WatchDogCtl; ++ ++ /* Number of 40-MHz ticks for WD Reset pulse to last */ ++ uint32 WDResetCount; ++} Timer; ++ ++#define TIMER ((volatile Timer * const) TIMR_BASE) ++ ++/* ++** UART ++*/ ++typedef struct UartChannel { ++ byte unused0; ++ byte control; ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ ++ byte config; ++#define XMITBREAK 0x40 ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ /* 4-LSBS represent STOP bits/char ++ * in 1/8 bit-time intervals. Zero ++ * represents 1/8 stop bit interval. ++ * Fifteen represents 2 stop bits. ++ */ ++ byte fifoctl; ++#define RSTTXFIFOS 0x80 ++#define RSTRXFIFOS 0x40 ++ /* 5-bit TimeoutCnt is in low bits of this register. ++ * This count represents the number of characters ++ * idle times before setting receive Irq when below threshold ++ */ ++ uint32 baudword; ++ /* When divide SysClk/2/(1+baudword) we should get 32*bit-rate ++ */ ++ ++ byte txf_levl; /* Read-only fifo depth */ ++ byte rxf_levl; /* Read-only fifo depth */ ++ byte fifocfg; /* Upper 4-bits are TxThresh, Lower are ++ * RxThreshold. Irq can be asserted ++ * when rx fifo> thresh, txfifo RI1 I Controlled by UartCtl[0] ELSE 0 ++ * GPIO[0] -> DMATC_i I Always ++ * GPIO[0] -> DMATC_o O Controlled by dma_enable_n|dma_drive_n ++ * GPIO[0] -> ebi_bsize[0] I Always ++ * ++ * GPIO[1] -> CTS1 I Controlled by UartCtl[1] ELSE 0 ++ * GPIO[1] -> DMAACK1 (18) O Controlled by dma_enable_n ++ * GPIO[1] -> ebi_bg_b O Controlled by ebi_master_n ++ * ++ * GPIO[2] -> DCD1 I Controlled by UartCtl[2] ELSE 0 ++ * GPIO[2] -> ebi_bsize[1] I Always ++ * ++ * GPIO[3] -> DSR1 I Controlled by UartCtl[3] ELSE 0 ++ * GPIO[3] -> INT2 I Always ++ * GPIO[3] -> ebi_bsize[2] I Always ++ * ++ * GPIO[4] -> DTR1 O Controlled by UartCtl[4]&GpioDir[4] ++ * GPIO[4] -> INT3 I Always ++ * GPIO[4] -> ebi_burst I Always ++ * ++ * GPIO[5] -> RTS1 O Controlled by UartCtl[5]&GpioDir[5] ++ * GPIO[5] -> DMAACK0 (17) O Controlled by dma_enable_n ++ * GPIO[5] -> ebi_tsize I Always ++ * ++ * GPIO[6] -> sDout1 O Controlled by UartCtl[6]&GpioDir[6] ++ * GPIO[6] -> DMARQ1 (18) I Always ++ * GPIO[6] -> ebi_bb_i I Always ++ * GPIO[6] -> ebi_bb_o O Controlled by ebi_master_n|ebi_bb_oen ++ * ++ * GPIO[7] -> sDin1 I Controlled by UartCtl[7] ELSE 0 ++ * GPIO[7] -> ebi_br_b I Always ++ * GPIO[7] -> DMARQ0 (17) I Always ++ * ++ * ------ ++ * GPIO_B ++ * ------ ++ * ++ * GPIO[8] -> RI0 I Controlled by UartCtl[8] ELSE 0 ++ * GPIO[8] -> ebi_cs_b[6] O Controlled by ebi_cs_en[6] ++ * ++ * GPIO[9] -> CTS0 I Controlled by UartCtl[9] ELSE 0 ++ * ++ * GPIO[a] -> DCD0 I Controlled by UartCtl[a] ELSE 0 ++ * GPIO[a] -> ebi_cs_b[7] O Controlled by ebi_cs_en[7] ++ * ++ * GPIO[b] -> DSR0 I Controlled by UartCtl[b] ELSE 0 ++ * GPIO[b] -> ebi_int_cs_b I Always ++ * ++ * GPIO[c] -> DTR0 O Controlled by UartCtl[c]&GpioDir[c] ++ * ++ * GPIO[d] -> RTS0 O Controlled by UartCtl[d]&&GpioDir[d] ++ * ++ * GPIO[e] -> INT0 I Always ++ * ++ * GPIO[f] -> INT1 I Always ++ * ++ * sDout0 -> (bist_en[15]) ? pll_clk48:sDout0_int ++ * ++ *********************************************************************/ ++ ++} GpioControl; ++ ++#define GPIO ((volatile GpioControl * const) GPIO_BASE) ++ ++#define GPIO_NUM_MAX_BITS_MASK 0x0f ++#define GPIO_NUM_TO_MASK(X) (1 << ((X) & GPIO_NUM_MAX_BITS_MASK)) ++ ++/* ++** DMA Channel (1 .. 20) ++*/ ++typedef struct DmaChannel { ++ uint32 cfg; /* (00) assorted configuration */ ++#define DMA_FLOWC_EN 0x00000010 /* flow control enable */ ++#define DMA_WRAP_EN 0x00000008 /* use DMA_WRAP bit */ ++#define DMA_CHAINING 0x00000004 /* chaining mode */ ++#define DMA_STALL 0x00000002 ++#define DMA_ENABLE 0x00000001 /* set to enable channel */ ++ uint32 maxBurst; /* (04) max burst length permitted */ ++ /* non-chaining / chaining */ ++ uint32 startAddr; /* (08) source addr / ring start address */ ++ uint32 length; /* (0c) xfer len / ring len */ ++#define DMA_KICKOFF 0x80000000 /* start non-chaining xfer */ ++ ++ uint32 bufStat; /* (10) buffer status for non-chaining */ ++ uint32 intStat; /* (14) interrupts control and status */ ++ uint32 intMask; /* (18) interrupts mask */ ++#define DMA_BUFF_DONE 0x00000001 /* buffer done */ ++#define DMA_DONE 0x00000002 /* packet xfer complete */ ++#define DMA_NO_DESC 0x00000004 /* no valid descriptors */ ++ ++// DMA HW bits are clugy in this version of chip (mask/status shifted) ++#define DMA_BUFF_DONE_MASK 0x00000004 /* buffer done */ ++#define DMA_DONE_MASK 0x00000001 /* packet xfer complete */ ++#define DMA_NO_DESC_MASK 0x00000002 /* no valid descriptors */ ++ ++ uint32 fcThreshold; /* (1c) flow control threshold */ ++ uint32 numAlloc; /* */ ++ uint32 unused[7]; /* (20-3c) pad to next descriptor */ ++} DmaChannel; ++/* register offsets, useful for ebi master access */ ++#define DMA_CFG 0 ++#define DMA_MAX_BURST 4 ++#define DMA_START_ADDR 8 ++#define DMA_LENGTH 12 ++#define DMA_BUF_STAT 16 ++#define DMA_INT_STAT 20 ++#define DMA_FC_THRESHOLD 24 ++#define DMA_NUM_ALLOC 28 ++ ++ ++/* paste in your program ... ++DmaChannel *dmaChannels = (DmaChannel *)DMA_BASE; ++DmaChannel *dma1 = dmaChannels[1]; ++*/ ++ ++ ++/* ++** DMA Buffer ++*/ ++typedef struct DmaDesc { ++ uint16 length; /* in bytes of data in buffer */ ++ uint16 status; /* buffer status */ ++#define DMA_OWN 0x8000 /* cleared by DMA, set by SW */ ++#define DMA_EOP 0x0800 /* last buffer in packet */ ++#define DMA_SOP 0x0400 /* first buffer in packet */ ++#define DMA_WRAP 0x0200 /* */ ++#define DMA_APPEND_CRC 0x0100 /* .. for emac tx */ ++#define DATA_FLAG 0x0100 /* .. for secmod rx */ ++#define AUTH_FAIL_FLAG 0x0100 /* .. for secmod tx */ ++ ++/* EMAC Descriptor Status definitions */ ++#define EMAC_UNDERRUN 0x4000 /* Tx underrun, dg-mod ???) */ ++#define EMAC_MISS 0x0080 /* framed address recognition failed (promiscuous) */ ++#define EMAC_BRDCAST 0x0040 /* DA is Broadcast */ ++#define EMAC_MULT 0x0020 /* DA is multicast */ ++#define EMAC_LG 0x0010 /* frame length > RX_LENGTH register value */ ++#define EMAC_NO 0x0008 /* Non-Octet aligned */ ++#define EMAC_RXER 0x0004 /* RX_ERR on MII while RX_DV assereted */ ++#define EMAC_CRC_ERROR 0x0002 /* CRC error */ ++#define EMAC_OV 0x0001 /* Overflow */ ++ ++/* HDLC Descriptor Status definitions */ ++#define DMA_HDLC_TX_ABORT 0x0100 ++#define DMA_HDLC_RX_OVERRUN 0x4000 ++#define DMA_HDLC_RX_TOO_LONG 0x2000 ++#define DMA_HDLC_RX_CRC_OK 0x1000 ++#define DMA_HDLC_RX_ABORT 0x0100 ++ ++ uint32 address; /* address of data */ ++} DmaDesc; ++ ++/* ++** Sdram Controller ++*/ ++typedef struct SdramControllerRegs { ++ uint16 unused1; ++ uint16 initControl; /* 02 */ ++#define SD_POWER_DOWN 0x200 /* put sdram into power down */ ++#define SD_SELF_REFRESH 0x100 /* enable self refresh mode */ ++#define SD_SOFT_RESET 0x080 /* soft reset all sdram controller regs */ ++#define SD_EDO_SELECT 0x040 /* select EDO mode */ ++#define SD_EDO_WAIT_STATE 0x020 /* add an EDO wait state */ ++#define SD_8MEG 0x010 /* map sdram to 8 megs */ ++#define SD_MASTER_ENABLE 0x008 /* enable accesses to external sdram */ ++#define SD_MRS 0x004 /* generate a mode register select cycle */ ++#define SD_PRECHARGE 0x002 /* generate a precharge cycle */ ++#define SD_CBR 0x001 /* generate a refresh cycle */ ++ uint8 unused2[3]; ++ uint8 config; /* 07 */ ++#define SD_FAST_MEM 0x04 /* 1=CAS latency of 2, 0 = CAS latency of 3 */ ++#define SD_BURST_LEN 0x03 /* set burst length */ ++#define SD_BURST_FULL_PAGE 0x00 /* .. full page */ ++#define SD_BURST_8 0x01 /* .. 8 words */ ++#define SD_BURST_4 0x02 /* .. 4 words */ ++#define SD_BURST_2 0x03 /* .. 2 words */ ++ uint16 unused3; ++ uint16 refreshControl; /* 0a */ ++#define SD_REFRESH_ENABLE 0x8000 /* refresh enable */ ++#define SD_REFRESH_PERIOD 0x00ff /* refresh period (16 x n x clock_period) */ ++ ++ uint32 memoryBase; /* 0c */ ++#define SD_MEMBASE_MASK 0xffffe000 /* base address mask */ ++#define SD_MEMSIZE_8MEG 0x00000001 /* memory is 8 meg */ ++#define SD_MEMSIZE_2MEG 0x00000001 /* memory is 2 meg */ ++ ++} SdramControllerRegs; ++ ++/* ++** External Bus Interface ++*/ ++typedef struct EbiChipSelect { ++ uint32 base; /* base address in upper 24 bits */ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ uint32 config; ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define EBI_WTST_SHIFT 1 /* .. for shifting wait states */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_WREN 0x00000020 /* enable posted writes */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert something, ++ ** don't know what yet */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. use fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++} EbiChipSelect; ++ ++typedef struct EbiRegisters { ++ EbiChipSelect cs[5]; /* size chip select configuration */ ++ uint32 reserved[6]; ++ uint32 ebi_config; /* configuration */ ++#define EBI_MASTER_ENABLE 0x80000000 /* allow external masters */ ++#define EBI_EXT_MAST_PRIO 0x40000000 /* maximize ext master priority */ ++#define EBI_CTRL_ENABLE 0x20000000 ++#define EBI_TA_ENABLE 0x10000000 ++ uint32 dma_control; ++#define EBI_TX_INV_IRQ_EN 0x00080000 ++#define EBI_RX_INV_IRQ_EN 0x00040000 ++#define EBI_TX_PKT_DN_IRQ_EN 0x00020000 ++#define EBI_RX_PKT_DN_IRQ_EN 0x00010000 ++#define EBI_TX_INV_CLR 0x00001000 ++#define EBI_RX_INV_CLR 0x00000800 ++#define EBI_CHAINING 0x00000400 ++#define EBI_EXT_MODE 0x00000200 ++#define EBI_HALF_WORD 0x00000100 ++#define EBI_TX_PKT_DN_CLR 0x00000080 ++#define EBI_RX_PKT_DN_CLR 0x00000040 ++#define EBI_TX_BUF_DN_CLR 0x00000020 ++#define EBI_RX_BUF_DN_CLR 0x00000010 ++#define EBI_TX_BUF_DN_IRQ_EN 0x00000008 ++#define EBI_RX_BUF_DN_IRQ_EN 0x00000004 ++#define EBI_TX_EN 0x00000002 ++#define EBI_RX_EN 0x00000001 ++ uint32 dma_rx_start_addr; ++ uint32 dma_rx_buf_size; ++ uint32 dma_tx_start_addr; ++ uint32 dma_tx_buf_size; ++ uint32 dma_status; ++#define EBI_TX_INV_DESC 0x00000020 ++#define EBI_RX_INV_DESC 0x00000010 ++#define EBI_TX_PKT_DN 0x00000008 ++#define EBI_RX_PKT_DN 0x00000004 ++#define EBI_TX_BUF_DN 0x00000002 ++#define EBI_RX_BUF_DN 0x00000001 ++} EbiRegisters; ++ ++#define EBIC ((volatile EbiRegisters * const) EBIC_BASE) ++ ++typedef struct PcmciaRegisters { ++ /*Each of base has 24 bits of base address followed by size select field*/ ++ uint32 mem_base; ++ uint32 mem_cntrl; ++ uint32 attr_base; ++ uint32 attr_cntrl; ++ uint32 io_base; ++ uint32 io_cntrl; ++#define PCMCIA_CS_ENABLE 0x00000001 ++#define PCMCIA_CS_FIFO_ENABLE 0x00000200 ++#define PCMCIA_DSTSIZE_16 0x00000010 // 0 -8bit, 1- 16bit ++#define PCMCIA_RENDIAN 0x00000400 ++ /* Skip ECR and EBI-DMA registers */ ++ uint32 other1[7]; ++ ++ byte mem_waitcnt4; // Only bits [5:0] ++ byte mem_waitcnt3; // Only bits [4:0] ++ byte mem_waitcnt2; // Only bits [4:0] ++ byte mem_waitcnt1; // Only bits [4:0] ++ ++ byte attr_waitcnt4; // Only bits [5:0] ++ byte attr_waitcnt3; // Only bits [4:0] ++ byte attr_waitcnt2; // Only bits [4:0] ++ byte attr_waitcnt1; // Only bits [4:0] ++ ++ byte io_waitcnt4; // Only bits [5:0] ++ byte io_waitcnt3; // Only bits [4:0] ++ byte io_waitcnt2; // Only bits [4:0] ++ byte io_waitcnt1; // Only bits [4:0] ++ ++} PcmciaRegisters; ++ ++#define PCMCIA ((volatile PcmciaRegisters * const) PCMCIA_BASE) ++ ++/* ++** EMAC transmit MIB counters ++*/ ++typedef struct EmacTxMib { ++ uint32 tx_good_octets; /* (200) good byte count */ ++ uint32 tx_good_pkts; /* (204) good pkt count */ ++ uint32 tx_octets; /* (208) good and bad byte count */ ++ uint32 tx_pkts; /* (20c) good and bad pkt count */ ++ uint32 tx_broadcasts_pkts; /* (210) good broadcast packets */ ++ uint32 tx_multicasts_pkts; /* (214) good mulitcast packets */ ++ uint32 tx_len_64; /* (218) RMON tx pkt size buckets */ ++ uint32 tx_len_65_to_127; /* (21c) */ ++ uint32 tx_len_128_to_255; /* (220) */ ++ uint32 tx_len_256_to_511; /* (224) */ ++ uint32 tx_len_512_to_1023; /* (228) */ ++ uint32 tx_len_1024_to_max; /* (22c) */ ++ uint32 tx_jabber_pkts; /* (230) > 1518 with bad crc */ ++ uint32 tx_oversize_pkts; /* (234) > 1518 with good crc */ ++ uint32 tx_fragment_pkts; /* (238) < 63 with bad crc */ ++ uint32 tx_underruns; /* (23c) fifo underrun */ ++ uint32 tx_total_cols; /* (240) total collisions in all tx pkts */ ++ uint32 tx_single_cols; /* (244) tx pkts with single collisions */ ++ uint32 tx_multiple_cols; /* (248) tx pkts with multiple collisions */ ++ uint32 tx_excessive_cols; /* (24c) tx pkts with excessive cols */ ++ uint32 tx_late_cols; /* (250) tx pkts with late cols */ ++ uint32 tx_defered; /* (254) tx pkts deferred */ ++ uint32 tx_carrier_lost; /* (258) tx pkts with CRS lost */ ++ uint32 tx_pause_pkts; /* (25c) tx pause pkts sent */ ++#define NumEmacTxMibVars 24 ++} EmacTxMib; ++ ++/* ++** EMAC receive MIB counters ++*/ ++typedef struct EmacRxMib { ++ uint32 rx_good_octets; /* (280) good byte count */ ++ uint32 rx_good_pkts; /* (284) good pkt count */ ++ uint32 rx_octets; /* (288) good and bad byte count */ ++ uint32 rx_pkts; /* (28c) good and bad pkt count */ ++ uint32 rx_broadcasts_pkts; /* (290) good broadcast packets */ ++ uint32 rx_multicasts_pkts; /* (294) good mulitcast packets */ ++ uint32 rx_len_64; /* (298) RMON rx pkt size buckets */ ++ uint32 rx_len_65_to_127; /* (29c) */ ++ uint32 rx_len_128_to_255; /* (2a0) */ ++ uint32 rx_len_256_to_511; /* (2a4) */ ++ uint32 rx_len_512_to_1023; /* (2a8) */ ++ uint32 rx_len_1024_to_max; /* (2ac) */ ++ uint32 rx_jabber_pkts; /* (2b0) > 1518 with bad crc */ ++ uint32 rx_oversize_pkts; /* (2b4) > 1518 with good crc */ ++ uint32 rx_fragment_pkts; /* (2b8) < 63 with bad crc */ ++ uint32 rx_missed_pkts; /* (2bc) missed packets */ ++ uint32 rx_crc_align_errs; /* (2c0) both or either */ ++ uint32 rx_undersize; /* (2c4) < 63 with good crc */ ++ uint32 rx_crc_errs; /* (2c8) crc errors (only) */ ++ uint32 rx_align_errs; /* (2cc) alignment errors (only) */ ++ uint32 rx_symbol_errs; /* (2d0) pkts with RXERR assertions (symbol errs) */ ++ uint32 rx_pause_pkts; /* (2d4) MAC control, PAUSE */ ++ uint32 rx_nonpause_pkts; /* (2d8) MAC control, not PAUSE */ ++#define NumEmacRxMibVars 23 ++} EmacRxMib; ++ ++typedef struct EmacRegisters { ++ uint32 rxControl; /* (00) receive control */ ++#define EMAC_PM_REJ 0x80 /* - reject DA match in PMx regs */ ++#define EMAC_UNIFLOW 0x40 /* - accept cam match fc */ ++#define EMAC_FC_EN 0x20 /* - enable flow control */ ++#define EMAC_LOOPBACK 0x10 /* - loopback */ ++#define EMAC_PROM 0x08 /* - promiscuous */ ++#define EMAC_RDT 0x04 /* - ignore transmissions */ ++#define EMAC_ALL_MCAST 0x02 /* - ignore transmissions */ ++#define EMAC_NO_BCAST 0x01 /* - ignore transmissions */ ++ ++ ++ uint32 rxMaxLength; /* (04) receive max length */ ++ uint32 txMaxLength; /* (08) transmit max length */ ++ uint32 unused1[1]; ++ uint32 mdioFreq; /* (10) mdio frequency */ ++#define EMAC_MII_PRE_EN 0x0100 /* prepend preamble sequence */ ++#define EMAC_MDIO_PRE 0x100 /* - enable MDIO preamble */ ++#define EMAC_MDC_FREQ 0x0ff /* - mdio frequency */ ++ ++ uint32 mdioData; /* (14) mdio data */ ++#define MDIO_WR 0x50020000 /* - write framing */ ++#define MDIO_RD 0x60020000 /* - read framing */ ++#define MDIO_PMD_SHIFT 23 ++#define MDIO_REG_SHIFT 18 ++ ++ uint32 intMask; /* (18) int mask */ ++ uint32 intStatus; /* (1c) int status */ ++#define EMAC_FLOW_INT 0x04 /* - flow control event */ ++#define EMAC_MIB_INT 0x02 /* - mib event */ ++#define EMAC_MDIO_INT 0x01 /* - mdio event */ ++ ++ uint32 unused2[3]; ++ uint32 config; /* (2c) config */ ++#define EMAC_ENABLE 0x001 /* - enable emac */ ++#define EMAC_DISABLE 0x002 /* - disable emac */ ++#define EMAC_SOFT_RST 0x004 /* - soft reset */ ++#define EMAC_SOFT_RESET 0x004 /* - emac soft reset */ ++#define EMAC_EXT_PHY 0x008 /* - external PHY select */ ++ ++ uint32 txControl; /* (30) transmit control */ ++#define EMAC_FD 0x001 /* - full duplex */ ++#define EMAC_FLOWMODE 0x002 /* - flow mode */ ++#define EMAC_NOBKOFF 0x004 /* - no backoff in */ ++#define EMAC_SMALLSLT 0x008 /* - small slot time */ ++ ++ uint32 txThreshold; /* (34) transmit threshold */ ++ uint32 mibControl; /* (38) mib control */ ++#define EMAC_NO_CLEAR 0x001 /* don't clear on read */ ++ ++ uint32 unused3[7]; ++ ++ uint32 pm0DataLo; /* (58) perfect match 0 data lo */ ++ uint32 pm0DataHi; /* (5C) perfect match 0 data hi (15:0) */ ++ uint32 pm1DataLo; /* (60) perfect match 1 data lo */ ++ uint32 pm1DataHi; /* (64) perfect match 1 data hi (15:0) */ ++ uint32 pm2DataLo; /* (68) perfect match 2 data lo */ ++ uint32 pm2DataHi; /* (6C) perfect match 2 data hi (15:0) */ ++ uint32 pm3DataLo; /* (70) perfect match 3 data lo */ ++ uint32 pm3DataHi; /* (74) perfect match 3 data hi (15:0) */ ++#define EMAC_CAM_V 0x10000 /* - cam index */ ++#define EMAC_CAM_VALID 0x00010000 ++ ++ uint32 unused4[98]; /* (78-1fc) */ ++ ++ EmacTxMib tx_mib; /* (200) emac tx mib */ ++ uint32 unused5[8]; /* (260-27c) */ ++ ++ EmacRxMib rx_mib; /* (280) rx mib */ ++ ++} EmacRegisters; ++ ++/* register offsets for subrouting access */ ++#define EMAC_RX_CONTROL 0x00 ++#define EMAC_RX_MAX_LENGTH 0x04 ++#define EMAC_TX_MAC_LENGTH 0x08 ++#define EMAC_MDIO_FREQ 0x10 ++#define EMAC_MDIO_DATA 0x14 ++#define EMAC_INT_MASK 0x18 ++#define EMAC_INT_STATUS 0x1C ++#define EMAC_CAM_DATA_LO 0x20 ++#define EMAC_CAM_DATA_HI 0x24 ++#define EMAC_CAM_CONTROL 0x28 ++#define EMAC_CONTROL 0x2C ++#define EMAC_TX_CONTROL 0x30 ++#define EMAC_TX_THRESHOLD 0x34 ++#define EMAC_MIB_CONTROL 0x38 ++ ++ ++#define EMAC ((volatile EmacRegisters * const) EMAC_BASE) ++ ++/* ++** USB Registers ++*/ ++typedef struct UsbRegisters { ++ byte inttf_setting; ++ byte current_config; ++ uint16 status_frameNum; ++#define USB_BUS_RESET 0x1000 ++#define USB_SUSPENDED 0x0800 ++ byte unused1; ++ byte endpt_prnt; ++ byte endpt_dirn; ++ byte endpt_status; ++#define USB_ENDPOINT_0 0x01 ++#define USB_ENDPOINT_1 0x02 ++#define USB_ENDPOINT_2 0x04 ++#define USB_ENDPOINT_3 0x08 ++#define USB_ENDPOINT_4 0x10 ++#define USB_ENDPOINT_5 0x20 ++#define USB_ENDPOINT_6 0x40 ++#define USB_ENDPOINT_7 0x80 ++ uint32 unused2; ++ byte conf_mem_ctl; ++#define USB_CONF_MEM_RD 0x80 ++#define USB_CONF_MEM_RDY 0x40 ++ byte unused2a; ++ byte conf_mem_read_address; ++ byte conf_mem_write_address; ++ ++ byte unused3; ++ byte dev_req_bytesel; ++ uint16 ext_dev_data; ++ ++ byte unused4; ++ byte clr_fifo; ++ byte endpt_stall_reset; // use same endpoint #'s from above ++ byte usb_cntl; ++#define USB_FORCE_ERR 0x20 ++#define USB_SOFT_RESET 0x10 ++#define USB_RESUME 0x08 ++#define USB_COMMAND_ERR 0x04 ++#define USB_COMMAND_OVER 0x02 ++ byte irq_addr; ++ byte iso_out_in_addr; ++ byte blk_out_in_addr; ++ byte cntl_addr; ++ uint32 mux_cntl; ++#define USB_TX_DMA_OPER 0x00000000 ++#define USB_TX_CNTL_FIFO_OPER 0x00000004 ++#define USB_TX_BULK_FIFO_OPER 0x00000008 ++#define USB_TX_ISO_FIFO_OPER 0x0000000c ++#define USB_TX_IRQ_OPER 0x00000010 ++#define USB_RX_DMA_OPER 0x00000000 ++#define USB_RX_CNTL_FIFO_OPER 0x00000001 ++#define USB_RX_BULK_FIFO_OPER 0x00000002 ++#define USB_RX_ISO_FIFO_OPER 0x00000003 ++ uint32 rx_ram_read_port; ++ uint32 tx_ram_write_port; ++ uint32 fifo_status; ++#define USB_CTRLI_FIFO_FULL 0x00000001 ++#define USB_CTRLI_FIFO_EMPTY 0x00000002 ++#define USB_CTRLO_FIFO_FULL 0x00000100 ++#define USB_CTRLO_FIFO_EMPTY 0x00000200 ++ uint32 irq_status; ++ uint32 irq_mask; ++#define USB_NEW_CONFIG 0x01 ++#define USB_SETUP_COMMAND_RECV 0x02 // non-standard setup command received ++#define USB_OUT_FIFO_OV 0x04 ++#define USB_RESET_RECV 0x08 ++#define USB_SUSPEND_RECV 0x10 ++#define USB_FIFO_REWIND 0x20 ++#define USB_RX_BULK_FIFO_DATA_AVAIL 0x40 ++#define USB_RX_ISO_FIFO_DATA_AVAIL 0x80 ++ uint32 endpt_cntl; ++#define USB_R_WK_EN 0x0100 ++#define USB_TX_EOP 0x0200 ++#define USB_TX_CNTL_DMA_EN 0x0400 ++#define USB_TX_BULK_DMA_EN 0x0800 ++#define USB_TX_ISO_DMA_EN 0x1000 ++#define USB_RX_CNTL_DMA_EN 0x2000 ++#define USB_RX_BULK_DMA_EN 0x4800 ++#define USB_RX_ISO_DMA_EN 0x8000 ++ uint32 rx_status_read_port; ++ uint32 confmem_read_port; ++ uint32 confmem_write_port; ++ uint32 fifo_ovf_count; ++ uint32 fifo_rewind_cnt; ++} UsbRegisters; ++ ++#define USB ((volatile UsbRegisters * const) USB_BASE) ++ ++/* ++** ADSL core Registers ++*/ ++ ++#define _PADLINE(line) pad ## line ++#define _XSTR(line) _PADLINE(line) ++#define PAD _XSTR(__LINE__) ++ ++typedef struct AdslRegisters { ++ uint32 core_control; ++#define ADSL_RESET 0x01 ++ ++ uint32 core_status; ++#define ADSL_HOST_MSG 0x01 ++ ++ uint32 PAD; ++ uint32 bist_status; ++ uint32 PAD[4]; ++ uint32 int_status_i; /* 0x20 */ ++ uint32 int_mask_i; ++ uint32 int_status_f; ++ uint32 int_mask_f; ++#define ADSL_INT_HOST_MSG 0x00000020 ++#define ADSL_INT_DESC_ERR 0x00000400 ++#define ADSL_INT_DATA_ERR 0x00000800 ++#define ADSL_INT_DESC_PROTO_ERR 0x00001000 ++#define ADSL_INT_RCV_DESC_UF 0x00002000 ++#define ADSL_INT_RCV_FIFO_OF 0x00004000 ++#define ADSL_INT_XMT_FIFO_UF 0x00008000 ++#define ADSL_INT_RCV 0x00010000 ++#define ADSL_INT_XMT 0x01000000 ++ ++ uint32 PAD[116]; ++ ++ uint32 xmtcontrol_intr; /* 0x200 */ ++#define ADSL_DMA_XMT_EN 0x00000001 ++#define ADSL_DMA_XMT_LE 0x00000004 ++ uint32 xmtaddr_intr; ++#define ADSL_DMA_ADDR_MASK 0xFFFFF000 ++ uint32 xmtptr_intr; ++#define ADSL_DMA_LAST_DESC_MASK 0x00000FFF ++ uint32 xmtstatus_intr; ++#define ADSL_DMA_CURR_DESC_MASK 0x00000FFF ++#define ADSL_DMA_XMT_STATE_MASK 0x0000F000 ++#define ADSL_DMA_XMT_STATE_DIS 0x00000000 ++#define ADSL_DMA_XMT_STATE_ACT 0x00001000 ++#define ADSL_DMA_XMT_STATE_IDLE 0x00002000 ++#define ADSL_DMA_XMT_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_XMT_ERR_MASK 0x000F0000 ++#define ADSL_DMA_XMT_ERR_NONE 0x00000000 ++#define ADSL_DMA_XMT_ERR_DPE 0x00010000 ++#define ADSL_DMA_XMT_ERR_FIFO 0x00020000 ++#define ADSL_DMA_XMT_ERR_DTE 0x00030000 ++#define ADSL_DMA_XMT_ERR_DRE 0x00040000 ++ ++ uint32 rcvcontrol_intr; ++#define ADSL_DMA_RCV_EN 0x00000001 ++#define ADSL_DMA_RCV_FO 0x000000FE ++ uint32 rcvaddr_intr; ++ uint32 rcvptr_intr; ++ uint32 rcvstatus_intr; ++#define ADSL_DMA_RCV_STATE_MASK 0x0000F000 ++#define ADSL_DMA_RCV_STATE_DIS 0x00000000 ++#define ADSL_DMA_RCV_STATE_ACT 0x00001000 ++#define ADSL_DMA_RCV_STATE_IDLE 0x00002000 ++#define ADSL_DMA_RCV_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_RCV_ERR_MASK 0x000F0000 ++#define ADSL_DMA_RCV_ERR_NONE 0x00000000 ++#define ADSL_DMA_RCV_ERR_DPE 0x00010000 ++#define ADSL_DMA_RCV_ERR_FIFO 0x00020000 ++#define ADSL_DMA_RCV_ERR_DTE 0x00030000 ++#define ADSL_DMA_RCV_ERR_DRE 0x00040000 ++ ++ uint32 xmtcontrol_fast; ++ uint32 xmtaddr_fast; ++ uint32 xmtptr_fast; ++ uint32 xmtstatus_fast; ++ uint32 rcvcontrol_fast; ++ uint32 rcvaddr_fast; ++ uint32 rcvptr_fast; ++ uint32 rcvstatus_fast; ++ uint32 PAD[48]; ++ ++ uint32 host_message; /* 0x300 */ ++ uint32 PAD[805]; ++ uint32 core_reset; ++ uint32 core_error; ++ uint32 core_revision; ++ ++#define ADSL_CORE_REV 0x0000000F ++#define ADSL_CORE_TYPE 0x0000FFF0 ++} AdslRegisters; ++ ++#define ADSL ((volatile AdslRegisters * const) ADSL_BASE) ++ ++#if __cplusplus ++} ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6348_common.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6348_common.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6348_common.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6348_common.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,225 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6348_common.h */ ++/* DATE: 04/12/19 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6348 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6348_MAP_COMMON_H ++#define __BCM6348_MAP_COMMON_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#define PERF_BASE 0xfffe0000 /* chip control registers */ ++#define BB_BASE 0xfffe0100 /* bus bridge registers */ ++#define TIMR_BASE 0xfffe0200 /* timer registers */ ++#define UART_BASE 0xfffe0300 /* uart registers */ ++#define GPIO_BASE 0xfffe0400 /* gpio registers */ ++#define SPI_BASE 0xfffe0c00 /* SPI master controller registers */ ++ ++#define USB_CTL_BASE 0xfffe1000 /* USB control registers */ ++#define USB_DMA_BASE 0xfffe1400 /* USB DMA control registers */ ++#define USB_HOST_BASE 0xfffe1b00 /* USB host registers */ ++ ++#define MPI_BASE 0xfffe2000 /* MPI control registers */ ++#define SDRAM_BASE 0xfffe2300 /* SDRAM control registers */ ++ ++#define ADSL_BASE 0xfffe3000 /* ADSL core control registers */ ++#define ATM_BASE 0xfffe4000 /* ATM SAR control registers */ ++#define UBUS_BASE 0xfffe5000 /* UBUS status registers */ ++#define EMAC1_BASE 0xfffe6000 /* EMAC1 control registers */ ++#define EMAC2_BASE 0xfffe6800 /* EMAC2 control registers */ ++#define EMAC_DMA_BASE 0xfffe7000 /* EMAC DMA control registers */ ++ ++/* ++##################################################################### ++# System PLL Control Register ++##################################################################### ++*/ ++#define SYSPLLCFG 0x08 ++ ++#define M_MPI_MASK 0x00000018 // 4:3 ++#define M_MPI_SHFT 3 ++#define M_MPI_50MHZ 0 ++#define M_MPI_40MHZ 1 ++#define M_MPI_33MHZ 2 ++#define M_MPI_25MHZ 3 ++ ++#define M_UTO_MASK 0x00000002 // 1:1 ++#define M_UTO_SHFT 1 ++ ++#define SOFT_RESET 0x00000001 ++ ++#define PLL_STRAP_VALUE 0x34 ++ ++/* ++##################################################################### ++# SDRAM Control Registers ++##################################################################### ++*/ ++#define SDR_INIT_CTL 0x00 ++ /* Control Bits */ ++#define SDR_PFEN1 (1<<16) ++#define SDR_PFEN0 (1<<15) ++#define SDR_EMPRS (1<<14) ++#define SDR_2_BANKS (1<<13) ++#define SDR_1_BANK (0<<13) ++#define SDR_CS1_EN (1<<12) ++#define SDR_PEND (1<<11) ++#define SDR_32_BIT (1<<10) ++#define SDR_POWER_DOWN (1<<9) ++#define SDR_SELF_REFRESH (1<<8) ++#define SDR_11_COLS (3<<6) ++#define SDR_10_COLS (2<<6) ++#define SDR_9_COLS (1<<6) ++#define SDR_8_COLS (0<<6) ++#define SDR_13_ROWS (2<<4) ++#define SDR_12_ROWS (1<<4) ++#define SDR_11_ROWS (0<<4) ++#define SDR_MASTER_EN (1<<3) ++#define SDR_MRS_CMD (1<<2) ++#define SDR_PRE_CMD (1<<1) ++#define SDR_CBR_CMD (1<<0) ++ ++#define SDR_CFG_REG 0x04 ++ /* Control Bits */ ++#define SDR_FULL_PG 0 ++#define SDR_BURST8 1 ++#define SDR_BURST4 2 ++#define SDR_BURST2 3 ++#define SDR_FAST_MEM (1<<2) ++#define SDR_SLOW_MEM (0<<2) ++ ++#define SDR_REF_CTL 0x0C ++ /* Control Bits */ ++#define SDR_REF_EN (1<<15) ++ ++#define SDR_PRIOR ++ /* Control Bits */ ++#define SDR_EN_PRIOR (1<<31) ++ ++ ++/* ++##################################################################### ++# MPI Control Registers ++##################################################################### ++*/ ++#define CS0BASE 0x00 ++#define CS0CNTL 0x04 ++ ++/* ++# CSxBASE settings ++# Size in low 4 bits ++# Base Address for match in upper 24 bits ++*/ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ ++/* CSxCNTL settings */ ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define ZEROWT 0x00000000 /* .. 0 WS */ ++#define ONEWT 0x00000002 /* .. 1 WS */ ++#define TWOWT 0x00000004 /* .. 2 WS */ ++#define THREEWT 0x00000006 /* .. 3 WS */ ++#define FOURWT 0x00000008 /* .. 4 WS */ ++#define FIVEWT 0x0000000a /* .. 5 WS */ ++#define SIXWT 0x0000000c /* .. 6 WS */ ++#define SEVENWT 0x0000000e /* .. 7 WS */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert chip select polarity */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. enable fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++ ++/* ++##################################################################### ++# UART Control Registers ++##################################################################### ++*/ ++#define UART0CONTROL 0x01 ++#define UART0CONFIG 0x02 ++#define UART0RXTIMEOUT 0x03 ++#define UART0BAUD 0x04 ++#define UART0FIFOCFG 0x0a ++#define UART0INTMASK 0x10 ++#define UART0INTSTAT 0x12 ++#define UART0DATA 0x17 ++ ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ ++#define XMITBREAK 0x40 /* Config register */ ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ ++#define RSTTXFIFOS 0x80 /* Rx Timeout register */ ++#define RSTRXFIFOS 0x40 ++ ++#define TX4 0x40 /* FIFO config register */ ++#define RX4 0x04 ++ ++#define DELTAIP 0x0001 /* Interrupt Status and Mask registers */ ++#define TXUNDERR 0x0002 ++#define TXOVFERR 0x0004 ++#define TXFIFOTHOLD 0x0008 ++#define TXREADLATCH 0x0010 ++#define TXFIFOEMT 0x0020 ++#define RXUNDERR 0x0040 ++#define RXOVFERR 0x0080 ++#define RXTIMEOUT 0x0100 ++#define RXFIFOFULL 0x0200 ++#define RXFIFOTHOLD 0x0400 ++#define RXFIFONE 0x0800 ++#define RXFRAMERR 0x1000 ++#define RXPARERR 0x2000 ++#define RXBRK 0x4000 ++ ++#if __cplusplus ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6348_map.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6348_map.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/6348_map.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/6348_map.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,1095 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: 6348_map.h */ ++/* DATE: 11/06/03 */ ++/* PURPOSE: Define addresses of major hardware components of */ ++/* BCM6348 */ ++/* */ ++/***********************************************************************/ ++#ifndef __BCM6348_MAP_H ++#define __BCM6348_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++#include "6348_common.h" ++#include "6348_intr.h" ++ ++/* macro to convert logical data addresses to physical */ ++/* DMA hardware must see physical address */ ++#define LtoP( x ) ( (uint32)x & 0x1fffffff ) ++#define PtoL( x ) ( LtoP(x) | 0xa0000000 ) ++ ++/* ++** Interrupt Controller ++*/ ++typedef struct PerfControl { ++ uint32 RevID; /* (00) */ ++ uint16 testControl; /* (04) */ ++ uint16 blkEnables; /* (06) */ ++ ++#define ADSL_CLK_EN 0x0001 ++#define MPI_CLK_EN 0x0002 ++#define DRAM_CLK_EN 0x0004 ++#define M2M_CLK_EN 0x0008 ++#define EMAC_CLK_EN 0x0010 ++#define SAR_CLK_EN 0x0020 ++#define USBS_CLK_EN 0x0040 ++#define USBH_CLK_EN 0x0100 ++#define SPI_CLK_EN 0x0200 ++ ++ uint32 pll_control; /* (08) */ ++#define CHIP_SOFT_RESET 0x00000001 ++#define MPI_CLK_50MHZ 0x00000000 ++#define MPI_CLK_40MHZ 0x00000008 ++#define MPI_CLK_33MHZ 0x00000010 ++#define MPI_CLK_25MHZ 0x00000018 ++#define MPI_CLK_MASK 0x00000018 ++ ++ uint32 IrqMask; /* (0c) */ ++ uint32 IrqStatus; /* (10) */ ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 5 ++#define EI_CLEAR_SHFT 10 ++#define EI_MASK_SHFT 15 ++#define EI_INSENS_SHFT 20 ++#define EI_LEVEL_SHFT 25 ++ ++ uint32 unused[4]; /* (18) */ ++ uint32 BlockSoftReset; /* (28) */ ++#define BSR_SPI 0x00000001 ++#define BSR_EMAC 0x00000004 ++#define BSR_USBH 0x00000008 ++#define BSR_USBS 0x00000010 ++#define BSR_ADSL 0x00000020 ++#define BSR_DMAMEM 0x00000040 ++#define BSR_SAR 0x00000080 ++#define BSR_ACLC 0x00000100 ++#define BSR_ADSL_MIPS_PLL 0x00000400 ++#define BSR_ALL_BLOCKS \ ++ (BSR_SPI | BSR_EMAC | BSR_USBH | BSR_USBS | BSR_ADSL | BSR_DMAMEM | \ ++ BSR_SAR | BSR_ACLC | BSR_ADSL_MIPS_PLL) ++ uint32 unused2[2]; /* (2c) */ ++ uint32 PllStrap; /* (34) */ ++#define PLL_N1_SHFT 20 ++#define PLL_N1_MASK (7< thresh, txfifo= 32) ? (1 << ((X-32) & GPIO_NUM_MAX_BITS_MASK_HIGH)) : (0) ) ++ ++ ++/* ++** Spi Controller ++*/ ++ ++typedef struct SpiControl { ++ uint16 spiCmd; /* (0x0): SPI command */ ++#define SPI_CMD_NOOP 0 ++#define SPI_CMD_SOFT_RESET 1 ++#define SPI_CMD_HARD_RESET 2 ++#define SPI_CMD_START_IMMEDIATE 3 ++ ++#define SPI_CMD_COMMAND_SHIFT 0 ++#define SPI_CMD_DEVICE_ID_SHIFT 4 ++#define SPI_CMD_PREPEND_BYTE_CNT_SHIFT 8 ++#define SPI_CMD_ONE_BYTE_SHIFT 11 ++#define SPI_CMD_ONE_WIRE_SHIFT 12 ++#define SPI_DEV_ID_0 0 ++#define SPI_DEV_ID_1 1 ++#define SPI_DEV_ID_2 2 ++#define SPI_DEV_ID_3 3 ++ ++ byte spiIntStatus; /* (0x2): SPI interrupt status */ ++ byte spiMaskIntStatus; /* (0x3): SPI masked interrupt status */ ++ ++ byte spiIntMask; /* (0x4): SPI interrupt mask */ ++#define SPI_INTR_CMD_DONE 0x01 ++#define SPI_INTR_RX_OVERFLOW 0x02 ++#define SPI_INTR_INTR_TX_UNDERFLOW 0x04 ++#define SPI_INTR_TX_OVERFLOW 0x08 ++#define SPI_INTR_RX_UNDERFLOW 0x10 ++#define SPI_INTR_CLEAR_ALL 0x1f ++ ++ byte spiStatus; /* (0x5): SPI status */ ++#define SPI_RX_EMPTY 0x02 ++#define SPI_CMD_BUSY 0x04 ++#define SPI_SERIAL_BUSY 0x08 ++ ++ byte spiClkCfg; /* (0x6): SPI clock configuration */ ++#define SPI_CLK_0_391MHZ 1 ++#define SPI_CLK_0_781MHZ 2 /* default */ ++#define SPI_CLK_1_563MHZ 3 ++#define SPI_CLK_3_125MHZ 4 ++#define SPI_CLK_6_250MHZ 5 ++#define SPI_CLK_12_50MHZ 6 ++#define SPI_CLK_MASK 0x07 ++#define SPI_SSOFFTIME_MASK 0x38 ++#define SPI_SSOFFTIME_SHIFT 3 ++#define SPI_BYTE_SWAP 0x80 ++ ++ byte spiFillByte; /* (0x7): SPI fill byte */ ++ ++ byte unused0; ++ byte spiMsgTail; /* (0x9): msgtail */ ++ byte unused1; ++ byte spiRxTail; /* (0xB): rxtail */ ++ ++ uint32 unused2[13]; /* (0x0c - 0x3c) reserved */ ++ ++ byte spiMsgCtl; /* (0x40) control byte */ ++#define FULL_DUPLEX_RW 0 ++#define HALF_DUPLEX_W 1 ++#define HALF_DUPLEX_R 2 ++#define SPI_MSG_TYPE_SHIFT 6 ++#define SPI_BYTE_CNT_SHIFT 0 ++ byte spiMsgData[63]; /* (0x41 - 0x7f) msg data */ ++ byte spiRxDataFifo[64]; /* (0x80 - 0xbf) rx data */ ++ byte unused3[64]; /* (0xc0 - 0xff) reserved */ ++} SpiControl; ++ ++#define SPI ((volatile SpiControl * const) SPI_BASE) ++ ++#define IUDMA_MAX_CHANNELS 16 ++ ++/* ++** DMA Channel Configuration (1 .. 16) ++*/ ++typedef struct DmaChannelCfg { ++ uint32 cfg; /* (00) assorted configuration */ ++#define DMA_BURST_HALT 0x00000004 /* idle after finish current memory burst */ ++#define DMA_PKT_HALT 0x00000002 /* idle after an EOP flag is detected */ ++#define DMA_ENABLE 0x00000001 /* set to enable channel */ ++ uint32 intStat; /* (04) interrupts control and status */ ++ uint32 intMask; /* (08) interrupts mask */ ++#define DMA_BUFF_DONE 0x00000001 /* buffer done */ ++#define DMA_DONE 0x00000002 /* packet xfer complete */ ++#define DMA_NO_DESC 0x00000004 /* no valid descriptors */ ++ uint32 maxBurst; /* (0C) max burst length permitted */ ++} DmaChannelCfg; ++ ++/* ++** DMA State RAM (1 .. 16) ++*/ ++typedef struct DmaStateRam { ++ uint32 baseDescPtr; /* (00) descriptor ring start address */ ++ uint32 state_data; /* (04) state/bytes done/ring offset */ ++ uint32 desc_len_status; /* (08) buffer descriptor status and len */ ++ uint32 desc_base_bufptr; /* (0C) buffer descrpitor current processing */ ++} DmaStateRam; ++ ++/* ++** DMA Registers ++*/ ++typedef struct DmaRegs { ++#define DMA_MASTER_EN 0x00000001 ++#define DMA_FLOWC_CH1_EN 0x00000002 ++#define DMA_FLOWC_CH3_EN 0x00000004 ++#define DMA_NUM_CHS_MASK 0x0f000000 ++#define DMA_NUM_CHS_SHIFT 24 ++#define DMA_FLOWCTL_MASK 0x30000000 ++#define DMA_FLOWCTL_CH1 0x10000000 ++#define DMA_FLOWCTL_CH3 0x20000000 ++#define DMA_FLOWCTL_SHIFT 28 ++ uint32 controller_cfg; /* (00) controller configuration */ ++ ++ // Flow control Ch1 ++ uint32 flowctl_ch1_thresh_lo; /* (04) EMAC1 RX DMA channel */ ++ uint32 flowctl_ch1_thresh_hi; /* (08) EMAC1 RX DMA channel */ ++ uint32 flowctl_ch1_alloc; /* (0C) EMAC1 RX DMA channel */ ++#define DMA_BUF_ALLOC_FORCE 0x80000000 ++ ++ // Flow control Ch3 ++ uint32 flowctl_ch3_thresh_lo; /* (10) EMAC2 RX DMA channel */ ++ uint32 flowctl_ch3_thresh_hi; /* (14) EMAC2 RX DMA channel */ ++ uint32 flowctl_ch3_alloc; /* (18) EMAC2 RX DMA channel */ ++ ++ // Unused words ++ uint32 resv[57]; ++ ++ // Per channel registers/state ram ++ DmaChannelCfg chcfg[IUDMA_MAX_CHANNELS]; /* (100) Channel configuration */ ++ union { ++ DmaStateRam s[IUDMA_MAX_CHANNELS]; ++ uint32 u32[4 * IUDMA_MAX_CHANNELS]; ++ } stram; /* (200) state ram */ ++} DmaRegs; ++ ++/* ++** DMA Buffer ++*/ ++typedef struct DmaDesc { ++ uint16 length; /* in bytes of data in buffer */ ++#define DMA_DESC_USEFPM 0x8000 ++#define DMA_DESC_MULTICAST 0x4000 ++#define DMA_DESC_BUFLENGTH 0x0fff ++ uint16 status; /* buffer status */ ++#define DMA_OWN 0x8000 /* cleared by DMA, set by SW */ ++#define DMA_EOP 0x4000 /* last buffer in packet */ ++#define DMA_SOP 0x2000 /* first buffer in packet */ ++#define DMA_WRAP 0x1000 /* */ ++#define DMA_APPEND_CRC 0x0100 ++ ++/* EMAC Descriptor Status definitions */ ++#define EMAC_MISS 0x0080 /* framed address recognition failed (promiscuous) */ ++#define EMAC_BRDCAST 0x0040 /* DA is Broadcast */ ++#define EMAC_MULT 0x0020 /* DA is multicast */ ++#define EMAC_LG 0x0010 /* frame length > RX_LENGTH register value */ ++#define EMAC_NO 0x0008 /* Non-Octet aligned */ ++#define EMAC_RXER 0x0004 /* RX_ERR on MII while RX_DV assereted */ ++#define EMAC_CRC_ERROR 0x0002 /* CRC error */ ++#define EMAC_OV 0x0001 /* Overflow */ ++ ++/* HDLC Descriptor Status definitions */ ++#define DMA_HDLC_TX_ABORT 0x0100 ++#define DMA_HDLC_RX_OVERRUN 0x4000 ++#define DMA_HDLC_RX_TOO_LONG 0x2000 ++#define DMA_HDLC_RX_CRC_OK 0x1000 ++#define DMA_HDLC_RX_ABORT 0x0100 ++ ++ uint32 address; /* address of data */ ++} DmaDesc; ++ ++/* ++** Sdram Controller ++*/ ++typedef struct SdramControllerRegs { ++ uint16 unused1; ++ uint16 initControl; /* 02 */ ++#define SD_POWER_DOWN 0x200 /* put sdram into power down */ ++#define SD_SELF_REFRESH 0x100 /* enable self refresh mode */ ++#define SD_SOFT_RESET 0x080 /* soft reset all sdram controller regs */ ++#define SD_EDO_SELECT 0x040 /* select EDO mode */ ++#define SD_EDO_WAIT_STATE 0x020 /* add an EDO wait state */ ++#define SD_8MEG 0x010 /* map sdram to 8 megs */ ++#define SD_MASTER_ENABLE 0x008 /* enable accesses to external sdram */ ++#define SD_MRS 0x004 /* generate a mode register select cycle */ ++#define SD_PRECHARGE 0x002 /* generate a precharge cycle */ ++#define SD_CBR 0x001 /* generate a refresh cycle */ ++ uint8 unused2[3]; ++ uint8 config; /* 07 */ ++#define SD_FAST_MEM 0x04 /* 1=CAS latency of 2, 0 = CAS latency of 3 */ ++#define SD_BURST_LEN 0x03 /* set burst length */ ++#define SD_BURST_FULL_PAGE 0x00 /* .. full page */ ++#define SD_BURST_8 0x01 /* .. 8 words */ ++#define SD_BURST_4 0x02 /* .. 4 words */ ++#define SD_BURST_2 0x03 /* .. 2 words */ ++ uint16 unused3; ++ uint16 refreshControl; /* 0a */ ++#define SD_REFRESH_ENABLE 0x8000 /* refresh enable */ ++#define SD_REFRESH_PERIOD 0x00ff /* refresh period (16 x n x clock_period) */ ++ ++ uint32 memoryBase; /* 0c */ ++#define SD_MEMBASE_MASK 0xffffe000 /* base address mask */ ++#define SD_MEMSIZE_8MEG 0x00000001 /* memory is 8 meg */ ++#define SD_MEMSIZE_2MEG 0x00000001 /* memory is 2 meg */ ++ ++} SdramControllerRegs; ++ ++/* ++** External Bus Interface ++*/ ++typedef struct EbiChipSelect { ++ uint32 base; /* base address in upper 24 bits */ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ uint32 config; ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define EBI_WTST_SHIFT 1 /* .. for shifting wait states */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_WREN 0x00000020 /* enable posted writes */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert something, ++ ** don't know what yet */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. use fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++} EbiChipSelect; ++ ++typedef struct MpiRegisters { ++ EbiChipSelect cs[7]; /* size chip select configuration */ ++#define EBI_CS0_BASE 0 ++#define EBI_CS1_BASE 1 ++#define EBI_CS2_BASE 2 ++#define EBI_CS3_BASE 3 ++#define PCMCIA_COMMON_BASE 4 ++#define PCMCIA_ATTRIBUTE_BASE 5 ++#define PCMCIA_IO_BASE 6 ++ uint32 unused0[2]; /* reserved */ ++ uint32 ebi_control; /* ebi control */ ++ uint32 unused1[4]; /* reserved */ ++#define EBI_ACCESS_TIMEOUT 0x000007FF ++ uint32 pcmcia_cntl1; /* pcmcia control 1 */ ++#define PCCARD_CARD_RESET 0x00040000 ++#define CARDBUS_ENABLE 0x00008000 ++#define PCMCIA_ENABLE 0x00004000 ++#define PCMCIA_GPIO_ENABLE 0x00002000 ++#define CARDBUS_IDSEL 0x00001F00 ++#define VS2_OEN 0x00000080 ++#define VS1_OEN 0x00000040 ++#define VS2_OUT 0x00000020 ++#define VS1_OUT 0x00000010 ++#define VS2_IN 0x00000008 ++#define VS1_IN 0x00000004 ++#define CD2_IN 0x00000002 ++#define CD1_IN 0x00000001 ++#define VS_MASK 0x0000000C ++#define CD_MASK 0x00000003 ++ uint32 unused2; /* reserved */ ++ uint32 pcmcia_cntl2; /* pcmcia control 2 */ ++#define PCMCIA_BYTESWAP_DIS 0x00000002 ++#define PCMCIA_HALFWORD_EN 0x00000001 ++ uint32 unused3[40]; /* reserved */ ++ ++ uint32 sp0range; /* PCI to internal system bus address space */ ++#define ADDR_SPACE_MASK 0xFFFF0000 ++ uint32 sp0remap; ++ uint32 sp0cfg; ++ uint32 sp1range; ++ uint32 sp1remap; ++ uint32 sp1cfg; ++ ++ uint32 EndianCfg; ++ ++ uint32 l2pcfgctl; /* internal system bus to PCI IO/Cfg control */ ++#define DIR_CFG_SEL 0x80000000 /* change from PCI I/O access to PCI config access */ ++#define DIR_CFG_USEREG 0x40000000 /* use this register info for PCI configuration access */ ++#define DEVICE_NUMBER 0x00007C00 /* device number for the PCI configuration access */ ++#define FUNC_NUMBER 0x00000300 /* function number for the PCI configuration access */ ++#define REG_NUMBER 0x000000FC /* register number for the PCI configuration access */ ++#define CONFIG_TYPE 0x00000003 /* configuration type for the PCI configuration access */ ++ ++ uint32 l2pmrange1; /* internal system bus to PCI memory space */ ++#define PCI_SIZE_64K 0xFFFF0000 ++#define PCI_SIZE_128K 0xFFFE0000 ++#define PCI_SIZE_256K 0xFFFC0000 ++#define PCI_SIZE_512K 0xFFF80000 ++#define PCI_SIZE_1M 0xFFF00000 ++#define PCI_SIZE_2M 0xFFE00000 ++#define PCI_SIZE_4M 0xFFC00000 ++#define PCI_SIZE_8M 0xFF800000 ++#define PCI_SIZE_16M 0xFF000000 ++ uint32 l2pmbase1; /* kseg0 or kseg1 address & 0x1FFFFFFF */ ++ uint32 l2pmremap1; ++#define CARDBUS_MEM 0x00000004 ++#define MEM_WINDOW_EN 0x00000001 ++ uint32 l2pmrange2; ++ uint32 l2pmbase2; ++ uint32 l2pmremap2; ++ uint32 l2piorange; /* internal system bus to PCI I/O space */ ++ uint32 l2piobase; ++ uint32 l2pioremap; ++ ++ uint32 pcimodesel; ++#define PCI2_INT_BUS_RD_PREFECH 0x000000F0 ++#define PCI_BAR2_NOSWAP 0x00000002 /* BAR at offset 0x20 */ ++#define PCI_BAR1_NOSWAP 0x00000001 /* BAR at affset 0x1c */ ++ ++ uint32 pciintstat; /* PCI interrupt mask/status */ ++#define MAILBOX1_SENT 0x08 ++#define MAILBOX0_SENT 0x04 ++#define MAILBOX1_MSG_RCV 0x02 ++#define MAILBOX0_MSG_RCV 0x01 ++ uint32 locbuscntrl; /* internal system bus control */ ++#define DIR_U2P_NOSWAP 0x00000002 ++#define EN_PCI_GPIO 0x00000001 ++ uint32 locintstat; /* internal system bus interrupt mask/status */ ++#define CSERR 0x0200 ++#define SERR 0x0100 ++#define EXT_PCI_INT 0x0080 ++#define DIR_FAILED 0x0040 ++#define DIR_COMPLETE 0x0020 ++#define PCI_CFG 0x0010 ++ uint32 unused4[7]; ++ ++ uint32 mailbox0; ++ uint32 mailbox1; ++ ++ uint32 pcicfgcntrl; /* internal system bus PCI configuration control */ ++#define PCI_CFG_REG_WRITE_EN 0x00000080 ++#define PCI_CFG_ADDR 0x0000003C ++ uint32 pcicfgdata; /* internal system bus PCI configuration data */ ++ ++ uint32 locch2ctl; /* PCI to interrnal system bus DMA (downstream) local control */ ++#define MPI_DMA_HALT 0x00000008 /* idle after finish current memory burst */ ++#define MPI_DMA_PKT_HALT 0x00000004 /* idle after an EOP flag is detected */ ++#define MPI_DMA_STALL 0x00000002 /* idle after an EOP flag is detected */ ++#define MPI_DMA_ENABLE 0x00000001 /* set to enable channel */ ++ uint32 locch2intStat; ++#define MPI_DMA_NO_DESC 0x00000004 /* no valid descriptors */ ++#define MPI_DMA_DONE 0x00000002 /* packet xfer complete */ ++#define MPI_DMA_BUFF_DONE 0x00000001 /* buffer done */ ++ uint32 locch2intMask; ++ uint32 unused5; ++ uint32 locch2descaddr; ++ uint32 locch2status1; ++#define LOCAL_DESC_STATE 0xE0000000 ++#define PCI_DESC_STATE 0x1C000000 ++#define BYTE_DONE 0x03FFC000 ++#define RING_ADDR 0x00003FFF ++ uint32 locch2status2; ++#define BUFPTR_OFFSET 0x1FFF0000 ++#define PCI_MASTER_STATE 0x000000C0 ++#define LOC_MASTER_STATE 0x00000038 ++#define CONTROL_STATE 0x00000007 ++ uint32 unused6; ++ ++ uint32 locch1Ctl; /*internal system bus to PCI DMA (upstream) local control */ ++#define DMA_U2P_LE 0x00000200 /* local bus is little endian */ ++#define DMA_U2P_NOSWAP 0x00000100 /* lccal bus is little endian but no data swapped */ ++ uint32 locch1intstat; ++ uint32 locch1intmask; ++ uint32 unused7; ++ uint32 locch1descaddr; ++ uint32 locch1status1; ++ uint32 locch1status2; ++ uint32 unused8; ++ ++ uint32 pcich1ctl; /* internal system bus to PCI DMA PCI control */ ++ uint32 pcich1intstat; ++ uint32 pcich1intmask; ++ uint32 pcich1descaddr; ++ uint32 pcich1status1; ++ uint32 pcich1status2; ++ ++ uint32 pcich2Ctl; /* PCI to internal system bus DMA PCI control */ ++ uint32 pcich2intstat; ++ uint32 pcich2intmask; ++ uint32 pcich2descaddr; ++ uint32 pcich2status1; ++ uint32 pcich2status2; ++ ++ uint32 perm_id; /* permanent device and vendor id */ ++ uint32 perm_rev; /* permanent revision id */ ++} MpiRegisters; ++ ++#define MPI ((volatile MpiRegisters * const) MPI_BASE) ++ ++/* PCI configuration address space start offset 0x40 */ ++#define BRCM_PCI_CONFIG_TIMER 0x40 ++#define BRCM_PCI_CONFIG_TIMER_RETRY_MASK 0x0000FF00 ++#define BRCM_PCI_CONFIG_TIMER_TRDY_MASK 0x000000FF ++ ++/* ++** EMAC transmit MIB counters ++*/ ++typedef struct EmacTxMib { ++ uint32 tx_good_octets; /* (200) good byte count */ ++ uint32 tx_good_pkts; /* (204) good pkt count */ ++ uint32 tx_octets; /* (208) good and bad byte count */ ++ uint32 tx_pkts; /* (20c) good and bad pkt count */ ++ uint32 tx_broadcasts_pkts; /* (210) good broadcast packets */ ++ uint32 tx_multicasts_pkts; /* (214) good mulitcast packets */ ++ uint32 tx_len_64; /* (218) RMON tx pkt size buckets */ ++ uint32 tx_len_65_to_127; /* (21c) */ ++ uint32 tx_len_128_to_255; /* (220) */ ++ uint32 tx_len_256_to_511; /* (224) */ ++ uint32 tx_len_512_to_1023; /* (228) */ ++ uint32 tx_len_1024_to_max; /* (22c) */ ++ uint32 tx_jabber_pkts; /* (230) > 1518 with bad crc */ ++ uint32 tx_oversize_pkts; /* (234) > 1518 with good crc */ ++ uint32 tx_fragment_pkts; /* (238) < 63 with bad crc */ ++ uint32 tx_underruns; /* (23c) fifo underrun */ ++ uint32 tx_total_cols; /* (240) total collisions in all tx pkts */ ++ uint32 tx_single_cols; /* (244) tx pkts with single collisions */ ++ uint32 tx_multiple_cols; /* (248) tx pkts with multiple collisions */ ++ uint32 tx_excessive_cols; /* (24c) tx pkts with excessive cols */ ++ uint32 tx_late_cols; /* (250) tx pkts with late cols */ ++ uint32 tx_defered; /* (254) tx pkts deferred */ ++ uint32 tx_carrier_lost; /* (258) tx pkts with CRS lost */ ++ uint32 tx_pause_pkts; /* (25c) tx pause pkts sent */ ++#define NumEmacTxMibVars 24 ++} EmacTxMib; ++ ++/* ++** EMAC receive MIB counters ++*/ ++typedef struct EmacRxMib { ++ uint32 rx_good_octets; /* (280) good byte count */ ++ uint32 rx_good_pkts; /* (284) good pkt count */ ++ uint32 rx_octets; /* (288) good and bad byte count */ ++ uint32 rx_pkts; /* (28c) good and bad pkt count */ ++ uint32 rx_broadcasts_pkts; /* (290) good broadcast packets */ ++ uint32 rx_multicasts_pkts; /* (294) good mulitcast packets */ ++ uint32 rx_len_64; /* (298) RMON rx pkt size buckets */ ++ uint32 rx_len_65_to_127; /* (29c) */ ++ uint32 rx_len_128_to_255; /* (2a0) */ ++ uint32 rx_len_256_to_511; /* (2a4) */ ++ uint32 rx_len_512_to_1023; /* (2a8) */ ++ uint32 rx_len_1024_to_max; /* (2ac) */ ++ uint32 rx_jabber_pkts; /* (2b0) > 1518 with bad crc */ ++ uint32 rx_oversize_pkts; /* (2b4) > 1518 with good crc */ ++ uint32 rx_fragment_pkts; /* (2b8) < 63 with bad crc */ ++ uint32 rx_missed_pkts; /* (2bc) missed packets */ ++ uint32 rx_crc_align_errs; /* (2c0) both or either */ ++ uint32 rx_undersize; /* (2c4) < 63 with good crc */ ++ uint32 rx_crc_errs; /* (2c8) crc errors (only) */ ++ uint32 rx_align_errs; /* (2cc) alignment errors (only) */ ++ uint32 rx_symbol_errs; /* (2d0) pkts with RXERR assertions (symbol errs) */ ++ uint32 rx_pause_pkts; /* (2d4) MAC control, PAUSE */ ++ uint32 rx_nonpause_pkts; /* (2d8) MAC control, not PAUSE */ ++#define NumEmacRxMibVars 23 ++} EmacRxMib; ++ ++typedef struct EmacRegisters { ++ uint32 rxControl; /* (00) receive control */ ++#define EMAC_PM_REJ 0x80 /* - reject DA match in PMx regs */ ++#define EMAC_UNIFLOW 0x40 /* - accept cam match fc */ ++#define EMAC_FC_EN 0x20 /* - enable flow control */ ++#define EMAC_LOOPBACK 0x10 /* - loopback */ ++#define EMAC_PROM 0x08 /* - promiscuous */ ++#define EMAC_RDT 0x04 /* - ignore transmissions */ ++#define EMAC_ALL_MCAST 0x02 /* - ignore transmissions */ ++#define EMAC_NO_BCAST 0x01 /* - ignore transmissions */ ++ ++ ++ uint32 rxMaxLength; /* (04) receive max length */ ++ uint32 txMaxLength; /* (08) transmit max length */ ++ uint32 unused1[1]; ++ uint32 mdioFreq; /* (10) mdio frequency */ ++#define EMAC_MII_PRE_EN 0x00000080 /* prepend preamble sequence */ ++#define EMAC_MDIO_PRE 0x00000080 /* - enable MDIO preamble */ ++#define EMAC_MDC_FREQ 0x0000007f /* - mdio frequency */ ++ ++ uint32 mdioData; /* (14) mdio data */ ++#define MDIO_WR 0x50020000 /* - write framing */ ++#define MDIO_RD 0x60020000 /* - read framing */ ++#define MDIO_PMD_SHIFT 23 ++#define MDIO_REG_SHIFT 18 ++ ++ uint32 intMask; /* (18) int mask */ ++ uint32 intStatus; /* (1c) int status */ ++#define EMAC_FLOW_INT 0x04 /* - flow control event */ ++#define EMAC_MIB_INT 0x02 /* - mib event */ ++#define EMAC_MDIO_INT 0x01 /* - mdio event */ ++ ++ uint32 unused2[3]; ++ uint32 config; /* (2c) config */ ++#define EMAC_ENABLE 0x001 /* - enable emac */ ++#define EMAC_DISABLE 0x002 /* - disable emac */ ++#define EMAC_SOFT_RST 0x004 /* - soft reset */ ++#define EMAC_SOFT_RESET 0x004 /* - emac soft reset */ ++#define EMAC_EXT_PHY 0x008 /* - external PHY select */ ++ ++ uint32 txControl; /* (30) transmit control */ ++#define EMAC_FD 0x001 /* - full duplex */ ++#define EMAC_FLOWMODE 0x002 /* - flow mode */ ++#define EMAC_NOBKOFF 0x004 /* - no backoff in */ ++#define EMAC_SMALLSLT 0x008 /* - small slot time */ ++ ++ uint32 txThreshold; /* (34) transmit threshold */ ++ uint32 mibControl; /* (38) mib control */ ++#define EMAC_NO_CLEAR 0x001 /* don't clear on read */ ++ ++ uint32 unused3[7]; ++ ++ uint32 pm0DataLo; /* (58) perfect match 0 data lo */ ++ uint32 pm0DataHi; /* (5C) perfect match 0 data hi (15:0) */ ++ uint32 pm1DataLo; /* (60) perfect match 1 data lo */ ++ uint32 pm1DataHi; /* (64) perfect match 1 data hi (15:0) */ ++ uint32 pm2DataLo; /* (68) perfect match 2 data lo */ ++ uint32 pm2DataHi; /* (6C) perfect match 2 data hi (15:0) */ ++ uint32 pm3DataLo; /* (70) perfect match 3 data lo */ ++ uint32 pm3DataHi; /* (74) perfect match 3 data hi (15:0) */ ++#define EMAC_CAM_V 0x10000 /* - cam index */ ++#define EMAC_CAM_VALID 0x00010000 ++ ++ uint32 unused4[98]; /* (78-1fc) */ ++ ++ EmacTxMib tx_mib; /* (200) emac tx mib */ ++ uint32 unused5[8]; /* (260-27c) */ ++ ++ EmacRxMib rx_mib; /* (280) rx mib */ ++ ++} EmacRegisters; ++ ++/* register offsets for subrouting access */ ++#define EMAC_RX_CONTROL 0x00 ++#define EMAC_RX_MAX_LENGTH 0x04 ++#define EMAC_TX_MAC_LENGTH 0x08 ++#define EMAC_MDIO_FREQ 0x10 ++#define EMAC_MDIO_DATA 0x14 ++#define EMAC_INT_MASK 0x18 ++#define EMAC_INT_STATUS 0x1C ++#define EMAC_CAM_DATA_LO 0x20 ++#define EMAC_CAM_DATA_HI 0x24 ++#define EMAC_CAM_CONTROL 0x28 ++#define EMAC_CONTROL 0x2C ++#define EMAC_TX_CONTROL 0x30 ++#define EMAC_TX_THRESHOLD 0x34 ++#define EMAC_MIB_CONTROL 0x38 ++ ++ ++#define EMAC1 ((volatile EmacRegisters * const) EMAC1_BASE) ++#define EMAC2 ((volatile EmacRegisters * const) EMAC2_BASE) ++ ++/* ++** USB Registers ++*/ ++typedef struct UsbRegisters { ++ byte inttf_setting; ++ byte current_config; ++ uint16 status_frameNum; ++#define USB_LINK 0x2000 ++#define USB_BUS_RESET 0x1000 ++#define USB_SUSPENDED 0x0800 ++ byte unused1; ++ byte endpt_prnt; ++ byte endpt_dirn; ++ byte endpt_status; ++#define USB_ENDPOINT_0 0x01 ++#define USB_ENDPOINT_1 0x02 ++#define USB_ENDPOINT_2 0x04 ++#define USB_ENDPOINT_3 0x08 ++#define USB_ENDPOINT_4 0x10 ++#define USB_ENDPOINT_5 0x20 ++#define USB_ENDPOINT_6 0x40 ++#define USB_ENDPOINT_7 0x80 ++ uint32 unused2; ++ byte conf_mem_ctl; ++#define USB_CONF_MEM_RD 0x80 ++#define USB_CONF_MEM_RDY 0x40 ++ byte unused2a; ++ byte conf_mem_read_address; ++ byte conf_mem_write_address; ++ ++ byte unused3; ++ byte dev_req_bytesel; ++ uint16 ext_dev_data; ++ ++ byte unused4; ++ byte clr_fifo; ++ byte endpt_stall_reset; // use same endpoint #'s from above ++ byte usb_cntl; ++#define USB_FORCE_ERR 0x20 ++#define USB_SOFT_RESET 0x10 ++#define USB_RESUME 0x08 ++#define USB_COMMAND_ERR 0x04 ++#define USB_COMMAND_OVER 0x02 ++ byte irq_addr; ++ byte iso_out_in_addr; ++ byte blk_out_in_addr; ++ byte cntl_addr; ++ uint32 unusedx[2]; ++ uint32 tx_ram_write_port; ++ uint32 fifo_status; // (see bcm6348 data sheet for definition) ++ ++ uint32 irq_status; ++ uint32 irq_mask; ++#define USB_NEW_CONFIG 0x00000001 ++#define USB_SETUP_COMMAND_RECV 0x00000002 // non-standard setup cmd rcvd ++#define USB_OUT_FIFO_OV 0x00000004 ++#define USB_RESET_RECV 0x00000008 ++#define USB_SUSPEND_RECV 0x00000010 ++#define USB_FIFO_REWIND 0x00000020 ++#define USB_RX_BULK_FIFO_DATA_AVAIL 0x00000040 ++#define USB_RX_ISO_FIFO_DATA_AVAIL 0x00000080 ++#define USB_LINK_CHANGE 0x00010000 ++ uint32 endpt_cntl; ++#define USB_R_WK_EN 0x0100 ++#define USB_TX_EOP 0x0200 ++#define USB_TX_CNTL_DMA_EN 0x0400 ++#define USB_TX_BULK_DMA_EN 0x0800 ++#define USB_TX_ISO_DMA_EN 0x1000 ++#define USB_RX_CNTL_DMA_EN 0x2000 ++#define USB_RX_BULK_DMA_EN 0x4800 ++#define USB_RX_ISO_DMA_EN 0x8000 ++ uint32 rx_status_read_port; ++ uint32 confmem_read_port; ++ uint32 confmem_write_port; ++ uint32 fifo_ovf_count; ++ uint32 fifo_rewind_cnt; ++ uint32 terminal_count; ++} UsbRegisters; ++ ++#define USB ((volatile UsbRegisters * const) USB_CTL_BASE) ++ ++/* ++** ADSL core Registers ++*/ ++ ++#define _PADLINE(line) pad ## line ++#define _XSTR(line) _PADLINE(line) ++#define PAD _XSTR(__LINE__) ++ ++typedef struct AdslRegisters { ++ uint32 core_control; ++#define ADSL_RESET 0x01 ++ ++ uint32 core_status; ++#define ADSL_HOST_MSG 0x01 ++ ++ uint32 PAD; ++ uint32 bist_status; ++ uint32 PAD[4]; ++ uint32 int_status_i; /* 0x20 */ ++ uint32 int_mask_i; ++ uint32 int_status_f; ++ uint32 int_mask_f; ++#define ADSL_INT_HOST_MSG 0x00000020 ++#define ADSL_INT_DESC_ERR 0x00000400 ++#define ADSL_INT_DATA_ERR 0x00000800 ++#define ADSL_INT_DESC_PROTO_ERR 0x00001000 ++#define ADSL_INT_RCV_DESC_UF 0x00002000 ++#define ADSL_INT_RCV_FIFO_OF 0x00004000 ++#define ADSL_INT_XMT_FIFO_UF 0x00008000 ++#define ADSL_INT_RCV 0x00010000 ++#define ADSL_INT_XMT 0x01000000 ++ ++ uint32 PAD[116]; ++ ++ uint32 xmtcontrol_intr; /* 0x200 */ ++#define ADSL_DMA_XMT_EN 0x00000001 ++#define ADSL_DMA_XMT_LE 0x00000004 ++ uint32 xmtaddr_intr; ++#define ADSL_DMA_ADDR_MASK 0xFFFFF000 ++ uint32 xmtptr_intr; ++#define ADSL_DMA_LAST_DESC_MASK 0x00000FFF ++ uint32 xmtstatus_intr; ++#define ADSL_DMA_CURR_DESC_MASK 0x00000FFF ++#define ADSL_DMA_XMT_STATE_MASK 0x0000F000 ++#define ADSL_DMA_XMT_STATE_DIS 0x00000000 ++#define ADSL_DMA_XMT_STATE_ACT 0x00001000 ++#define ADSL_DMA_XMT_STATE_IDLE 0x00002000 ++#define ADSL_DMA_XMT_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_XMT_ERR_MASK 0x000F0000 ++#define ADSL_DMA_XMT_ERR_NONE 0x00000000 ++#define ADSL_DMA_XMT_ERR_DPE 0x00010000 ++#define ADSL_DMA_XMT_ERR_FIFO 0x00020000 ++#define ADSL_DMA_XMT_ERR_DTE 0x00030000 ++#define ADSL_DMA_XMT_ERR_DRE 0x00040000 ++ ++ uint32 rcvcontrol_intr; ++#define ADSL_DMA_RCV_EN 0x00000001 ++#define ADSL_DMA_RCV_FO 0x000000FE ++ uint32 rcvaddr_intr; ++ uint32 rcvptr_intr; ++ uint32 rcvstatus_intr; ++#define ADSL_DMA_RCV_STATE_MASK 0x0000F000 ++#define ADSL_DMA_RCV_STATE_DIS 0x00000000 ++#define ADSL_DMA_RCV_STATE_ACT 0x00001000 ++#define ADSL_DMA_RCV_STATE_IDLE 0x00002000 ++#define ADSL_DMA_RCV_STATE_STOP 0x00003000 ++ ++#define ADSL_DMA_RCV_ERR_MASK 0x000F0000 ++#define ADSL_DMA_RCV_ERR_NONE 0x00000000 ++#define ADSL_DMA_RCV_ERR_DPE 0x00010000 ++#define ADSL_DMA_RCV_ERR_FIFO 0x00020000 ++#define ADSL_DMA_RCV_ERR_DTE 0x00030000 ++#define ADSL_DMA_RCV_ERR_DRE 0x00040000 ++ ++ uint32 xmtcontrol_fast; ++ uint32 xmtaddr_fast; ++ uint32 xmtptr_fast; ++ uint32 xmtstatus_fast; ++ uint32 rcvcontrol_fast; ++ uint32 rcvaddr_fast; ++ uint32 rcvptr_fast; ++ uint32 rcvstatus_fast; ++ uint32 PAD[48]; ++ ++ uint32 host_message; /* 0x300 */ ++ uint32 PAD[805]; ++ uint32 core_reset; ++ uint32 core_error; ++ uint32 core_revision; ++ ++#define ADSL_CORE_REV 0x0000000F ++#define ADSL_CORE_TYPE 0x0000FFF0 ++} AdslRegisters; ++ ++#define ADSL ((volatile AdslRegisters * const) ADSL_BASE) ++ ++#if __cplusplus ++} ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/AdslMibDef.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/AdslMibDef.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/AdslMibDef.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/AdslMibDef.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,712 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/**************************************************************************** ++ * ++ * AdslMibOid.h ++ * ++ * Description: ++ * SNMP object identifiers for ADSL MIB and other related MIBs ++ * ++ * Copyright (c) 1993-1998 AltoCom, Inc. All rights reserved. ++ * Authors: Ilya Stomakhin ++ * ++ * $Revision: 1.17 $ ++ * ++ * $Id: AdslMibDef.h,v 1.17 2004/07/27 19:24:40 ilyas Exp $ ++ * ++ * $Log: AdslMibDef.h,v $ ++ * Revision 1.17 2004/07/27 19:24:40 ilyas ++ * Added AnnexM configuration option ++ * ++ * Revision 1.16 2004/06/04 18:56:01 ilyas ++ * Added counter for ADSL2 framing and performance ++ * ++ * Revision 1.15 2004/05/25 16:15:04 ilyas ++ * Added ADSL2 framing status ++ * ++ * Revision 1.14 2004/03/31 19:09:48 ilyas ++ * Added ADSL2+ modulation control ++ * ++ * Revision 1.13 2004/03/03 20:14:05 ilyas ++ * Merged changes for ADSL2+ from ADSL driver ++ * ++ * Revision 1.12 2003/10/17 21:02:12 ilyas ++ * Added more data for ADSL2 ++ * ++ * Revision 1.11 2003/10/14 00:55:27 ilyas ++ * Added UAS, LOSS, SES error seconds counters. ++ * Support for 512 tones (AnnexI) ++ * ++ * Revision 1.10 2003/09/29 18:39:51 ilyas ++ * Added new definitions for AnnexI ++ * ++ * Revision 1.9 2003/07/18 19:14:34 ilyas ++ * Merged with ADSL driver ++ * ++ * Revision 1.8 2003/07/08 18:34:16 ilyas ++ * Added fields to adsl configuration structure ++ * ++ * Revision 1.7 2003/03/25 00:07:00 ilyas ++ * Added "long" BERT supprt ++ * ++ * Revision 1.6 2003/02/27 07:10:52 ilyas ++ * Added more configuration and status parameters (for EFNT) ++ * ++ * Revision 1.5 2003/01/23 20:29:37 ilyas ++ * Added structure for ADSL PHY configuration command ++ * ++ * Revision 1.4 2002/11/13 21:32:49 ilyas ++ * Added adjustK support for Centillium non-standard framing mode ++ * ++ * Revision 1.3 2002/10/31 01:35:50 ilyas ++ * Fixed size of K for S=1/2 ++ * ++ * Revision 1.2 2002/10/05 03:28:31 ilyas ++ * Added extra definitions for Linux and VxWorks drivers. ++ * Added definitions for SelfTest support ++ * ++ * Revision 1.1 2002/07/20 00:51:41 ilyas ++ * Merged witchanges made for VxWorks/Linux driver. ++ * ++ * Revision 1.1 2001/12/21 22:39:30 ilyas ++ * Added support for ADSL MIB data objects (RFC2662) ++ * ++ * ++ *****************************************************************************/ ++ ++#ifndef AdslMibDefHeader ++#define AdslMibDefHeader ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++/* ++** ++** ADSL configuration parameters ++** ++*/ ++ ++#define kAdslCfgModMask (0x00000007 | 0x0000F000) ++#define kAdslCfgModAny 0x00000000 ++ ++#define kAdslCfgModGdmtOnly 0x00000001 ++#define kAdslCfgModGliteOnly 0x00000002 ++#define kAdslCfgModT1413Only 0x00000004 ++#define kAdslCfgModAnnexIOnly 0x00000004 ++#define kAdslCfgModAdsl2Only 0x00001000 ++#define kAdslCfgModAdsl2pOnly 0x00002000 ++ ++#define kAdslCfgBitmapMask 0x00000018 ++#define kAdslCfgDBM 0x00000000 ++#define kAdslCfgFBM 0x00000008 ++#define kAdslCfgFBMSoL 0x00000010 ++ ++#define kAdslCfgLinePairMask 0x00000020 ++#define kAdslCfgLineInnerPair 0x00000000 ++#define kAdslCfgLineOuterPair 0x00000020 ++ ++#define kAdslCfgCentilliumCRCWorkAroundMask 0x00000040 ++#define kAdslCfgCentilliumCRCWorkAroundDisabled 0x00000000 ++#define kAdslCfgCentilliumCRCWorkAroundEnabled 0x00000040 ++ ++#define kAdslCfgExtraData 0x00000080 ++#define kAdslCfgTrellisMask (0x00000100 | kAdslCfgExtraData) ++#define kAdslCfgTrellisOn (0x00000100 | kAdslCfgExtraData) ++#define kAdslCfgTrellisOff (0 | kAdslCfgExtraData) ++#define kAdslCfgExtraMask 0xFFFFFF80 ++ ++#define kAdslCfgLOSMonitoringMask 0x00000200 ++#define kAdslCfgLOSMonitoringOff 0x00000200 ++#define kAdslCfgLOSMonitoringOn 0x00000000 ++ ++#define kAdslCfgMarginMonitoringMask 0x00000400 ++#define kAdslCfgMarginMonitoringOn 0x00000400 ++#define kAdslCfgMarginMonitoringOff 0x00000000 ++ ++#define kAdslCfgDemodCapMask 0x00000800 ++#define kAdslCfgDemodCapOn 0x00000800 ++#define kAdslCfgDemodCapOff 0x00000000 ++ ++/* Flags 0x00001000 - 0x00008000 are reserved for modulation (see above) */ ++ ++/* Upstream mode flags 0x00010000 - 0x00030000 */ ++ ++#define kAdslCfgUpstreamModeMask 0x00030000 ++#define kAdslCfgUpstreamMax 0x00000000 ++#define kAdslCfgUpstreamSingle 0x00010000 ++#define kAdslCfgUpstreamDouble 0x00020000 ++#define kAdslCfgUpstreamTriple 0x00030000 ++ ++#define kAdslCfgNoSpectrumOverlap 0x00040000 ++ ++/* Pwm sync clock configuration */ ++ ++#define kAdslCfgPwmSyncClockMask 0x00080000 ++#define kAdslCfgPwmSyncClockOn 0x00080000 ++#define kAdslCfgPwmSyncClockOff 0x00000000 ++ ++#define kAdslCfgDefaultTrainingMargin -1 ++#define kAdslCfgDefaultShowtimeMargin -1 ++#define kAdslCfgDefaultLOMTimeThld -1 ++ ++/* ADSL2 parameters */ ++ ++#define kAdsl2CfgReachExOn 0x00000001 ++#define kAdsl2CfgAnnexMEnabled 0x00000002 ++ ++typedef struct _adslCfgProfile { ++ long adslAnnexCParam; ++ long adslAnnexAParam; ++ long adslTrainingMarginQ4; ++ long adslShowtimeMarginQ4; ++ long adslLOMTimeThldSec; ++ long adslDemodCapMask; ++ long adslDemodCapValue; ++ long adsl2Param; ++ long adslPwmSyncClockFreq; ++} adslCfgProfile; ++ ++/* ++** ++** ADSL PHY configuration ++** ++*/ ++ ++typedef struct _adslPhyCfg { ++ long demodCapMask; ++ long demodCap; ++} adslPhyCfg; ++ ++/* ++** ++** ADSL version info parameters ++** ++*/ ++ ++#define kAdslVersionStringSize 32 ++ ++#define kAdslTypeUnknown 0 ++#define kAdslTypeAnnexA 1 ++#define kAdslTypeAnnexB 2 ++#define kAdslTypeAnnexC 3 ++#define kAdslTypeSADSL 4 ++ ++typedef struct _adslVersionInfo { ++ unsigned short phyType; ++ unsigned short phyMjVerNum; ++ unsigned short phyMnVerNum; ++ char phyVerStr[kAdslVersionStringSize]; ++ unsigned short drvMjVerNum; ++ unsigned short drvMnVerNum; ++ char drvVerStr[kAdslVersionStringSize]; ++} adslVersionInfo; ++ ++/* ++** ++** ADSL self-test parameters ++** ++*/ ++ ++#define kAdslSelfTestLMEM 0x00000001 ++#define kAdslSelfTestSDRAM 0x00000002 ++#define kAdslSelfTestAFE 0x00000004 ++#define kAdslSelfTestQproc 0x00000008 ++#define kAdslSelfTestRS 0x00000010 ++#define kAdslSelfTestHostDma 0x00000020 ++ ++#define kAdslSelfTestAll ((kAdslSelfTestHostDma - 1) | kAdslSelfTestHostDma) ++ ++#define kAdslSelfTestInProgress 0x40000000 ++#define kAdslSelfTestCompleted 0x80000000 ++ ++/* MIB OID's for ADSL objects */ ++ ++#define kOidMaxObjLen 80 ++ ++#define kOidAdsl 94 ++#define kOidAdslInterleave 124 ++#define kOidAdslFast 125 ++#define kOidAtm 37 ++#define kOidAdslPrivate 255 ++#define kOidAdslPrivatePartial 254 ++ ++#define kAdslMibAnnexAToneNum 256 ++#define kAdslMibToneNum kAdslMibAnnexAToneNum ++#define kAdslMibMaxToneNum kAdslMibAnnexAToneNum*2*2 ++ ++#define kOidAdslPrivSNR 1 ++#define kOidAdslPrivBitAlloc 2 ++#define kOidAdslPrivGain 3 ++#define kOidAdslPrivShowtimeMargin 4 ++#define kOidAdslPrivChanCharLin 5 ++#define kOidAdslPrivChanCharLog 6 ++#define kOidAdslPrivQuietLineNoise 7 ++#define kOidAdslPrivExtraInfo 255 ++ ++#define kOidAdslLine 1 ++#define kOidAdslMibObjects 1 ++ ++#define kOidAdslLineTable 1 ++#define kOidAdslLineEntry 1 ++#define kOidAdslLineCoding 1 ++#define kOidAdslLineType 2 ++#define kOidAdslLineSpecific 3 ++#define kOidAdslLineConfProfile 4 ++#define kOidAdslLineAlarmConfProfile 5 ++ ++#define kOidAdslAtucPhysTable 2 ++#define kOidAdslAturPhysTable 3 ++#define kOidAdslPhysEntry 1 ++#define kOidAdslPhysInvSerialNumber 1 ++#define kOidAdslPhysInvVendorID 2 ++#define kOidAdslPhysInvVersionNumber 3 ++#define kOidAdslPhysCurrSnrMgn 4 ++#define kOidAdslPhysCurrAtn 5 ++#define kOidAdslPhysCurrStatus 6 ++#define kOidAdslPhysCurrOutputPwr 7 ++#define kOidAdslPhysCurrAttainableRate 8 ++ ++#define kOidAdslAtucChanTable 4 ++#define kOidAdslAturChanTable 5 ++#define kOidAdslChanEntry 1 ++#define kOidAdslChanInterleaveDelay 1 ++#define kOidAdslChanCurrTxRate 2 ++#define kOidAdslChanPrevTxRate 3 ++#define kOidAdslChanCrcBlockLength 4 ++ ++#define kOidAdslAtucPerfDataTable 6 ++#define kOidAdslAturPerfDataTable 7 ++#define kOidAdslPerfDataEntry 1 ++#define kOidAdslPerfLofs 1 ++#define kOidAdslPerfLoss 2 ++#define kOidAdslPerfLprs 3 ++#define kOidAdslPerfESs 4 ++#define kOidAdslPerfValidIntervals 5 ++#define kOidAdslPerfInvalidIntervals 6 ++#define kOidAdslPerfCurr15MinTimeElapsed 7 ++#define kOidAdslPerfCurr15MinLofs 8 ++#define kOidAdslPerfCurr15MinLoss 9 ++#define kOidAdslPerfCurr15MinLprs 10 ++#define kOidAdslPerfCurr15MinESs 11 ++#define kOidAdslPerfCurr1DayTimeElapsed 12 ++#define kOidAdslPerfCurr1DayLofs 13 ++#define kOidAdslPerfCurr1DayLoss 14 ++#define kOidAdslPerfCurr1DayLprs 15 ++#define kOidAdslPerfCurr1DayESs 16 ++#define kOidAdslPerfPrev1DayMoniSecs 17 ++#define kOidAdslPerfPrev1DayLofs 18 ++#define kOidAdslPerfPrev1DayLoss 19 ++#define kOidAdslPerfPrev1DayLprs 20 ++#define kOidAdslPerfPrev1DayESs 21 ++ ++#define kOidAdslAtucPerfIntervalTable 8 ++#define kOidAdslAturPerfIntervalTable 9 ++#define kOidAdslPerfIntervalEntry 1 ++#define kOidAdslIntervalNumber 1 ++#define kOidAdslIntervalLofs 2 ++#define kOidAdslIntervalLoss 3 ++#define kOidAdslIntervalLprs 4 ++#define kOidAdslIntervalESs 5 ++#define kOidAdslIntervalValidData 6 ++ ++#define kOidAdslAtucChanPerfTable 10 ++#define kOidAdslAturChanPerfTable 11 ++#define kOidAdslChanPerfEntry 1 ++#define kOidAdslChanReceivedBlks 1 ++#define kOidAdslChanTransmittedBlks 2 ++#define kOidAdslChanCorrectedBlks 3 ++#define kOidAdslChanUncorrectBlks 4 ++#define kOidAdslChanPerfValidIntervals 5 ++#define kOidAdslChanPerfInvalidIntervals 6 ++#define kOidAdslChanPerfCurr15MinTimeElapsed 7 ++#define kOidAdslChanPerfCurr15MinReceivedBlks 8 ++#define kOidAdslChanPerfCurr15MinTransmittedBlks 9 ++#define kOidAdslChanPerfCurr15MinCorrectedBlks 10 ++#define kOidAdslChanPerfCurr15MinUncorrectBlks 11 ++#define kOidAdslChanPerfCurr1DayTimeElapsed 12 ++#define kOidAdslChanPerfCurr1DayReceivedBlks 13 ++#define kOidAdslChanPerfCurr1DayTransmittedBlks 14 ++#define kOidAdslChanPerfCurr1DayCorrectedBlks 15 ++#define kOidAdslChanPerfCurr1DayUncorrectBlks 16 ++#define kOidAdslChanPerfPrev1DayMoniSecs 17 ++#define kOidAdslChanPerfPrev1DayReceivedBlks 18 ++#define kOidAdslChanPerfPrev1DayTransmittedBlks 19 ++#define kOidAdslChanPerfPrev1DayCorrectedBlks 20 ++#define kOidAdslChanPerfPrev1DayUncorrectBlks 21 ++ ++#define kOidAdslAtucChanIntervalTable 12 ++#define kOidAdslAturChanIntervalTable 13 ++#define kOidAdslChanIntervalEntry 1 ++#define kOidAdslChanIntervalNumber 1 ++#define kOidAdslChanIntervalReceivedBlks 2 ++#define kOidAdslChanIntervalTransmittedBlks 3 ++#define kOidAdslChanIntervalCorrectedBlks 4 ++#define kOidAdslChanIntervalUncorrectBlks 5 ++#define kOidAdslChanIntervalValidData 6 ++ ++#define kOidAtmMibObjects 1 ++#define kOidAtmTcTable 4 ++#define kOidAtmTcEntry 1 ++#define kOidAtmOcdEvents 1 ++#define kOidAtmAlarmState 2 ++ ++/* Adsl Channel coding */ ++ ++#define kAdslRcvDir 0 ++#define kAdslXmtDir 1 ++ ++#define kAdslRcvActive (1 << kAdslRcvDir) ++#define kAdslXmtActive (1 << kAdslXmtDir) ++ ++#define kAdslIntlChannel 0 ++#define kAdslFastChannel 1 ++ ++#define kAdslTrellisOff 0 ++#define kAdslTrellisOn 1 ++ ++/* AnnexC modulation and bitmap types for the field (adslConnection.modType) */ ++ ++#define kAdslModMask 0x7 ++ ++#define kAdslModGdmt 0 ++#define kAdslModT1413 1 ++#define kAdslModGlite 2 ++#define kAdslModAnnexI 3 ++#define kAdslModAdsl2 4 ++#define kAdslModAdsl2p 5 ++#define kAdslModReAdsl2 6 ++ ++#define kAdslBitmapShift 3 ++#define kAdslBitmapMask kAdslCfgBitmapMask ++#define kAdslDBM (0 << kAdslBitmapShift) ++#define kAdslFBM (1 << kAdslBitmapShift) ++#define kAdslFBMSoL (2 << kAdslBitmapShift) ++ ++#define kAdslUpstreamModeShift 5 ++#define kAdslUpstreamModeMask (3 << kAdslUpstreamModeShift) ++#define kAdslUpstreamModeSingle (0 << kAdslUpstreamModeShift) ++#define kAdslUpstreamModeDouble (1 << kAdslUpstreamModeShift) ++#define kAdslUpstreamModeTriple (2 << kAdslUpstreamModeShift) ++ ++/* AdslLineCodingType definitions */ ++ ++#define kAdslLineCodingOther 1 ++#define kAdslLineCodingDMT 2 ++#define kAdslLineCodingCAP 3 ++#define kAdslLineCodingQAM 4 ++ ++/* AdslLineType definitions */ ++ ++#define kAdslLineTypeNoChannel 1 ++#define kAdslLineTypeFastOnly 2 ++#define kAdslLineTypeIntlOnly 3 ++#define kAdslLineTypeFastOrIntl 4 ++#define kAdslLineTypeFastAndIntl 5 ++ ++typedef struct _adslLineEntry { ++ unsigned char adslLineCoding; ++ unsigned char adslLineType; ++} adslLineEntry; ++ ++ ++/* AdslPhys status definitions */ ++ ++#define kAdslPhysStatusNoDefect (1 << 0) ++#define kAdslPhysStatusLOF (1 << 1) /* lossOfFraming (not receiving valid frame) */ ++#define kAdslPhysStatusLOS (1 << 2) /* lossOfSignal (not receiving signal) */ ++#define kAdslPhysStatusLPR (1 << 3) /* lossOfPower */ ++#define kAdslPhysStatusLOSQ (1 << 4) /* lossOfSignalQuality */ ++#define kAdslPhysStatusLOM (1 << 5) /* lossOfMargin */ ++ ++typedef struct _adslPhysEntry { ++ long adslCurrSnrMgn; ++ long adslCurrAtn; ++ long adslCurrStatus; ++ long adslCurrOutputPwr; ++ long adslCurrAttainableRate; ++} adslPhysEntry; ++ ++#define kAdslPhysVendorIdLen 8 ++#define kAdslPhysSerialNumLen 32 ++#define kAdslPhysVersionNumLen 32 ++ ++typedef struct _adslFullPhysEntry { ++ char adslSerialNumber[kAdslPhysSerialNumLen]; ++ char adslVendorID[kAdslPhysVendorIdLen]; ++ char adslVersionNumber[kAdslPhysVersionNumLen]; ++ long adslCurrSnrMgn; ++ long adslCurrAtn; ++ long adslCurrStatus; ++ long adslCurrOutputPwr; ++ long adslCurrAttainableRate; ++} adslFullPhysEntry; ++ ++/* Adsl channel entry definitions */ ++ ++typedef struct _adslChanEntry { ++ unsigned long adslChanIntlDelay; ++ unsigned long adslChanCurrTxRate; ++ unsigned long adslChanPrevTxRate; ++ unsigned long adslChanCrcBlockLength; ++} adslChanEntry; ++ ++/* Adsl performance data definitions */ ++ ++typedef struct _adslPerfCounters { ++ unsigned long adslLofs; ++ unsigned long adslLoss; ++ unsigned long adslLols; /* Loss of Link failures (ATUC only) */ ++ unsigned long adslLprs; ++ unsigned long adslESs; /* Count of Errored Seconds */ ++ unsigned long adslInits; /* Count of Line initialization attempts (ATUC only) */ ++ unsigned long adslUAS; /* Count of Unavailable Seconds */ ++ unsigned long adslSES; /* Count of Severely Errored Seconds */ ++ unsigned long adslLOSS; /* Count of LOS seconds */ ++ unsigned long adslFECs; /* Count of FEC seconds */ ++} adslPerfCounters; ++ ++typedef struct _adslPerfDataEntry { ++ adslPerfCounters perfTotal; ++ unsigned long adslPerfValidIntervals; ++ unsigned long adslPerfInvalidIntervals; ++ adslPerfCounters perfCurr15Min; ++ unsigned long adslPerfCurr15MinTimeElapsed; ++ adslPerfCounters perfCurr1Day; ++ unsigned long adslPerfCurr1DayTimeElapsed; ++ adslPerfCounters perfPrev1Day; ++ unsigned long adslAturPerfPrev1DayMoniSecs; ++} adslPerfDataEntry; ++ ++#define kAdslMibPerfIntervals 4 ++ ++/* Adsl channel performance data definitions */ ++ ++typedef struct _adslChanCounters { ++ unsigned long adslChanReceivedBlks; ++ unsigned long adslChanTransmittedBlks; ++ unsigned long adslChanCorrectedBlks; ++ unsigned long adslChanUncorrectBlks; ++} adslChanCounters; ++ ++typedef struct _adslChanPerfDataEntry { ++ adslChanCounters perfTotal; ++ unsigned long adslChanPerfValidIntervals; ++ unsigned long adslChanPerfInvalidIntervals; ++ adslChanCounters perfCurr15Min; ++ unsigned long adslPerfCurr15MinTimeElapsed; ++ adslChanCounters perfCurr1Day; ++ unsigned long adslPerfCurr1DayTimeElapsed; ++ adslChanCounters perfPrev1Day; ++ unsigned long adslAturPerfPrev1DayMoniSecs; ++} adslChanPerfDataEntry; ++ ++#define kAdslMibChanPerfIntervals 4 ++ ++/* Adsl trap threshold definitions */ ++ ++#define kAdslEventLinkChange 0x001 ++#define kAdslEventRateChange 0x002 ++#define kAdslEventLofThresh 0x004 ++#define kAdslEventLosThresh 0x008 ++#define kAdslEventLprThresh 0x010 ++#define kAdslEventESThresh 0x020 ++#define kAdslEventFastUpThresh 0x040 ++#define kAdslEventIntlUpThresh 0x080 ++#define kAdslEventFastDownThresh 0x100 ++#define kAdslEventIntlDwonThresh 0x200 ++ ++typedef struct _adslThreshCounters { ++ unsigned long adslThreshLofs; ++ unsigned long adslThreshLoss; ++ unsigned long adslThreshLols; /* Loss of Link failures (ATUC only) */ ++ unsigned long adslThreshLprs; ++ unsigned long adslThreshESs; ++ unsigned long adslThreshFastRateUp; ++ unsigned long adslThreshIntlRateUp; ++ unsigned long adslThreshFastRateDown; ++ unsigned long adslThreshIntlRateDown; ++} adslThreshCounters; ++ ++ ++/* Atm PHY performance data definitions */ ++ ++#define kAtmPhyStateNoAlarm 1 ++#define kAtmPhyStateLcdFailure 2 ++ ++typedef struct _atmPhyDataEntrty { ++ unsigned long atmInterfaceOCDEvents; ++ unsigned long atmInterfaceTCAlarmState; ++} atmPhyDataEntrty; ++ ++typedef struct _adslBertResults { ++ unsigned long bertTotalBits; ++ unsigned long bertErrBits; ++} adslBertResults; ++ ++typedef struct { ++ unsigned long cntHi; ++ unsigned long cntLo; ++} cnt64; ++ ++typedef struct _adslBertStatusEx { ++ unsigned long bertSecTotal; ++ unsigned long bertSecElapsed; ++ unsigned long bertSecCur; ++ cnt64 bertTotalBits; ++ cnt64 bertErrBits; ++} adslBertStatusEx; ++ ++typedef struct _adslDataConnectionInfo { ++ unsigned short K; ++ unsigned char S, R, D; ++} adslDataConnectionInfo; ++ ++typedef struct _adslConnectionInfo { ++ unsigned char chType; /* fast or interleaved */ ++ unsigned char modType; /* modulation type: G.DMT or T1.413 */ ++ unsigned char trellisCoding; /* off(0) or on(1) */ ++ adslDataConnectionInfo rcvInfo; ++ adslDataConnectionInfo xmtInfo; ++} adslConnectionInfo; ++ ++typedef struct _adsl2DataConnectionInfo { ++ unsigned char Nlp; ++ unsigned char Nbc; ++ unsigned char MSGlp; ++ unsigned short MSGc; ++ ++ unsigned long L; ++ unsigned short M; ++ unsigned short T; ++ unsigned short D; ++ unsigned short R; ++ unsigned short B; ++} adsl2DataConnectionInfo; ++ ++typedef struct _adsl2ConnectionInfo { ++ long adsl2Mode; ++ long rcvRate; ++ long xmtRate; ++ unsigned char pwrState; /* Lx state: x = 0..3 */ ++ adsl2DataConnectionInfo rcv2Info; ++ adsl2DataConnectionInfo xmt2Info; ++} adsl2ConnectionInfo; ++ ++typedef struct _adslConnectionDataStat { ++ unsigned long cntRS; ++ unsigned long cntRSCor; ++ unsigned long cntRSUncor; ++ unsigned long cntSF; ++ unsigned long cntSFErr; ++} adslConnectionDataStat; ++ ++typedef struct _adslConnectionStat { ++ adslConnectionDataStat rcvStat; ++ adslConnectionDataStat xmtStat; ++} adslConnectionStat; ++ ++typedef struct _atmConnectionDataStat { ++ unsigned long cntHEC; ++ unsigned long cntOCD; ++ unsigned long cntLCD; ++ unsigned long cntES; ++ unsigned long cntCellTotal; ++ unsigned long cntCellData; ++ unsigned long cntCellDrop; ++ unsigned long cntBitErrs; ++} atmConnectionDataStat; ++ ++typedef struct _atmConnectionStat { ++ atmConnectionDataStat rcvStat; ++ atmConnectionDataStat xmtStat; ++} atmConnectionStat; ++ ++#define kAdslFramingModeMask 0x0F ++#define kAtmFramingModeMask 0xF0 ++#define kAtmHeaderCompression 0x80 ++ ++/* ADSL2 data */ ++ ++typedef struct _adslDiagModeData { ++ long loopAttn; ++ long signalAttn; ++ long snrMargin; ++ long attnDataRate; ++ long actXmtPower; ++ long hlinScaleFactor; ++} adslDiagModeData; ++ ++/* AdslMibGetObjectValue return codes */ ++ ++#define kAdslMibStatusSuccess 0 ++#define kAdslMibStatusFailure -1 ++#define kAdslMibStatusNoObject -2 ++#define kAdslMibStatusObjectInvalid -3 ++#define kAdslMibStatusBufferTooSmall -4 ++#define kAdslMibStatusLastError -4 ++ ++/* Adsl training codes */ ++ ++#define kAdslTrainingIdle 0 ++#define kAdslTrainingG994 1 ++#define kAdslTrainingG992Started 2 ++#define kAdslTrainingG992ChanAnalysis 3 ++#define kAdslTrainingG992Exchange 4 ++#define kAdslTrainingConnected 5 ++ ++/* Global info structure */ ++ ++typedef struct _adslMibInfo { ++ adslLineEntry adslLine; ++ adslPhysEntry adslPhys; ++ adslChanEntry adslChanIntl; ++ adslChanEntry adslChanFast; ++ adslPerfDataEntry adslPerfData; ++ adslPerfCounters adslPerfIntervals[kAdslMibPerfIntervals]; ++ adslChanPerfDataEntry adslChanIntlPerfData; ++ adslChanPerfDataEntry adslChanFastPerfData; ++ adslChanCounters adslChanIntlPerfIntervals[kAdslMibChanPerfIntervals]; ++ adslChanCounters adslChanFastPerfIntervals[kAdslMibChanPerfIntervals]; ++ ++ adslThreshCounters adslAlarm; ++ ++ atmPhyDataEntrty adslChanIntlAtmPhyData; ++ atmPhyDataEntrty adslChanFastAtmPhyData; ++ ++ adslBertResults adslBertRes; ++ ++ adslConnectionInfo adslConnection; ++ adslConnectionStat adslStat; ++ unsigned char adslTrainingState; ++ atmConnectionStat atmStat; ++ ++ adslFullPhysEntry adslAtucPhys; ++ unsigned char adslRxNonStdFramingAdjustK; ++ unsigned char adslFramingMode; ++ adslBertStatusEx adslBertStatus; ++ long afeRxPgaGainQ1; ++ ++ adslDiagModeData adslDiag; ++ adsl2ConnectionInfo adsl2Info; ++ adslPerfCounters adslTxPerfTotal; ++} adslMibInfo; ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif /* AdslMibDefHeader */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/DiagDef.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/DiagDef.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/DiagDef.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/DiagDef.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,209 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++ ++/******************************************************************* ++ * DiagDef.h ++ * ++ * Description: ++ * Diag definitions ++ * ++ * $Revision: 1.22 $ ++ * ++ * $Id: DiagDef.h,v 1.22 2004/10/16 23:43:19 ilyas Exp $ ++ * ++ * $Log: DiagDef.h,v $ ++ * Revision 1.22 2004/10/16 23:43:19 ilyas ++ * Added playback resume command ++ * ++ * Revision 1.21 2004/10/16 23:24:08 ilyas ++ * Improved FileRead command support for LOG file playback (RecordTest on the board) ++ * ++ * Revision 1.20 2004/04/28 16:52:32 ilyas ++ * Added GDB frame processing ++ * ++ * Revision 1.19 2004/03/10 22:26:53 ilyas ++ * Added command-line parameter for IP port number. ++ * Added proxy remote termination ++ * ++ * Revision 1.18 2004/01/24 23:41:37 ilyas ++ * Added DIAG_DEBUG_CMD_LOG_SAMPLES debug command ++ * ++ * Revision 1.17 2003/11/19 02:25:45 ilyas ++ * Added definitions for LOG frame retransmission, time, ADSL2 plots ++ * ++ * Revision 1.16 2003/11/14 18:46:05 ilyas ++ * Added G992p3 debug commands ++ * ++ * Revision 1.15 2003/10/02 19:50:41 ilyas ++ * Added support for buffering data for AnnexI and statistical counters ++ * ++ * Revision 1.14 2003/09/03 19:45:11 ilyas ++ * To refuse connection with older protocol versions ++ * ++ * Revision 1.13 2003/08/30 00:12:39 ilyas ++ * Added support for running chip test regressions via DslDiags ++ * ++ * Revision 1.12 2003/08/12 00:19:28 ilyas ++ * Improved image downloading protocol. ++ * Added DEBUG command support ++ * ++ * Revision 1.11 2003/04/11 00:37:24 ilyas ++ * Added DiagProtoFrame definition ++ * ++ * Revision 1.10 2003/03/25 00:10:07 ilyas ++ * Added command for "long" BERT test ++ * ++ * Revision 1.9 2003/01/30 03:29:32 ilyas ++ * Added PHY_CFG support and fixed printing showtime counters ++ * ++ * Revision 1.8 2002/12/16 20:56:38 ilyas ++ * Added support for binary statuses ++ * ++ * Revision 1.7 2002/12/06 20:19:13 ilyas ++ * Added support for binary statuses and scrambled status strings ++ * ++ * Revision 1.6 2002/11/05 00:18:27 ilyas ++ * Added configuration dialog box for Eye tone selection. ++ * Added Centillium CRC workaround to AnnexC config dialog ++ * Bit allocation update on bit swap messages ++ * ++ * Revision 1.5 2002/07/30 23:23:43 ilyas ++ * Implemented DIAG configuration command for AnnexA and AnnexC ++ * ++ * Revision 1.4 2002/07/30 22:47:15 ilyas ++ * Added DIAG command for configuration ++ * ++ * Revision 1.3 2002/07/15 23:52:51 ilyas ++ * iAdded switch RJ11 pair command ++ * ++ * Revision 1.2 2002/04/25 17:55:51 ilyas ++ * Added mibGet command ++ * ++ * Revision 1.1 2002/04/02 22:56:39 ilyas ++ * Support DIAG connection at any time; BERT commands ++ * ++ * ++ ******************************************************************/ ++ ++#define LOG_PROTO_ID "*L" ++ ++#define DIAG_PARTY_ID_MASK 0x01 ++#define LOG_PARTY_CLIENT 0x01 ++#define LOG_PARTY_SERVER 0x00 ++ ++#define DIAG_DATA_MASK 0x0E ++#define DIAG_DATA_LOG 0x02 ++#define DIAG_DATA_EYE 0x04 ++#define DIAG_DATA_LOG_TIME 0x08 ++ ++#define DIAG_DATA_EX 0x80 ++#define DIAG_PARTY_ID_MASK_EX (DIAG_DATA_EX | DIAG_PARTY_ID_MASK) ++#define LOG_PARTY_SERVER_EX (DIAG_DATA_EX | LOG_PARTY_SERVER) ++ ++#define DIAG_ACK_FRAME_ACK_MASK 0x000000FF ++#define DIAG_ACK_FRAME_RCV_SHIFT 8 ++#define DIAG_ACK_FRAME_RCV_MASK 0x0000FF00 ++#define DIAG_ACK_FRAME_RCV_PRESENT 0x00010000 ++#define DIAG_ACK_TIMEOUT -1 ++#define DIAG_ACK_LEN_INDICATION -1 ++ ++#define LOG_CMD_GDB 236 ++#define LOG_CMD_PROXY 237 ++#define LOG_CMD_RETR 238 ++#define LOG_CMD_DEBUG 239 ++#define LOG_CMD_BERT_EX 240 ++#define LOG_CMD_CFG_PHY 241 ++#define LOG_CMD_RESET 242 ++#define LOG_CMD_SCRAMBLED_STRING 243 ++#define LOG_CMD_EYE_CFG 244 ++#define LOG_CMD_CONFIG_A 245 ++#define LOG_CMD_CONFIG_C 246 ++#define LOG_CMD_SWITCH_RJ11_PAIR 247 ++#define LOG_CMD_MIB_GET 248 ++#define LOG_CMD_LOG_STOP 249 ++#define LOG_CMD_PING_REQ 250 ++#define LOG_CMD_PING_RSP 251 ++#define LOG_CMD_DISCONNECT 252 ++#define LOG_CMD_STRING_DATA 253 ++#define LOG_CMD_TEST_DATA 254 ++#define LOG_CMD_CONNECT 255 ++ ++typedef struct _LogProtoHeader { ++ unsigned char logProtoId[2]; ++ unsigned char logPartyId; ++ unsigned char logCommmand; ++} LogProtoHeader; ++ ++#define LOG_FILE_PORT 5100 ++#define LOG_MAX_BUF_SIZE 1400 ++#define LOG_MAX_DATA_SIZE (LOG_MAX_BUF_SIZE - sizeof(LogProtoHeader)) ++ ++typedef struct { ++ LogProtoHeader diagHdr; ++ unsigned char diagData[LOG_MAX_DATA_SIZE]; ++} DiagProtoFrame; ++ ++#define DIAG_PROXY_TERMINATE 1 ++ ++#define DIAG_DEBUG_CMD_READ_MEM 1 ++#define DIAG_DEBUG_CMD_SET_MEM 2 ++#define DIAG_DEBUG_CMD_RESET_CONNECTION 3 ++#define DIAG_DEBUG_CMD_RESET_PHY 4 ++#define DIAG_DEBUG_CMD_RESET_CHIP 5 ++#define DIAG_DEBUG_CMD_EXEC_FUNC 6 ++#define DIAG_DEBUG_CMD_EXEC_ADSL_FUNC 7 ++#define DIAG_DEBUG_CMD_WRITE_FILE 8 ++#define DIAG_DEBUG_CMD_G992P3_DEBUG 9 ++#define DIAG_DEBUG_CMD_G992P3_DIAG_MODE 10 ++#define DIAG_DEBUG_CMD_CLEAR_TIME 11 ++#define DIAG_DEBUG_CMD_PRINT_TIME 12 ++#define DIAG_DEBUG_CMD_LOG_SAMPLES 13 ++ ++#define DIAG_DEBUG_CMD_PLAYBACK_STOP 14 ++#define DIAG_DEBUG_CMD_PLAYBACK_RESUME 15 ++ ++#define DIAG_DEBUG_CMD_PRINT_STAT 21 ++#define DIAG_DEBUG_CMD_CLEAR_STAT 22 ++ ++typedef struct { ++ unsigned short cmd; ++ unsigned short cmdId; ++ unsigned long param1; ++ unsigned long param2; ++ unsigned char diagData[1]; ++} DiagDebugData; ++ ++#define DIAG_TEST_CMD_LOAD 101 ++#define DIAG_TEST_CMD_READ 102 ++#define DIAG_TEST_CMD_WRITE 103 ++#define DIAG_TEST_CMD_APPEND 104 ++#define DIAG_TEST_CMD_TEST_COMPLETE 105 ++ ++#define DIAG_TEST_FILENAME_LEN 64 ++ ++typedef struct { ++ unsigned short cmd; ++ unsigned short cmdId; ++ unsigned long offset; ++ unsigned long len; ++ unsigned long bufPtr; ++ char fileName[DIAG_TEST_FILENAME_LEN]; ++} DiagTestData; ++ ++typedef struct { ++ unsigned long frStart; ++ unsigned long frNum; ++} DiagLogRetrData; +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/adsldrv.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/adsldrv.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/adsldrv.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/adsldrv.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,203 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/*************************************************************************** ++ * File Name : AdslDrv.h ++ * ++ * Description: This file contains the definitions and structures for the ++ * Linux IOCTL interface that used between the user mode ADSL ++ * API library and the kernel ADSL API driver. ++ * ++ * Updates : 11/02/2001 lkaplan. Created. ++ ***************************************************************************/ ++ ++#if !defined(_ADSLDRV_H_) ++#define _ADSLDRV_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++/* Incldes. */ ++#include ++ ++/* Defines. */ ++#define DSL_IFNAME "dsl0" ++#define ADSLDRV_MAJOR 208 /* arbitrary unused value */ ++ ++#define ADSLIOCTL_CHECK \ ++ _IOR(ADSLDRV_MAJOR, 0, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_INITIALIZE \ ++ _IOWR(ADSLDRV_MAJOR, 1, ADSLDRV_INITIALIZE) ++#define ADSLIOCTL_UNINITIALIZE \ ++ _IOR(ADSLDRV_MAJOR, 2, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_CONNECTION_START \ ++ _IOWR(ADSLDRV_MAJOR, 3, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_CONNECTION_STOP \ ++ _IOR(ADSLDRV_MAJOR, 4, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_GET_PHY_ADDR \ ++ _IOR(ADSLDRV_MAJOR, 5, ADSLDRV_PHY_ADDR) ++#define ADSLIOCTL_SET_PHY_ADDR \ ++ _IOWR(ADSLDRV_MAJOR, 6, ADSLDRV_PHY_ADDR) ++#define ADSLIOCTL_MAP_ATM_PORT_IDS \ ++ _IOWR(ADSLDRV_MAJOR, 7, ADSLDRV_MAP_ATM_PORT) ++#define ADSLIOCTL_GET_CONNECTION_INFO \ ++ _IOR(ADSLDRV_MAJOR, 8, ADSLDRV_CONNECTION_INFO) ++#define ADSLIOCTL_DIAG_COMMAND \ ++ _IOR(ADSLDRV_MAJOR, 9, ADSLDRV_DIAG) ++#define ADSLIOCTL_GET_OBJ_VALUE \ ++ _IOR(ADSLDRV_MAJOR, 10, ADSLDRV_GET_OBJ) ++#define ADSLIOCTL_START_BERT \ ++ _IOR(ADSLDRV_MAJOR, 11, ADSLDRV_BERT) ++#define ADSLIOCTL_STOP_BERT \ ++ _IOR(ADSLDRV_MAJOR, 12, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_CONFIGURE \ ++ _IOR(ADSLDRV_MAJOR, 13, ADSLDRV_CONFIGURE) ++#define ADSLIOCTL_TEST \ ++ _IOR(ADSLDRV_MAJOR, 14, ADSLDRV_TEST) ++#define ADSLIOCTL_GET_CONSTEL_POINTS \ ++ _IOR(ADSLDRV_MAJOR, 15, ADSLDRV_GET_CONSTEL_POINTS) ++#define ADSLIOCTL_GET_VERSION \ ++ _IOR(ADSLDRV_MAJOR, 16, ADSLDRV_GET_VERSION) ++#define ADSLIOCTL_SET_SDRAM_BASE \ ++ _IOR(ADSLDRV_MAJOR, 17, ADSLDRV_SET_SDRAM_BASE) ++#define ADSLIOCTL_RESET_STAT_COUNTERS \ ++ _IOR(ADSLDRV_MAJOR, 18, ADSLDRV_STATUS_ONLY) ++#define ADSLIOCTL_SET_OEM_PARAM \ ++ _IOR(ADSLDRV_MAJOR, 19, ADSLDRV_SET_OEM_PARAM) ++#define ADSLIOCTL_START_BERT_EX \ ++ _IOR(ADSLDRV_MAJOR, 20, ADSLDRV_BERT_EX) ++#define ADSLIOCTL_STOP_BERT_EX \ ++ _IOR(ADSLDRV_MAJOR, 21, ADSLDRV_STATUS_ONLY) ++ ++#define MAX_ADSLDRV_IOCTL_COMMANDS 22 ++ ++/* Typedefs. */ ++typedef struct ++{ ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_STATUS_ONLY, *PADSLDRV_STATUS_ONLY; ++ ++typedef struct ++{ ++ ADSL_FN_NOTIFY_CB pFnNotifyCb; ++ UINT32 ulParm; ++ adslCfgProfile *pAdslCfg; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_INITIALIZE, *PADSLDRV_INITIALIZE; ++ ++typedef struct ++{ ++ ADSL_CHANNEL_ADDR ChannelAddr; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_PHY_ADDR, *PADSLDRV_PHY_ADDR; ++ ++typedef struct ++{ ++ UINT16 usAtmFastPortId; ++ UINT16 usAtmInterleavedPortId; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_MAP_ATM_PORT, *PADSLDRV_MAP_ATM_PORT; ++ ++typedef struct ++{ ++ ADSL_CONNECTION_INFO ConnectionInfo; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_CONNECTION_INFO, *PADSLDRV_CONNECTION_INFO; ++ ++typedef struct ++{ ++ int diagCmd; ++ int diagMap; ++ int logTime; ++ int srvIpAddr; ++ int gwIpAddr; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_DIAG, *PADSLDRV_DIAG; ++ ++typedef struct ++{ ++ char *objId; ++ int objIdLen; ++ char *dataBuf; ++ long dataBufLen; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_GET_OBJ, *PADSLDRV_GET_OBJ; ++ ++typedef struct ++{ ++ unsigned long totalBits; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_BERT, *PADSLDRV_BERT; ++ ++typedef struct ++{ ++ unsigned long totalSec; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_BERT_EX, *PADSLDRV_BERT_EX; ++ ++typedef struct ++{ ++ adslCfgProfile *pAdslCfg; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_CONFIGURE, *PADSLDRV_CONFIGURE; ++ ++typedef struct ++{ ++ unsigned long testCmd; ++ unsigned long xmtStartTone; ++ unsigned long xmtNumTones; ++ unsigned long rcvStartTone; ++ unsigned long rcvNumTones; ++ char *xmtToneMap; ++ char *rcvToneMap; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_TEST, *PADSLDRV_TEST; ++ ++typedef struct ++{ ++ int toneId; ++ ADSL_CONSTELLATION_POINT *pointBuf; ++ int numPoints; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_GET_CONSTEL_POINTS, *PADSLDRV_GET_CONSTEL_POINTS; ++ ++typedef struct ++{ ++ adslVersionInfo *pAdslVer; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_GET_VERSION, *PADSLDRV_GET_VERSION; ++ ++typedef struct ++{ ++ unsigned long sdramBaseAddr; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_SET_SDRAM_BASE, *PADSLDRV_SET_SDRAM_BASE; ++ ++ ++typedef struct ++{ ++ int paramId; ++ void *buf; ++ int len; ++ BCMADSL_STATUS bvStatus; ++} ADSLDRV_SET_OEM_PARAM, *PADSLDRV_SET_OEM_PARAM; ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _ADSLDRV_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmapidrv.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmapidrv.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmapidrv.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmapidrv.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,212 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++/*************************************************************************** ++ * File Name : AtmApiDrv.h ++ * ++ * Description: This file contains the definitions and structures for the ++ * Linux IOCTL interface that used between the user mode ATM ++ * API library and the kernel ATM API driver. ++ * ++ * Updates : 09/15/2000 lat. Created. ++ ***************************************************************************/ ++ ++#if !defined(_ATMAPIDRV_H_) ++#define _ATMAPIDRV_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++/* Incldes. */ ++#include ++ ++/* Defines. */ ++#define ATMDRV_MAJOR 205 /* arbitrary unused value */ ++ ++#define ATMIOCTL_INITIALIZE \ ++ _IOWR(ATMDRV_MAJOR, 0, ATMDRV_INITIALIZE) ++#define ATMIOCTL_UNINITIALIZE \ ++ _IOR(ATMDRV_MAJOR, 1, ATMDRV_STATUS_ONLY) ++#define ATMIOCTL_GET_INTERFACE_ID \ ++ _IOWR(ATMDRV_MAJOR, 2, ATMDRV_INTERFACE_ID) ++#define ATMIOCTL_GET_TRAFFIC_DESCR_TABLE_SIZE \ ++ _IOR(ATMDRV_MAJOR, 3, ATMDRV_TRAFFIC_DESCR_TABLE_SIZE) ++#define ATMIOCTL_GET_TRAFFIC_DESCR_TABLE \ ++ _IOWR(ATMDRV_MAJOR, 4, ATMDRV_TRAFFIC_DESCR_TABLE) ++#define ATMIOCTL_SET_TRAFFIC_DESCR_TABLE \ ++ _IOWR(ATMDRV_MAJOR, 5, ATMDRV_TRAFFIC_DESCR_TABLE) ++#define ATMIOCTL_GET_INTERFACE_CFG \ ++ _IOWR(ATMDRV_MAJOR, 6, ATMDRV_INTERFACE_CFG) ++#define ATMIOCTL_SET_INTERFACE_CFG \ ++ _IOWR(ATMDRV_MAJOR, 7, ATMDRV_INTERFACE_CFG) ++#define ATMIOCTL_GET_VCC_CFG \ ++ _IOWR(ATMDRV_MAJOR, 8, ATMDRV_VCC_CFG) ++#define ATMIOCTL_SET_VCC_CFG \ ++ _IOWR(ATMDRV_MAJOR, 9, ATMDRV_VCC_CFG) ++#define ATMIOCTL_GET_VCC_ADDRS \ ++ _IOWR(ATMDRV_MAJOR, 10, ATMDRV_VCC_ADDRS) ++#define ATMIOCTL_GET_INTERFACE_STATISTICS \ ++ _IOWR(ATMDRV_MAJOR, 11, ATMDRV_INTERFACE_STATISTICS) ++#define ATMIOCTL_GET_VCC_STATISTICS \ ++ _IOWR(ATMDRV_MAJOR, 12, ATMDRV_VCC_STATISTICS) ++#define ATMIOCTL_SET_INTERFACE_LINK_INFO \ ++ _IOWR(ATMDRV_MAJOR, 13, ATMDRV_INTERFACE_LINK_INFO) ++#define ATMIOCTL_TEST \ ++ _IOWR(ATMDRV_MAJOR, 14, ATMDRV_TEST) ++#define ATMIOCTL_OAM_LOOPBACK_TEST \ ++ _IOWR(ATMDRV_MAJOR, 15, ATMDRV_OAM_LOOPBACK) ++ ++ ++#define MAX_ATMDRV_IOCTL_COMMANDS 16 ++ ++/* Typedefs. */ ++typedef struct ++{ ++ BCMATM_STATUS baStatus; ++} ATMDRV_STATUS_ONLY, *PATMDRV_STATUS_ONLY; ++ ++typedef struct ++{ PATM_INITIALIZATION_PARMS pInit; ++ BCMATM_STATUS baStatus; ++} ATMDRV_INITIALIZE, *PATMDRV_INITIALIZE; ++ ++typedef struct ++{ ++ UINT8 ucPhyPort; ++ UINT8 ucReserved[3]; ++ UINT32 ulInterfaceId; ++ BCMATM_STATUS baStatus; ++} ATMDRV_INTERFACE_ID, *PATMDRV_INTERFACE_ID; ++ ++typedef struct ++{ ++ UINT32 ulTrafficDescrTableSize; ++ BCMATM_STATUS baStatus; ++} ATMDRV_TRAFFIC_DESCR_TABLE_SIZE, *PATMDRV_TRAFFIC_DESCR_TABLE_SIZE; ++ ++typedef struct ++{ ++ PATM_TRAFFIC_DESCR_PARM_ENTRY pTrafficDescrTable; ++ UINT32 ulTrafficDescrTableSize; ++ BCMATM_STATUS baStatus; ++} ATMDRV_TRAFFIC_DESCR_TABLE, *PATMDRV_TRAFFIC_DESCR_TABLE; ++ ++typedef struct ++{ ++ UINT32 ulInterfaceId; ++ PATM_INTERFACE_CFG pInterfaceCfg; ++ BCMATM_STATUS baStatus; ++} ATMDRV_INTERFACE_CFG, *PATMDRV_INTERFACE_CFG; ++ ++typedef struct ++{ ++ ATM_VCC_ADDR VccAddr; ++ PATM_VCC_CFG pVccCfg; ++ BCMATM_STATUS baStatus; ++} ATMDRV_VCC_CFG, *PATMDRV_VCC_CFG; ++ ++typedef struct ++{ ++ UINT32 ulInterfaceId; ++ PATM_VCC_ADDR pVccAddrs; ++ UINT32 ulNumVccs; ++ UINT32 ulNumReturned; ++ BCMATM_STATUS baStatus; ++} ATMDRV_VCC_ADDRS, *PATMDRV_VCC_ADDRS; ++ ++typedef struct ++{ ++ UINT32 ulInterfaceId; ++ PATM_INTERFACE_STATS pStatistics; ++ UINT32 ulReset; ++ BCMATM_STATUS baStatus; ++} ATMDRV_INTERFACE_STATISTICS, *PATMDRV_INTERFACE_STATISTICS; ++ ++typedef struct ++{ ++ ATM_VCC_ADDR VccAddr; ++ PATM_VCC_STATS pVccStatistics; ++ UINT32 ulReset; ++ BCMATM_STATUS baStatus; ++} ATMDRV_VCC_STATISTICS, *PATMDRV_VCC_STATISTICS; ++ ++typedef struct ++{ ++ UINT32 ulInterfaceId; ++ ATM_INTERFACE_LINK_INFO InterfaceCfg; ++ BCMATM_STATUS baStatus; ++} ATMDRV_INTERFACE_LINK_INFO, *PATMDRV_INTERFACE_LINK_INFO; ++ ++typedef struct ++{ ++ ATM_VCC_ADDR VccAddr; ++ UINT32 ulNumToSend; ++ BCMATM_STATUS baStatus; ++} ATMDRV_TEST, *PATMDRV_TEST; ++ ++typedef struct ++{ ++ ATM_VCC_ADDR VccAddr; ++ UINT32 type; ++ BCMATM_STATUS baStatus; ++} ATMDRV_OAM_LOOPBACK, *PATMDRV_OAM_LOOPBACK; ++ ++#define OAM_TYPE_FUNCTION_BYTE_OFFSET 0 ++#define OAM_LB_INDICATION_BYTE_OFFSET 1 ++#define OAM_LB_CORRELATION_TAG_BYTE_OFFSET 2 ++#define OAM_LB_LOCATION_ID_BYTE_OFFSET 6 ++#define OAM_LB_SRC_ID_BYTE_OFFSET 22 ++#define OAM_LB_UNUSED_BYTE_OFFSET 38 ++#define OAM_RDI_UNUSED_BYTE_OFFSET 1 ++#define OAM_LB_CRC_BYTE_OFFSET 46 ++#define OAM_RDI_CRC_BYTE_OFFSET 46 ++#define OAM_LB_CORRELATION_TAG_LEN 4 ++#define OAM_LB_LOCATION_ID_LEN 16 ++#define OAM_LB_SRC_ID_LEN 16 ++#define OAM_LB_UNUSED_BYTE_LEN 8 ++#define OAM_RDI_UNUSED_BYTE_LEN 45 ++#define OAM_LB_CRC_BYTE_LEN 2 ++#define OAM_RDI_CRC_BYTE_LEN 2 ++#define OAM_FAULT_MANAGEMENT_LB 0x18 ++#define OAM_FAULT_MANAGEMENT_RDI 0x11 ++#define OAM_FAULT_MANAGEMENT_LB_REQUEST 1 ++#define OAM_FAULT_MANAGEMENT_LB_RESPOND 0 ++#define OAM_FAULT_MANAGEMENT_CORRELATION_VAL 0xbcbcbcbc ++#define OAM_FAULT_MANAGEMENT_SRC_ID_3 0xffffffff ++#define OAM_FAULT_MANAGEMENT_SRC_ID_2 0xffffffff ++#define OAM_FAULT_MANAGEMENT_SRC_ID_1 0xffffffff ++#define OAM_FAULT_MANAGEMENT_SRC_ID_0 0xffffffff ++#define OAM_FAULT_MANAGEMENT_LOCATION_ID_3 0xffffffff ++#define OAM_FAULT_MANAGEMENT_LOCATION_ID_2 0xffffffff ++#define OAM_FAULT_MANAGEMENT_LOCATION_ID_1 0xffffffff ++#define OAM_FAULT_MANAGEMENT_LOCATION_ID_0 0xffffffff ++#define OAM_LB_UNUSED_BYTE_DEFAULT 0x6a ++#define OAM_LB_SEGMENT_TYPE 0 ++#define OAM_LB_END_TO_END_TYPE 1 ++#define OAM_F4_LB_SEGMENT_TYPE 2 ++#define OAM_F4_LB_END_TO_END_TYPE 3 ++#define RM_PROT_ID_OFFSET 0 ++#define RM_MESSAGE_TYPE_OFFSET 1 ++#define RM_PROTOCOL_ID 1 ++#define RM_TYPE_DEFAULT 0x20 /* forward/source_generated/congested */ ++#define RM_UNUSED_BYTES_OFFSET 2 ++#define RM_UNUSED_BYTES_LEN 46 ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _ATMAPIDRV_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmdiag.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmdiag.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmdiag.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmdiag.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,764 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++ ++#ifndef __ATMDIAG_H__ ++#define __ATMDIAG_H__ ++ ++//#define BRCM_6348 ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++#define ATM_DIAG_FAIL -1 ++#define ATM_DIAG_PASS 0 ++#define ATM_REGADDR 0xFFFE4000 ++#define ATM_REGSIZE 0x800 ++#define ATM_TX_VPI_VCI_CAM_OFFSET 0x500 ++#define ATM_RX_VPI_VCI_CAM_OFFSET 0x600 ++#define ATM_TRAFFIC_SHAPER_OFFSET 0x700 ++#define ATM_TX_STATUS_OFFSET 0x40c ++#define ATM_RX_STATUS_OFFSET 0x41c ++#define ATM_RX_AAL_STATUS_OFFSET 0x428 ++#define ATM_MIP_COUNTERS_OFFSET 0x440 ++#define ATM_UTOPIA_SETTING_OFFSET 0x42c ++#define ATM_ADSL_PHY_PORT_SETTING 0x15c ++#define UT_MAX_TDT_ENTRIES 2 ++#define UT_MAX_MGMT_ENTRIES 4 ++#define UT_LINE_RATE (146200000) /* 344811 cells/sec, CIT = 29ns */ ++#define UT_CELL_RATE (53 * 8) ++#define UT_MIN_PCR_SCR 310 /* ~128Kbps */ ++#define UT_MAX_PCR_SCR 344811 /* ~146.2Kpbs */ ++#define UT_MIN_MBS 2 ++#define UT_MAX_MBS 200000 ++ //#ifdef BRCM_6348 currently, the driver only support 8 VCCS ++ //#define UT_MAX_VCCS 16 ++ //#else ++#define UT_MAX_VCCS 8 ++ //#endif ++#define UT_MAX_PHY_PORTS 2 ++#define UT_BASE_PORT_NUMBER 1 ++#define UT_MIN_QUEUE 1 ++#define UT_MAX_QUEUE UT_MAX_VCCS ++#define UT_MULTI_QUEUE 1 ++#define UT_SINGLE_QUEUE 0 ++#define UT_MIN_PRIORITY 1 ++#define UT_MAX_PRIORITY 4 /* priority ranging from 1-4 */ ++#define UT_BUFFER_SIZE 20 ++#define UT_MGMT_IDX 6 ++#define UT_ENABLED 1 ++#define UT_DISABLED 0 ++#define UT_MAX_TD_INDEX UT_MAX_VCCS ++#define UT_SSTED_TRAILER_SIZE 8 ++#define UT_DIALED_DIGITS 2 ++#define UT_FREE_CELL_Q_SIZE 800 ++#define UT_FREE_PKT_Q_SIZE 800 ++#define UT_FREE_PKT_Q_BUF_SIZE 1600 ++#define UT_RX_PKT_Q_SIZE 800 ++#define UT_RX_CELL_Q_SIZE 800 ++#define UT_AAL5_MAX_SDU_LENGTH 65535 ++#define UT_TX_FIFO_PRIORITY 4 ++#define UT_MIN_DATA_LEN 48 ++#define UT_MAX_DATA_LEN 1500 ++#define UT_BASE_VPI_NUMBER 0 ++#define UT_MAX_VPI_NUMBER 256 ++#define UT_BASE_VCI_NUMBER 32 ++#define UT_MAX_VCI_NUMBER 65536 ++#define UT_UTOPIA_MODE 1 ++#define UT_ADSL_MODE 0 ++#define UT_UTOPIA_ADSL_MODE 0x11 /* utopia port 0, adsl port 1 */ ++#define UT_TOGGLE_DISPLAY_MODE 1 ++#define UT_TOGGLE_CAPTURE_MODE 0 ++#define UT_TOGGLE_VERIFICATION_MODE 2 ++#define UT_TOGGLE_MODE_ON 1 ++#define UT_TOGGLE_MODE_OFF 0 ++#define UT_DUMP_TX_VPI_VCI_TABLE 1 ++#define UT_DUMP_RX_VPI_VCI_TABLE 2 ++#define UT_DISPLAY_STATS 1 ++#define UT_CLEAR_STATS 2 ++#define UT_TRAFFIC_DESCRIPTOR_DISPLAY 1 ++#define UT_TRAFFIC_DESCRIPTOR_MODIFY 2 ++#define UT_PORT_UTOPIA_SETTING 1 ++#define UT_GLOBAL_UTOPIA_SETTING 2 ++#define UT_DISPLAY_CAPTURED 0 ++#define UT_ERASE_CAPTURED 1 ++#define UT_CAPTURED_ERROR_STATS 2 ++#define UT_PATTERN_INCREMENT 1 ++#define UT_PATTERN_FIX 0 ++#define UT_MODIFY_OPERATION 1 ++#define UT_DISPLAY_OPERATION 0 ++#define DIAG_ATM_MODULE "bcmatmtest" ++#define DIAG_ATM_PROC "/proc/atmtest" ++ ++/* command is made up of 2_bytes_command|2_bytes_index */ ++/* index is ranging from 0-7 for 8 VCs */ ++#define UT_PROC_CMD_ADD_VC 1 ++#define UT_PROC_CMD_DELETE_VC 2 ++#define UT_PROC_CMD_START_SEND_VC 3 ++#define UT_PROC_CMD_SEND_MULTI_VC 4 ++#define UT_PROC_CMD_STOP_SEND_VC 5 ++#define UT_PROC_CMD_CAPTURE 6 ++#define UT_PROC_CMD_TOGGLE 7 ++#define UT_PROC_CMD_GET_STATS 8 ++#define UT_PROC_CMD_CLEAR_STATS 9 ++#define UT_PROC_CMD_SEND_MULTI_PRIORITY 10 ++#define UT_PROC_CMD_MODIFY_TRAFFIC_SHAPER 11 ++#define UT_PROC_CMD_START_SEND_ALL_VC 12 ++#define UT_PROC_CMD_ADSL_LOOPBACK 13 ++#define UT_PROC_CMD_SEND_MANAGEMENT 14 ++#define UT_PROC_CMD_ADD_MPVC 15 ++#define UT_PROC_CMD_DELETE_MPVC 16 ++#define UT_PROC_CMD_START_SEND_MPVC 17 ++#define UT_PROC_CMD_UTOPIA_SET 18 ++ ++#define UT_OAM_LB_END_TO_END 10 /* was 1 */ ++#define UT_OAM_LB_SEGMENT 11 /* was 2 */ ++#define UT_OAM_RDI_END_TO_END 3 ++#define UT_OAM_RDI_SEGMENT 4 ++#define UT_VPC_RM_TYPE 5 ++#define UT_VCC_RM_TYPE 6 ++#define UT_OAM_CRC10_SOFTWARE 0 ++#define UT_OAM_CRC10_HARDWARE 1 ++#define UT_TOGGLE_DISPLAY 0 ++#define UT_TOGGLE_CAPTURE 1 ++#define UT_TOGGLE_VERIFY 2 ++ ++#define AP_REG_OFFSET_END 0x7ff ++#define AP_INDIRECT_RAM_ADDRESS_REG ATM_PROCESSOR_BASE + 0x7c0 ++#define AP_INDIRECT_RAM_REG ATM_PROCESSOR_BASE + 0x7c4 ++#define AP_IRQ_MASK AP_INTR_REGS_BASE+0x4 ++#define AP_IRQ_STATUS AP_INTR_REGS_BASE ++#define AP_ROUTE_OAM_TO_RCQ 0 ++#define AP_ROUTE_OAM_TO_MCF 1 ++#define AP_IR_ASSERT 1 ++#define AP_IR_DEASSERT 0 ++#define AP_RX_STATUS_ERR_MASK 0x32ecc /* mask out idleCell, vc & unused */ ++#define AP_RX_AAL_STATUS_ERR_MASK 0x3008 /* only look at rx router stats, discard */ ++ ++typedef struct utVccCfg { ++ UINT8 ulAalType; ++ UINT8 ulAtmVccCpcsAcceptCorruptedPdus; ++}UT_VCC_CFG, *pUT_VCC_CFG; ++ ++typedef struct utTrafficDescrParmEntry { ++ UINT32 ulTrafficDescrIndex; ++ UINT32 ulTrafficDescrType; ++ UINT32 ulTrafficDescrParm1; ++ UINT32 ulTrafficDescrParm2; ++ UINT32 ulTrafficDescrParm3; ++ UINT32 ulTrafficDescrParm4; ++ UINT32 ulTrafficDescrParm5; ++ UINT32 ulTrafficDescrRowStatus; ++ UINT32 ulServiceCategory; ++}UT_TRAFFIC_DESCR_PARM_ENTRY,*pUT_TRAFFIC_DESCR_PARM_ENTRY; ++ ++typedef struct utMultiSendInfo { ++ UINT32 len; ++ UINT8 pattern; ++ UINT8 dataByte; ++ UINT32 numSent; ++ UINT32 rate; ++ UINT8 circuitType; ++ UINT32 cellsPerPdu; ++ UINT32 delay; ++ UINT32 txCount; ++}UT_MULTISEND_INFO, *pUT_MULTISEND_INFO; ++ ++typedef struct utUserSendInfo { ++ UINT32 len; ++ UINT8 incremental; ++ UINT8 dataByte; ++ UINT32 rate; ++ UINT32 aalType; ++ UINT32 delay; ++ UINT32 txCount; /* number of cells/pkt user want to send */ ++ UINT8 multiQPriority; ++ UINT8 basePriority; ++ UINT8 numOfQueues; ++}UT_USER_SEND_INFO, *pUT_USER_SEND_INFO; ++ ++typedef struct utVccAddrInfo { ++ ATM_VCC_ADDR vccAddr; ++ UINT8 priority; /* priority of the queue of this VCC */ ++ UINT8 numOfQueues; ++}UT_VCC_ADDR_INFO, *pUT_VCC_ADDR_INFO; ++ ++typedef struct utVccListInfo { ++ UINT32 handle; ++ UINT32 managementHandle; ++}UT_VCC_LIST_INFO, *pUT_VCC_LIST_INFO; ++ ++typedef struct atmCaptureHdr { ++ UINT8 valid; ++ UINT8 vpi; ++ UINT16 vci; ++ UINT8 circuitType; ++ UINT8 cid; ++ UINT8 uuData8; ++ UINT8 uuData5; ++ UINT8 ucFlags; ++ UINT32 dataLen; ++ UINT8 *dataPtr; ++ UINT8 interface; ++} ATM_CAPTURE_HDR, *pATM_CAPTURE_HDR; ++ ++typedef struct atmTxBufferHdr { ++ ATM_VCC_DATA_PARMS dataParms; ++ struct atmTxBufferHdr *next; ++} ATM_TX_BUFFER_HDR, *pATM_TX_BUFFER_HDR; ++ ++typedef struct tx_buffer_list{ ++ pATM_TX_BUFFER_HDR headPtr; ++ pATM_TX_BUFFER_HDR tailPtr; ++ UINT32 len; ++ UINT32 seqNumber; ++ UINT32 lastSent; ++ UINT32 sentInterval; ++ UINT32 cellsPerPdu; ++} ATM_TX_BUFFER_LIST, *pATM_TX_BUFFER_LIST; ++ ++typedef struct atmTestError { ++ UINT32 total; ++ UINT32 data_err; ++ UINT32 data_length; ++ UINT32 sequence_err; ++ UINT32 aalCrcError; ++ UINT32 aalCpcsLen0; ++ UINT32 aalLenError; ++ UINT32 aalSduLenError; ++ UINT32 gfc; ++ UINT32 crc; ++ UINT32 pti; ++ UINT32 pmi_2sml; ++ UINT32 pmi_2big; ++ UINT32 vcam_mme; ++ UINT32 pne; ++ UINT32 came_1; ++ UINT32 came_0; ++ UINT32 dc_1; ++ UINT32 dc_0; ++ UINT32 ec_1; ++ UINT32 ec_0; ++ UINT32 aal5_drop_cell; ++ UINT32 routerDiscard_1; ++ UINT32 routerDiscard_0; ++ UINT32 camLkup; ++ UINT32 idle; ++ UINT32 hec; ++} ATM_TEST_ERROR, *pATM_TEST_ERROR; ++ ++typedef struct atmMibStats { ++ UINT32 tx_aal5_0; ++ UINT32 tx_aal5_1; ++ UINT32 tx_aal0_0; ++ UINT32 tx_aal0_1; ++ UINT32 rx_aal5_0; ++ UINT32 rx_aal5_1; ++ UINT32 rx_aal0_0; ++ UINT32 rx_aal0_1; ++} ATM_MIB_STATS, *pATM_MIB_STATS; ++ ++/* These are from TX status register; they are collected every 1 second interval */ ++typedef struct atmTxStats { ++ UINT32 fifoFull; /* fifoFull_port0 */ ++ UINT32 aal2bigErr; ++ UINT32 aal5LenErr; ++ UINT32 aal5MaxLenErr; ++ UINT32 droppedCellErr; /* tx aal or tx atm dropped cell port 0 */ ++ UINT32 aal5PortNotEnableErr; /* pne_err_port0 */ ++ UINT32 fifoFullErr; /* ff_err_port0 */ ++ UINT32 aal5CountErr; ++} ATM_TX_STATS, *pATM_TX_STATS; ++ ++/* these are from RX ATM and RX AAL status registers */ ++typedef struct atmRxStats { ++ UINT32 gfcErr; ++ UINT32 crcErr; ++ UINT32 ptiErr; ++ UINT32 vcamMmErr; /* vcam_mme VCAM multiple match error */ ++ UINT32 camLookupErr; /* came_port0 */ ++ UINT32 portNotEnableErr; /* pne_err */ ++ UINT32 discardErr; /* dc_port0 */ ++ UINT32 errCellErr; /* ec_port0 */ ++ UINT32 routerDrop; /* rxRouterStat_port0 */ ++ UINT32 aalDrop; /* aal5d */ ++#ifdef BRCM_6348 ++ UINT32 overflowErr; ++ UINT32 uto2small; ++ UINT32 uto2big; ++#endif ++} ATM_RX_STATS, *pATM_RX_STATS; ++ ++typedef struct atmStats ++{ ++ ATM_MIB_STATS mibStats; ++ ATM_TX_STATS txStats; ++ ATM_RX_STATS rxStats; ++}ATM_STATS, *pATM_STATS; ++ ++typedef struct atm_test_tx_info { ++ UINT32 index; ++ UINT32 len; ++ UINT32 lineTxInterval; ++ UINT32 count; ++ UINT8 incremental; ++ UINT8 dataByte; ++ UINT8 aalType; ++ UINT8 numOfQueues; ++ UINT8 basePriority; ++ UINT32 handle; ++ UINT32 rate; ++ UINT32 sending; ++ UINT8 managementType; /* f4, f5, rm */ ++ UINT8 interleaveManagement; ++ UINT16 managementVpi; ++ UINT16 managementVci; ++ UINT16 managementCrc; ++ UINT32 managementInterface; ++} ATM_TEST_TX_INFO, *pATM_TEST_TX_INFO; ++ ++typedef struct atm_test_info { ++ ATM_TEST_TX_INFO atmTestTxInfo[UT_MAX_VCCS+1]; /* one extra for f4 since it doesn't ++ have a vcc created, index is last one */ ++ UT_TRAFFIC_DESCR_PARM_ENTRY ms_Tdt[UT_MAX_TD_INDEX]; ++ UT_VCC_CFG ms_VccCfgs[UT_MAX_VCCS]; ++ UT_VCC_ADDR_INFO ms_VccAddrs[UT_MAX_VCCS]; ++ UINT32 commandStatus; /* command-2 bytes, status 2 bytes */ ++ ATM_TEST_ERROR m_ucTestError[UT_MAX_VCCS+1]; ++ ATM_STATS atmStats; ++ UINT8 displayData; /* current mode: 0=disable, 1=enable */ ++ UINT8 captureData; /* current mode: 0=disable, 1=enable */ ++ UINT8 verifyData; /* current mode: 0=disable, 1=enable */ ++ UINT32 pduSent[UT_MAX_VCCS+1]; /* one extra for f4 */ ++ UINT32 pduReceived[UT_MAX_VCCS+1]; ++ UINT32 multiPriority; ++} ATM_TEST_INFO, *pATM_TEST_INFO; ++ ++typedef struct atm_verfication_info { ++ int seqNumber; ++ UINT8 incremental; ++ UINT8 dataByte; ++ int len; ++} ATM_VERIFICATION_INFO, *pATM_VERIFICATION_INFO; ++ ++typedef struct atm_data_struct { ++ PATM_VCC_DATA_PARMS data; ++ ATM_VCC_ADDR vccAddr; ++} ATM_DATA_STRUCT, *PATM_DATA_STRUCT; ++ ++typedef struct atmDiagCb { ++ ATM_TRAFFIC_DESCR_PARM_ENTRY ms_Tdt[UT_MAX_TD_INDEX]; ++ ATM_VCC_CFG ms_VccCfgs[UT_MAX_VCCS]; ++ UT_VCC_ADDR_INFO ms_VccAddrs[UT_MAX_VCCS]; ++ UINT32 ms_multiPriority[UT_MAX_VCCS]; ++ ATM_TX_BUFFER_LIST mTxHdrQ[UT_MAX_VCCS+1]; /* tx Q; an extra one for f4 cells */ ++ UT_VCC_LIST_INFO m_ulVccList[UT_MAX_VCCS+1]; /* tx Q; an extra one for f4 cells */ ++ UINT32 managementHandle_port0; ++ UINT32 managementHandle_port1; ++ UINT32 rxTaskId; ++ UINT32 txTaskId; ++ UINT32 statsTaskId; ++ UINT32 rxTaskSem; /* protect Rx Q */ ++ UINT32 txTaskSem; /* protect Tx Q */ ++ UINT32 rxQMuSem; /* rx task semphore */ ++ UINT32 txQMuSem; /* tx task semphore */ ++ UINT32 txTaskExit; /* clean up purpose */ ++ UINT32 rxTaskExit; /* clean up purpose */ ++ ATM_DATA_STRUCT m_pDpHead; /* rx Q */ ++ ATM_DATA_STRUCT m_pDpTail; /* rx Q */ ++ UINT8 displayData; /* 1 to display rx data on screen; default is 0 */ ++ UINT8 captureData; ++ UINT8 verifyData; ++ ATM_CAPTURE_HDR m_ulData[UT_BUFFER_SIZE]; ++ int m_ulBufferPosition; ++ UINT32 m_ulCurSeqNumber; ++ ATM_TEST_ERROR m_ucTestError[UT_MAX_VCCS+1]; ++ ATM_STATS m_atmStats; ++ ATM_VERIFICATION_INFO dataVerficationInfo[UT_MAX_VCCS]; ++ UINT8 txStop; ++} ATM_DIAG_CB, *pATM_DIAG_CB; ++ ++/* 0xfffe15c */ ++typedef union phyLastDescConfig { ++ struct { ++ UINT32 unused:22; ++ UINT32 rxCfg:2; ++ UINT32 unused1:2; ++ UINT32 txCfg:2; ++ UINT32 numRxDesc:2; ++ UINT32 numTxDesc:2; ++ }bit; ++ UINT32 reg; ++} PHY_LAST_DESC_CONFIG, *pPHY_LAST_DESC_CONFIG; ++ ++/* 0xfffe4500-0xfffe45ff */ ++typedef union txAtmVpiVciTable { ++ struct { ++ UINT32 unused:6; ++ UINT32 swFlags:1; ++ UINT32 crcEnable:1; ++ UINT32 vpi: 8; ++ UINT32 vci:16; ++ }bit; ++ UINT32 entry; ++} TX_ATM_VPI_VCI_TABLE, *pTX_ATM_VPI_VCI_TABLE; ++ ++/* 0xfffe4600-0xfffe46ff */ ++typedef union RxAtmVpiVciTable { ++ struct { ++ UINT32 unused:6; ++ UINT32 valid:1; ++ UINT32 vpi:8; ++ UINT32 vci:16; ++ UINT32 port:1; ++ } camSide; /* even; */ ++ struct { ++ UINT32 unused:21; ++ UINT32 userDataIR:1; /* assert IR for user data immediate response */ ++ UINT32 oamIR:1; /* assert IR for OAM immediate response */ ++ UINT32 rmIR:1; /* assert IR for RM immediate response */ ++ UINT32 vcId:3; /* VCID */ ++ UINT32 userDataCrcEnable:1; ++ UINT32 oamRouteCode:1; /* 0=route to rx cell q; 1= route to rx mips cell fifo */ ++ UINT32 udrc:1; /* User Data Routing Code */ ++ UINT32 circuitType:2; ++ } ramSide; /* odd; */ ++ UINT32 entry; ++} RX_ATM_VPI_VCI_TABLE, *pRX_ATM_VPI_VCI_TABLE; ++ ++/* 6345; 0xfffe4300- 0xfffe43ff */ ++typedef union atmIntrRegs { ++ struct { ++ UINT32 unused:20; ++ UINT32 vcamMm:1; /* RX VCAM multiple match */ ++ UINT32 rxRtDc:1; /* Rx Router discard cell due to full rx buffer */ ++ UINT32 rpqIr:1; /* Receive Packet Queue got a packet tagged with immediate response */ ++ UINT32 rcqIr:1; /* Receive Cell Queue got a cell tagged with immediate response */ ++ UINT32 rpqWd:1; /* RX Pkt Q watchdog- no pkt rxed for the duration defined in RCQ wd timer */ ++ UINT32 rcqWd:1; /* RX Cell Q watchdog */ ++ UINT32 mibHf:1; /* one or more of the MIB coutners is half full */ ++ UINT32 fpqAe:1; /* Free Packet Queue almost empty- has fewer buffers than FPQ watermark */ ++ UINT32 rpqAf:1; /* Rx Packet Queue has exceeded RPQ watermark */ ++ UINT32 fcqAe:1; /* Free Cell Queue almost Empty */ ++ UINT32 rcqAf:1; /* Rx Cell Q almost full */ ++ UINT32 txs:1; /* Tx SDRAM Interrupt- one of the TX SDRAM sub-channels intr is set */ ++ }statusMaskBit; /* status & interrupt mask */ ++#ifdef BRCM_6348 ++ struct { ++ UINT32 unused1:8; ++ UINT32 sdqMask:8; /* TX SDRAM watchdog timer interrupt */ ++ UINT32 unused:4; ++ UINT32 irqMask:12; ++ }irqMaskBit; ++ struct { ++ UINT32 unused:28; ++ UINT32 sdWd:4; /* TX SDRAM Watchdog */ ++ }txSdramValue; ++#else /* 6345 */ ++ struct { ++ UINT32 unused:16; ++ UINT32 irqMask:16; ++ }irqMaskBit; ++#endif /* BRCM_6348 */ ++ struct { ++ UINT32 fcqAeWm:16; /* Free Cell Q almost empty watermark */ ++ UINT32 rcqAfWm:16; /* Rx Cell Q almost full watermark */ ++ }rxCellQBit; ++ struct { ++ UINT32 fpqAeWm:16; /* Free Packet Q almost empty watermark */ ++ UINT32 rpqAfWm:16; /* Rx Paket Q almost full watermark */ ++ }rxPktQBit; ++ struct { ++ UINT32 pktWdTo:16; /* Watchdog timeout value in 50 uSec increments */ ++ UINT32 cellWdTo:16; /* Watchdog timeout value in 50 uSec increments */ ++ }rxWdTimer; ++} ATM_INTR_REGS, *pATM_INTR_REGS; ++ ++/* 0xfffe4700-0xfffe47ff */ ++typedef union atmShaperCtrlReg { ++#ifdef BRCM_6348 ++ struct { ++ UINT32 unused:7; ++ UINT32 rst:1; /* reset shaper */ ++ UINT32 pcr:12; /* peak cell rate */ ++ UINT32 mpEn:1; /* Multi-priority enabled */ ++ UINT32 priority:2; /* source scheduling sub-priority */ ++ UINT32 mcrEnable:1;/* Minimum Cell Rate Enabled */ ++ UINT32 alg:2; /* source shaping algorithm */ ++ UINT32 pid:1; /* Source destination Port ID */ ++ UINT32 vcid:4; /* source VC ID */ ++ UINT32 enable:1; /* source shaper enable */ ++ }bit; ++#else /* 6345 */ ++ struct { ++ UINT32 unused:9; ++ UINT32 rst:1; /* reset shaper */ ++ UINT32 pcr:12; /* peak cell rate */ ++ UINT32 mpEn:1; /* Multi-priority enabled */ ++ UINT32 priority:2; /* source scheduling sub-priority */ ++ UINT32 alg:2; /* source shaping algorithm */ ++ UINT32 pid:1; /* Source destination Port ID */ ++ UINT32 vcid:3; /* source VC ID */ ++ UINT32 enable:1; /* source shaper enable */ ++ }bit; ++#endif /* BRCM_6348 */ ++ UINT32 entry; ++} ATM_SHAPER_CTRL_REG, *pATM_SHAPER_CTRL_REG; ++ ++typedef union atmShaperVbrReg { ++ struct { ++ UINT32 unused:1; ++ UINT32 bt:19; ++ UINT32 scr:12; ++ }bit; ++ UINT32 entry; ++} ATM_SHAPER_VBR_REG, *pATM_SHAPER_VBR_REG; ++ ++#ifdef BRCM_6348 ++typedef union atmShaperMcrReg { ++ struct { ++ UINT32 unused:20; ++ UINT32 mcr:12; ++ }bit; ++ UINT32 entry; ++} ATM_SHAPER_MCR_REG, *pATM_SHAPER_MCR_REG; ++#endif /* BRCM_6348 */ ++ ++typedef union atmCellHdr { ++ struct { ++ UINT32 gfc:4; ++ UINT32 msb_vpi:4; ++ UINT32 vpi:4; ++ UINT32 msb_vci:4; ++ UINT32 vci:8; ++ UINT32 lsb_vci:4; ++ UINT32 pt:3; ++ UINT32 clp:1; ++ }bit; ++ UINT32 word1; ++} ATM_CELL_HDR, *pATM_CELL_HDR; ++#define ATM_RX_AAL_STATUS_ERROR_MASK_PORT0 0x108 ++ ++/* 0xfffe4428 */ ++typedef union atmRxAalStatusReg { ++ struct { ++ UINT32 unused:22; ++ UINT32 rxRouterStat_port1:1; /* RX cells dropped due to full cell buffer; */ ++ UINT32 rxRouterStat_port0:1; /* bit 8=port 0 fifo rx drop cell */ ++ UINT32 aal0ccnt_port1:1; /* aal0 cell count has been incremented; bit 4=port0 */ ++ UINT32 aal0ccnt_port0:1; /* aal0 cell count has been incremented; bit 4=port0 */ ++ UINT32 aal5ccnt_port1:1; /* aal5 cell count has been incremented; bit 4=port0 */ ++ UINT32 aal5ccnt_port0:1; /* aal5 cell count has been incremented; bit 4=port0 */ ++ UINT32 aal5d:1; /* aal5 dropped cells */ ++ UINT32 aal5p:1; /* aal5 pdu received */ ++ UINT32 aalxp:1; /* non aal5 received */ ++ UINT32 aal5c:1; /* aal5 received cells */ ++ }bit; ++ UINT32 reg; ++} ATM_RX_AAL_STATUS_REG, *pATM_RX_AAL_STATUS_REG; ++/* 0xfffe441c */ ++#define ATM_RX_STATUS_ERROR_MASK_PORT0 0x32354 ++typedef union atmRxStatusReg { ++ struct { ++ UINT32 unused:14; ++ UINT32 gfc_err:1; /* non zero gfc detected */ ++ UINT32 crc_err:1; /* CRC-10 error detected on OAM/RM cells */ ++#ifdef BRCM_6348 ++ UINT32 rx_flow_err:1; /* Receive cell dropped by RXATM layer 'cause RX cell FIFO full */ ++#else /* 6345 */ ++ UINT32 unused1:1; ++#endif ++ UINT32 idle_err:1; /* Idle cell detected */ ++ UINT32 pti_err:1; /* PTI Error detected (i.e. PT=binary 111) */ ++#ifdef BRCM_6348 ++ UINT32 unused2:1; ++ UINT32 uto2small:1;/* Too small of a cell from RX Utopia */ ++ UINT32 uto2big:1; /* Too big of a cell from RX Utopia */ ++#else /* BRCM_6345 */ ++ UINT32 unused2:3; ++#endif ++ UINT32 vcam_mme:1; /* VCAM multiple match error */ ++ UINT32 pne_err:1; /* port not enable error */ ++ UINT32 came_port1:1; /* PER port cam lookup error; bit6=port 0 */ ++ UINT32 came_port0:1; /* PER port cam lookup error; bit6=port 0 */ ++ UINT32 dc_port1:1; /* per port dropped cell; bit 4= port 0 */ ++ UINT32 dc_port0:1; /* per port dropped cell; bit 4= port 0 */ ++ UINT32 ec_port1:1; /* per port erred cell; bit 2=port 0 */ ++ UINT32 ec_port0:1; /* per port erred cell; bit 2=port 0 */ ++ UINT32 vc_port1:1; /* per port valid cell; bit 0=port 0 */ ++ UINT32 vc_port0:1; /* per port valid cell; bit 0=port 0 */ ++ }bit; ++ UINT32 reg; ++} ATM_RX_STATUS_REG, *pATM_RX_STATUS_REG; ++ ++#define ATM_TX_STATUS_ERROR_MASK_PORT0 0x41e80c54 ++typedef union atmTxStatusReg { ++ struct { ++ UINT32 fifoFull_port1:1; /* per port FIFO Full Status (1=full) */ ++ UINT32 fifoFull_port0:1; /* per port FIFO Full Status (1=full) */ ++ UINT32 unused:1; ++ UINT32 aal0_port1:1; /* aal0_port1 tx */ ++ UINT32 aal0_port0:1; /* aal0_port0 tx */ ++ UINT32 aal5_port1:1; /* aal5_port1 tx */ ++ UINT32 aal5_port0:1; /* aal5_port0 tx */ ++ UINT32 aal2big:1; /* aal too big cell input */ ++ UINT32 aal5liErr:1;/* aal5 length indicator error */ ++ UINT32 aal5mlErr:1;/* aal5 max length error */ ++ UINT32 aal5ctErr:1;/* aal5 count error */ ++ UINT32 unused1:1; ++ UINT32 aal5d:1; /* aal5 drop cell */ ++ UINT32 aal5p:1; /* aal5 pdu passed */ ++ UINT32 aalxc:1; /* non aal5 cell passed */ ++ UINT32 aal5c:1; /* aal cell passed */ ++ UINT32 dropCell_port1:1; /* tx aal or tx atm dropped cell */ ++ UINT32 dropReq_port1:1; /* one of the port dropped request */ ++ UINT32 scheCell_port1:1; /* per port scheduled cell */ ++ UINT32 sit_port1:1; /* per port schedule interval timer count event */ ++ UINT32 dropCell_port0:1; /* tx aal or tx atm dropped cell */ ++ UINT32 dropReq_port0:1; /* one of the port dropped request */ ++ UINT32 scheCell_port0:1; /* per port scheduled cell */ ++ UINT32 sit_port0:1; /* per port schedule interval timer count event */ ++ UINT32 pne_err_port1:1; /* port not enable error */ ++ UINT32 pne_err_port0:1; /* port not enable error */ ++ UINT32 ff_err_port1:1; /* fifo full error */ ++ UINT32 ff_err_port0:1; /* fifo full error */ ++ UINT32 dc_port1:1; /* per port dropped cell */ ++ UINT32 dc_port0:1; /* per port dropped cell */ ++ UINT32 pc_port1:1; /* per port processed cell */ ++ UINT32 pc_port0:1; /* per port processed cell */ ++ }bit; ++ UINT32 reg; ++} ATM_TX_STATUS_REG, *pATM_TX_STATUS_REG; ++ ++ ++typedef union atmTxHdrReg { ++ struct { ++ UINT32 unused1:14; ++ UINT32 aal5SwTrailer:1; /* software trailer enable */ ++ UINT32 schedCrst_1:1; /* scheuler reset */ ++ UINT32 schedCrst_0:1; ++ UINT32 unused:1; ++ UINT32 haltShpt_1:1; /* halt shaper, used for dynamic configuration of shaper */ ++ UINT32 haltShpt_0:1; ++ UINT32 altGFC:4; /* alternate GFC value */ ++ UINT32 altGFCen_1:1; ++ UINT32 altGFCen_0:1; /* alternate GFC mode enable */ ++ UINT32 fRst_1:1; ++ UINT32 fRst_0:1; ++ UINT32 oamCrcEn_1:1; ++ UINT32 oamCrcEn_0:1; ++ UINT32 txEn_1:1; ++ UINT32 txEn_0:1; ++ }bit; ++ UINT32 reg; ++} ATM_TX_HDR_CFG_REG, *pATM_TX_HDR_CFG_REG; ++ ++typedef union rxAalError { ++ struct { ++ UINT8 crc:1; /* aal5 CRC error */ ++ UINT8 cpcsLen0:1; /* aal5 cpcsLen error */ ++ UINT8 length:1; /* aal5 len error */ ++ UINT8 maxSduExceed:1; /* max sdu exceed error */ ++ UINT8 unused:4; ++ }bit; ++ UINT8 entry; ++} RX_AAL_ERROR; ++ ++typedef union rxAtmError { ++ struct { ++ UINT8 pne:1; /* port not enable error */ ++ UINT8 hec:1; /* HEC error */ ++ UINT8 pti:1; /* pti error */ ++ UINT8 idle:1; /* idle rx */ ++ UINT8 camLkup:1; /* cam look up error */ ++ UINT8 unused:1; ++ UINT8 oamCrc:1; /* oam crc */ ++ UINT8 gfc:1; /* gfc error */ ++ }bit; ++ UINT8 entry; ++} RX_ATM_ERROR; ++ ++/* 0xfffe442c */ ++typedef union atmUtopiaCfg { ++ struct { ++ UINT32 unused:26; ++ UINT32 rxLevel2:1; /* when set=level 2, when 0=level 1 */ ++ UINT32 rxEn:1; /* enable RX Utopia Operation */ ++ UINT32 unused1:2; ++ UINT32 txLevel2:1; /* when set=level 2, when 0=level 1 */ ++ UINT32 txEn:1; /* enable TX Utopia Operation */ ++ }bit; ++ UINT32 entry; ++} ATM_UTOPIA_CFG, *pATM_UTOPIA_CFG; ++ ++typedef union portSchedulerCfg { ++ struct { ++ UINT32 cit:16; ++ UINT32 unused:12; ++ UINT32 mode:2; ++ UINT32 arb:1; ++ UINT32 en:1; ++ }bit; ++ UINT32 entry; ++} ATM_PORT_SCHEDULER_CFG, *pATM_PORT_SCHEDULER_CFG; ++ ++/* memory map operation definition */ ++typedef struct atm_regs { ++ int kmem_fd; ++ char *mmap_addr; ++ unsigned long addr; ++ unsigned int size; ++ unsigned int offset; ++} atm_regs; ++ ++int getVccNextIndex(void); ++void removeVccIndex(int index); ++int isVpiVciExisted(UINT32 interface, UINT16 vpi, UINT16 vci); ++void atmDiagInit(void); ++BCMATM_STATUS bcmAtmDiagInit(void); ++BCMATM_STATUS bcmAtmDiagUnInit(void); ++BCMATM_STATUS bcmAtmAddVccCommand(pUT_VCC_ADDR_INFO pVccAddrs, pUT_VCC_CFG pVccCfg, ++ pUT_TRAFFIC_DESCR_PARM_ENTRY pTd); ++BCMATM_STATUS bcmAtmSendVccCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmCaptureCommand(int mode); ++BCMATM_STATUS bcmAtmSendManagementCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmDeleteVccCommand(pUT_VCC_ADDR_INFO pVccAddrs); ++BCMATM_STATUS bcmAtmSendAllVccsCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmSendMultiPriorityCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmSendLoopbackCommand(UINT8 mode); ++BCMATM_STATUS bcmAtmAddMPVccCommand(pUT_VCC_ADDR_INFO pVccAddrs, pUT_VCC_CFG pVccCfg, ++ pUT_TRAFFIC_DESCR_PARM_ENTRY pTd); ++BCMATM_STATUS bcmAtmDeleteMPVccCommand(pUT_VCC_ADDR_INFO pVccAddrs); ++BCMATM_STATUS bcmAtmSendMPVccCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmSendMultiPriorityCommand(pATM_TEST_TX_INFO pAtmInfo); ++BCMATM_STATUS bcmAtmModifyTDCommand(pUT_TRAFFIC_DESCR_PARM_ENTRY pTD, UINT32 index); ++int bcmAtmGetStatsCommand(int reset); ++int bcmAtmToggleVerifyCommand(void); ++int bcmAtmToggleCaptureCommand(void); ++int bcmAtmToggleDisplayCommand(void); ++int bcmAtmStopTxCommand(void); ++int isVpiVciExisted(UINT32 interface, UINT16 vpi, UINT16 vci); ++int bcmDiag_unmapregs(atm_regs *mapregs); ++atm_regs *bcmDiag_mapregs(unsigned long addr, int size); ++int bcmDiagGetVerificationStats(int vcc,char *pResult); ++void bcmDiagClearSARstats(void); ++void bcmDiagReadSARstats(int parm); ++int bcmDiagGetSARStats(char *pResult); ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmosservices.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmosservices.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/atmosservices.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/atmosservices.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,98 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++//************************************************************************** ++// File Name : BcmAtmApi.h ++// ++// Description: This file contains the definitions, structures and function ++// prototypes for the Broadcom Asynchronous Transfer Mode (ATM) ++// Application Program Interface (API). ++// ++// Updates : 09/15/2000 lat. Created. ++//************************************************************************** ++ ++#if !defined(_ATMOSSERVICES_H_) ++#define _ATMOSSERVICES_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++//************************************************************************** ++// Constant Definitions ++//************************************************************************** ++#define RTN_SUCCESS 0 ++#define RTN_ERROR 1 ++#define USE_CURRENT_THREAD_PRIORITY 0 ++ ++//************************************************************************** ++// Type Definitions ++//************************************************************************** ++typedef void (*FN_GENERIC) (void *); ++typedef struct AtmOsFuncs ++{ ++ FN_GENERIC pfnAlloc; ++ FN_GENERIC pfnFree; ++ FN_GENERIC pfnDelay; ++ FN_GENERIC pfnCreateSem; ++ FN_GENERIC pfnRequestSem; ++ FN_GENERIC pfnReleaseSem; ++ FN_GENERIC pfnDeleteSem; ++ FN_GENERIC pfnDisableInts; ++ FN_GENERIC pfnEnableInts; ++ FN_GENERIC pfnInvalidateCache; ++ FN_GENERIC pfnFlushCache; ++ FN_GENERIC pfnGetTopMemAddr; ++ FN_GENERIC pfnBlinkLed; ++ FN_GENERIC pfnGetSystemTick; ++ FN_GENERIC pfnStartTimer; ++ FN_GENERIC pfnPrintf; ++} ATM_OS_FUNCS, *PATM_OS_FUNCS; ++ ++//************************************************************************** ++// Function Prototypes ++//************************************************************************** ++ ++UINT32 AtmOsInitialize( PATM_OS_FUNCS pFuncs ); ++char *AtmOsAlloc( UINT32 ulSize ); ++void AtmOsFree( char *pBuf ); ++UINT32 AtmOsCreateThread( char *pszName, void *pFnEntry, UINT32 ulFnParm, ++ UINT32 ulPriority, UINT32 ulStackSize, UINT32 *pulThreadId ); ++UINT32 AtmOsCreateSem( UINT32 ulInitialState ); ++UINT32 AtmOsRequestSem( UINT32 ulSem, UINT32 ulTimeoutMs ); ++void AtmOsReleaseSem( UINT32 ulSem ); ++void AtmOsDeleteSem( UINT32 ulSem ); ++UINT32 AtmOsDisableInts( void ); ++void AtmOsEnableInts( UINT32 ulLevel ); ++void AtmOsDelay( UINT32 ulTimeoutMs ); ++UINT32 AtmOsTickGet( void ); ++UINT32 AtmOsTickCheck( UINT32 ulWaitTime, UINT32 ulMsToWait ); ++void AtmOsInvalidateCache( void *pBuf, UINT32 ulLength ); ++void AtmOsFlushCache( void *pBuf, UINT32 ulLength ); ++char *AtmOsTopMemAddr( void ); ++void AtmOsBlinkLed( void ); ++UINT32 AtmOsInitDeferredHandler( void *pFnEntry, UINT32 ulFnParm, ++ UINT32 ulTimeout ); ++void AtmOsScheduleDeferred( UINT32 ulHandle ); ++void AtmOsUninitDeferredHandler( UINT32 ulHandle ); ++UINT32 AtmOsStartTimer( void *pFnEntry, UINT32 ulFnParm, UINT32 ulTimeout ); ++void AtmOsPrintf( char *, ... ); ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _ATMOSSERVICES_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcm_common.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcm_common.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcm_common.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcm_common.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,48 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2004 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++ ++#ifndef __BCM_COMMON_H ++#define __BCM_COMMON_H ++ ++#if defined(CONFIG_BCM96338) ++#include <6338_common.h> ++#endif ++#if defined(CONFIG_BCM96345) ++#include <6345_common.h> ++#endif ++#if defined(CONFIG_BCM96348) ++#include <6348_common.h> ++#endif ++ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,5) /* starting from 2.4.5 */ ++#define skb_dataref(x) (&skb_shinfo(x)->dataref) ++#else ++#define skb_dataref(x) skb_datarefp(x) ++#endif ++ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,19) /* starting from 2.4.19 */ ++#define VIRT_TO_PHY(a) (((unsigned long)(a)) & 0x1fffffff) ++#else ++#define VIRT_TO_PHY virt_to_phys ++#endif ++ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++#define __save_and_cli save_and_cli ++#define __restore_flags restore_flags ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcm_map.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcm_map.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcm_map.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcm_map.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,31 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2004 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++ ++#ifndef __BCM_MAP_H ++#define __BCM_MAP_H ++ ++#if defined(CONFIG_BCM96338) ++#include <6338_map.h> ++#endif ++#if defined(CONFIG_BCM96345) ++#include <6345_map.h> ++#endif ++#if defined(CONFIG_BCM96348) ++#include <6348_map.h> ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmadsl.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmadsl.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmadsl.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmadsl.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,199 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++//************************************************************************** ++// File Name : Adsl.h ++// ++// Description: This file contains the definitions, structures and function ++// prototypes for ADSL PHY interface ++// ++//************************************************************************** ++#if !defined(_BCMADSL_H_) ++#define _BCMADSL_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++/* Incldes. */ ++#include "AdslMibDef.h" ++ ++//************************************************************************** ++// Type Definitions ++//************************************************************************** ++ ++// Return status values ++typedef enum BcmAdslStatus ++{ ++ BCMADSL_STATUS_SUCCESS = 0, ++ BCMADSL_STATUS_ERROR ++} BCMADSL_STATUS; ++ ++// Return status values ++typedef enum AdslLinkState ++{ ++ BCM_ADSL_LINK_UP = 0, ++ BCM_ADSL_LINK_DOWN, ++ BCM_ADSL_TRAINING_G992_EXCHANGE, ++ BCM_ADSL_TRAINING_G992_CHANNEL_ANALYSIS, ++ BCM_ADSL_TRAINING_G992_STARTED, ++ BCM_ADSL_TRAINING_G994, ++ BCM_ADSL_G994_NONSTDINFO_RECEIVED, ++ BCM_ADSL_BERT_COMPLETE, ++ BCM_ADSL_ATM_IDLE, ++ BCM_ADSL_EVENT, ++ BCM_ADSL_G997_FRAME_RECEIVED, ++ BCM_ADSL_G997_FRAME_SENT ++} ADSL_LINK_STATE; ++ ++#ifndef DISABLE_ADSL_OLD_DEF ++#define ADSL_LINK_UP BCM_ADSL_LINK_UP ++#define ADSL_LINK_DOWN BCM_ADSL_LINK_DOWN ++#endif ++ ++/* ADSL test modes */ ++typedef enum AdslTestMode ++{ ++ ADSL_TEST_NORMAL = 0, ++ ADSL_TEST_REVERB, ++ ADSL_TEST_MEDLEY, ++ ADSL_TEST_SELECT_TONES, ++ ADSL_TEST_NO_AUTO_RETRAIN, ++ ADSL_TEST_MARGIN_TWEAK, ++ ADSL_TEST_ESTIMATE_PLL_PHASE, ++ ADSL_TEST_REPORT_PLL_PHASE_STATUS, ++ ADSL_TEST_AFELOOPBACK, ++ ADSL_TEST_L3, ++ ADSL_TEST_DIAGMODE, ++ ADSL_TEST_L0 ++} ADSL_TEST_MODE; ++ ++// ADSL_CHANNEL_ADDR Contains ADSL Utopia PHY addresses ++typedef struct AdslChannelAddr ++{ ++ UINT16 usFastChannelAddr; ++ UINT16 usInterleavedChannelAddr; ++} ADSL_CHANNEL_ADDR, *PADSL_CHANNEL_ADDR; ++ ++// ADSL_CONNECTION_INFO Contains ADSL Connection Info ++typedef struct AdslConnectionInfo ++{ ++ ADSL_LINK_STATE LinkState; ++ UINT32 ulFastUpStreamRate; ++ UINT32 ulFastDnStreamRate; ++ UINT32 ulInterleavedUpStreamRate; ++ UINT32 ulInterleavedDnStreamRate; ++} ADSL_CONNECTION_INFO, *PADSL_CONNECTION_INFO; ++ ++/* OEM parameter definition */ ++#define ADSL_OEM_G994_VENDOR_ID 1 /* Vendor ID used during G.994 handshake */ ++#define ADSL_OEM_G994_XMT_NS_INFO 2 /* G.994 non-standard info field to send */ ++#define ADSL_OEM_G994_RCV_NS_INFO 3 /* G.994 received non-standard */ ++#define ADSL_OEM_EOC_VENDOR_ID 4 /* EOC reg. 0 */ ++#define ADSL_OEM_EOC_VERSION 5 /* EOC reg. 1 */ ++#define ADSL_OEM_EOC_SERIAL_NUMBER 6 /* EOC reg. 2 */ ++#define ADSL_OEM_T1413_VENDOR_ID 7 /* Vendor ID used during T1.413 handshake */ ++#define ADSL_OEM_T1413_EOC_VENDOR_ID 8 /* EOC reg. 0 (vendor ID) in T1.413 mode */ ++ ++/* XMT gain definitions */ ++#define ADSL_XMT_GAIN_AUTO 0x80000000 ++ ++typedef struct ++{ ++ int diagCmd; ++ int diagMap; ++ int logTime; ++ int srvIpAddr; ++ int gwIpAddr; ++} ADSL_DIAG, *PADSL_DIAG; ++ ++typedef struct ++{ ++ short x; ++ short y; ++} ADSL_CONSTELLATION_POINT, *PADSL_CONSTELLATION_POINT; ++ ++#define ADSL_CONSTEL_DATA_ID 0 ++#define ADSL_CONSTEL_PILOT_ID 1 ++ ++#define ADSL_MIB_INFO adslMibInfo ++typedef ADSL_MIB_INFO *PADSL_MIB_INFO; ++ ++typedef void (*ADSL_FN_NOTIFY_CB) (ADSL_LINK_STATE AdslLinkState, UINT32 ulParm); ++ ++//************************************************************************** ++// Function Prototypes ++//************************************************************************** ++ ++BCMADSL_STATUS BcmAdsl_Check(void); ++BCMADSL_STATUS BcmAdsl_Initialize(ADSL_FN_NOTIFY_CB pFnNotifyCb, UINT32 ulParm, adslCfgProfile *pAdslCfg); ++#ifdef LINUX ++BCMADSL_STATUS BcmAdsl_MapAtmPortIDs(UINT16 usAtmFastPortId, UINT16 usAtmInterleavedPortId); ++#endif ++BCMADSL_STATUS BcmAdsl_Uninitialize(void); ++BCMADSL_STATUS BcmAdsl_ConnectionStart(void); ++BCMADSL_STATUS BcmAdsl_ConnectionStop(void); ++BCMADSL_STATUS BcmAdsl_GetPhyAddresses(PADSL_CHANNEL_ADDR pChannelAddr); ++BCMADSL_STATUS BcmAdsl_SetPhyAddresses(PADSL_CHANNEL_ADDR pChannelAddr); ++BCMADSL_STATUS BcmAdsl_GetConnectionInfo(PADSL_CONNECTION_INFO pConnectionInfo); ++BCMADSL_STATUS BcmAdsl_DiagCommand(PADSL_DIAG pAdslDiag); ++int BcmAdsl_GetObjectValue(char *objId, int objIdLen, char *dataBuf, long *dataBufLen); ++BCMADSL_STATUS BcmAdsl_StartBERT(unsigned long totalBits); ++BCMADSL_STATUS BcmAdsl_StopBERT(void); ++BCMADSL_STATUS BcmAdsl_BertStartEx(unsigned long bertSec); ++BCMADSL_STATUS BcmAdsl_BertStopEx(void); ++BCMADSL_STATUS BcmAdsl_CheckPowerLoss(void); ++BCMADSL_STATUS BcmAdsl_SendDyingGasp(int powerCtl); ++BCMADSL_STATUS BcmAdsl_Configure(adslCfgProfile *pAdslCfg); ++BCMADSL_STATUS BcmAdsl_GetVersion(adslVersionInfo *pAdslVer); ++BCMADSL_STATUS BcmAdsl_SetSDRAMBaseAddr(void *pAddr); ++BCMADSL_STATUS BcmAdsl_SetVcEntry (int gfc, int port, int vpi, int vci); ++BCMADSL_STATUS BcmAdsl_SetVcEntryEx (int gfc, int port, int vpi, int vci, int pti_clp); ++ ++BCMADSL_STATUS BcmAdsl_ResetStatCounters(void); ++BCMADSL_STATUS BcmAdsl_SetAtmLoopbackMode(void); ++BCMADSL_STATUS BcmAdsl_SetTestMode(ADSL_TEST_MODE testMode); ++BCMADSL_STATUS BcmAdsl_SelectTones( ++ int xmtStartTone, ++ int xmtNumTones, ++ int rcvStartTone, ++ int rcvNumTones, ++ char *xmtToneMap, ++ char *rcvToneMap ++ ); ++BCMADSL_STATUS BcmAdsl_SetDiagMode(int diagMode); ++ ++int BcmAdsl_GetConstellationPoints (int toneId, ADSL_CONSTELLATION_POINT *pointBuf, int numPoints); ++ ++int BcmAdsl_GetOemParameter (int paramId, void *buf, int len); ++int BcmAdsl_SetOemParameter (int paramId, void *buf, int len); ++int BcmAdsl_SetXmtGain(int gain); ++ ++UINT32 BcmAdsl_GetSelfTestMode(void); ++void BcmAdsl_SetSelfTestMode(UINT32 stMode); ++UINT32 BcmAdsl_GetSelfTestResults(void); ++ ++BCMADSL_STATUS BcmAdsl_G997SendData(void *buf, int len); ++void *BcmAdsl_G997FrameGet(int *pLen); ++void *BcmAdsl_G997FrameGetNext(int *pLen); ++void BcmAdsl_G997FrameFinished(void); ++void BcmAdsl_DyingGaspHandler(void *context); ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _BCMADSL_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmatmapi.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmatmapi.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmatmapi.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmatmapi.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,699 @@ ++/* ++<:copyright-broadcom ++ ++ Copyright (c) 2002 Broadcom Corporation ++ All Rights Reserved ++ No portions of this material may be reproduced in any form without the ++ written permission of: ++ Broadcom Corporation ++ 16215 Alton Parkway ++ Irvine, California 92619 ++ All information contained in this document is Broadcom Corporation ++ company private, proprietary, and trade secret. ++ ++:> ++*/ ++//************************************************************************** ++// File Name : BcmAtmApi.h ++// ++// Description: This file contains the definitions, structures and function ++// prototypes for the Broadcom Asynchronous Transfer Mode (ATM) ++// Application Program Interface (API). ++// ++// Updates : 09/15/2000 lat. Created. ++//************************************************************************** ++ ++#if !defined(_BCMATMAPI_H_) ++#define _BCMATMAPI_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++//************************************************************************** ++// Constant Definitions ++//************************************************************************** ++ ++// ATM physical port constants. ++#define PHY_NUM_PORTS 4 ++#define PHY_0 0 ++#define PHY_1 1 ++#define PHY_2 2 // [BCM635x Only] ++#define PHY_3 3 // [BCM635x Only] ++ ++// Used for backwards compatibility. ++#define PHY_UTOPIA0 0 ++#define PHY_UTOPIA1 1 ++#define PHY_UTOPIA2 2 ++#define PHY_UTOPIA3_TC_LOOPBACK 3 ++ ++// Values for ATM_PORT_CFG ucPortType. ++#define PT_DISABLED 0 ++#define PT_UTOPIA 1 ++#define PT_LOOPBACK 2 ++#define PT_TC 3 // [BCM635x Only] ++#define PT_ADSL_INTERLEAVED 4 // [BCM6345 Only] ++#define PT_ADSL_FAST 5 // [BCM6345 Only] ++ ++// Wildcard definitions. ++#define ALL_INTERFACES 0xffffffff ++#define ANY_PRIORITY 0xff ++ ++// Values for ATM_TRAFFIC_DESCR_PARM_ENTRY ulTrafficDescrType. ++#define TDT_ATM_NO_TRAFFIC_DESCRIPTOR 1 ++#define TDT_ATM_NO_CLP_NO_SCR 2 ++#define TDT_ATM_CLP_NO_TAGGING_NO_SCR 3 ++#define TDT_ATM_CLP_TAGGING_NO_SCR 4 ++#define TDT_ATM_NO_CLP_SCR 5 ++#define TDT_ATM_CLP_NO_TAGGING_SCR 6 // [BCM635x Only] ++#define TDT_ATM_CLP_TAGGING_SCR 7 // [BCM635x Only] ++#define TDT_ATM_CLP_NO_TAGGING_MCR 8 // [BCM6348 Only] ++#define TDT_ATM_CLP_TRANSPARENT_NO_SCR 9 ++#define TDT_ATM_CLP_TRANSPARENT_SCR 10 ++#define TDT_ATM_NO_CLP_TAGGING_NO_SCR 11 ++#define TDT_ATM_NO_CLP_NO_SCR_CDVT 12 ++#define TDT_ATM_NO_CLP_SCR_CDVT 13 ++#define TDT_ATM_CLP_NO_TAGGING_SCR_CDVT 14 // [BCM635x Only] ++#define TDT_ATM_CLP_TAGGING_SCR_CDVT 15 // [BCM635x Only] ++ ++// Values for ATM_TRAFFIC_DESCR_PARM_ENTRY ulTrafficDescrRowStatus. ++#define TDRS_ACTIVE 1 ++#define TDRS_NOT_IN_SERVICE 2 ++ ++// Values for ATM_TRAFFIC_DESCR_PARM_ENTRY ulServiceCategory. ++#define SC_OTHER 1 ++#define SC_CBR 2 ++#define SC_RT_VBR 3 ++#define SC_NRT_VBR 4 ++#define SC_UBR 6 ++ ++// Values for ATM_INTERFACE_CFG ulIfAdminStatus and ATM_VCC_CFG ++// ulAtmVclAdminStatus. ++#define ADMSTS_UP 1 ++#define ADMSTS_DOWN 2 ++#define ADMSTS_TESTING 3 ++ ++// Values for ATM_INTERFACE_CFG ulIfOperStatus and ATM_VCC_CFG ++// ulAtmVclOperStatus. ++#define OPRSTS_UP 1 ++#define OPRSTS_DOWN 2 ++#define OPRSTS_UNKNOWN 3 ++ ++// Values for ATM_INTERFACE_LINK_INFO ulLinkState. ++#define LINK_UP 1 ++#define LINK_DOWN 2 ++ ++// Values for ulAalType. ++#define AAL_2 0 // [BCM635x Only] ++#define AAL_TRANSPARENT 1 ++#define AAL_0_PACKET 2 ++#define AAL_0_CELL_CRC 3 ++#define AAL_5 7 ++ ++// Values for ATM_VCC_CFG ulAtmVccEncapsType. ++#define ET_VC_MULTIPLEX_ROUTED_PROTOCOL 1 ++#define ET_VC_MULTIPLEX_BRG_PROTOCOL_8023 2 ++#define ET_VC_MULTIPLEX_BRG_PROTOCOL_8025 3 ++#define ET_VC_MULTIPLEX_BRG_PROTOCOL_8026 4 ++#define ET_VC_MULTIPLEX_LAN_EMULATION_8023 5 ++#define ET_VC_MULTIPLEX_LAN_EMULATION_8025 6 ++#define ET_LLC_ENCAPSULATION 7 ++#define ET_MULTI_PROTOCOL_FRAME_RELAY_SSCS 8 ++#define ET_OTHER 9 ++#define ET_UNKNOWN 10 ++ ++// [BCM635x Only] Values for ATM_AAL2_VCC_CFG ucAal2CpsOptimisation. ++#define OPT_SNG_PKT_PER_PDU_NO_OVERLAP 1 ++#define OPT_MULT_PKTS_PER_PDU_OVERLAP 2 ++ ++// [BCM635x Only] Values for ATM_INTERFACE_STATS ulTcAlarmState. ++#define TCALM_NO_ALARM 1 ++#define TCALM_LCD_FAILURE 2 ++ ++// Values for ATM_NOTIFY_PARMS ulNotificationType. ++#define ATM_NOTIFY_INTERFACE_CHANGE 1 ++ ++// Values for AN_INTF_CHANGE_PARMS ulInterfaceState. ++#define ATM_INTERFACE_UP 1 ++#define ATM_INTERFACE_DOWN 2 ++ ++// Values for AN_VCC_CHANGE_PARMS ulInterfaceState. ++#define ATM_VCC_UP 1 ++#define ATM_VCC_DOWN 2 ++ ++// Values for ATM_VCC_ATTACH_PARMS ulFlags. ++#define AVAP_ALLOW_OAM_F5_SEGMENT_CELLS 0x0001 ++#define AVAP_ALLOW_OAM_F5_END_TO_END_CELLS 0x0002 ++#define AVAP_ALLOW_RM_CELLS 0x0004 ++#define AVAP_ALLOW_OAM_F4_SEGMENT_CELLS 0x0008 ++#define AVAP_ALLOW_OAM_F4_END_TO_END_CELLS 0x0010 ++#define AVAP_ALLOW_CELLS_WITH_ERRORS 0x0020 ++#define AVAP_ADD_AAL0_CRC10 0x0040 ++#define AVAP_DSP 0x8000 // [BCM635x Only] ++ ++// [BCM635x Only] Values for ATM_VCC_AAL2_CHANNEL_ID_PARMS ucVoiceRouting. ++#define VOICE_ROUTE_MIPS 0 ++#define VOICE_ROUTE_DSP 2 ++ ++// [BCM635x Only] Values for ATM_VCC_AAL2_CHANNEL_ID_PARMS ucFlags. ++#define CID_USE_FRAME_MODE 0x01 ++ ++// Values for ATM_VCC_DATA_PARMS ucCircuitType. ++#define CT_AAL0_PACKET 0x02 ++#define CT_AAL0_CELL_CRC 0x03 ++#define CT_OAM_F5_SEGMENT 0x04 ++#define CT_OAM_F5_END_TO_END 0x05 ++#define CT_RM 0x06 ++#define CT_AAL5 0x07 ++#define CT_HDLC_PACKET 0x08 // [BCM6348 Only] ++#define CT_ANY_AAL2_MASK 0x08 // [BCM635x Only] ++#define CT_AAL2_ALARM 0x08 // [BCM635x Only] ++#define CT_AAL2_TYPE_3 0x09 // [BCM635x Only] ++#define CT_AAL2_TYPE_1 0x0A // [BCM635x Only] ++#define CT_AAL2_FRAME 0x0B // [BCM635x Only] ++#define CT_TRANSPARENT 0x10 ++#define CT_OAM_F4_ANY 0x20 ++ ++// OAM F4 VCI values. ++#define VCI_OAM_F4_SEGMENT 3 ++#define VCI_OAM_F4_END_TO_END 4 ++#define VCI_RM 6 ++ ++// Values for ATM_VCC_DATA_PARMS ucFlags. ++#define ATMDATA_CI 0x04 ++#define ATMDATA_CLP 0x08 ++ ++// [BCM635x Only] DSP specific values. ++#define DSP_VCID 31 ++ ++// ATM cell layer interface name ++#define ATM_CELL_LAYER_IFNAME "atm0" ++ ++// AAL5 CPCS layer interface name ++#define AAL5_CPCS_LAYER_IFNAME "cpcs0" ++ ++//************************************************************************** ++// Type Definitions ++//************************************************************************** ++ ++// Return status values ++typedef enum BcmAtmStatus ++{ ++ STS_SUCCESS = 0, ++ STS_ERROR, ++ STS_STATE_ERROR, ++ STS_PARAMETER_ERROR, ++ STS_ALLOC_ERROR, ++ STS_RESOURCE_ERROR, ++ STS_IN_USE, ++ STS_VCC_DOWN, ++ STS_INTERFACE_DOWN, ++ STS_LINK_DOWN, ++ STS_NOT_FOUND, ++ STS_NOT_SUPPORTED, ++ STS_VCAM_MULT_MATCH_ERROR, ++ STS_CCAM_MULT_MATCH_ERROR, ++ STS_PKTERR_INVALID_VPI_VCI, ++ STS_PKTERR_PORT_NOT_ENABLED, ++ STS_PKTERR_HEC_ERROR, ++ STS_PKTERR_PTI_ERROR, ++ STS_PKTERR_RECEIVED_IDLE_CELL, ++ STS_PKTERR_CIRCUIT_TYPE_ERROR, ++ STS_PKTERR_OAM_RM_CRC_ERROR, ++ STS_PKTERR_GFC_ERROR, ++ STS_PKTERR_AAL5_AAL0_CRC_ERROR, ++ STS_PKTERR_AAL5_AAL0_SHORT_PKT_ERROR, ++ STS_PKTERR_AAL5_AAL0_LENGTH_ERROR, ++ STS_PKTERR_AAL5_AAL0_BIG_PKT_ERROR, ++ STS_PKTERR_AAL5_AAL0_SAR_TIMEOUT_ERROR, ++ STS_PKTERR_AAL2F_HEC_ERROR, ++ STS_PKTERR_AAL2F_SEQ_NUM_ERROR, ++ STS_PKTERR_AAL2F_PARITY_ERROR, ++ STS_PKTERR_AAL2F_CRC_ERROR, ++ STS_PKTERR_AAL2F_CAM_ERROR, ++ STS_PKTERR_AAL2F_BIG_PKT_ERROR, ++ STS_PKTERR_AAL2F_RAS_TIMEOUT_ERROR, ++ STS_PKTERR_AAL2F_SHORT_PKT_ERROR, ++ STS_PKTERR_AAL2F_LENGTH_MISMATCH_ERROR, ++ STS_PKTERR_AAL2V_HEC_ERROR, ++ STS_PKTERR_AAL2V_SEQ_NUM_ERROR, ++ STS_PKTERR_AAL2V_PARITY_ERROR, ++ STS_PKTERR_AAL2V_CRC_ERROR, ++ STS_PKTERR_AAL2V_CAM_ERROR, ++ STS_PKTERR_AAL2V_OSF_MISMATCH_ERROR, ++ STS_PKTERR_AAL2V_OSF_ERROR, ++ STS_PKTERR_AAL2V_HEC_OVERLAP_ERROR, ++ STS_PKTERR_AAL2V_BIG_PKT_ERROR, ++ STS_PKTERR_AAL2V_RAS_ERROR, ++ STS_PKTERR_AAL2V_UUI_ERROR ++} BCMATM_STATUS; ++ ++ ++// ATM_VCC_ADDR identifies a Virtual Channel Connection (VCC). ++typedef struct AtmVccAddr ++{ ++ UINT32 ulInterfaceId; ++ UINT16 usVpi; ++ UINT16 usVci; ++} ATM_VCC_ADDR, *PATM_VCC_ADDR; ++ ++ ++// ATM_PORT_CFG contains ATM physical port configuration parameters. ++typedef struct AtmPortCfg ++{ ++ UINT32 ulInterfaceId; ++ UINT8 ucPortType; ++ UINT8 ucPortAddr; ++ UINT8 ucReserved[2]; ++} ATM_PORT_CFG, *PATM_PORT_CFG; ++ ++ ++// ATM_INITIALIZATION_PARMS contains ATM API module initialization parameters. ++#define ID_ATM_INITIALIZATION_PARMS 2 ++typedef struct AtmInitialization ++{ ++ UINT32 ulStructureId; ++ UINT32 ulThreadPriority; ++ UINT16 usFreeCellQSize; ++ UINT16 usFreePktQSize; ++ UINT16 usFreePktQBufferSize; ++ UINT16 usFreePktQBufferOffset; // offset into buffer to start receiving data ++ UINT16 usReceiveCellQSize; ++ UINT16 usReceivePktQSize; ++ UINT8 ucTransmitFifoPriority; // [BCM635x Only] ++ UINT8 ucReserved; ++ UINT16 usAal5CpcsMaxSduLength; ++ UINT16 usAal2SscsMaxSsarSduLength; // [BCM635x Only] ++ ATM_PORT_CFG PortCfg[PHY_NUM_PORTS]; ++} ATM_INITIALIZATION_PARMS, *PATM_INITIALIZATION_PARMS; ++ ++ ++// ATM_TRAFFIC_DESCR_PARM_ENTRY contains the fields needed to create a Traffic ++// Descriptor Table parameter entry. ++#define ID_ATM_TRAFFIC_DESCR_PARM_ENTRY 1 ++typedef struct AtmTrafficDescrParmEntry ++{ ++ UINT32 ulStructureId; ++ UINT32 ulTrafficDescrIndex; ++ UINT32 ulTrafficDescrType; ++ UINT32 ulTrafficDescrParm1; ++ UINT32 ulTrafficDescrParm2; ++ UINT32 ulTrafficDescrParm3; ++ UINT32 ulTrafficDescrParm4; ++ UINT32 ulTrafficDescrParm5; ++ UINT32 ulTrafficDescrRowStatus; ++ UINT32 ulServiceCategory; ++ UINT32 ulTrafficFrameDiscard; ++} ATM_TRAFFIC_DESCR_PARM_ENTRY, *PATM_TRAFFIC_DESCR_PARM_ENTRY; ++ ++ ++// ATM_INTERFACE_CFG contains configuration fields for an ATM interface. ++#define ID_ATM_INTERFACE_CFG 3 ++typedef struct AtmInterfaceCfg ++{ ++ UINT32 ulStructureId; ++ UINT32 ulAtmInterfaceMaxVccs; ++ UINT32 ulAtmInterfaceConfVccs; ++ UINT32 ulAtmInterfaceMaxActiveVpiBits; ++ UINT32 ulAtmInterfaceMaxActiveVciBits; ++ UINT32 ulAtmInterfaceCurrentMaxVpiBits; ++ UINT32 ulAtmInterfaceCurrentMaxVciBits; ++ UINT32 ulIfAdminStatus; ++ UINT32 ulIfOperStatus; // read-only ++ UINT32 ulSendNullCells; ++ UINT32 ulTcScramble; ++ UINT32 ulPortType; // read-only ++ UINT32 ulIfLastChange; ++} ATM_INTERFACE_CFG, *PATM_INTERFACE_CFG; ++ ++ ++// ATM_VCC_TRANSMIT_QUEUE_PARMS contains fields for configuring an transmit ++// queue. ++#define ID_ATM_VCC_TRANSMIT_QUEUE_PARMS 1 ++typedef struct AtmVccTransmitQueueParms ++{ ++ UINT32 ulStructureId; ++ UINT32 ulSize; ++ UINT32 ulPriority; ++ UINT32 ulReserved; ++} ATM_VCC_TRANSMIT_QUEUE_PARMS, *PATM_VCC_TRANSMIT_QUEUE_PARMS; ++ ++ ++// ATM_AAL5_VCC_CFG contains configuration fields for an ATM AAL5 Virtual ++// Channel Connection (VCC). ++typedef struct AtmAal5VccCfg ++{ ++ UINT32 ulAtmVccEncapsType; ++ UINT32 ulAtmVccCpcsAcceptCorruptedPdus; ++} ATM_AAL5_VCC_CFG, *PATM_AAL5_VCC_CFG; ++ ++ ++// [BCM635x Only] ATM_AAL2_VCC_CFG contains configuration fields for an ATM ++// AAL2 Virtual Channel Connection (VCC). ++typedef struct AtmAal2VccCfg ++{ ++ UINT8 ucAal2CpsMaxMultiplexedChannels; ++ UINT8 ucAal2CpsMaxSduLength; ++ UINT8 ucAal2CpsCidLowerLimit; ++ UINT8 ucAal2CpsCidUpperLimit; ++ UINT8 ucAal2CpsOptimisation; ++ UINT8 ucReserved[3]; ++} ATM_AAL2_VCC_CFG, *PATM_AAL2_VCC_CFG; ++ ++ ++// ATM_AAL0_VCC_CFG contains configuration fields for an ATM AAL0 Virtual ++// Channel Connection (VCC). ++typedef struct AtmAal0VccCfg ++{ ++ UINT8 ucReserved; ++ // Reserved for future use. ++} ATM_AAL0_VCC_CFG, *PATM_AAL0_VCC_CFG; ++ ++ ++// ATM_VCC_CFG contains configuration fields for an ATM Virtual Channel ++// Connection (VCC). ++#define ID_ATM_VCC_CFG 2 ++#define TX_Q_PARM_SIZE 8 ++typedef struct AtmVccCfg ++{ ++ UINT32 ulStructureId; ++ UINT32 ulAalType; ++ UINT32 ulAtmVclAdminStatus; ++ UINT32 ulAtmVclOperStatus; ++ UINT32 ulAtmVclLastChange; ++ UINT32 ulAtmVclReceiveTrafficDescrIndex; ++ UINT32 ulAtmVclTransmitTrafficDescrIndex; ++ UINT32 ulTransmitQParmsSize; ++ ATM_VCC_TRANSMIT_QUEUE_PARMS TransmitQParms[TX_Q_PARM_SIZE]; ++ union ++ { ++ ATM_AAL5_VCC_CFG Aal5Cfg; ++ ATM_AAL2_VCC_CFG Aal2Cfg; // [BCM635x Only] ++ ATM_AAL0_VCC_CFG Aal0Cfg; ++ } u; ++} ATM_VCC_CFG, *PATM_VCC_CFG; ++ ++ ++// ATM_INTF_ATM_STATS contains statistics for the ATM layer of an interface. ++typedef struct AtmIntfAtmStats ++{ ++ UINT32 ulIfInOctets; ++ UINT32 ulIfOutOctets; ++ UINT32 ulIfInErrors; ++ UINT32 ulIfInUnknownProtos; ++ UINT32 ulIfOutErrors; ++ ++ // The following fields are added together to calculate ulIfInErrors. ++ UINT32 ulIfInHecErrors; ++ ++ // The following fields are added together to calculate ulIfInUnknownProtos. ++ UINT32 ulIfInInvalidVpiVciErrors; ++ UINT32 ulIfInPortNotEnabledErrors; ++ UINT32 ulIfInPtiErrors; ++ UINT32 ulIfInIdleCells; ++ UINT32 ulIfInCircuitTypeErrors; ++ UINT32 ulIfInOamRmCrcErrors; ++ UINT32 ulIfInGfcErrors; ++} ATM_INTF_ATM_STATS, *PATM_INTF_ATM_STATS; ++ ++ ++// [BCM635x Only] ATM_INTF_ATM_STATS contains statistics for the TC layer. ++typedef struct AtmIntfTcStats ++{ ++ UINT32 ulTcInDataCells; ++ UINT32 ulTcInTotalCells; ++ UINT32 ulTcInHecErrors; ++ UINT32 ulTcInOcdEvents; ++ UINT32 ulTcAlarmState; ++} ATM_INTF_TC_STATS, *PATM_INTF_TC_STATS; ++ ++ ++// ATM_INTF_AAL5_AAL0_STATS contains statistics for all AAL5/AAL0 VCCs on an ++// ATM interface. ++typedef struct AtmIntfAal5Aal0Stats ++{ ++ UINT32 ulIfInOctets; ++ UINT32 ulIfOutOctets; ++ UINT32 ulIfInUcastPkts; ++ UINT32 ulIfOutUcastPkts; ++ UINT32 ulIfInErrors; ++ UINT32 ulIfOutErrors; ++ UINT32 ulIfInDiscards; ++ UINT32 ulIfOutDiscards; ++} ATM_INTF_AAL5_AAL0_STATS, *PATM_INTF_AAL5_AAL0_STATS; ++ ++ ++// [BCM635x Only] ATM_INTF_AAL2_STATS contains statistics for all AAL2 VCCs ++// on an ATM interface. ++typedef struct AtmIntfAal2Stats ++{ ++ UINT32 ulIfInOctets; ++ UINT32 ulIfOutOctets; ++ UINT32 ulIfInUcastPkts; ++ UINT32 ulIfOutUcastPkts; ++ UINT32 ulIfInErrors; ++ UINT32 ulIfOutErrors; ++ UINT32 ulIfInDiscards; ++ UINT32 ulIfOutDiscards; ++} ATM_INTF_AAL2_STATS, *PATM_INTF_AAL2_STATS; ++ ++ ++// ATM_INTERFACE_STATS contains statistics for an ATM interface. ++#define ID_ATM_INTERFACE_STATS 1 ++typedef struct AtmInterfaceStats ++{ ++ UINT32 ulStructureId; ++ ATM_INTF_ATM_STATS AtmIntfStats; ++ ATM_INTF_TC_STATS TcIntfStats; // [BCM635x Only] ++ ATM_INTF_AAL5_AAL0_STATS Aal5IntfStats; ++ ATM_INTF_AAL2_STATS Aal2IntfStats; // [BCM635x Only] ++ ATM_INTF_AAL5_AAL0_STATS Aal0IntfStats; ++} ATM_INTERFACE_STATS, *PATM_INTERFACE_STATS; ++ ++ ++// ATM_VCC_AAL5_STATS contains statistics for an AAL5 VCC. ++typedef struct AtmVccAal5Stats ++{ ++ UINT32 ulAal5VccCrcErrors; ++ UINT32 ulAal5VccSarTimeOuts; ++ UINT32 ulAal5VccOverSizedSdus; ++ UINT32 ulAal5VccShortPacketErrors; ++ UINT32 ulAal5VccLengthErrors; ++} ATM_VCC_AAL5_STATS, *PATM_VCC_AAL5_STATS; ++ ++ ++// [BCM635x Only] ATM_VCC_AAL2_STATS contains statistics for an AAL2 VCC. ++typedef struct AtmVccAal2Stats ++{ ++ UINT32 ulAal2CpsInPkts; ++ UINT32 ulAal2CpsOutPkts; ++ UINT32 ulAal2CpsParityErrors; ++ UINT32 ulAal2CpsSeqNumErrors; ++ UINT32 ulAal2CpsOsfMismatchErrors; ++ UINT32 ulAal2CpsOsfErrors; ++ UINT32 ulAal2CpsHecOverlapErrors; ++ UINT32 ulAal2CpsHecErrors; ++ UINT32 ulAal2CpsOversizedSduErrors; ++ UINT32 ulAal2CpsReassemblyErrors; ++ UINT32 ulAal2CpsUuiErrors; ++ UINT32 ulAal2CpsCidErrors; ++ UINT32 ulAal2SscsOversizedSssarSduErrors; ++ UINT32 ulAal2SscsSssarRasTimerExipiryErrors; ++ UINT32 ulAal2SscsUndersizedSstedPduErrors; ++ UINT32 ulAal2SscsSstedPduLengthMismatchErrors; ++ UINT32 ulAal2SscsSstedCrcMismatchErrors; ++} ATM_VCC_AAL2_STATS, *PATM_VCC_AAL2_STATS; ++ ++ ++// ATM_VCC_AAL0PKT_STATS contains statistics for an AAL0 Packet VCC. ++typedef struct AtmVccAal0PktStats ++{ ++ UINT32 ulAal0VccSarTimeOuts; ++ UINT32 ulAal0VccOverSizedSdus; ++} ATM_VCC_AAL0PKT_STATS, *PATM_VCC_AAL0PKT_STATS; ++ ++ ++// ATM_VCC_AAL0CELL_STATS contains statistics for an AAL0 Cell with CRC VCC. ++typedef struct AtmVccAal0CellStats ++{ ++ UINT32 ulAal0VccCrcErrors; ++} ATM_VCC_AAL0CELL_STATS, *PATM_VCC_AAL0CELL_STATS; ++ ++ ++// ATM_VCC_STATS contains statistics for a VCC. ++#define ID_ATM_VCC_STATS 1 ++typedef struct AtmVccStatistics ++{ ++ UINT32 ulStructureId; ++ UINT32 ulAalType; ++ union ++ { ++ ATM_VCC_AAL5_STATS AtmVccAal5Stats; ++ ATM_VCC_AAL2_STATS AtmVccAal2Stats; // [BCM635x Only] ++ ATM_VCC_AAL0PKT_STATS AtmVccAal0PktStats; ++ ATM_VCC_AAL0CELL_STATS AtmVccAal0CellStats; ++ } u; ++} ATM_VCC_STATS, *PATM_VCC_STATS; ++ ++ ++// ATM_INTERFACE_LINK_INFO contains fields for the physical link that the ++// ATM interface is using. ++#define ID_ATM_INTERFACE_LINK_INFO 1 ++typedef struct AtmInterfaceLinkInfo ++{ ++ UINT32 ulStructureId; ++ UINT32 ulLinkState; ++ UINT32 ulLineRate; ++ UINT32 ulReserved[2]; ++} ATM_INTERFACE_LINK_INFO, *PATM_INTERFACE_LINK_INFO; ++ ++ ++// AN_INTF_CHANGE_PARMS contains notification fields that passed to an ++// application callback function when the ATM interface goes up or down. ++#define ID_AN_INTF_CHANGE_PARMS 1 ++typedef struct AnIntfChangeParms ++{ ++ UINT32 ulInterfaceId; ++ UINT32 ulInterfaceState; ++ UINT32 ulInterfaceLineRate; ++} AN_INTF_CHANGE_PARMS, *PAN_INTF_CHANGE_PARMS; ++ ++ ++// ATM_NOTIFY_PARMS contains notification fields that passed to an application ++// callback function when an ATM notification event occurs. ++typedef struct AtmNotifyParms ++{ ++ UINT32 ulNotifyType; ++ union ++ { ++ AN_INTF_CHANGE_PARMS IntfChangeParms; ++ ++ // Other fields and structures that are specific ++ // to the type of notification are declared here. ++ } u; ++} ATM_NOTIFY_PARMS, *PATM_NOTIFY_PARMS; ++ ++typedef void (*FN_NOTIFY_CB) (PATM_NOTIFY_PARMS pNotifyParms); ++ ++ ++// ATM_VCC_ATTACH_PARMS contains fields for attaching to a VCC. It is used ++// by all BcmAtm_Attach... functions. ++struct AtmVccDataParms; ++typedef void (*FN_RECEIVE_CB) (UINT32 ulHandle, PATM_VCC_ADDR pVccAddr, ++ struct AtmVccDataParms *pDataParms, UINT32 ulParmReceiveData); ++ ++#define ID_ATM_VCC_ATTACH_PARMS 1 ++typedef struct AtmAttachParms ++{ ++ UINT32 ulStructureId; ++ UINT32 ulFlags; ++ FN_RECEIVE_CB pFnReceiveDataCb; ++ UINT32 ulParmReceiveData; ++ ATM_VCC_TRANSMIT_QUEUE_PARMS *pTransmitQParms; ++ UINT32 ulTransmitQParmsSize; ++ UINT32 ulHandle; ++ UINT32 ulReserved; ++} ATM_VCC_ATTACH_PARMS, *PATM_VCC_ATTACH_PARMS; ++ ++ ++// [BCM635x Only] ATM_VCC_AAL2_CHANNEL_ID_PARMS contains fields for ++// configuring an transmit queue. ++#define ID_ATM_VCC_AAL2_CHANNEL_ID_PARMS 1 ++typedef struct AtmVccAal2ChannelIdParms ++{ ++ UINT32 ulStructureId; ++ UINT8 ucChannelId; ++ UINT8 ucVoiceRouting; ++ UINT8 ucFlags; ++ UINT8 ucReserved[5]; ++} ATM_VCC_AAL2_CHANNEL_ID_PARMS, *PATM_VCC_AAL2_CHANNEL_ID_PARMS; ++ ++ ++// ATM_BUFFER contains fields for passing data to, and receive data from, the ++// ATM API. ++typedef struct AtmBuffer ++{ ++ struct AtmBuffer *pNextAtmBuf; ++ UINT8 *pDataBuf; ++ UINT32 ulDataLen; ++ UINT16 usDataOffset; ++ UINT16 usReserved; ++ UINT32 ulReserved; ++} ATM_BUFFER, *PATM_BUFFER; ++ ++ ++// ATM_VCC_DATA_PARMS contains fields for sending or receiving data on a VCC. ++// It is used by all BcmAtm_Send... and receive functions. ++typedef void (*FN_FREE_DATA_PARMS) (struct AtmVccDataParms *pDataParms); ++ ++#define ID_ATM_VCC_DATA_PARMS 2 ++typedef struct AtmVccDataParms ++{ ++ UINT32 ulStructureId; ++ UINT8 ucCircuitType; ++ UINT8 ucAal2ChannelId; // [BCM635x Only] ++ UINT8 ucUuData8; ++ UINT8 ucUuData5; ++ UINT8 ucFlags; ++ UINT8 ucSendPriority; ++ UINT8 ucReserved[2]; ++ BCMATM_STATUS baReceiveStatus; ++ PATM_BUFFER pAtmBuffer; ++ FN_FREE_DATA_PARMS pFnFreeDataParms; ++ UINT32 ulParmFreeDataParms; ++ struct AtmVccDataParms *pApplicationLink; ++ UINT32 ulApplicationDefined[2]; ++} ATM_VCC_DATA_PARMS, *PATM_VCC_DATA_PARMS; ++ ++ ++//************************************************************************** ++// Function Prototypes ++//************************************************************************** ++ ++BCMATM_STATUS BcmAtm_Initialize( PATM_INITIALIZATION_PARMS pInitValues ); ++BCMATM_STATUS BcmAtm_Uninitialize( void ); ++BCMATM_STATUS BcmAtm_GetInterfaceId( UINT8 ucPhyPort, UINT32 *pulInterfaceId ); ++BCMATM_STATUS BcmAtm_GetTrafficDescrTableSize(UINT32 *pulTrafficDescrTableSize); ++BCMATM_STATUS BcmAtm_GetTrafficDescrTable( PATM_TRAFFIC_DESCR_PARM_ENTRY ++ pTrafficDescTable, UINT32 ulTrafficDescrTableSize ); ++BCMATM_STATUS BcmAtm_SetTrafficDescrTable( PATM_TRAFFIC_DESCR_PARM_ENTRY ++ pTrafficDescTable, UINT32 ulTrafficDescrTableSize ); ++BCMATM_STATUS BcmAtm_GetInterfaceCfg( UINT32 ulInterfaceId, PATM_INTERFACE_CFG ++ pInterfaceCfg ); ++BCMATM_STATUS BcmAtm_SetInterfaceCfg( UINT32 ulInterfaceId, PATM_INTERFACE_CFG ++ pInterfaceCfg ); ++BCMATM_STATUS BcmAtm_GetVccCfg( PATM_VCC_ADDR pVccAddr, PATM_VCC_CFG pVccCfg ); ++BCMATM_STATUS BcmAtm_SetVccCfg( PATM_VCC_ADDR pVccAddr, PATM_VCC_CFG pVccCfg ); ++BCMATM_STATUS BcmAtm_GetVccAddrs( UINT32 ulInterfaceId, PATM_VCC_ADDR pVccAddrs, ++ UINT32 ulNumVccs, UINT32 *pulNumReturned ); ++BCMATM_STATUS BcmAtm_GetInterfaceStatistics( UINT32 ulInterfaceId, ++ PATM_INTERFACE_STATS pStatistics, UINT32 ulReset ); ++BCMATM_STATUS BcmAtm_GetVccStatistics( PATM_VCC_ADDR pVccAddr, PATM_VCC_STATS ++ pVccStatistics, UINT32 ulReset ); ++BCMATM_STATUS BcmAtm_SetInterfaceLinkInfo( UINT32 ulInterfaceId, ++ PATM_INTERFACE_LINK_INFO pInterfaceCfg ); ++BCMATM_STATUS BcmAtm_SetNotifyCallback( FN_NOTIFY_CB pFnNotifyCb ); ++BCMATM_STATUS BcmAtm_ResetNotifyCallback( FN_NOTIFY_CB pFnNotifyCb ); ++BCMATM_STATUS BcmAtm_AttachVcc( PATM_VCC_ADDR pVccAddr, PATM_VCC_ATTACH_PARMS ++ pAttachParms ); ++BCMATM_STATUS BcmAtm_AttachMgmtCells( UINT32 ulInterfaceId, ++ PATM_VCC_ATTACH_PARMS pAttachParms ); ++BCMATM_STATUS BcmAtm_AttachTransparent( UINT32 ulInterfaceId, ++ PATM_VCC_ATTACH_PARMS pAttachParms ); ++BCMATM_STATUS BcmAtm_Detach( UINT32 ulHandle ); ++BCMATM_STATUS BcmAtm_SetAal2ChannelIds( UINT32 ulHandle, ++ PATM_VCC_AAL2_CHANNEL_ID_PARMS pChannelIdParms, UINT32 ++ ulNumChannelIdParms ); // [BCM635x Only] ++BCMATM_STATUS BcmAtm_SendVccData( UINT32 ulHandle, ++ PATM_VCC_DATA_PARMS pDataParms ); ++BCMATM_STATUS BcmAtm_SendMgmtData( UINT32 ulHandle, PATM_VCC_ADDR pVccAddr, ++ PATM_VCC_DATA_PARMS pDataParms ); ++BCMATM_STATUS BcmAtm_SendTransparentData( UINT32 ulHandle, UINT32 ulInterfaceId, ++ PATM_VCC_DATA_PARMS pDataParms ); ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _BCMATMAPI_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmnet.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmnet.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmnet.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmnet.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,78 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: bcmnet.h */ ++/* DATE: 05/16/02 */ ++/* PURPOSE: network interface ioctl definition */ ++/* */ ++/***********************************************************************/ ++#ifndef _IF_NET_H_ ++#define _IF_NET_H_ ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#define LINKSTATE_DOWN 0 ++#define LINKSTATE_UP 1 ++ ++/*---------------------------------------------------------------------*/ ++/* Ethernet Switch Type */ ++/*---------------------------------------------------------------------*/ ++#define ESW_TYPE_UNDEFINED 0 ++#define ESW_TYPE_BCM5325M 1 ++#define ESW_TYPE_BCM5325E 2 ++#define ESW_TYPE_BCM5325F 3 ++ ++/* ++ * Ioctl definitions. ++ */ ++/* reserved SIOCDEVPRIVATE */ ++enum { ++ SIOCGLINKSTATE = SIOCDEVPRIVATE + 1, ++ SIOCSCLEARMIBCNTR, ++ SIOCGIFTRANSSTART, ++ SIOCMIBINFO, ++ SIOCSDUPLEX, /* 0: auto 1: full 2: half */ ++ SIOCSSPEED, /* 0: auto 1: 100mbps 2: 10mbps */ ++ SIOCCIFSTATS, ++ SIOCGENABLEVLAN, ++ SIOCGDISABLEVLAN, ++ SIOCGQUERYNUMVLANPORTS, ++ SIOCGSWITCHTYPE, ++ SIOCGQUERYNUMPORTS, ++ SIOCLAST ++}; ++ ++#define SPEED_10MBIT 10000000 ++#define SPEED_100MBIT 100000000 ++ ++typedef struct IoctlMibInfo ++{ ++ unsigned long ulIfLastChange; ++ unsigned long ulIfSpeed; ++} IOCTL_MIB_INFO, *PIOCTL_MIB_INFO; ++ ++ ++#if __cplusplus ++} ++#endif ++ ++#endif /* _IF_NET_H_ */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmos.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmos.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/bcmos.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/bcmos.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,98 @@ ++/*************************************************************************** ++* Copyright 2000 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16251 Laguna Canyon Road ++* Irvine, California 92618 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: bcmos.h ++* Creation Date: 8 June 2000 (v0.00) ++* VSS Info: ++* $Revision: 16 $ ++* $Date: 5/03/01 5:03p $ ++* ++**************************************************************************** ++* Description: ++* ++* Broadcom Generic Operating System Functions. ++* ++****************************************************************************/ ++ ++#ifndef _BCMOS_H ++#define _BCMOS_H ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#ifdef __KERNEL__ ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++ ++#define malloc(arg) kmalloc(arg, GFP_KERNEL) ++#define free(arg) kfree(arg) ++ ++#define BCMOS_ASSERT(expr) \ ++if ((expr)? 0:1) \ ++{ \ ++ printk(" ASSERT !!! File %s, line %u \n", __FILE__, __LINE__); \ ++ bosSleep( 10 ); \ ++ cli(); /* Disable interrupts */ \ ++ while(1){ ; } \ ++} ++ ++#define CXC_ASSERT BCMOS_ASSERT // For compatibility with CX's endpoint ++ ++/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!*/ ++/* Special BOS definitions */ ++/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!*/ ++#define DSL_NO_RESETSUPPORT ++ ++ ++#define bosSocketHtoNL( num ) ((UINT32)( num )) ++#define bosSocketHtoNS( num ) ((UINT16)( num )) ++#define bosSocketNtoHL( num ) ((UINT32)( num )) ++#define bosSocketNtoHS( num ) ((UINT16)( num )) ++#define bosSocketNtoHS( num ) ((UINT16)( num )) ++#define bosSocketNtoHU16 bosSocketNtoHS ++ ++ ++#else /* LINUX */ ++ ++#include ++#include ++#include ++#include ++ ++#define BCMOS_TASKNAME( nameVar, nameStr ) char nameVar[] = nameStr ++ ++#define TEN_MSEC 10 ++#define TWENTY_MSEC 20 ++#define ONE_HUNDRED_MSEC 100 ++#define FIVE_HUNDRED_MSEC 500 ++#define ONE_SECOND 1000 ++#define TWO_SECONDS 2000 ++ ++#define BCMOS_ASSERT( expr) assert( expr ) ++ ++#endif ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++ ++#endif /* _BCMOS_H */ ++ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/cxcEnv.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/cxcEnv.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/cxcEnv.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/cxcEnv.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,79 @@ ++/*************************************************************************** ++* Copyright 2000 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16251 Laguna Canyon Road ++* Irvine, California 92618 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: cxcEnv.h ++* Creation Date: ++* VSS Info: ++* $Revision: 43 $ ++* $Date: 12/03/02 5:50p $ ++* ++**************************************************************************** ++* Description: ++* ++* This file is used in CableX to provide system-wide types and definitions. Howewever. ++* since iit tries to include various C run-time library dcefintions (eh stdio.h, it is not ++* appropriate for use "as is" in a Linux kernel environment. So the CableX endpoint source ++* does not need to change, we use this file to recursively include bcmtypes.h ++* ++* NOTE: This file is based upon LDX's hausenv.h, but has been renamed to ++* avoid project dependencies, and allow for CablexChange customizations. ++* ++****************************************************************************/ ++ ++#ifndef CXC_ENV_H ++#define CXC_ENV_H ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++/* -------------------------------------------------------------------------- ++** Just include definitions from bcmtypes.h ++*/ ++#include ++ ++#undef EPT_TEST ++ ++#if !defined( HAUS_SINT16_DEFINED ) ++#define HAUS_SINT16_DEFINED ++typedef signed short SINT16; /* SINT16 is platform independant */ ++#endif ++ ++ ++#if !defined( HAUS_SINT32_DEFINED ) ++#define HAUS_SINT32_DEFINED ++typedef signed long SINT32; ++#endif ++ ++#define SUCCESS 0 ++#define FAILURE 1 ++ ++ ++// GNU definition imported from cxc_compiler.h ++#define CXC_INLINE __inline__ ++ ++// Endian-ness imported from cxc_cpu.h ++#define CXC_CPU_BIG_ENDIAN 1 ++#define CXC_CPU_LITTLE_ENDIAN 0 ++ ++#if defined(__KERNEL__) ++#define CXC_OS_LINUX 1 ++#define PSOS 0 ++#define VXWORKS 0 ++#endif ++ ++#ifdef __cplusplus ++} ++#endif ++ ++#endif /* CXC_ENV_H */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/cxcLog.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/cxcLog.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/cxcLog.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/cxcLog.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,34 @@ ++/*************************************************************************** ++* Copyright 2000 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16251 Laguna Canyon Road ++* Irvine, California 92618 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: log.h ++* Creation Date: 17 September 2001 (v0.00) ++* VSS Info: ++* $Revision: 3 $ ++* $Date: 11/13/02 3:42p $ ++* ++**************************************************************************** ++* Description: ++* ++* This filename is preserved in order to minimize the changes ++* in the endpoint code, which is shared with the Cablex endpoint. ++* cxcLog.h simply includes log.h, which contains the log macros. ++* ++****************************************************************************/ ++ ++#ifndef CXC_LOG_H ++#define CXC_LOG_H ++ ++#include ++ ++#endif /* CXC_LOG_H */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/endpointdrv.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/endpointdrv.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/endpointdrv.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/endpointdrv.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,243 @@ ++/*************************************************************************** ++ * Broadcom Corp. Confidential ++ * Copyright 2001 Broadcom Corp. All Rights Reserved. ++ * ++ * THIS SOFTWARE MAY ONLY BE USED SUBJECT TO AN EXECUTED ++ * SOFTWARE LICENSE AGREEMENT BETWEEN THE USER AND BROADCOM. ++ * YOU HAVE NO RIGHT TO USE OR EXPLOIT THIS MATERIAL EXCEPT ++ * SUBJECT TO THE TERMS OF SUCH AN AGREEMENT. ++ * ++ *************************************************************************** ++ * File Name : EndpointDrv.h ++ * ++ * Description: This file contains the definitions and structures for the ++ * Linux IOCTL interface that used between the user mode Endpoint ++ * API library and the kernel Endpoint API driver. ++ * ++ * Updates : 04/04/2002 YD. Created. ++ ***************************************************************************/ ++ ++#if !defined(_ENDPOINTDRV_H_) ++#define _ENDPOINTDRV_H_ ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++/* Includes. */ ++#include ++#include ++#include ++ ++/* Maximum size for the event data passed with the event callback */ ++#define MAX_EVENTDATA_SIZE 256 ++ ++typedef enum ENDPOINTIOCTL_INDEX ++{ ++ ENDPTIO_INIT_INDEX = 0, ++ ENDPTIO_DEINIT_INDEX, ++ ENDPTIO_CREATE_INDEX, ++ ENDPTIO_CAPABILITIES_INDEX, ++ ENDPTIO_SIGNAL_INDEX, ++ ENDPTIO_CREATE_CONNECTION_INDEX, ++ ENDPTIO_MODIFY_CONNECTION_INDEX, ++ ENDPTIO_DELETE_CONNECTION_INDEX, ++ ENDPTIO_PACKET_INDEX, ++ ENDPTIO_GET_PACKET_INDEX, ++ ENDPTIO_GET_EVENT_INDEX, ++ ENDPTIO_GET_CODECMAP_INDEX, ++ ENDPTIO_VOICESTAT_INDEX, ++ ENDPTIO_ISINITIALIZED_INDEX, ++ ENDPTIO_CONSOLE_CMD_INDEX, ++ ENDPTIO_TEST_INDEX, ++ ENDPTIO_ENDPOINTCOUNT_INDEX, ++ ENDPTIO_MAX_INDEX ++} ENDPOINTIOCTL_INDEX; ++ ++ ++/* Defines. */ ++#define ENDPOINTDRV_MAJOR 209 /* arbitrary unused value */ ++ ++#define ENDPOINTIOCTL_ENDPT_INIT \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_INIT_INDEX, ENDPOINTDRV_INIT_PARAM) ++ ++#define ENDPOINTIOCTL_ENDPT_DEINIT \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_DEINIT_INDEX, ENDPOINTDRV_INIT_PARAM) ++ ++#define ENDPOINTIOCTL_ENDPT_CREATE \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_CREATE_INDEX, ENDPOINTDRV_CREATE_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_CAPABILITIES \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_CAPABILITIES_INDEX, ENDPOINTDRV_CAP_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_SIGNAL \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_SIGNAL_INDEX, ENDPOINTDRV_SIGNAL_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_CREATE_CONNECTION \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_CREATE_CONNECTION_INDEX, ENDPOINTDRV_CONNECTION_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_MODIFY_CONNECTION \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_MODIFY_CONNECTION_INDEX, ENDPOINTDRV_CONNECTION_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_DELETE_CONNECTION \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_DELETE_CONNECTION_INDEX, ENDPOINTDRV_DELCONNECTION_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_PACKET \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_PACKET_INDEX, ENDPOINTDRV_PACKET_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_GET_PACKET \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_GET_PACKET_INDEX, ENDPOINTDRV_PACKET_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_GET_EVENT \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_GET_EVENT_INDEX, ENDPOINTDRV_EVENT_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_GET_CODECMAP \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_GET_CODECMAP_INDEX, ENDPOINTDRV_CODECMAP_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_VOICESTAT \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_VOICESTAT_INDEX, ENDPOINTDRV_VOICESTAT_PARM) ++ ++#define ENDPOINTIOCTL_ISINITIALIZED \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_ISINITIALIZED_INDEX, ENDPOINTDRV_ISINITIALIZED_PARM) ++ ++#define ENDPOINTIOCTL_ENDPT_CONSOLE_CMD \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_CONSOLE_CMD_INDEX, ENDPOINTDRV_CONSOLE_CMD_PARM) ++ ++#define ENDPOINTIOCTL_TEST \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_TEST_INDEX, ENDPOINTDRV_TESTPARM) ++ ++#define ENDPOINTIOCTL_ENDPOINTCOUNT \ ++ _IOWR(ENDPOINTDRV_MAJOR, ENDPTIO_ENDPOINTCOUNT_INDEX, ENDPOINTDRV_ENDPOINTCOUNT_PARM) ++ ++#define MAX_ENDPOINTDRV_IOCTL_COMMANDS ENDPTIO_MAX_INDEX ++ ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ VRG_COUNTRY country; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_INIT_PARAM, *PENDPOINTDRV_INIT_PARAM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ UINT32 physId; ++ UINT32 lineId; ++ VRG_ENDPT_STATE* endptState; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_CREATE_PARM, *PENDPOINTDRV_CREATE_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ EPZCAP* capabilities; ++ ENDPT_STATE* state; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_CAP_PARM, *PENDPOINTDRV_CAP_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ ENDPT_STATE* state; ++ UINT32 cnxId; ++ EPSIG signal; ++ UINT32 value; // Reserve an array, can be a pointer ++ EPSTATUS epStatus; ++ int duration; ++ int period; ++ int repetition; ++} ENDPOINTDRV_SIGNAL_PARM, *PENDPOINTDRV_SIGNAL_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ ENDPT_STATE* state; ++ int cnxId; ++ EPZCNXPARAM* cnxParam; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_CONNECTION_PARM, *PENDPOINTDRV_CONNECTION_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ ENDPT_STATE* state; ++ int cnxId; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_DELCONNECTION_PARM, *PENDPOINTDRV_DELCONNECTION_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ ENDPT_STATE* state; ++ int cnxId; ++ EPPACKET* epPacket; ++ int length; ++ UINT32 bufDesc; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_PACKET_PARM, *PENDPOINTDRV_PACKET_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ int lineId; ++ int cnxId; ++ int length; ++ EPEVT event; ++ UINT8 eventData[MAX_EVENTDATA_SIZE]; ++} ENDPOINTDRV_EVENT_PARM, *PENDPOINTDRV_EVENT_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ int isInitialized; ++} ENDPOINTDRV_ISINITIALIZED_PARM, *PENDPOINTDRV_ISINITIALIZED_PARM; ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ UINT32 testParm1; ++ UINT32 testParm2; ++ EPZCNXPARAM* testParm3; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_TESTPARM, *PENDPOINTDRV_TESTPARM; ++ ++typedef struct ENDPOINTDRV_PACKET ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ int cnxId; ++ int length; ++ EPMEDIATYPE mediaType; ++ UINT8 data[1024]; ++} ENDPOINTDRV_PACKET; ++ ++typedef struct ENDPOINTDRV_VOICESTAT_PARM ++{ ++ int lineId; ++ ENDPT_VOICE_STATS* stats; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_VOICESTAT_PARM, *PENDPOINTDRV_VOICESTAT_PARM; ++ ++typedef struct ENDPOINTDRV_CONSOLE_CMD_PARM ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ int lineId; ++ int cnxId; ++ int cmd; ++ ENDPT_STATE* state; ++ EPSTATUS epStatus; ++} ENDPOINTDRV_CONSOLE_CMD_PARM, *PENDPOINTDRV_CONSOLE_CMD_PARM; ++ ++ ++typedef struct ++{ ++ UINT32 size; /* Size of the structure (including the size field) */ ++ int endpointNum; ++} ENDPOINTDRV_ENDPOINTCOUNT_PARM, *PENDPOINTDRV_ENDPOINTCOUNT_PARM; ++ ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif // _ENDPOINTDRV_H_ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/endptvoicestats.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/endptvoicestats.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/endptvoicestats.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/endptvoicestats.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,106 @@ ++/*************************************************************************** ++ * Broadcom Corp. Confidential ++ * Copyright 2001 Broadcom Corp. All Rights Reserved. ++ * ++ * THIS SOFTWARE MAY ONLY BE USED SUBJECT TO AN EXECUTED ++ * SOFTWARE LICENSE AGREEMENT BETWEEN THE USER AND BROADCOM. ++ * YOU HAVE NO RIGHT TO USE OR EXPLOIT THIS MATERIAL EXCEPT ++ * SUBJECT TO THE TERMS OF SUCH AN AGREEMENT. ++ * ++ *************************************************************************** ++ * File Name : endptvoicestats.h ++ * ++ * Description: This file contains the definitions of the voice statistics ++ * structures. This file should be used in user space when ++ * working with the voice statistics structure. ++ * ++ * The files hpnet.h and hppve.h ++ * should not be included in user space because of a conflict ++ * in the definitions supplied by hausenv.h (in the endpoint/vocm/ ++ * ldxIntf/dspinc directory) and the definitions supplied by bcmtypes.h ++ * (in the /sgibcm_2_4_17/linux/include/asm-mips/bcm96345 directory). ++ * ++ * Updates : ++ ***************************************************************************/ ++ ++#if !defined(ENDPTSTATS_H) ++#define ENDPTSTATS_H ++ ++#if defined(__cplusplus) ++extern "C" { ++#endif ++ ++typedef struct ++{ ++#ifdef ENDPT_6345 ++ UINT16 peakHoldingTime; /* Peak Holding Time since last statistic */ ++ ++ /* Total number of superpackets arriving on the egress path */ ++ UINT16 packetCount; /* # of packets received */ ++ ++ /* addTail and reorder are successful additions to the JB */ ++ /* addTail is typically 1..N times the packetCount if superpackets are enabled */ ++ UINT16 addTailCount; /* # of frames added to tail of JB - normal case */ ++ UINT16 reorderCount; /* # of frames reordered */ ++ ++ /* overrun, duplicate, outOfRange, tooLate, jitterMax excess are packets that have been discarded */ ++ UINT16 overrunCount; /* Decoder overrun count */ ++ UINT16 duplicateCount; /* # of duplicate frames deleted */ ++ UINT16 outOfRangeCount; /* # of frames with timestamps too far from current TS to be handled */ ++ UINT16 tooLateCount; /* Packet arrived too late (it's redundant mate already played) */ ++ ++ /* cantDecode are packets that can't be played out due to algorithm not available */ ++ UINT16 cantDecodeCount; /* Can't decode packet - decoder not in load or pkt hdr bad */ ++ ++ /* The following are internal to the AJC module - they do not represent physical packets */ ++ UINT16 ajcUnderrunCount; /* Adaptive Jitter Control: jitter buffer underruns */ ++ UINT16 ajcDeleteCount; /* Adaptive Jitter Control: # of packet deletes done to reduce holding time */ ++ UINT16 ajcRepeatCount; /* Adaptive Jitter Control: # of packet repeats done to either increase holding time ++ or due to late frame or lost frames. */ ++ UINT16 ajcResyncCount; /* Number of times ajb resynced (went through buildout state) */ ++ UINT16 ajcPhaseJitterCount; /* Number of times ajb inserted a phase discontinuity ++ (possibly in silence or during CNG or due to a repeat/delete). */ ++ /* 14 entries. Make sure this is even (!) */ ++#else ++ UINT16 peakHoldingTime; /* Peak Holding Time since last statistic */ ++ UINT16 minimumHoldingTime; /* Long-term tracker of min. Hold Time */ ++ UINT16 targetHoldingTime; /* Target holding Time */ ++ UINT16 inactiveFrameCount; /* Inactive Frame Count */ ++ UINT16 activeFrameCount; /* Active Frame Count */ ++ UINT16 hsxDecoderOverrunCount; /* Decoder overrun count */ ++ UINT16 hsxDecoderUnderrunCount; /* Decoder underrun count */ ++ UINT16 lostFrameCount; /* Lost frames resulting in frame repeat */ ++#endif ++} ENDPT_VOICE_DECODERSTATS; ++ ++/* Encoder Statistics */ ++typedef struct ++{ ++#ifdef ENDPT_6345 ++ UINT16 inactiveFrameCount; /* Inactive Frame Count of Suppressed Frames*/ ++ UINT16 activeFrameCount; /* Active Frame Count - actually sent ingress */ ++ UINT16 sidFrameCount; /* SID Frame Count */ ++ UINT16 toneRelayCount; /* # of tone packets from PTE relayed ingress */ ++#else ++ UINT16 hsxEncoderOverrunCount; /* Encoder overrun count */ ++#endif ++} ENDPT_VOICE_ENCODERSTATS; ++ ++ ++typedef struct ++{ ++ ENDPT_VOICE_DECODERSTATS decoder; ++ ENDPT_VOICE_ENCODERSTATS encoder; ++} ENDPT_VOICE_PVE_STATS; ++ ++typedef struct ++{ ++ ENDPT_VOICE_PVE_STATS hsxPVEstats; /* statistics for PVE encoder and decoder */ ++ ++} ENDPT_VOICE_STATS; ++ ++#if defined(__cplusplus) ++} ++#endif ++ ++#endif /* ENDPTSTATS_H */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/log.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/log.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/log.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/log.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,104 @@ ++/*************************************************************************** ++* Copyright 2000 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16251 Laguna Canyon Road ++* Irvine, California 92618 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: log.h ++* Creation Date: 4 July 2000 (v0.00) ++* VSS Info: ++* $Revision: 23 $ ++* $Date: 9/14/01 4:54p $ ++* ++**************************************************************************** ++* Description: ++* ++* This header file contains the needed macros and function prototypes ++* for logging on the terminal. ++* ++****************************************************************************/ ++ ++#ifndef LOG_H ++#define LOG_H ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#define LOG_DBG ++ ++#if (! (defined(__KERNEL__) || defined (LINUX)) ) ++ ++extern void Log( char const *format,...); ++extern void LogMsg( char *string ); ++extern void LogDirectSerial( char const *format,...); ++ ++#define PANIC(m) Log(m) ++#define LOG(fmt) Log fmt ++#define LOGERROR(fmt) Log fmt ++#define LOG1(fmt) Log fmt /* Level 1 logging */ ++#define LOG2(fmt) /* Level 2 logging */ ++#define LOGMSG(buf) LogMsg buf ++ ++/*********************************** ++** Error logging * ++***********************************/ ++#elif defined(__KERNEL__) ++ ++#define LOG(fmt) printk fmt ; printk("\n"); ++#define LOG_RAW(fmt) printk fmt ; printk("\n"); ++#define PANIC(fmt) printk("!!! PANIC !!! \n"); printk fmt ; printk("\n"); ++#define LOGERROR(fmt) printk("!!! ERROR !!! \n"); printk fmt ; printk("\n"); ++ ++#elif defined(LINUX) ++ ++#include ++ ++#ifdef LOG_DBG ++ ++#include ++ ++#define LOG(fmt) \ ++{ \ ++ struct tm *tm_ptr; \ ++ time_t curtime; \ ++ time( &curtime ); \ ++ tm_ptr = gmtime( &curtime ); \ ++ printf("%02d:%02d:%02d ", \ ++ tm_ptr->tm_hour, \ ++ tm_ptr->tm_min, \ ++ tm_ptr->tm_sec); \ ++ printf fmt; \ ++ printf("\n"); \ ++} ++#else ++#define LOG(fmt) printf fmt ; printf("\n"); ++#endif /* LOG_DBG */ ++ ++#define PANIC(fmt) printk("!!! PANIC !!! \n"); printk fmt ; printk("\n"); ++#define LOGERROR(fmt) \ ++{ \ ++ printf("ERROR !!! File %s (line %u): ", __FILE__, __LINE__);\ ++ printf fmt; \ ++ printf("\n"); \ ++} ++ ++#else ++#error Unknown OS ++#endif ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif /* LOG_H */ ++ ++ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/mtacfg.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/mtacfg.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/mtacfg.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/mtacfg.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,72 @@ ++/*************************************************************************** ++* Copyright 2000 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16251 Laguna Canyon Road ++* Irvine, California 92618 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: mtacfg.h ++* Creation Date: 4 July 2000 (v0.00) ++* VSS Info: ++* $Revision: 23 $ ++* $Date: 9/14/01 4:54p $ ++* ++**************************************************************************** ++* Description: ++* ++* This header file contains all the different build options that ++* are required by CablexChange components. ++* ++****************************************************************************/ ++ ++#ifndef _MTACFG_H ++#define _MTACFG_H ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#include ++#include ++#include ++ ++#define MTA_VERSION_INFO "1.0" ++ ++#if ( defined(IP_MGCP) || defined(IP_H323) || defined(IP_SIP) || defined(IP_MEGACO) ) ++#define VOIP ++#endif ++ ++#ifndef VOIP ++#define ENDPOINT_NULL_SHIM ++#endif ++ ++ ++/*************************************************************** ++** Task Priority options ++****************************************************************/ ++ ++#define RTP_TASK_PRIORITY BCMOS_TASK_PRTY_8 /* task priority for rtp */ ++#define HGCP_TASK_PRIORITY BCMOS_TASK_PRTY_8 /* task priority for HGCP */ ++#define RTCP_TASK_PRIORITY BCMOS_TASK_PRTY_13 /* task priority for rtcp */ ++ ++ ++/* Additional DSL specific definitions not provided by Cable Cfg files */ ++ ++/* For backward compatibility with older code */ ++#define MAX_ENDPT VOCM_CFG_MAX_ENDPT ++#define MAX_CNX VOCM_CFG_MAX_CNX ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif /* MTACFG_H */ ++ ++ ++ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/profdrv.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/profdrv.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/profdrv.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/profdrv.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,151 @@ ++/*************************************************************************** ++* Copyright 2004 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16215 Alton Parkway ++* P.O. Box 57013 ++* Irvine, California 92619-7013 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: profdrv.h ++* ++**************************************************************************** ++* Description: ++* ++* This file contains the profiler device driver ++* ++****************************************************************************/ ++#ifndef PROFDRV_DEVICE_DRIVER__H__INCLUDED ++#define PROFDRV_DEVICE_DRIVER__H__INCLUDED ++ ++#include ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#define PROFILER_NAME_MAX_LENGTH 32 ++#define PROFILER_MAX_RECSEQ 2048 ++ ++#define PROFILER_CPU_UTIL_VALID_START 0x01 ++#define PROFILER_CPU_UTIL_VALID_STOP 0x02 ++ ++#define PROFILER_SOURCE_USER 0x00 ++#define PROFILER_SOURCE_KERNEL 0x01 ++ ++#ifndef __STR ++#define __STR(x) #x ++#endif ++#ifndef STR ++#define STR(x) __STR(x) ++#endif ++ ++#define profdrv_read_32bit_cp0_register(source) \ ++({ int __res; \ ++ __asm__ __volatile__( \ ++ ".set\tpush\n\t" \ ++ ".set\treorder\n\t" \ ++ "mfc0\t%0,"STR(source)"\n\t" \ ++ ".set\tpop" \ ++ : "=r" (__res)); \ ++ __res;}) ++ ++/* ++ Structure used to pass profiling information data at the user/kernel interface. ++*/ ++typedef struct ++{ ++ char name[PROFILER_NAME_MAX_LENGTH]; ++ ++} PROFILER_IOCTL_DATA; ++ ++/* ++ This structure is used to keep track of the CPU utilization during the profiling period. ++*/ ++typedef struct ++{ ++ unsigned tick_uptime_start; ++ unsigned tick_idle_start; ++ unsigned tick_user_start; ++ unsigned tick_kernel_start; ++ unsigned tick_uptime_stop; ++ unsigned tick_idle_stop; ++ unsigned tick_user_stop; ++ unsigned tick_kernel_stop; ++ unsigned char valid_data; ++ ++} PROFILER_CPU_UTILIZATION; ++ ++/* ++ A generic structure to pass information about the profiler status. ++*/ ++typedef struct ++{ ++ unsigned status; ++ unsigned cpu_jiffies_start; ++ unsigned cpu_jiffies_stop; ++ unsigned cpu_jiffies_factor; ++ unsigned cpu_clock; ++ ++} PROFILER_STATUS; ++ ++/* ++ The ioctl action index. ++*/ ++typedef enum ++{ ++ PROFILER_IOCTL_GET_DATA_DUMP_INDEX, ++ PROFILER_IOCTL_GET_RECSEQ_DATA_DUMP_INDEX, ++ PROFILER_IOCTL_SET_DATA_CLEAN_INDEX, ++ PROFILER_IOCTL_SET_PROF_OPS_INDEX, ++ PROFILER_IOCTL_REGISTER_CALL_INDEX, ++ PROFILER_IOCTL_DEREGISTER_CALL_INDEX, ++ PROFILER_IOCTL_START_CALL_INDEX, ++ PROFILER_IOCTL_STOP_CALL_INDEX, ++ PROFILER_IOCTL_PROFILER_STATUS_INDEX, ++ PROFILER_IOCTL_SET_CPU_UTIL_INDEX, ++ PROFILER_IOCTL_GET_CPU_UTIL_INDEX, ++ PROFILER_IOCTL_GET_RECSEQ_DI_INDEX ++ ++} PROFILER_IOCTL_INDEX; ++ ++/* ++ Assigning a device driver major number for the sake of making this application work ++*/ ++#define PROFDRV_DEVICE_DRIVER_MAJOR 224 ++ ++#define PROFILER_IOCTL_GET_DATA_DUMP \ ++ _IOR( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_GET_DATA_DUMP_INDEX, unsigned ) ++#define PROFILER_IOCTL_GET_RECSEQ_DATA_DUMP \ ++ _IOR( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_GET_RECSEQ_DATA_DUMP_INDEX, unsigned ) ++#define PROFILER_IOCTL_SET_DATA_CLEAN \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_SET_DATA_CLEAN_INDEX, unsigned ) ++#define PROFILER_IOCTL_SET_PROF_OPS \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_SET_PROF_OPS_INDEX, unsigned ) ++#define PROFILER_IOCTL_REGISTER_CALL \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_REGISTER_CALL_INDEX, PROFILER_IOCTL_DATA ) ++#define PROFILER_IOCTL_DEREGISTER_CALL \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_DEREGISTER_CALL_INDEX, PROFILER_IOCTL_DATA ) ++#define PROFILER_IOCTL_START_CALL \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_START_CALL_INDEX, PROFILER_IOCTL_DATA ) ++#define PROFILER_IOCTL_STOP_CALL \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_STOP_CALL_INDEX, PROFILER_IOCTL_DATA ) ++#define PROFILER_IOCTL_PROFILER_STATUS_DATA \ ++ _IOR( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_PROFILER_STATUS_INDEX, PROFILER_STATUS ) ++#define PROFILER_IOCTL_SET_CPU_UTIL \ ++ _IOW( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_SET_CPU_UTIL_INDEX, PROFILER_CPU_UTILIZATION ) ++#define PROFILER_IOCTL_GET_CPU_UTIL \ ++ _IOR( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_GET_CPU_UTIL_INDEX, PROFILER_CPU_UTILIZATION ) ++#define PROFILER_IOCTL_GET_RECSEQ_DATA_INDEX \ ++ _IOR( PROFDRV_DEVICE_DRIVER_MAJOR, PROFILER_IOCTL_GET_RECSEQ_DI_INDEX, unsigned ) ++ ++#ifdef __cplusplus ++} ++#endif ++ ++#endif /* PROFDRV_DEVICE_DRIVER__H__INCLUDED */ +diff -urN linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/profiler.h linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/profiler.h +--- linux-2.6.8.1/bcmdrivers/broadcom/include/bcm963xx/profiler.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/broadcom/include/bcm963xx/profiler.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,114 @@ ++/*************************************************************************** ++* Copyright 2004 Broadcom Corporation ++* All Rights Reserved ++* No portions of this material may be reproduced in any form without the ++* written permission of: ++* Broadcom Corporation ++* 16215 Alton Parkway ++* P.O. Box 57013 ++* Irvine, California 92619-7013 ++* All information contained in this document is Broadcom Corporation ++* company private, proprietary, and trade secret. ++* ++**************************************************************************** ++* ++* Filename: profiler.h ++* ++**************************************************************************** ++* Description: ++* ++* This file contains the API definition for usage of the profiler tool ++* ++****************************************************************************/ ++#ifndef PROFILER__H__INCLUDED ++#define PROFILER__H__INCLUDED ++ ++#include "profdrv.h" ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#define PROFILER_MAX_MONITORED_PROFILE 32 ++#define PROFILER_CPU_UTILIZATION_MIN 0.000001 ++#define PROFILER_MISC_STRING_LENGTH 256 ++#define PROFILER_CPU_TICK_FACTOR 2.0 ++#define PROFILER_S2MS_FACTOR 1000.0 ++ ++#define PROFILER_FLAG_RESOURCE_FREE 0x00 ++#define PROFILER_FLAG_RESOURCE_ALLOCATED 0x01 ++#define PROFILER_FLAG_RESOURCE_ERROR 0x02 ++#define PROFILER_FLAG_RESOURCE_COLLECT_PENDING 0x04 ++ ++/* ++ This structure defines the data collected by the profiler. ++*/ ++typedef struct ++{ ++ unsigned char source; /* User or Kernel */ ++ unsigned char flag; /* Generic flag */ ++ char name[PROFILER_NAME_MAX_LENGTH]; /* Name of the function monitored */ ++ unsigned int now_cycle; /* The current cycle count saved */ ++ unsigned int min_cycle; /* The minimum number of cycles calculated for this function */ ++ unsigned int max_cycle; /* The maximum number of cycles calculated for this function */ ++ unsigned int avg_cycle; /* The average numnber of cycles calculated for this function */ ++ unsigned int count; /* The number of time this function has been profiled */ ++ ++} PROFILER_COLLECTED_DATA; ++ ++ ++/* ++ This structure defines the recorded sequence data collected by the profiler. ++*/ ++typedef struct PROFILER_RECSEQ_DATA ++{ ++ unsigned int id; ++ unsigned long startTime; ++ unsigned long endTime; ++} PROFILER_RECSEQ_DATA; ++ ++ ++void kernel_profiler_register( char *pName, unsigned char src ); ++void kernel_profiler_deregister( char *pName, unsigned char src ); ++void kernel_profiler_start( char *pName, unsigned char src ); ++void kernel_profiler_stop( char *pName, unsigned char src ); ++void kernel_profiler_recseq_start( unsigned int id ); ++void kernel_profiler_recseq_stop( unsigned int id ); ++ ++void kernel_profiler_reinit_collected( void ); ++void kernel_profiler_dump( void ); ++void kernel_profiler_recseq_dump( void ); ++void kernel_profiler_start_collect( void ); ++void kernel_profiler_stop_collect( void ); ++ ++ ++void profiler_init( void ); ++void profiler_get_status( PROFILER_STATUS *pStatus ); ++PROFILER_COLLECTED_DATA *profiler_get_data_dump( void ); ++PROFILER_RECSEQ_DATA* profiler_get_recseq_data_dump( void ); ++void profiler_get_cpu_util( PROFILER_CPU_UTILIZATION *pData ); ++void profiler_set_cpu_util( PROFILER_CPU_UTILIZATION *pData ); ++unsigned int profiler_get_recseq_data_index( void ); ++ ++/* ++ This is the generic API that should be used by clients to access the profiler ++*/ ++#define PROFILER_REGISTER( name ) ( kernel_profiler_register( (name), PROFILER_SOURCE_KERNEL ) ) ++#define PROFILER_DEREGISTER( name ) ( kernel_profiler_deregister( (name), PROFILER_SOURCE_KERNEL ) ) ++#define PROFILER_START( name ) ( kernel_profiler_start( (name), PROFILER_SOURCE_KERNEL ) ) ++#define PROFILER_STOP( name ) ( kernel_profiler_stop( (name), PROFILER_SOURCE_KERNEL ) ) ++#define PROFILER_RECSEQ_START( source ) ( kernel_profiler_recseq_start( (source) ) ) ++#define PROFILER_RECSEQ_STOP( source ) ( kernel_profiler_recseq_stop( (source)) ) ++ ++#define PROFILER_REINIT_COLLECTED() ( kernel_profiler_reinit_collected() ) ++#define PROFILER_DUMP() ( kernel_profiler_dump() ) ++#define PROFILER_RECSEQ_DUMP() ( kernel_profiler_recseq_dump() ) ++#define PROFILER_START_COLLECT() ( kernel_profiler_start_collect() ) ++#define PROFILER_STOP_COLLECT() ( kernel_profiler_stop_collect() ) ++ ++ ++#ifdef __cplusplus ++} ++#endif ++ ++#endif /* PROFILER__H__INCLUDED */ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/Makefile +--- linux-2.6.8.1/bcmdrivers/opensource/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,26 @@ ++# File: modules/drivers/Makefile ++# ++# Makefile for the GPLed Linux kernel modules. ++# ++BRCM_BOARD:=bcm963xx ++BRCM_CHIP:=6348 ++LN_NAME=bcm9$(BRCM_CHIP) ++LN_DRIVER_DIRS = ++ ++-include $(KERNEL_DIR)/.config ++ ++ifneq ($(CONFIG_BCM_BOARD),) ++ LN_DRIVER_DIRS +=ln -sn impl$(CONFIG_BCM_BOARD_IMPL) char/board/$(BRCM_BOARD)/$(LN_NAME); ++endif ++ ++ifneq ($(CONFIG_BCM_SERIAL),) ++ LN_DRIVER_DIRS +=ln -sn impl$(CONFIG_BCM_SERIAL_IMPL) char/serial/$(LN_NAME); ++endif ++ ++obj-$(CONFIG_BCM_BOARD) += char/board/$(BRCM_BOARD)/$(LN_NAME)/ ++obj-$(CONFIG_BCM_SERIAL) += char/serial/$(LN_NAME)/ ++ ++ ++symlinks: ++ find . -lname "*" -name "$(LN_NAME)" -print -exec rm -f "{}" ";" ++ $(CONFIG_SHELL) -c "$(LN_DRIVER_DIRS)" +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/Makefile +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,17 @@ ++# Makefile for the bcm963xx board drivers ++# ++ ++ ++obj-y := board.o cfiflash.o bcm63xx_flash.o bcm63xx_led.o ++ ++EXTRA_CFLAGS += -I. -I$(INC_BRCMBOARDPARMS_PATH)/$(BRCM_BOARD) -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++ ++ifeq ($(strip $(WIRELESS)),1) ++ EXTRA_CFLAGS += -DWIRELESS ++endif ++ ++-include $(TOPDIR)/Rules.make ++ ++clean: ++ rm -f core *.o *.a *.s ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_flash.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_flash.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_flash.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_flash.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,775 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ *************************************************************************** ++ * File Name : bcm63xx_flash.c ++ * ++ * Description: This file contains the flash device driver APIs for bcm63xx board. ++ * ++ * Created on : 8/10/2002 seanl: use cfiflash.c, cfliflash.h (AMD specific) ++ * ++ ***************************************************************************/ ++ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#define BCMTAG_EXE_USE ++#include ++#include "cfiflash.h" ++#include "boardparms.h" ++ ++//#define DEBUG_FLASH ++ ++static FLASH_ADDR_INFO fInfo; ++static int flashInitialized = 0; ++ ++void *retriedKmalloc(size_t size) ++{ ++ void *pBuf; ++ int tryCount = 0; ++ ++ // try 1000 times before quit ++ while (((pBuf = kmalloc(size, GFP_KERNEL)) == NULL) && (tryCount++ < 1000)) ++ { ++ current->state = TASK_INTERRUPTIBLE; ++ schedule_timeout(HZ/10); ++ } ++ if (tryCount >= 1000) ++ pBuf = NULL; ++ else ++ memset(pBuf, 0, size); ++ ++ return pBuf; ++} ++ ++void retriedKfree(void *pBuf) ++{ ++ kfree(pBuf); ++} ++ ++/*************************************************************************** ++// Function Name: getCrc32 ++// Description : caculate the CRC 32 of the given data. ++// Parameters : pdata - array of data. ++// size - number of input data bytes. ++// crc - either CRC32_INIT_VALUE or previous return value. ++// Returns : crc. ++****************************************************************************/ ++UINT32 getCrc32(byte *pdata, UINT32 size, UINT32 crc) ++{ ++ while (size-- > 0) ++ crc = (crc >> 8) ^ Crc32_table[(crc ^ *pdata++) & 0xff]; ++ ++ return crc; ++} ++ ++// get the nvram start addr ++// ++unsigned long get_nvram_start_addr(void) ++{ ++ return ((unsigned long) ++ (flash_get_memptr(fInfo.flash_nvram_start_blk) + fInfo.flash_nvram_blk_offset)); ++} ++ ++// get the scratch_pad start addr ++// ++unsigned long get_scratch_pad_start_addr(void) ++{ ++ return ((unsigned long) ++ (flash_get_memptr(fInfo.flash_scratch_pad_start_blk) + fInfo.flash_scratch_pad_blk_offset)); ++} ++ ++ ++ ++/* ********************************************************************* ++ * kerSysImageTagGet() ++ * Get the image tag ++ * Input parameters: ++ * none ++ * Return value: ++ * point to tag -- Found ++ * NULL -- failed ++ ********************************************************************* */ ++PFILE_TAG kerSysImageTagGet(void) ++{ ++ int i; ++ int totalBlks = flash_get_numsectors(); ++ UINT32 crc; ++ unsigned char *sectAddr; ++ PFILE_TAG pTag; ++ ++#if defined(DEBUG_FLASH) ++ printk("totalblks in tagGet=%d\n", totalBlks); ++#endif ++ ++ // start from 2nd blk, assume 1st one is always CFE ++ for (i = 1; i < totalBlks; i++) ++ { ++ sectAddr = flash_get_memptr((byte) i); ++ crc = CRC32_INIT_VALUE; ++ crc = getCrc32(sectAddr, (UINT32)TAG_LEN-TOKEN_LEN, crc); ++ pTag = (PFILE_TAG) sectAddr; ++ ++#if defined(DEBUG_FLASH) ++ printk("Check Tag crc on blk [%d]\n", i); ++#endif ++ ++ if (crc == (UINT32)(*(UINT32*)(pTag->tagValidationToken))) ++ return pTag; ++ } ++ ++ return (PFILE_TAG) NULL; ++} ++ ++// Initialize the flash and fill out the fInfo structure ++void kerSysFlashInit( void ) ++{ ++ int i = 0; ++ int totalBlks = 0; ++ int totalSize = 0; ++ int startAddr = 0; ++ int usedBlkSize = 0; ++ NVRAM_DATA nvramData; ++ UINT32 crc = CRC32_INIT_VALUE, savedCrc; ++ PFILE_TAG pTag = NULL; ++ unsigned long kernelEndAddr = 0; ++ unsigned long spAddr = 0; ++ ++ if (flashInitialized) ++ return; ++ ++ flashInitialized = 1; ++ flash_init(); ++ ++ totalBlks = flash_get_numsectors(); ++ totalSize = flash_get_total_size(); ++ ++ printk("Total Flash size: %dK with %d sectors\n", totalSize/1024, totalBlks); ++ ++ /* nvram is always at the end of flash */ ++ fInfo.flash_nvram_length = FLASH45_LENGTH_NVRAM; ++ fInfo.flash_nvram_start_blk = 0; /* always the first block */ ++ fInfo.flash_nvram_number_blk = 1; /*always fits in the first block */ ++ fInfo.flash_nvram_blk_offset = NVRAM_DATA_OFFSET; ++ ++ // check nvram CRC ++ memcpy((char *)&nvramData, (char *)get_nvram_start_addr(), sizeof(NVRAM_DATA)); ++ savedCrc = nvramData.ulCheckSum; ++ nvramData.ulCheckSum = 0; ++ crc = getCrc32((char *)&nvramData, (UINT32) sizeof(NVRAM_DATA), crc); ++ ++ BpSetBoardId( nvramData.szBoardId ); ++ ++ fInfo.flash_persistent_length = NVRAM_PSI_DEFAULT; ++ if (savedCrc != crc) ++ { ++ printk("***Board is not initialized****: Using the default PSI size: %d\n", ++ fInfo.flash_persistent_length); ++ } ++ else ++ { ++ unsigned long ulPsiSize; ++ if( BpGetPsiSize( &ulPsiSize ) == BP_SUCCESS ) ++ fInfo.flash_persistent_length = ulPsiSize; ++ else ++ { ++ printk("***Board id is not set****: Using the default PSI size: %d\n", ++ fInfo.flash_persistent_length); ++ } ++ } ++ ++ fInfo.flash_persistent_length *= ONEK; ++ startAddr = totalSize - fInfo.flash_persistent_length; ++ fInfo.flash_persistent_start_blk = flash_get_blk(startAddr+FLASH_BASE_ADDR_REG); ++ fInfo.flash_persistent_number_blk = totalBlks - fInfo.flash_persistent_start_blk; ++ // save abs SP address (Scratch Pad). it is before PSI ++ spAddr = startAddr - SP_MAX_LEN ; ++ // find out the offset in the start_blk ++ usedBlkSize = 0; ++ for (i = fInfo.flash_persistent_start_blk; ++ i < (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk); i++) ++ { ++ usedBlkSize += flash_get_sector_size((byte) i); ++ } ++ fInfo.flash_persistent_blk_offset = usedBlkSize - fInfo.flash_persistent_length; ++ ++ // get the info for sp ++ if (!(pTag = kerSysImageTagGet())) ++ { ++ printk("Failed to read image tag from flash\n"); ++ return; ++ } ++ kernelEndAddr = (unsigned long) simple_strtoul(pTag->kernelAddress, NULL, 10) + \ ++ (unsigned long) simple_strtoul(pTag->kernelLen, NULL, 10); ++ ++ // make suer sp does not share kernel block ++ fInfo.flash_scratch_pad_start_blk = flash_get_blk(spAddr+FLASH_BASE_ADDR_REG); ++ if (fInfo.flash_scratch_pad_start_blk != flash_get_blk(kernelEndAddr)) ++ { ++ fInfo.flash_scratch_pad_length = SP_MAX_LEN; ++ if (fInfo.flash_persistent_start_blk == fInfo.flash_scratch_pad_start_blk) // share blk ++ { ++#if 1 /* do not used scratch pad unless it's in its own sector */ ++ printk("Scratch pad is not used for this flash part.\n"); ++ fInfo.flash_scratch_pad_length = 0; // no sp ++#else /* allow scratch pad to share a sector with another section such as PSI */ ++ fInfo.flash_scratch_pad_number_blk = 1; ++ fInfo.flash_scratch_pad_blk_offset = fInfo.flash_persistent_blk_offset - fInfo.flash_scratch_pad_length; ++#endif ++ } ++ else // on different blk ++ { ++ fInfo.flash_scratch_pad_number_blk = fInfo.flash_persistent_start_blk\ ++ - fInfo.flash_scratch_pad_start_blk; ++ // find out the offset in the start_blk ++ usedBlkSize = 0; ++ for (i = fInfo.flash_scratch_pad_start_blk; ++ i < (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk); i++) ++ usedBlkSize += flash_get_sector_size((byte) i); ++ fInfo.flash_scratch_pad_blk_offset = usedBlkSize - fInfo.flash_scratch_pad_length; ++ } ++ } ++ else ++ { ++ printk("No flash for scratch pad!\n"); ++ fInfo.flash_scratch_pad_length = 0; // no sp ++ } ++ ++#if defined(DEBUG_FLASH) ++ printk("fInfo.flash_scratch_pad_start_blk = %d\n", fInfo.flash_scratch_pad_start_blk); ++ printk("fInfo.flash_scratch_pad_number_blk = %d\n", fInfo.flash_scratch_pad_number_blk); ++ printk("fInfo.flash_scratch_pad_length = 0x%x\n", fInfo.flash_scratch_pad_length); ++ printk("fInfo.flash_scratch_pad_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_scratch_pad_blk_offset); ++ ++ printk("fInfo.flash_nvram_start_blk = %d\n", fInfo.flash_nvram_start_blk); ++ printk("fInfo.flash_nvram_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_nvram_blk_offset); ++ printk("fInfo.flash_nvram_number_blk = %d\n", fInfo.flash_nvram_number_blk); ++ ++ printk("psi startAddr = %x\n", startAddr+FLASH_BASE_ADDR_REG); ++ printk("fInfo.flash_persistent_start_blk = %d\n", fInfo.flash_persistent_start_blk); ++ printk("fInfo.flash_persistent_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_persistent_blk_offset); ++ printk("fInfo.flash_persistent_number_blk = %d\n", fInfo.flash_persistent_number_blk); ++#endif ++ ++} ++ ++ ++ ++/*********************************************************************** ++ * Function Name: kerSysFlashAddrInfoGet ++ * Description : Fills in a structure with information about the NVRAM ++ * and persistent storage sections of flash memory. ++ * Fro physmap.c to mount the fs vol. ++ * Returns : None. ++ ***********************************************************************/ ++void kerSysFlashAddrInfoGet(PFLASH_ADDR_INFO pflash_addr_info) ++{ ++ pflash_addr_info->flash_nvram_blk_offset = fInfo.flash_nvram_blk_offset; ++ pflash_addr_info->flash_nvram_length = fInfo.flash_nvram_length; ++ pflash_addr_info->flash_nvram_number_blk = fInfo.flash_nvram_number_blk; ++ pflash_addr_info->flash_nvram_start_blk = fInfo.flash_nvram_start_blk; ++ pflash_addr_info->flash_persistent_blk_offset = fInfo.flash_persistent_blk_offset; ++ pflash_addr_info->flash_persistent_length = fInfo.flash_persistent_length; ++ pflash_addr_info->flash_persistent_number_blk = fInfo.flash_persistent_number_blk; ++ pflash_addr_info->flash_persistent_start_blk = fInfo.flash_persistent_start_blk; ++} ++ ++ ++// get shared blks into *** pTempBuf *** which has to be released bye the caller! ++// return: if pTempBuf != NULL, poits to the data with the dataSize of the buffer ++// !NULL -- ok ++// NULL -- fail ++static char *getSharedBlks(int start_blk, int end_blk) ++{ ++ int i = 0; ++ int usedBlkSize = 0; ++ int sect_size = 0; ++ char *pTempBuf = NULL; ++ char *pBuf = NULL; ++ ++ for (i = start_blk; i < end_blk; i++) ++ usedBlkSize += flash_get_sector_size((byte) i); ++ ++#if defined(DEBUG_FLASH) ++ printk("usedBlkSize = %d\n", usedBlkSize); ++#endif ++ ++ if ((pTempBuf = (char *) retriedKmalloc(usedBlkSize)) == NULL) ++ { ++ printk("failed to allocate memory with size: %d\n", usedBlkSize); ++ return pTempBuf; ++ } ++ ++ pBuf = pTempBuf; ++ for (i = start_blk; i < end_blk; i++) ++ { ++ sect_size = flash_get_sector_size((byte) i); ++ ++#if defined(DEBUG_FLASH) ++ printk("i = %d, sect_size = %d, end_blk = %d\n", i, sect_size, end_blk); ++#endif ++ flash_read_buf((byte)i, 0, pBuf, sect_size); ++ pBuf += sect_size; ++ } ++ ++ return pTempBuf; ++} ++ ++ ++ ++// Set the pTempBuf to flash from start_blk to end_blk ++// return: ++// 0 -- ok ++// -1 -- fail ++static int setSharedBlks(int start_blk, int end_blk, char *pTempBuf) ++{ ++ int i = 0; ++ int sect_size = 0; ++ int sts = 0; ++ char *pBuf = pTempBuf; ++ ++ for (i = start_blk; i < end_blk; i++) ++ { ++ sect_size = flash_get_sector_size((byte) i); ++ flash_sector_erase_int(i); ++ if (flash_write_buf(i, 0, pBuf, sect_size) != sect_size) ++ { ++ printk("Error writing flash sector %d.", i); ++ sts = -1; ++ break; ++ } ++ pBuf += sect_size; ++ } ++ ++ return sts; ++} ++ ++ ++ ++/******************************************************************************* ++ * NVRAM functions ++ *******************************************************************************/ ++ ++// get nvram data ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysNvRamGet(char *string, int strLen, int offset) ++{ ++ char *pBuf = NULL; ++ ++ if (!flashInitialized) ++ kerSysFlashInit(); ++ ++ if (strLen > FLASH45_LENGTH_NVRAM) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_start_blk + fInfo.flash_nvram_number_blk))) == NULL) ++ return -1; ++ ++ // get string off the memory buffer ++ memcpy(string, (pBuf + fInfo.flash_nvram_blk_offset + offset), strLen); ++ ++ retriedKfree(pBuf); ++ ++ return 0; ++} ++ ++ ++// set nvram ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysNvRamSet(char *string, int strLen, int offset) ++{ ++ int sts = 0; ++ char *pBuf = NULL; ++ ++ if (strLen > FLASH45_LENGTH_NVRAM) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_start_blk + fInfo.flash_nvram_number_blk))) == NULL) ++ return -1; ++ ++ // set string to the memory buffer ++ memcpy((pBuf + fInfo.flash_nvram_blk_offset + offset), string, strLen); ++ ++ if (setSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_number_blk + fInfo.flash_nvram_start_blk), pBuf) != 0) ++ sts = -1; ++ ++ retriedKfree(pBuf); ++ ++ return sts; ++} ++ ++ ++/*********************************************************************** ++ * Function Name: kerSysEraseNvRam ++ * Description : Erase the NVRAM storage section of flash memory. ++ * Returns : 1 -- ok, 0 -- fail ++ ***********************************************************************/ ++int kerSysEraseNvRam(void) ++{ ++ int sts = 1; ++ char *tempStorage = retriedKmalloc(FLASH45_LENGTH_NVRAM); ++ ++ // just write the whole buf with '0xff' to the flash ++ if (!tempStorage) ++ sts = 0; ++ else ++ { ++ memset(tempStorage, 0xff, FLASH45_LENGTH_NVRAM); ++ if (kerSysNvRamSet(tempStorage, FLASH45_LENGTH_NVRAM, 0) != 0) ++ sts = 0; ++ retriedKfree(tempStorage); ++ } ++ ++ return sts; ++} ++ ++ ++/******************************************************************************* ++ * PSI functions ++ *******************************************************************************/ ++// get psi data ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysPersistentGet(char *string, int strLen, int offset) ++{ ++ char *pBuf = NULL; ++ ++ if (strLen > fInfo.flash_persistent_length) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk))) == NULL) ++ return -1; ++ ++ // get string off the memory buffer ++ memcpy(string, (pBuf + fInfo.flash_persistent_blk_offset + offset), strLen); ++ ++ retriedKfree(pBuf); ++ ++ return 0; ++} ++ ++ ++// set psi ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysPersistentSet(char *string, int strLen, int offset) ++{ ++ int sts = 0; ++ char *pBuf = NULL; ++ ++ if (strLen > fInfo.flash_persistent_length) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk))) == NULL) ++ return -1; ++ ++ // set string to the memory buffer ++ memcpy((pBuf + fInfo.flash_persistent_blk_offset + offset), string, strLen); ++ ++ if (setSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_number_blk + fInfo.flash_persistent_start_blk), pBuf) != 0) ++ sts = -1; ++ ++ retriedKfree(pBuf); ++ ++ return sts; ++} ++ ++ ++// flash bcm image ++// return: ++// 0 - ok ++// !0 - the sector number fail to be flashed (should not be 0) ++int kerSysBcmImageSet( int flash_start_addr, char *string, int size) ++{ ++ int sts; ++ int sect_size; ++ int blk_start; ++ int i; ++ char *pTempBuf = NULL; ++ int whole_image = 0; ++ ++ blk_start = flash_get_blk(flash_start_addr); ++ if( blk_start < 0 ) ++ return( -1 ); ++ ++ if (flash_start_addr == FLASH_BASE && size > FLASH45_LENGTH_BOOT_ROM) ++ whole_image = 1; ++ ++ /* write image to flash memory */ ++ do ++ { ++ sect_size = flash_get_sector_size(blk_start); ++// NOTE: for memory problem in multiple PVC configuration, temporary get rid of kmalloc this 64K for now. ++// if ((pTempBuf = (char *)retriedKmalloc(sect_size)) == NULL) ++// { ++// printk("Failed to allocate memory with size: %d. Reset the router...\n", sect_size); ++// kerSysMipsSoftReset(); // reset the board right away. ++// } ++ // for whole image, no check on psi ++ if (!whole_image && blk_start == fInfo.flash_persistent_start_blk) // share the blk with psi ++ { ++ if (size > (sect_size - fInfo.flash_persistent_length)) ++ { ++ printk("Image is too big\n"); ++ break; // image is too big. Can not overwrite to nvram ++ } ++ if ((pTempBuf = (char *)retriedKmalloc(sect_size)) == NULL) ++ { ++ printk("Failed to allocate memory with size: %d. Reset the router...\n", sect_size); ++ kerSysMipsSoftReset(); // reset the board right away. ++ } ++ flash_read_buf((byte)blk_start, 0, pTempBuf, sect_size); ++ if (copy_from_user((void *)pTempBuf,(void *)string, size) != 0) ++ break; // failed ? ++ flash_sector_erase_int(blk_start); // erase blk before flash ++ if (flash_write_buf(blk_start, 0, pTempBuf, sect_size) == sect_size) ++ size = 0; // break out and say all is ok ++ retriedKfree(pTempBuf); ++ break; ++ } ++ ++ flash_sector_erase_int(blk_start); // erase blk before flash ++ ++ if (sect_size > size) ++ { ++ if (size & 1) ++ size++; ++ sect_size = size; ++ } ++ ++ if ((i = flash_write_buf(blk_start, 0, string, sect_size)) != sect_size) { ++ break; ++ } ++ blk_start++; ++ string += sect_size; ++ size -= sect_size; ++ } while (size > 0); ++ ++ if (whole_image) ++ { ++ // If flashing a whole image, erase to end of flash. ++ int total_blks = flash_get_numsectors(); ++ while( blk_start < total_blks ) ++ { ++ flash_sector_erase_int(blk_start); ++ blk_start++; ++ } ++ } ++ if (pTempBuf) ++ retriedKfree(pTempBuf); ++ ++ if( size == 0 ) ++ sts = 0; // ok ++ else ++ sts = blk_start; // failed to flash this sector ++ ++ return sts; ++} ++ ++/******************************************************************************* ++ * SP functions ++ *******************************************************************************/ ++// get sp data. NOTE: memcpy work here -- not using copy_from/to_user ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysScratchPadGet(char *tokenId, char *tokBuf, int bufLen) ++{ ++ PSP_HEADER pHead = NULL; ++ PSP_TOKEN pToken = NULL; ++ char *pBuf = NULL; ++ char *pShareBuf = NULL; ++ char *startPtr = NULL; ++ char *endPtr = NULL; ++ char *spEndPtr = NULL; ++ int sts = -1; ++ ++ if (fInfo.flash_scratch_pad_length == 0) ++ return sts; ++ ++ if (bufLen >= (fInfo.flash_scratch_pad_length - sizeof(SP_HEADER) - sizeof(SP_TOKEN))) ++ { ++ printk("Exceed scratch pad space by %d\n", bufLen - fInfo.flash_scratch_pad_length \ ++ - sizeof(SP_HEADER) - sizeof(SP_TOKEN)); ++ return sts; ++ } ++ ++ if ((pShareBuf = getSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk))) == NULL) ++ return sts; ++ ++ // pBuf points to SP buf ++ pBuf = pShareBuf + fInfo.flash_scratch_pad_blk_offset; ++ ++ pHead = (PSP_HEADER) pBuf; ++ if (memcmp(pHead->SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN) != 0) ++ { ++ printk("Scrap pad is not initialized.\n"); ++ return sts; ++ } ++ ++ // search up to SPUsedLen for the token ++ startPtr = pBuf + sizeof(SP_HEADER); ++ endPtr = pBuf + pHead->SPUsedLen; ++ spEndPtr = pBuf + SP_MAX_LEN; ++ while (startPtr < endPtr && startPtr < spEndPtr) ++ { ++ pToken = (PSP_TOKEN) startPtr; ++ if (strncmp(pToken->tokenName, tokenId, TOKEN_NAME_LEN) == 0) ++ { ++ memcpy(tokBuf, startPtr + sizeof(SP_TOKEN), bufLen); ++ sts = 0; ++ break; ++ } ++ // get next token ++ startPtr += sizeof(SP_TOKEN) + pToken->tokenLen; ++ } ++ ++ retriedKfree(pShareBuf); ++ ++ return sts; ++} ++ ++ ++// set sp. NOTE: memcpy work here -- not using copy_from/to_user ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysScratchPadSet(char *tokenId, char *tokBuf, int bufLen) ++{ ++ PSP_TOKEN pToken = NULL; ++ PSP_HEADER pHead = NULL; ++ char *pShareBuf = NULL; ++ char *pBuf = NULL; ++ SP_HEADER SPHead; ++ SP_TOKEN SPToken; ++ char *curPtr; ++ int sts = -1; ++ ++ if (fInfo.flash_scratch_pad_length == 0) ++ return sts; ++ ++ if (bufLen >= (fInfo.flash_scratch_pad_length - sizeof(SP_HEADER) - sizeof(SP_TOKEN))) ++ { ++ printk("Exceed scratch pad space by %d\n", bufLen - fInfo.flash_scratch_pad_length \ ++ - sizeof(SP_HEADER) - sizeof(SP_TOKEN)); ++ return sts; ++ } ++ ++ if ((pShareBuf = getSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk))) == NULL) ++ return sts; ++ ++ // pBuf points to SP buf ++ pBuf = pShareBuf + fInfo.flash_scratch_pad_blk_offset; ++ pHead = (PSP_HEADER) pBuf; ++ ++ // form header info. SPUsedLen later on... ++ memset((char *)&SPHead, 0, sizeof(SP_HEADER)); ++ memcpy(SPHead.SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN); ++ SPHead.SPVersion = SP_VERSION; ++ ++ // form token info. ++ memset((char*)&SPToken, 0, sizeof(SP_TOKEN)); ++ strncpy(SPToken.tokenName, tokenId, TOKEN_NAME_LEN - 1); ++ SPToken.tokenLen = bufLen; ++ if (memcmp(pHead->SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN) != 0) ++ { ++ // new sp, so just flash the token ++ printk("No Scrap pad found. Initialize scratch pad...\n"); ++ SPHead.SPUsedLen = sizeof(SP_HEADER) + sizeof(SP_TOKEN) + bufLen; ++ memcpy(pBuf, (char *)&SPHead, sizeof(SP_HEADER)); ++ curPtr = pBuf + sizeof(SP_HEADER); ++ memcpy(curPtr, (char *)&SPToken, sizeof(SP_TOKEN)); ++ curPtr += sizeof(SP_TOKEN); ++ memcpy(curPtr, tokBuf, bufLen); ++ } ++ else ++ { ++ // need search for the token, if exist with same size overwrite it. if sizes differ, ++ // move over the later token data over and put the new one at the end ++ char *endPtr = pBuf + pHead->SPUsedLen; ++ char *spEndPtr = pBuf + SP_MAX_LEN; ++ curPtr = pBuf + sizeof(SP_HEADER); ++ while (curPtr < endPtr && curPtr < spEndPtr) ++ { ++ pToken = (PSP_TOKEN) curPtr; ++ if (strncmp(pToken->tokenName, tokenId, TOKEN_NAME_LEN) == 0) ++ { ++ if (pToken->tokenLen == bufLen) // overwirte it ++ { ++ memcpy((curPtr+sizeof(SP_TOKEN)), tokBuf, bufLen); ++ break; ++ } ++ else // move later data over and put the new token at the end ++ { ++ memcpy((curPtr+sizeof(SP_TOKEN)), tokBuf, bufLen); // ~~~ ++ break; ++ } ++ } ++ else // not same token ~~~ ++ { ++ } ++ // get next token ++ curPtr += sizeof(SP_TOKEN) + pToken->tokenLen; ++ } // end while ++ SPHead.SPUsedLen = sizeof(SP_HEADER) + sizeof(SP_TOKEN) + bufLen; // ~~~ ++ if (SPHead.SPUsedLen > SP_MAX_LEN) ++ { ++ printk("No more Scratch pad space left! Over limit by %d bytes\n", SPHead.SPUsedLen - SP_MAX_LEN); ++ return sts; ++ } ++ ++ } // else if not new sp ++ ++ sts = setSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_number_blk + fInfo.flash_scratch_pad_start_blk), pShareBuf); ++ ++ retriedKfree(pShareBuf); ++ ++ return sts; ++ ++ ++} ++ ++int kerSysFlashSizeGet(void) ++{ ++ return flash_get_total_size(); ++} ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_led.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_led.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_led.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/bcm63xx_led.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,582 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/*************************************************************************** ++ * File Name : bcm63xx_led.c ++ * ++ * Description: ++ * ++ * This file contains bcm963xx board led control API functions. ++ * ++ * To use it, do the following ++ * ++ * 1). define in the board.c the following led mappping (this is for 6345GW board): ++ * const LED_MAP_PAIR cLedMapping45GW[] = ++ * { // led name Initial state physical pin (ledMask) ++ * {kLedUsb, kLedStateOff, GPIO_LED_PIN_7}, ++ * {kLedAdsl, kLedStateOff, GPIO_LED_PIN_8}, ++ * {kLedPPP, kLedStateOff, GPIO_LED_PIN_9}, // PPP and WanData share PIN_9 ++ * {kLedWanData, kLedStateOff, GPIO_LED_PIN_9}, ++ * {kLedWireless, kLedStateOff, GPIO_LED_PIN_10}, ++ * {kLedEnd, kLedStateOff, 0 } // NOTE: kLedEnd has to be at the end. ++ * ++ * 2). };To initialize led API and initial state of the leds, call the following function with the mapping ++ * pointer from the above struct ++ * ++ * boardLedInit((PLED_MAP_PAIR) &cLedMapping45R); ++ * ++ * 3). Sample call for kernel mode: ++ * ++ * kerSysLedCtrl(kLedAdsl, kLedStateBlinkOnce); // kLedxxx defines in board.h ++ * ++ * 4). Sample call for user mode ++ * ++ * sysLedCtrl(kLedAdsl, kLedStateBlinkOnce); // kLedxxx defines in board_api.h ++ * ++ * ++ * Created on : 10/28/2002 seanl ++ * ++ ***************************************************************************/ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++ ++#define k100ms (HZ / 10) // ~100 ms ++#define kFastBlinkCount 0 // ~100ms ++#define kSlowBlinkCount 5 // ~600ms ++ ++#define MAX_VIRT_LEDS 12 ++ ++// uncomment // for debug led ++//#define DEBUG_LED ++ ++// global variables: ++struct timer_list gLedTimer; ++int gTimerOn = FALSE; ++int gLedCount = 0; ++ ++typedef struct ledinfo ++{ ++ unsigned short ledMask; // mask for led: ie. giop 10 = 0x0400 ++ unsigned short ledActiveLow; // GPIO bit reset to turn on LED ++ unsigned short ledMaskFail; // mask for led: ie. giop 10 = 0x0400 ++ unsigned short ledActiveLowFail;// GPIO bit reset to turn on LED ++ BOARD_LED_STATE ledState; // current led state ++ BOARD_LED_STATE savedLedState; // used in blink once for restore to the orignal ledState ++ int blinkCountDown; // if == 0, do blink (toggle). Is assgined value and dec by 1 at each timer. ++} LED_INFO, *PLED_INFO; ++ ++static PLED_INFO gLed = NULL; ++static PLED_INFO gpVirtLeds[MAX_VIRT_LEDS]; ++static HANDLE_LED_FUNC gLedHwFunc[MAX_VIRT_LEDS]; ++static HANDLE_LED_FUNC gLedHwFailFunc[MAX_VIRT_LEDS]; ++ ++#if 0 /* BROKEN */ ++#if defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++static int gLedOffInBridgeMode = 1; ++#elif defined(CONFIG_BCM96345) ++static int gLedOffInBridgeMode = 0; ++#endif ++#endif ++ ++void ledTimerExpire(void); ++int initLedInfo( PLED_MAP_PAIR pCurMap, PLED_INFO pCurLed ); ++ ++//************************************************************************************** ++// LED operations ++//************************************************************************************** ++ ++// turn led on and set the ledState ++void ledOn(PLED_INFO pLed) ++{ ++ if( pLed->ledMask ) ++ { ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLow ) ++ GPIO->GPIOio &= ~pLed->ledMask; // turn on the led ++ else ++ GPIO->GPIOio |= pLed->ledMask; // turn on the led ++ pLed->ledState = pLed->savedLedState = kLedStateOn; ++ } ++} ++ ++ ++// turn led off and set the ledState ++void ledOff(PLED_INFO pLed) ++{ ++ if( pLed->ledMask ) ++ { ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLow ) ++ GPIO->GPIOio |= pLed->ledMask; // turn off the led ++ else ++ GPIO->GPIOio &= ~pLed->ledMask; // turn off the led ++ pLed->ledState = pLed->savedLedState = kLedStateOff; ++ } ++} ++ ++// turn led on and set the ledState ++void ledOnFail(PLED_INFO pLed) ++{ ++ if( pLed->ledMaskFail ) ++ { ++ GPIO->GPIODir |= pLed->ledMaskFail; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLowFail ) ++ GPIO->GPIOio &= ~pLed->ledMaskFail;// turn on the led ++ else ++ GPIO->GPIOio |= pLed->ledMaskFail; // turn on the led ++ pLed->ledState = pLed->savedLedState = kLedStateFail; ++ } ++} ++ ++ ++// turn led off and set the ledState ++void ledOffFail(PLED_INFO pLed) ++{ ++ if( pLed->ledMaskFail ) ++ { ++ GPIO->GPIODir |= pLed->ledMaskFail; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLowFail ) ++ GPIO->GPIOio |= pLed->ledMaskFail; // turn off the led ++ else ++ GPIO->GPIOio &= ~pLed->ledMaskFail;// turn off the led ++ pLed->ledState = pLed->savedLedState = kLedStateOff; ++ } ++} ++ ++ ++// toggle the led and return the current ledState ++BOARD_LED_STATE ledToggle(PLED_INFO pLed) ++{ ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if (GPIO->GPIOio & pLed->ledMask) ++ { ++ GPIO->GPIOio &= ~(pLed->ledMask); ++ return( (pLed->ledActiveLow) ? kLedStateOn : kLedStateOff ); ++ } ++ else ++ { ++ GPIO->GPIOio |= pLed->ledMask; ++ return( (pLed->ledActiveLow) ? kLedStateOff : kLedStateOn ); ++ } ++} ++ ++ ++// led timer. Will return if timer is already on ++void ledTimerStart(void) ++{ ++ if (gTimerOn) ++ return; ++ ++#if defined(DEBUG_LED) ++ printk("led: add_timer\n"); ++#endif ++ ++ init_timer(&gLedTimer); ++ gLedTimer.function = (void*)ledTimerExpire; ++ gLedTimer.expires = jiffies + k100ms; // timer expires in ~100ms ++ add_timer (&gLedTimer); ++ gTimerOn = TRUE; ++} ++ ++ ++// led timer expire kicks in about ~100ms and perform the led operation according to the ledState and ++// restart the timer according to ledState ++void ledTimerExpire(void) ++{ ++ int i; ++ PLED_INFO pCurLed; ++ ++ gTimerOn = FALSE; ++ ++ for (i = 0, pCurLed = gLed; i < gLedCount; i++, pCurLed++) ++ { ++#if defined(DEBUG_LED) ++ printk("led[%d]: Mask=0x%04x, State = %d, blcd=%d\n", i, pCurLed->ledMask, pCurLed->ledState, pCurLed->blinkCountDown); ++#endif ++ switch (pCurLed->ledState) ++ { ++ case kLedStateOn: ++ case kLedStateOff: ++ case kLedStateFail: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ break; ++ ++ case kLedStateBlinkOnce: ++ ledToggle(pCurLed); ++ pCurLed->blinkCountDown = 0; // reset to 0 ++ pCurLed->ledState = pCurLed->savedLedState; ++ if (pCurLed->ledState == kLedStateSlowBlinkContinues || ++ pCurLed->ledState == kLedStateFastBlinkContinues) ++ ledTimerStart(); // start timer if in blinkContinues stats ++ break; ++ ++ case kLedStateSlowBlinkContinues: ++ if (pCurLed->blinkCountDown-- == 0) ++ { ++ pCurLed->blinkCountDown = kSlowBlinkCount; ++ ledToggle(pCurLed); ++ } ++ ledTimerStart(); ++ break; ++ ++ case kLedStateFastBlinkContinues: ++ if (pCurLed->blinkCountDown-- == 0) ++ { ++ pCurLed->blinkCountDown = kFastBlinkCount; ++ ledToggle(pCurLed); ++ } ++ ledTimerStart(); ++ break; ++ ++ default: ++ printk("Invalid state = %d\n", pCurLed->ledState); ++ } ++ } ++} ++ ++// initialize the gLedCount and allocate and fill gLed struct ++void __init boardLedInit(PLED_MAP_PAIR cLedMapping) ++{ ++ PLED_MAP_PAIR p1, p2; ++ PLED_INFO pCurLed; ++ int needTimer = FALSE; ++ int alreadyUsed = 0; ++ ++#if defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++ /* Set blink rate for BCM6348/BCM6338 hardware LEDs. */ ++ GPIO->LEDCtrl &= ~LED_INTERVAL_SET_MASK; ++ GPIO->LEDCtrl |= LED_INTERVAL_SET_80MS; ++#endif ++ ++ memset( gpVirtLeds, 0x00, sizeof(gpVirtLeds) ); ++ memset( gLedHwFunc, 0x00, sizeof(gLedHwFunc) ); ++ memset( gLedHwFailFunc, 0x00, sizeof(gLedHwFailFunc) ); ++ ++ gLedCount = 0; ++ ++ // Check for multiple LED names and multiple LED GPIO pins that share the ++ // same physical board LED. ++ for( p1 = cLedMapping; p1->ledName != kLedEnd; p1++ ) ++ { ++ alreadyUsed = 0; ++ for( p2 = cLedMapping; p2 != p1; p2++ ) ++ { ++ if( (p1->ledMask && p1->ledMask == p2->ledMask) || ++ (p1->ledMaskFail && p1->ledMaskFail == p2->ledMaskFail) ) ++ { ++ alreadyUsed = 1; ++ break; ++ } ++ } ++ ++ if( alreadyUsed == 0 ) ++ gLedCount++; ++ } ++ ++ gLed = (PLED_INFO) kmalloc((gLedCount * sizeof(LED_INFO)), GFP_KERNEL); ++ if( gLed == NULL ) ++ { ++ printk( "LED memory allocation error.\n" ); ++ return; ++ } ++ ++ memset( gLed, 0x00, gLedCount * sizeof(LED_INFO) ); ++ ++ // initial the gLed with unique ledMask and initial state. If more than 1 ledNames share the physical led ++ // (ledMask) the first defined led's ledInitState will be used. ++ pCurLed = gLed; ++ for( p1 = cLedMapping; p1->ledName != kLedEnd; p1++ ) ++ { ++ if( (int) p1->ledName > MAX_VIRT_LEDS ) ++ continue; ++ ++ alreadyUsed = 0; ++ for( p2 = cLedMapping; p2 != p1; p2++ ) ++ { ++ if( (p1->ledMask && p1->ledMask == p2->ledMask) || ++ (p1->ledMaskFail && p1->ledMaskFail == p2->ledMaskFail) ) ++ { ++ alreadyUsed = 1; ++ break; ++ } ++ } ++ ++ if( alreadyUsed == 0 ) ++ { ++ // Initialize the board LED for the first time. ++ needTimer = initLedInfo( p1, pCurLed ); ++ gpVirtLeds[(int) p1->ledName] = pCurLed; ++ pCurLed++; ++ } ++ else ++ { ++ PLED_INFO pLed; ++ for( pLed = gLed; pLed != pCurLed; pLed++ ) ++ { ++ // Find the LED_INFO structure that has already been initialized. ++ if((pLed->ledMask && pLed->ledMask == p1->ledMask) || ++ (pLed->ledMaskFail && pLed->ledMaskFail==p1->ledMaskFail)) ++ { ++ // The board LED has already been initialized but possibly ++ // not completely initialized. ++ if( p1->ledMask ) ++ { ++ pLed->ledMask = p1->ledMask; ++ pLed->ledActiveLow = p1->ledActiveLow; ++ } ++ if( p1->ledMaskFail ) ++ { ++ pLed->ledMaskFail = p1->ledMaskFail; ++ pLed->ledActiveLowFail = p1->ledActiveLowFail; ++ } ++ gpVirtLeds[(int) p1->ledName] = pLed; ++ break; ++ } ++ } ++ } ++ } ++ ++ if (needTimer) ++ ledTimerStart(); ++ ++#if defined(DEBUG_LED) ++ int i; ++ for (i=0; i < gLedCount; i++) ++ printk("initLed: led[%d]: mask=0x%04x, state=%d\n", i,(gLed+i)->ledMask, (gLed+i)->ledState); ++#endif ++ ++} ++ ++// Initialize a structure that contains information about a physical board LED ++// control. The board LED may contain more than one GPIO pin to control a ++// normal condition (green) or a failure condition (red). ++int initLedInfo( PLED_MAP_PAIR pCurMap, PLED_INFO pCurLed ) ++{ ++ int needTimer = FALSE; ++ pCurLed->ledState = pCurLed->savedLedState = pCurMap->ledInitState; ++ pCurLed->ledMask = pCurMap->ledMask; ++ pCurLed->ledActiveLow = pCurMap->ledActiveLow; ++ pCurLed->ledMaskFail = pCurMap->ledMaskFail; ++ pCurLed->ledActiveLowFail = pCurMap->ledActiveLowFail; ++ ++ switch (pCurLed->ledState) ++ { ++ case kLedStateOn: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOn(pCurLed); ++ break; ++ case kLedStateOff: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOff(pCurLed); ++ break; ++ case kLedStateFail: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOnFail(pCurLed); ++ break; ++ case kLedStateBlinkOnce: ++ pCurLed->blinkCountDown = 1; ++ needTimer = TRUE; ++ break; ++ case kLedStateSlowBlinkContinues: ++ pCurLed->blinkCountDown = kSlowBlinkCount; ++ needTimer = TRUE; ++ break; ++ case kLedStateFastBlinkContinues: ++ pCurLed->blinkCountDown = kFastBlinkCount; ++ needTimer = TRUE; ++ break; ++ default: ++ printk("Invalid state = %d\n", pCurLed->ledState); ++ } ++ ++ return( needTimer ); ++} ++ ++#if 0 /* BROKEN */ ++// Determines if there is at least one interface in bridge mode. Bridge mode ++// is determined by the cfm convention of naming bridge interfaces nas17 ++// through nas24. ++static int isBridgedProtocol(void) ++{ ++ extern int dev_get(const char *name); ++ const int firstBridgeId = 17; ++ const int lastBridgeId = 24; ++ int i; ++ int ret = FALSE; ++ char name[16]; ++ ++ for( i = firstBridgeId; i <= lastBridgeId; i++ ) ++ { ++ sprintf( name, "nas%d", i ); ++ ++ if( dev_get(name) ) ++ { ++ ret = TRUE; ++ break; ++ } ++ } ++ ++ return(ret); ++} ++#endif ++ ++// led ctrl. Maps the ledName to the corresponding ledInfoPtr and perform the led operation ++void boardLedCtrl(BOARD_LED_NAME ledName, BOARD_LED_STATE ledState) ++{ ++ PLED_INFO ledInfoPtr; ++ ++ // do the mapping from virtual to physical led ++ if( (int) ledName < MAX_VIRT_LEDS ) ++ ledInfoPtr = gpVirtLeds[(int) ledName]; ++ else ++ ledInfoPtr = NULL; ++ ++ if (ledInfoPtr == NULL) ++ return; ++ ++ if( ledState != kLedStateFail && gLedHwFunc[(int) ledName] ) ++ { ++ (*gLedHwFunc[(int) ledName]) (ledName, ledState); ++ ledOffFail(ledInfoPtr); ++ return; ++ } ++ else ++ if( ledState == kLedStateFail && gLedHwFailFunc[(int) ledName] ) ++ { ++ (*gLedHwFailFunc[(int) ledName]) (ledName, ledState); ++ ledOff(ledInfoPtr); ++ return; ++ } ++ ++#if 0 /* BROKEN */ ++ // Do not blink the WAN Data LED if at least one interface is in bridge mode. ++ if(gLedOffInBridgeMode == 1 && (ledName == kLedWanData || ledName == kLedPPP)) ++ { ++ static int BridgedProtocol = -1; ++ ++ if( BridgedProtocol == -1 ) ++ BridgedProtocol = isBridgedProtocol(); ++ ++ if( BridgedProtocol == TRUE ) ++ return; ++ } ++#endif ++ ++ // If the state is kLedStateFail and there is not a failure LED defined ++ // in the board parameters, change the state to kLedStateFastBlinkContinues. ++ if( ledState == kLedStateFail && ledInfoPtr->ledMaskFail == 0 ) ++ ledState = kLedStateFastBlinkContinues; ++ ++ switch (ledState) ++ { ++ case kLedStateOn: ++ // First, turn off the complimentary (failure) LED GPIO. ++ if( ledInfoPtr->ledMaskFail ) ++ ledOffFail(ledInfoPtr); ++ else ++ if( gLedHwFailFunc[(int) ledName] ) ++ (*gLedHwFailFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn on the specified LED GPIO. ++ ledOn(ledInfoPtr); ++ break; ++ ++ case kLedStateOff: ++ // First, turn off the complimentary (failure) LED GPIO. ++ if( ledInfoPtr->ledMaskFail ) ++ ledOffFail(ledInfoPtr); ++ else ++ if( gLedHwFailFunc[(int) ledName] ) ++ (*gLedHwFailFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn off the specified LED GPIO. ++ ledOff(ledInfoPtr); ++ break; ++ ++ case kLedStateFail: ++ // First, turn off the complimentary (normal) LED GPIO. ++ if( ledInfoPtr->ledMask ) ++ ledOff(ledInfoPtr); ++ else ++ if( gLedHwFunc[(int) ledName] ) ++ (*gLedHwFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn on (red) the specified LED GPIO. ++ ledOnFail(ledInfoPtr); ++ break; ++ ++ case kLedStateBlinkOnce: ++ // skip blinkOnce if it is already in Slow/Fast blink continues state ++ if (ledInfoPtr->savedLedState == kLedStateSlowBlinkContinues || ++ ledInfoPtr->savedLedState == kLedStateFastBlinkContinues) ++ ; ++ else ++ { ++ if (ledInfoPtr->blinkCountDown == 0) // skip the call if it is 1 ++ { ++ ledToggle(ledInfoPtr); ++ ledInfoPtr->blinkCountDown = 1; // it will be reset to 0 when timer expires ++ ledInfoPtr->ledState = kLedStateBlinkOnce; ++ ledTimerStart(); ++ } ++ } ++ break; ++ ++ case kLedStateSlowBlinkContinues: ++ ledInfoPtr->blinkCountDown = kSlowBlinkCount; ++ ledInfoPtr->ledState = kLedStateSlowBlinkContinues; ++ ledInfoPtr->savedLedState = kLedStateSlowBlinkContinues; ++ ledTimerStart(); ++ break; ++ ++ case kLedStateFastBlinkContinues: ++ ledInfoPtr->blinkCountDown = kFastBlinkCount; ++ ledInfoPtr->ledState = kLedStateFastBlinkContinues; ++ ledInfoPtr->savedLedState = kLedStateFastBlinkContinues; ++ ledTimerStart(); ++ break; ++ ++ default: ++ printk("Invalid led state\n"); ++ } ++} ++ ++// This function is called for an LED that is controlled by hardware. ++void kerSysLedRegisterHwHandler( BOARD_LED_NAME ledName, ++ HANDLE_LED_FUNC ledHwFunc, int ledFailType ) ++{ ++ if( (int) ledName < MAX_VIRT_LEDS ) ++ { ++ if( ledFailType == 1 ) ++ gLedHwFailFunc[(int) ledName] = ledHwFunc; ++ else ++ gLedHwFunc[(int) ledName] = ledHwFunc; ++ } ++} ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/board.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/board.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/board.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/board.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,1570 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/*************************************************************************** ++ * File Name : board.c ++ * ++ * Description: This file contains Linux character device driver entry ++ * for the board related ioctl calls: flash, get free kernel ++ * page and dump kernel memory, etc. ++ * ++ * Created on : 2/20/2002 seanl: use cfiflash.c, cfliflash.h (AMD specific) ++ * ++ ***************************************************************************/ ++ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include "boardparms.h" ++#include "cfiflash.h" ++#include "bcm_intr.h" ++#include "board.h" ++#include "bcm_map_part.h" ++ ++/* Typedefs. */ ++#if defined (NON_CONSECUTIVE_MAC) ++// used to be the last octet. Now changed to the first 5 bits of the the forth octet ++// to reduced the duplicated MAC addresses. ++#define CHANGED_OCTET 3 ++#define SHIFT_BITS 3 ++#else ++#define CHANGED_OCTET 1 ++#define SHIFT_BITS 0 ++#endif ++ ++#if defined (WIRELESS) ++#define SES_BTN_PRESSED 0x00000001 ++#define SES_EVENTS SES_BTN_PRESSED /*OR all values if any*/ ++#define SES_LED_OFF 0 ++#define SES_LED_ON 1 ++#define SES_LED_BLINK 2 ++#endif ++ ++typedef struct ++{ ++ unsigned long ulId; ++ char chInUse; ++ char chReserved[3]; ++} MAC_ADDR_INFO, *PMAC_ADDR_INFO; ++ ++typedef struct ++{ ++ unsigned long ulSdramSize; ++ unsigned long ulPsiSize; ++ unsigned long ulNumMacAddrs; ++ unsigned long ucaBaseMacAddr[NVRAM_MAC_ADDRESS_LEN]; ++ MAC_ADDR_INFO MacAddrs[1]; ++} NVRAM_INFO, *PNVRAM_INFO; ++ ++typedef struct ++{ ++ unsigned long eventmask; ++} BOARD_IOC, *PBOARD_IOC; ++ ++ ++/*Dyinggasp callback*/ ++typedef void (*cb_dgasp_t)(void *arg); ++typedef struct _CB_DGASP__LIST ++{ ++ struct list_head list; ++ char name[IFNAMSIZ]; ++ cb_dgasp_t cb_dgasp_fn; ++ void *context; ++}CB_DGASP_LIST , *PCB_DGASP_LIST; ++ ++ ++static LED_MAP_PAIR LedMapping[] = ++{ // led name Initial state physical pin (ledMask) ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0} // NOTE: kLedEnd has to be at the end. ++}; ++ ++/* Externs. */ ++extern struct file fastcall *fget_light(unsigned int fd, int *fput_needed); ++extern unsigned int nr_free_pages (void); ++extern const char *get_system_type(void); ++extern void kerSysFlashInit(void); ++extern unsigned long get_nvram_start_addr(void); ++extern unsigned long get_scratch_pad_start_addr(void); ++extern unsigned long getMemorySize(void); ++extern void __init boardLedInit(PLED_MAP_PAIR); ++extern void boardLedCtrl(BOARD_LED_NAME, BOARD_LED_STATE); ++extern void kerSysLedRegisterHandler( BOARD_LED_NAME ledName, ++ HANDLE_LED_FUNC ledHwFunc, int ledFailType ); ++ ++/* Prototypes. */ ++void __init InitNvramInfo( void ); ++static int board_open( struct inode *inode, struct file *filp ); ++static int board_ioctl( struct inode *inode, struct file *flip, unsigned int command, unsigned long arg ); ++static ssize_t board_read(struct file *filp, char __user *buffer, size_t count, loff_t *ppos); ++static unsigned int board_poll(struct file *filp, struct poll_table_struct *wait); ++static int board_release(struct inode *inode, struct file *filp); ++ ++static BOARD_IOC* borad_ioc_alloc(void); ++static void borad_ioc_free(BOARD_IOC* board_ioc); ++ ++/* DyingGasp function prototype */ ++static void __init kerSysDyingGaspMapIntr(void); ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++static irqreturn_t kerSysDyingGaspIsr(int irq, void * dev_id, struct pt_regs * regs); ++#else ++static unsigned int kerSysDyingGaspIsr(void); ++#endif ++static void __init kerSysInitDyingGaspHandler( void ); ++static void __exit kerSysDeinitDyingGaspHandler( void ); ++/* -DyingGasp function prototype - */ ++ ++ ++#if defined (WIRELESS) ++static irqreturn_t sesBtn_isr(int irq, void *dev_id, struct pt_regs *ptregs); ++static void __init sesBtn_mapGpio(void); ++static void __init sesBtn_mapIntr(int context); ++static unsigned int sesBtn_poll(struct file *file, struct poll_table_struct *wait); ++static ssize_t sesBtn_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos); ++static void __init sesLed_mapGpio(void); ++static void sesLed_ctrl(int action); ++static void __init ses_board_init(void); ++static void __exit ses_board_deinit(void); ++#endif ++ ++static PNVRAM_INFO g_pNvramInfo = NULL; ++static int g_ledInitialized = 0; ++static wait_queue_head_t g_board_wait_queue; ++static CB_DGASP_LIST *g_cb_dgasp_list_head = NULL; ++ ++static int g_wakeup_monitor = 0; ++static struct file *g_monitor_file = NULL; ++static struct task_struct *g_monitor_task = NULL; ++static unsigned int (*g_orig_fop_poll) ++ (struct file *, struct poll_table_struct *) = NULL; ++ ++static struct file_operations board_fops = ++{ ++ open: board_open, ++ ioctl: board_ioctl, ++ poll: board_poll, ++ read: board_read, ++ release: board_release, ++}; ++ ++uint32 board_major = 0; ++ ++#if defined (WIRELESS) ++static unsigned short sesBtn_irq = BP_NOT_DEFINED; ++static unsigned short sesBtn_gpio = BP_NOT_DEFINED; ++static unsigned short sesLed_gpio = BP_NOT_DEFINED; ++#endif ++ ++#if defined(MODULE) ++int init_module(void) ++{ ++ return( brcm_board_init() ); ++} ++ ++void cleanup_module(void) ++{ ++ if (MOD_IN_USE) ++ printk("brcm flash: cleanup_module failed because module is in use\n"); ++ else ++ brcm_board_cleanup(); ++} ++#endif //MODULE ++ ++ ++ ++static int __init brcm_board_init( void ) ++{ ++ typedef int (*BP_LED_FUNC) (unsigned short *); ++ static struct BpLedInformation ++ { ++ BOARD_LED_NAME ledName; ++ BP_LED_FUNC bpFunc; ++ BP_LED_FUNC bpFuncFail; ++ } bpLedInfo[] = ++ {{kLedAdsl, BpGetAdslLedGpio, BpGetAdslFailLedGpio}, ++ {kLedWireless, BpGetWirelessLedGpio, NULL}, ++ {kLedUsb, BpGetUsbLedGpio, NULL}, ++ {kLedHpna, BpGetHpnaLedGpio, NULL}, ++ {kLedWanData, BpGetWanDataLedGpio, NULL}, ++ {kLedPPP, BpGetPppLedGpio, BpGetPppFailLedGpio}, ++ {kLedVoip, BpGetVoipLedGpio, NULL}, ++ {kLedSes, BpGetWirelessSesLedGpio, NULL}, ++ {kLedEnd, NULL, NULL} ++ }; ++ ++ int ret; ++ ++ ret = register_chrdev(BOARD_DRV_MAJOR, "bcrmboard", &board_fops ); ++ if (ret < 0) ++ printk( "brcm_board_init(major %d): fail to register device.\n",BOARD_DRV_MAJOR); ++ else ++ { ++ PLED_MAP_PAIR pLedMap = LedMapping; ++ unsigned short gpio; ++ struct BpLedInformation *pInfo; ++ ++ printk("brcmboard: brcm_board_init entry\n"); ++ board_major = BOARD_DRV_MAJOR; ++ InitNvramInfo(); ++ ++ for( pInfo = bpLedInfo; pInfo->ledName != kLedEnd; pInfo++ ) ++ { ++ if( pInfo->bpFunc && (*pInfo->bpFunc) (&gpio) == BP_SUCCESS ) ++ { ++ pLedMap->ledName = pInfo->ledName; ++ pLedMap->ledMask = GPIO_NUM_TO_MASK(gpio); ++ pLedMap->ledActiveLow = (gpio & BP_ACTIVE_LOW) ? 1 : 0; ++ } ++ if( pInfo->bpFuncFail && (*pInfo->bpFuncFail) (&gpio) == BP_SUCCESS ) ++ { ++ pLedMap->ledName = pInfo->ledName; ++ pLedMap->ledMaskFail = GPIO_NUM_TO_MASK(gpio); ++ pLedMap->ledActiveLowFail = (gpio & BP_ACTIVE_LOW) ? 1 : 0; ++ } ++ if( pLedMap->ledName != kLedEnd ) ++ pLedMap++; ++ } ++ ++ init_waitqueue_head(&g_board_wait_queue); ++#if defined (WIRELESS) ++ ses_board_init(); ++#endif ++ kerSysInitDyingGaspHandler(); ++ kerSysDyingGaspMapIntr(); ++ ++ boardLedInit(LedMapping); ++ g_ledInitialized = 1; ++ } ++ ++ return ret; ++} ++ ++void __init InitNvramInfo( void ) ++{ ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ unsigned long ulNumMacAddrs = pNvramData->ulNumMacAddrs; ++ ++ if( ulNumMacAddrs > 0 && ulNumMacAddrs <= NVRAM_MAC_COUNT_MAX ) ++ { ++ unsigned long ulNvramInfoSize = ++ sizeof(NVRAM_INFO) + ((sizeof(MAC_ADDR_INFO) - 1) * ulNumMacAddrs); ++ ++ g_pNvramInfo = (PNVRAM_INFO) kmalloc( ulNvramInfoSize, GFP_KERNEL ); ++ ++ if( g_pNvramInfo ) ++ { ++ unsigned long ulPsiSize; ++ if( BpGetPsiSize( &ulPsiSize ) != BP_SUCCESS ) ++ ulPsiSize = NVRAM_PSI_DEFAULT; ++ memset( g_pNvramInfo, 0x00, ulNvramInfoSize ); ++ g_pNvramInfo->ulPsiSize = ulPsiSize * 1024; ++ g_pNvramInfo->ulNumMacAddrs = pNvramData->ulNumMacAddrs; ++ memcpy( g_pNvramInfo->ucaBaseMacAddr, pNvramData->ucaBaseMacAddr, ++ NVRAM_MAC_ADDRESS_LEN ); ++ g_pNvramInfo->ulSdramSize = getMemorySize(); ++ } ++ else ++ printk("ERROR - Could not allocate memory for NVRAM data\n"); ++ } ++ else ++ printk("ERROR - Invalid number of MAC addresses (%ld) is configured.\n", ++ ulNumMacAddrs); ++} ++ ++void __exit brcm_board_cleanup( void ) ++{ ++ printk("brcm_board_cleanup()\n"); ++ ++ if (board_major != -1) ++ { ++#if defined (WIRELESS) ++ ses_board_deinit(); ++#endif ++ kerSysDeinitDyingGaspHandler(); ++ unregister_chrdev(board_major, "board_ioctl"); ++ } ++} ++ ++static BOARD_IOC* borad_ioc_alloc(void) ++{ ++ BOARD_IOC *board_ioc =NULL; ++ board_ioc = (BOARD_IOC*) kmalloc( sizeof(BOARD_IOC) , GFP_KERNEL ); ++ if(board_ioc) ++ { ++ memset(board_ioc, 0, sizeof(BOARD_IOC)); ++ } ++ return board_ioc; ++} ++ ++static void borad_ioc_free(BOARD_IOC* board_ioc) ++{ ++ if(board_ioc) ++ { ++ kfree(board_ioc); ++ } ++} ++ ++ ++static int board_open( struct inode *inode, struct file *filp ) ++{ ++ filp->private_data = borad_ioc_alloc(); ++ ++ if (filp->private_data == NULL) ++ return -ENOMEM; ++ ++ return( 0 ); ++} ++ ++static int board_release(struct inode *inode, struct file *filp) ++{ ++ BOARD_IOC *board_ioc = filp->private_data; ++ ++ wait_event_interruptible(g_board_wait_queue, 1); ++ borad_ioc_free(board_ioc); ++ ++ return( 0 ); ++} ++ ++ ++static unsigned int board_poll(struct file *filp, struct poll_table_struct *wait) ++{ ++ unsigned int mask = 0; ++#if defined (WIRELESS) ++ BOARD_IOC *board_ioc = filp->private_data; ++#endif ++ ++ poll_wait(filp, &g_board_wait_queue, wait); ++#if defined (WIRELESS) ++ if(board_ioc->eventmask & SES_EVENTS){ ++ mask |= sesBtn_poll(filp, wait); ++ } ++#endif ++ ++ return mask; ++} ++ ++ ++static ssize_t board_read(struct file *filp, char __user *buffer, size_t count, loff_t *ppos) ++{ ++#if defined (WIRELESS) ++ BOARD_IOC *board_ioc = filp->private_data; ++ if(board_ioc->eventmask & SES_EVENTS){ ++ return sesBtn_read(filp, buffer, count, ppos); ++ } ++#endif ++ return 0; ++} ++ ++//************************************************************************************** ++// Utitlities for dump memory, free kernel pages, mips soft reset, etc. ++//************************************************************************************** ++ ++/*********************************************************************** ++ * Function Name: dumpaddr ++ * Description : Display a hex dump of the specified address. ++ ***********************************************************************/ ++void dumpaddr( unsigned char *pAddr, int nLen ) ++{ ++ static char szHexChars[] = "0123456789abcdef"; ++ char szLine[80]; ++ char *p = szLine; ++ unsigned char ch, *q; ++ int i, j; ++ unsigned long ul; ++ ++ while( nLen > 0 ) ++ { ++ sprintf( szLine, "%8.8lx: ", (unsigned long) pAddr ); ++ p = szLine + strlen(szLine); ++ ++ for(i = 0; i < 16 && nLen > 0; i += sizeof(long), nLen -= sizeof(long)) ++ { ++ ul = *(unsigned long *) &pAddr[i]; ++ q = (unsigned char *) &ul; ++ for( j = 0; j < sizeof(long); j++ ) ++ { ++ *p++ = szHexChars[q[j] >> 4]; ++ *p++ = szHexChars[q[j] & 0x0f]; ++ *p++ = ' '; ++ } ++ } ++ ++ for( j = 0; j < 16 - i; j++ ) ++ *p++ = ' ', *p++ = ' ', *p++ = ' '; ++ ++ *p++ = ' ', *p++ = ' ', *p++ = ' '; ++ ++ for( j = 0; j < i; j++ ) ++ { ++ ch = pAddr[j]; ++ *p++ = (ch > ' ' && ch < '~') ? ch : '.'; ++ } ++ ++ *p++ = '\0'; ++ printk( "%s\r\n", szLine ); ++ ++ pAddr += i; ++ } ++ printk( "\r\n" ); ++} /* dumpaddr */ ++ ++ ++void kerSysMipsSoftReset(void) ++{ ++#if defined(CONFIG_BCM96348) ++ if (PERF->RevID == 0x634800A1) { ++ typedef void (*FNPTR) (void); ++ FNPTR bootaddr = (FNPTR) FLASH_BASE; ++ int i; ++ ++ /* Disable interrupts. */ ++ cli(); ++ ++ /* Reset all blocks. */ ++ PERF->BlockSoftReset &= ~BSR_ALL_BLOCKS; ++ for( i = 0; i < 1000000; i++ ) ++ ; ++ PERF->BlockSoftReset |= BSR_ALL_BLOCKS; ++ /* Jump to the power on address. */ ++ (*bootaddr) (); ++ } ++ else ++ PERF->pll_control |= SOFT_RESET; // soft reset mips ++#else ++ PERF->pll_control |= SOFT_RESET; // soft reset mips ++#endif ++} ++ ++ ++int kerSysGetMacAddress( unsigned char *pucaMacAddr, unsigned long ulId ) ++{ ++ int nRet = 0; ++ PMAC_ADDR_INFO pMai = NULL; ++ PMAC_ADDR_INFO pMaiFreeNoId = NULL; ++ PMAC_ADDR_INFO pMaiFreeId = NULL; ++ unsigned long i = 0, ulIdxNoId = 0, ulIdxId = 0, shiftedIdx = 0; ++ ++ for( i = 0, pMai = g_pNvramInfo->MacAddrs; i < g_pNvramInfo->ulNumMacAddrs; ++ i++, pMai++ ) ++ { ++ if( ulId == pMai->ulId || ulId == MAC_ADDRESS_ANY ) ++ { ++ /* This MAC address has been used by the caller in the past. */ ++ memcpy( pucaMacAddr, g_pNvramInfo->ucaBaseMacAddr, ++ NVRAM_MAC_ADDRESS_LEN ); ++ shiftedIdx = i; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMai->chInUse = 1; ++ pMaiFreeNoId = pMaiFreeId = NULL; ++ break; ++ } ++ else ++ if( pMai->chInUse == 0 ) ++ { ++ if( pMai->ulId == 0 && pMaiFreeNoId == NULL ) ++ { ++ /* This is an available MAC address that has never been ++ * used. ++ */ ++ pMaiFreeNoId = pMai; ++ ulIdxNoId = i; ++ } ++ else ++ if( pMai->ulId != 0 && pMaiFreeId == NULL ) ++ { ++ /* This is an available MAC address that has been used ++ * before. Use addresses that have never been used ++ * first, before using this one. ++ */ ++ pMaiFreeId = pMai; ++ ulIdxId = i; ++ } ++ } ++ } ++ ++ if( pMaiFreeNoId || pMaiFreeId ) ++ { ++ /* An available MAC address was found. */ ++ memcpy(pucaMacAddr, g_pNvramInfo->ucaBaseMacAddr,NVRAM_MAC_ADDRESS_LEN); ++ if( pMaiFreeNoId ) ++ { ++ shiftedIdx = ulIdxNoId; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMaiFreeNoId->ulId = ulId; ++ pMaiFreeNoId->chInUse = 1; ++ } ++ else ++ { ++ shiftedIdx = ulIdxId; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMaiFreeId->ulId = ulId; ++ pMaiFreeId->chInUse = 1; ++ } ++ } ++ else ++ if( i == g_pNvramInfo->ulNumMacAddrs ) ++ nRet = -EADDRNOTAVAIL; ++ ++ return( nRet ); ++} /* kerSysGetMacAddr */ ++ ++int kerSysReleaseMacAddress( unsigned char *pucaMacAddr ) ++{ ++ int nRet = -EINVAL; ++ unsigned long ulIdx = 0; ++ int idx = (pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] - ++ g_pNvramInfo->ucaBaseMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET]); ++ ++ // if overflow 255 (negitive), add 256 to have the correct index ++ if (idx < 0) ++ idx += 256; ++ ulIdx = (unsigned long) (idx >> SHIFT_BITS); ++ ++ if( ulIdx < g_pNvramInfo->ulNumMacAddrs ) ++ { ++ PMAC_ADDR_INFO pMai = &g_pNvramInfo->MacAddrs[ulIdx]; ++ if( pMai->chInUse == 1 ) ++ { ++ pMai->chInUse = 0; ++ nRet = 0; ++ } ++ } ++ ++ return( nRet ); ++} /* kerSysReleaseMacAddr */ ++ ++int kerSysGetSdramSize( void ) ++{ ++ return( (int) g_pNvramInfo->ulSdramSize ); ++} /* kerSysGetSdramSize */ ++ ++ ++void kerSysLedCtrl(BOARD_LED_NAME ledName, BOARD_LED_STATE ledState) ++{ ++ if (g_ledInitialized) ++ boardLedCtrl(ledName, ledState); ++} ++ ++unsigned int kerSysMonitorPollHook( struct file *f, struct poll_table_struct *t) ++{ ++ int mask = (*g_orig_fop_poll) (f, t); ++ ++ if( g_wakeup_monitor == 1 && g_monitor_file == f ) ++ { ++ /* If g_wakeup_monitor is non-0, the user mode application needs to ++ * return from a blocking select function. Return POLLPRI which will ++ * cause the select to return with the exception descriptor set. ++ */ ++ mask |= POLLPRI; ++ g_wakeup_monitor = 0; ++ } ++ ++ return( mask ); ++} ++ ++/* Put the user mode application that monitors link state on a run queue. */ ++void kerSysWakeupMonitorTask( void ) ++{ ++ g_wakeup_monitor = 1; ++ if( g_monitor_task ) ++ wake_up_process( g_monitor_task ); ++} ++ ++//******************************************************************************************** ++// misc. ioctl calls come to here. (flash, led, reset, kernel memory access, etc.) ++//******************************************************************************************** ++static int board_ioctl( struct inode *inode, struct file *flip, ++ unsigned int command, unsigned long arg ) ++{ ++ int ret = 0; ++ BOARD_IOCTL_PARMS ctrlParms; ++ unsigned char ucaMacAddr[NVRAM_MAC_ADDRESS_LEN]; ++ int allowedSize; ++ ++ switch (command) ++ { ++ case BOARD_IOCTL_FLASH_INIT: ++ // not used for now. kerSysBcmImageInit(); ++ break; ++ ++ ++ case BOARD_IOCTL_FLASH_WRITE: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ NVRAM_DATA SaveNvramData; ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ ++ switch (ctrlParms.action) ++ { ++ case SCRATCH_PAD: ++ ret = kerSysScratchPadSet(ctrlParms.string, ctrlParms.buf, ctrlParms.offset); ++ break; ++ ++ case PERSISTENT: ++ ret = kerSysPersistentSet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case NVRAM: ++ ret = kerSysNvRamSet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case BCM_IMAGE_CFE: ++ if( ctrlParms.strLen <= 0 || ctrlParms.strLen > FLASH45_LENGTH_BOOT_ROM ) ++ { ++ printk("Illegal CFE size [%d]. Size allowed: [%d]\n", ++ ctrlParms.strLen, FLASH45_LENGTH_BOOT_ROM); ++ ret = -1; ++ break; ++ } ++ ++ // save NVRAM data into a local structure ++ memcpy( &SaveNvramData, pNvramData, sizeof(NVRAM_DATA) ); ++ ++ // set memory type field ++ BpGetSdramSize( (unsigned long *) &ctrlParms.string[SDRAM_TYPE_ADDRESS_OFFSET] ); ++ ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ ++ // if nvram is not valid, restore the current nvram settings ++ if( BpSetBoardId( pNvramData->szBoardId ) != BP_SUCCESS && ++ *(unsigned long *) pNvramData == NVRAM_DATA_ID ) ++ { ++ kerSysNvRamSet((char *) &SaveNvramData, sizeof(SaveNvramData), 0); ++ } ++ break; ++ ++ case BCM_IMAGE_FS: ++ allowedSize = (int) flash_get_total_size() - \ ++ FLASH_RESERVED_AT_END - TAG_LEN - FLASH45_LENGTH_BOOT_ROM; ++ if( ctrlParms.strLen <= 0 || ctrlParms.strLen > allowedSize) ++ { ++ printk("Illegal root file system size [%d]. Size allowed: [%d]\n", ++ ctrlParms.strLen, allowedSize); ++ ret = -1; ++ break; ++ } ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ kerSysMipsSoftReset(); ++ break; ++ ++ case BCM_IMAGE_KERNEL: // not used for now. ++ break; ++ case BCM_IMAGE_WHOLE: ++ if(ctrlParms.strLen <= 0) ++ { ++ printk("Illegal flash image size [%d].\n", ctrlParms.strLen); ++ ret = -1; ++ break; ++ } ++ ++ // save NVRAM data into a local structure ++ memcpy( &SaveNvramData, pNvramData, sizeof(NVRAM_DATA) ); ++ ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ ++ // if nvram is not valid, restore the current nvram settings ++ if( BpSetBoardId( pNvramData->szBoardId ) != BP_SUCCESS && ++ *(unsigned long *) pNvramData == NVRAM_DATA_ID ) ++ { ++ kerSysNvRamSet((char *) &SaveNvramData, sizeof(SaveNvramData), 0); ++ } ++ ++ kerSysMipsSoftReset(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ printk("flash_ioctl_command: invalid command %d\n", ctrlParms.action); ++ break; ++ } ++ ctrlParms.result = ret; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_FLASH_READ: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ switch (ctrlParms.action) ++ { ++ case SCRATCH_PAD: ++ ret = kerSysScratchPadGet(ctrlParms.string, ctrlParms.buf, ctrlParms.offset); ++ break; ++ ++ case PERSISTENT: ++ ret = kerSysPersistentGet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case NVRAM: ++ ret = kerSysNvRamGet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case FLASH_SIZE: ++ ret = kerSysFlashSizeGet(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ printk("Not supported. invalid command %d\n", ctrlParms.action); ++ break; ++ } ++ ctrlParms.result = ret; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_NR_PAGES: ++ ctrlParms.result = nr_free_pages() + get_page_cache_size(); ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_DUMP_ADDR: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ dumpaddr( (unsigned char *) ctrlParms.string, ctrlParms.strLen ); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_SET_MEMORY: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ unsigned long *pul = (unsigned long *) ctrlParms.string; ++ unsigned short *pus = (unsigned short *) ctrlParms.string; ++ unsigned char *puc = (unsigned char *) ctrlParms.string; ++ switch( ctrlParms.strLen ) ++ { ++ case 4: ++ *pul = (unsigned long) ctrlParms.offset; ++ break; ++ case 2: ++ *pus = (unsigned short) ctrlParms.offset; ++ break; ++ case 1: ++ *puc = (unsigned char) ctrlParms.offset; ++ break; ++ } ++ dumpaddr( (unsigned char *) ctrlParms.string, sizeof(long) ); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_MIPS_SOFT_RESET: ++ kerSysMipsSoftReset(); ++ break; ++ ++ case BOARD_IOCTL_LED_CTRL: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ kerSysLedCtrl((BOARD_LED_NAME)ctrlParms.strLen, (BOARD_LED_STATE)ctrlParms.offset); ++ ret = 0; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_ID: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, ++ sizeof(ctrlParms)) == 0) ++ { ++ if( ctrlParms.string ) ++ { ++ char *p = (char *) get_system_type(); ++ if( strlen(p) + 1 < ctrlParms.strLen ) ++ ctrlParms.strLen = strlen(p) + 1; ++ __copy_to_user(ctrlParms.string, p, ctrlParms.strLen); ++ } ++ ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ ctrlParms.result = kerSysGetMacAddress( ucaMacAddr, ++ ctrlParms.offset ); ++ ++ if( ctrlParms.result == 0 ) ++ { ++ __copy_to_user(ctrlParms.string, ucaMacAddr, ++ sizeof(ucaMacAddr)); ++ } ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_RELEASE_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ if (copy_from_user((void*)ucaMacAddr, (void*)ctrlParms.string, \ ++ NVRAM_MAC_ADDRESS_LEN) == 0) ++ { ++ ctrlParms.result = kerSysReleaseMacAddress( ucaMacAddr ); ++ } ++ else ++ { ++ ctrlParms.result = -EACCES; ++ } ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_PSI_SIZE: ++ ctrlParms.result = (int) g_pNvramInfo->ulPsiSize; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_SDRAM_SIZE: ++ ctrlParms.result = (int) g_pNvramInfo->ulSdramSize; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_BASE_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ __copy_to_user(ctrlParms.string, g_pNvramInfo->ucaBaseMacAddr, NVRAM_MAC_ADDRESS_LEN); ++ ctrlParms.result = 0; ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_CHIP_ID: ++ ctrlParms.result = (int) (PERF->RevID & 0xFFFF0000) >> 16; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_NUM_ENET: { ++ ETHERNET_MAC_INFO EnetInfos[BP_MAX_ENET_MACS]; ++ int i, numeth = 0; ++ if (BpGetEthernetMacInfo(EnetInfos, BP_MAX_ENET_MACS) == BP_SUCCESS) { ++ for( i = 0; i < BP_MAX_ENET_MACS; i++) { ++ if (EnetInfos[i].ucPhyType != BP_ENET_NO_PHY) { ++ numeth++; ++ } ++ } ++ ctrlParms.result = numeth; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ ++ case BOARD_IOCTL_GET_CFE_VER: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ char *vertag = (char *)(FLASH_BASE + CFE_VERSION_OFFSET); ++ if (ctrlParms.strLen < CFE_VERSION_SIZE) { ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = -EFAULT; ++ } ++ else if (strncmp(vertag, "cfe-v", 5)) { // no tag info in flash ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else { ++ ctrlParms.result = 1; ++ __copy_to_user(ctrlParms.string, vertag+CFE_VERSION_MARK_SIZE, CFE_VERSION_SIZE); ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_ENET_CFG: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ ETHERNET_MAC_INFO EnetInfos[BP_MAX_ENET_MACS]; ++ if (BpGetEthernetMacInfo(EnetInfos, BP_MAX_ENET_MACS) == BP_SUCCESS) { ++ if (ctrlParms.strLen == sizeof(EnetInfos)) { ++ __copy_to_user(ctrlParms.string, EnetInfos, sizeof(EnetInfos)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++#if defined (WIRELESS) ++ case BOARD_IOCTL_GET_WLAN_ANT_INUSE: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ unsigned short antInUse = 0; ++ if (BpGetWirelessAntInUse(&antInUse) == BP_SUCCESS) { ++ if (ctrlParms.strLen == sizeof(antInUse)) { ++ __copy_to_user(ctrlParms.string, &antInUse, sizeof(antInUse)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#endif ++ case BOARD_IOCTL_SET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ ctrlParms.result = -EFAULT; ++ ret = -EFAULT; ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ board_ioc->eventmask |= *((int*)ctrlParms.string); ++#if defined (WIRELESS) ++ if((board_ioc->eventmask & SES_EVENTS)) { ++ if(sesBtn_irq != BP_NOT_DEFINED) { ++ BcmHalInterruptEnable(sesBtn_irq); ++ ctrlParms.result = 0; ++ ret = 0; ++ } ++ } ++#endif ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ __copy_to_user(ctrlParms.string, &board_ioc->eventmask, sizeof(unsigned long)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_UNSET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ board_ioc->eventmask &= (~(*((int*)ctrlParms.string))); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#if defined (WIRELESS) ++ case BOARD_IOCTL_SET_SES_LED: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ if (ctrlParms.strLen == sizeof(int)) { ++ sesLed_ctrl(*(int*)ctrlParms.string); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#endif ++ ++ case BOARD_IOCTL_SET_MONITOR_FD: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ int fput_needed = 0; ++ ++ g_monitor_file = fget_light( ctrlParms.offset, &fput_needed ); ++ if( g_monitor_file ) { ++ /* Hook this file descriptor's poll function in order to set ++ * the exception descriptor when there is a change in link ++ * state. ++ */ ++ g_monitor_task = current; ++ g_orig_fop_poll = g_monitor_file->f_op->poll; ++ g_monitor_file->f_op->poll = kerSysMonitorPollHook; ++ } ++ } ++ break; ++ ++ case BOARD_IOCTL_WAKEUP_MONITOR_TASK: ++ kerSysWakeupMonitorTask(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ ctrlParms.result = 0; ++ printk("board_ioctl: invalid command %x, cmd %d .\n",command,_IOC_NR(command)); ++ break; ++ ++ } /* switch */ ++ ++ return (ret); ++ ++} /* board_ioctl */ ++ ++/*************************************************************************** ++ * SES Button ISR/GPIO/LED functions. ++ ***************************************************************************/ ++#if defined (WIRELESS) ++static irqreturn_t sesBtn_isr(int irq, void *dev_id, struct pt_regs *ptregs) ++{ ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined(CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if (!(*gpio_reg & gpio_mask)){ ++ wake_up_interruptible(&g_board_wait_queue); ++ return IRQ_RETVAL(1); ++ } else { ++ return IRQ_RETVAL(0); ++ } ++} ++ ++static void __init sesBtn_mapGpio() ++{ ++ if( BpGetWirelessSesBtnGpio(&sesBtn_gpio) == BP_SUCCESS ) ++ { ++ printk("SES: Button GPIO 0x%x is enabled\n", sesBtn_gpio); ++ } ++} ++ ++static void __init sesBtn_mapIntr(int context) ++{ ++ if( BpGetWirelessSesExtIntr(&sesBtn_irq) == BP_SUCCESS ) ++ { ++ printk("SES: Button Interrupt 0x%x is enabled\n", sesBtn_irq); ++ } ++ else ++ return; ++ ++ sesBtn_irq += INTERRUPT_ID_EXTERNAL_0; ++ ++ if (BcmHalMapInterrupt((FN_HANDLER)sesBtn_isr, context, sesBtn_irq)) { ++ printk("SES: Interrupt mapping failed\n"); ++ } ++ BcmHalInterruptEnable(sesBtn_irq); ++} ++ ++ ++static unsigned int sesBtn_poll(struct file *file, struct poll_table_struct *wait) ++{ ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined(CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if (!(*gpio_reg & gpio_mask)){ ++ return POLLIN; ++ } ++ return 0; ++} ++ ++static ssize_t sesBtn_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos) ++{ ++ volatile unsigned int event=0; ++ ssize_t ret=0; ++ ++#if defined(_BCM96338_) || defined (CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined (CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if(*gpio_reg & gpio_mask){ ++ BcmHalInterruptEnable(sesBtn_irq); ++ return ret; ++ } ++ event = SES_EVENTS; ++ __copy_to_user((char*)buffer, (char*)&event, sizeof(event)); ++ BcmHalInterruptEnable(sesBtn_irq); ++ count -= sizeof(event); ++ buffer += sizeof(event); ++ ret += sizeof(event); ++ return ret; ++} ++ ++static void __init sesLed_mapGpio() ++{ ++ if( BpGetWirelessSesBtnGpio(&sesLed_gpio) == BP_SUCCESS ) ++ { ++ printk("SES: LED GPIO 0x%x is enabled\n", sesBtn_gpio); ++ } ++} ++ ++static void sesLed_ctrl(int action) ++{ ++ ++ //char status = ((action >> 8) & 0xff); /* extract status */ ++ //char event = ((action >> 16) & 0xff); /* extract event */ ++ //char blinktype = ((action >> 24) & 0xff); /* extract blink type for SES_LED_BLINK */ ++ ++ BOARD_LED_STATE led; ++ ++ if(sesLed_gpio == BP_NOT_DEFINED) ++ return; ++ ++ action &= 0xff; /* extract led */ ++ ++ //printk("blinktype=%d, event=%d, status=%d\n",(int)blinktype, (int)event, (int)status); ++ ++ switch (action) ++ { ++ case SES_LED_ON: ++ //printk("SES: led on\n"); ++ led = kLedStateOn; ++ break; ++ case SES_LED_BLINK: ++ //printk("SES: led blink\n"); ++ led = kLedStateSlowBlinkContinues; ++ break; ++ case SES_LED_OFF: ++ default: ++ //printk("SES: led off\n"); ++ led = kLedStateOff; ++ } ++ ++ kerSysLedCtrl(kLedSes, led); ++} ++ ++static void __init ses_board_init() ++{ ++ sesBtn_mapGpio(); ++ sesBtn_mapIntr(0); ++ sesLed_mapGpio(); ++} ++static void __exit ses_board_deinit() ++{ ++ if(sesBtn_irq) ++ BcmHalInterruptDisable(sesBtn_irq); ++} ++#endif ++ ++/*************************************************************************** ++ * Dying gasp ISR and functions. ++ ***************************************************************************/ ++#define KERSYS_DBG printk ++ ++#if defined(CONFIG_BCM96345) ++#define CYCLE_PER_US 70 ++#elif defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++/* The BCM6348 cycles per microsecond is really variable since the BCM6348 ++ * MIPS speed can vary depending on the PLL settings. However, an appoximate ++ * value of 120 will still work OK for the test being done. ++ */ ++#define CYCLE_PER_US 120 ++#endif ++#define DG_GLITCH_TO (100*CYCLE_PER_US) ++ ++static void __init kerSysDyingGaspMapIntr() ++{ ++ unsigned long ulIntr; ++ ++#if defined(CONFIG_BCM96348) || defined(_BCM96348_) || defined(CONFIG_BCM96338) || defined(_BCM96338_) ++ if( BpGetAdslDyingGaspExtIntr( &ulIntr ) == BP_SUCCESS ) { ++ BcmHalMapInterrupt((FN_HANDLER)kerSysDyingGaspIsr, 0, INTERRUPT_ID_DG); ++ BcmHalInterruptEnable( INTERRUPT_ID_DG ); ++ } ++#elif defined(CONFIG_BCM96345) || defined(_BCM96345_) ++ if( BpGetAdslDyingGaspExtIntr( &ulIntr ) == BP_SUCCESS ) { ++ ulIntr += INTERRUPT_ID_EXTERNAL_0; ++ BcmHalMapInterrupt((FN_HANDLER)kerSysDyingGaspIsr, 0, ulIntr); ++ BcmHalInterruptEnable( ulIntr ); ++ } ++#endif ++ ++} ++ ++void kerSysSetWdTimer(ulong timeUs) ++{ ++ TIMER->WatchDogDefCount = timeUs * (FPERIPH/1000000); ++ TIMER->WatchDogCtl = 0xFF00; ++ TIMER->WatchDogCtl = 0x00FF; ++} ++ ++ulong kerSysGetCycleCount(void) ++{ ++ ulong cnt; ++#ifdef _WIN32_WCE ++ cnt = 0; ++#else ++ __asm volatile("mfc0 %0, $9":"=d"(cnt)); ++#endif ++ return(cnt); ++} ++ ++static Bool kerSysDyingGaspCheckPowerLoss(void) ++{ ++ ulong clk0; ++ ulong ulIntr; ++ ++ ulIntr = 0; ++ clk0 = kerSysGetCycleCount(); ++ ++ UART->Data = 'D'; ++ UART->Data = '%'; ++ UART->Data = 'G'; ++ ++#if defined(CONFIG_BCM96345) ++ BpGetAdslDyingGaspExtIntr( &ulIntr ); ++ ++ do { ++ ulong clk1; ++ ++ clk1 = kerSysGetCycleCount(); /* time cleared */ ++ /* wait a little to get new reading */ ++ while ((kerSysGetCycleCount()-clk1) < CYCLE_PER_US*2) ++ ; ++ } while ((0 == (PERF->ExtIrqCfg & (1 << (ulIntr + EI_STATUS_SHFT)))) && ((kerSysGetCycleCount() - clk0) < DG_GLITCH_TO)); ++ ++ if (PERF->ExtIrqCfg & (1 << (ulIntr + EI_STATUS_SHFT))) { /* power glitch */ ++ BcmHalInterruptEnable( ulIntr + INTERRUPT_ID_EXTERNAL_0); ++ KERSYS_DBG(" - Power glitch detected. Duration: %ld us\n", (kerSysGetCycleCount() - clk0)/CYCLE_PER_US); ++ return 0; ++ } ++#elif (defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338)) && !defined(VXWORKS) ++ do { ++ ulong clk1; ++ ++ clk1 = kerSysGetCycleCount(); /* time cleared */ ++ /* wait a little to get new reading */ ++ while ((kerSysGetCycleCount()-clk1) < CYCLE_PER_US*2) ++ ; ++ } while ((PERF->IrqStatus & (1 << (INTERRUPT_ID_DG - INTERNAL_ISR_TABLE_OFFSET))) && ((kerSysGetCycleCount() - clk0) < DG_GLITCH_TO)); ++ ++ if (!(PERF->IrqStatus & (1 << (INTERRUPT_ID_DG - INTERNAL_ISR_TABLE_OFFSET)))) { ++ BcmHalInterruptEnable( INTERRUPT_ID_DG ); ++ KERSYS_DBG(" - Power glitch detected. Duration: %ld us\n", (kerSysGetCycleCount() - clk0)/CYCLE_PER_US); ++ return 0; ++ } ++#endif ++ return 1; ++} ++ ++static void kerSysDyingGaspShutdown( void ) ++{ ++ kerSysSetWdTimer(1000000); ++#if defined(CONFIG_BCM96345) ++ PERF->blkEnables &= ~(EMAC_CLK_EN | USB_CLK_EN | CPU_CLK_EN); ++#elif defined(CONFIG_BCM96348) ++ PERF->blkEnables &= ~(EMAC_CLK_EN | USBS_CLK_EN | USBH_CLK_EN | SAR_CLK_EN); ++#endif ++} ++ ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++static irqreturn_t kerSysDyingGaspIsr(int irq, void * dev_id, struct pt_regs * regs) ++#else ++static unsigned int kerSysDyingGaspIsr(void) ++#endif ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp, *dsl = NULL; ++ ++ if (kerSysDyingGaspCheckPowerLoss()) { ++ ++ /* first to turn off everything other than dsl */ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ if(strncmp(tmp->name, "dsl", 3)) { ++ (tmp->cb_dgasp_fn)(tmp->context); ++ }else { ++ dsl = tmp; ++ } ++ } ++ ++ /* now send dgasp */ ++ if(dsl) ++ (dsl->cb_dgasp_fn)(dsl->context); ++ ++ /* reset and shutdown system */ ++ kerSysDyingGaspShutdown(); ++ } ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++return( IRQ_HANDLED ); ++#else ++ return( 1 ); ++#endif ++} ++ ++static void __init kerSysInitDyingGaspHandler( void ) ++{ ++ CB_DGASP_LIST *new_node; ++ ++ if( g_cb_dgasp_list_head != NULL) { ++ printk("Error: kerSysInitDyingGaspHandler: list head is not null\n"); ++ return; ++ } ++ new_node= (CB_DGASP_LIST *)kmalloc(sizeof(CB_DGASP_LIST), GFP_KERNEL); ++ memset(new_node, 0x00, sizeof(CB_DGASP_LIST)); ++ INIT_LIST_HEAD(&new_node->list); ++ g_cb_dgasp_list_head = new_node; ++ ++} /* kerSysInitDyingGaspHandler */ ++ ++static void __exit kerSysDeinitDyingGaspHandler( void ) ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp; ++ ++ if(g_cb_dgasp_list_head == NULL) ++ return; ++ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ list_del(pos); ++ kfree(tmp); ++ } ++ ++ kfree(g_cb_dgasp_list_head); ++ g_cb_dgasp_list_head = NULL; ++ ++} /* kerSysDeinitDyingGaspHandler */ ++ ++void kerSysRegisterDyingGaspHandler(char *devname, void *cbfn, void *context) ++{ ++ CB_DGASP_LIST *new_node; ++ ++ if( g_cb_dgasp_list_head == NULL) { ++ printk("Error: kerSysRegisterDyingGaspHandler: list head is null\n"); ++ return; ++ } ++ ++ if( devname == NULL || cbfn == NULL ) { ++ printk("Error: kerSysRegisterDyingGaspHandler: register info not enough (%s,%x,%x)\n", devname, (unsigned int)cbfn, (unsigned int)context); ++ return; ++ } ++ ++ new_node= (CB_DGASP_LIST *)kmalloc(sizeof(CB_DGASP_LIST), GFP_KERNEL); ++ memset(new_node, 0x00, sizeof(CB_DGASP_LIST)); ++ INIT_LIST_HEAD(&new_node->list); ++ strncpy(new_node->name, devname, IFNAMSIZ); ++ new_node->cb_dgasp_fn = (cb_dgasp_t)cbfn; ++ new_node->context = context; ++ list_add(&new_node->list, &g_cb_dgasp_list_head->list); ++ ++ printk("dgasp: kerSysRegisterDyingGaspHandler: %s registered \n", devname); ++ ++} /* kerSysRegisterDyingGaspHandler */ ++ ++void kerSysDeregisterDyingGaspHandler(char *devname) ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp; ++ ++ if(g_cb_dgasp_list_head == NULL) { ++ printk("Error: kerSysDeregisterDyingGaspHandler: list head is null\n"); ++ return; ++ } ++ ++ if(devname == NULL) { ++ printk("Error: kerSysDeregisterDyingGaspHandler: devname is null\n"); ++ return; ++ } ++ ++ printk("kerSysDeregisterDyingGaspHandler: %s is deregistering\n", devname); ++ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ if(!strcmp(tmp->name, devname)) { ++ list_del(pos); ++ kfree(tmp); ++ printk("kerSysDeregisterDyingGaspHandler: %s is deregistered\n", devname); ++ return; ++ } ++ } ++ printk("kerSysDeregisterDyingGaspHandler: %s not (de)registered\n", devname); ++ ++} /* kerSysDeregisterDyingGaspHandler */ ++ ++/*************************************************************************** ++ * MACRO to call driver initialization and cleanup functions. ++ ***************************************************************************/ ++module_init( brcm_board_init ); ++module_exit( brcm_board_cleanup ); ++ ++EXPORT_SYMBOL(kerSysNvRamGet); ++EXPORT_SYMBOL(dumpaddr); ++EXPORT_SYMBOL(kerSysGetMacAddress); ++EXPORT_SYMBOL(kerSysReleaseMacAddress); ++EXPORT_SYMBOL(kerSysGetSdramSize); ++EXPORT_SYMBOL(kerSysLedCtrl); ++EXPORT_SYMBOL(kerSysLedRegisterHwHandler); ++EXPORT_SYMBOL(BpGetBoardIds); ++EXPORT_SYMBOL(BpGetSdramSize); ++EXPORT_SYMBOL(BpGetPsiSize); ++EXPORT_SYMBOL(BpGetEthernetMacInfo); ++EXPORT_SYMBOL(BpGetRj11InnerOuterPairGpios); ++EXPORT_SYMBOL(BpGetPressAndHoldResetGpio); ++EXPORT_SYMBOL(BpGetVoipResetGpio); ++EXPORT_SYMBOL(BpGetVoipIntrGpio); ++EXPORT_SYMBOL(BpGetPcmciaResetGpio); ++EXPORT_SYMBOL(BpGetRtsCtsUartGpios); ++EXPORT_SYMBOL(BpGetAdslLedGpio); ++EXPORT_SYMBOL(BpGetAdslFailLedGpio); ++EXPORT_SYMBOL(BpGetWirelessLedGpio); ++EXPORT_SYMBOL(BpGetUsbLedGpio); ++EXPORT_SYMBOL(BpGetHpnaLedGpio); ++EXPORT_SYMBOL(BpGetWanDataLedGpio); ++EXPORT_SYMBOL(BpGetPppLedGpio); ++EXPORT_SYMBOL(BpGetPppFailLedGpio); ++EXPORT_SYMBOL(BpGetVoipLedGpio); ++EXPORT_SYMBOL(BpGetWirelessExtIntr); ++EXPORT_SYMBOL(BpGetAdslDyingGaspExtIntr); ++EXPORT_SYMBOL(BpGetVoipExtIntr); ++EXPORT_SYMBOL(BpGetHpnaExtIntr); ++EXPORT_SYMBOL(BpGetHpnaChipSelect); ++EXPORT_SYMBOL(BpGetVoipChipSelect); ++EXPORT_SYMBOL(BpGetWirelessSesBtnGpio); ++EXPORT_SYMBOL(BpGetWirelessSesExtIntr); ++EXPORT_SYMBOL(BpGetWirelessSesLedGpio); ++EXPORT_SYMBOL(kerSysRegisterDyingGaspHandler); ++EXPORT_SYMBOL(kerSysDeregisterDyingGaspHandler); ++EXPORT_SYMBOL(kerSysGetCycleCount); ++EXPORT_SYMBOL(kerSysSetWdTimer); ++EXPORT_SYMBOL(kerSysWakeupMonitorTask); ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,692 @@ ++/************************************************************************/ ++/* */ ++/* AMD CFI Enabled Flash Memory Drivers */ ++/* File name: CFIFLASH.C */ ++/* Revision: 1.0 5/07/98 */ ++/* */ ++/* Copyright (c) 1998 ADVANCED MICRO DEVICES, INC. All Rights Reserved. */ ++/* This software is unpublished and contains the trade secrets and */ ++/* confidential proprietary information of AMD. Unless otherwise */ ++/* provided in the Software Agreement associated herewith, it is */ ++/* licensed in confidence "AS IS" and is not to be reproduced in whole */ ++/* or part by any means except for backup. Use, duplication, or */ ++/* disclosure by the Government is subject to the restrictions in */ ++/* paragraph (b) (3) (B) of the Rights in Technical Data and Computer */ ++/* Software clause in DFAR 52.227-7013 (a) (Oct 1988). */ ++/* Software owned by */ ++/* Advanced Micro Devices, Inc., */ ++/* One AMD Place, */ ++/* P.O. Box 3453 */ ++/* Sunnyvale, CA 94088-3453. */ ++/************************************************************************/ ++/* This software constitutes a basic shell of source code for */ ++/* programming all AMD Flash components. AMD */ ++/* will not be responsible for misuse or illegal use of this */ ++/* software for devices not supported herein. AMD is providing */ ++/* this source code "AS IS" and will not be responsible for */ ++/* issues arising from incorrect user implementation of the */ ++/* source code herein. It is the user's responsibility to */ ++/* properly design-in this source code. */ ++/* */ ++/************************************************************************/ ++#ifdef _CFE_ ++#include "lib_types.h" ++#include "lib_printf.h" ++#include "lib_string.h" ++#include "cfe_timer.h" ++#define printk printf ++#else // linux ++#include ++#include ++#include ++#endif ++ ++#include "cfiflash.h" ++ ++static int flash_wait(WORD sector, int offset, UINT16 data); ++static UINT16 flash_get_device_id(void); ++static int flash_get_cfi(struct cfi_query *query, UINT16 *cfi_struct, int flashFamily); ++static int flash_write(WORD sector, int offset, byte *buf, int nbytes); ++static void flash_command(int command, WORD sector, int offset, UINT16 data); ++ ++/*********************************************************************/ ++/* 'meminfo' should be a pointer, but most C compilers will not */ ++/* allocate static storage for a pointer without calling */ ++/* non-portable functions such as 'new'. We also want to avoid */ ++/* the overhead of passing this pointer for every driver call. */ ++/* Systems with limited heap space will need to do this. */ ++/*********************************************************************/ ++struct flashinfo meminfo; /* Flash information structure */ ++static int flashFamily = FLASH_UNDEFINED; ++static int totalSize = 0; ++static struct cfi_query query; ++ ++static UINT16 cfi_data_struct_29W160[] = { ++ 0x0020, 0x0049, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0x0051, 0x0052, 0x0059, 0x0002, 0x0000, 0x0040, 0x0000, 0x0000, ++ 0x0000, 0x0000, 0x0000, 0x0027, 0x0036, 0x0000, 0x0000, 0x0004, ++ 0x0000, 0x000a, 0x0000, 0x0004, 0x0000, 0x0003, 0x0000, 0x0015, ++ 0x0002, 0x0000, 0x0000, 0x0000, 0x0004, 0x0000, 0x0000, 0x0040, ++ 0x0000, 0x0001, 0x0000, 0x0020, 0x0000, 0x0000, 0x0000, 0x0080, ++ 0x0000, 0x001e, 0x0000, 0x0000, 0x0001, 0xffff, 0xffff, 0xffff, ++ 0x0050, 0x0052, 0x0049, 0x0031, 0x0030, 0x0000, 0x0002, 0x0001, ++ 0x0001, 0x0004, 0x0000, 0x0000, 0x0000, 0xffff, 0xffff, 0x0002, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0x0888, 0x252b, 0x8c84, 0x7dbc, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff ++}; ++ ++ ++/*********************************************************************/ ++/* Init_flash is used to build a sector table from the information */ ++/* provided through the CFI query. This information is translated */ ++/* from erase_block information to base:offset information for each */ ++/* individual sector. This information is then stored in the meminfo */ ++/* structure, and used throughout the driver to access sector */ ++/* information. */ ++/* */ ++/* This is more efficient than deriving the sector base:offset */ ++/* information every time the memory map switches (since on the */ ++/* development platform can only map 64k at a time). If the entire */ ++/* flash memory array can be mapped in, then the addition static */ ++/* allocation for the meminfo structure can be eliminated, but the */ ++/* drivers will have to be re-written. */ ++/* */ ++/* The meminfo struct occupies 653 bytes of heap space, depending */ ++/* on the value of the define MAXSECTORS. Adjust to suit */ ++/* application */ ++/*********************************************************************/ ++byte flash_init(void) ++{ ++ int i=0, j=0, count=0; ++ int basecount=0L; ++ UINT16 device_id; ++ int flipCFIGeometry = FALSE; ++ ++ /* First, assume ++ * a single 8k sector for sector 0. This is to allow ++ * the system to perform memory mapping to the device, ++ * even though the actual physical layout is unknown. ++ * Once mapped in, the CFI query will produce all ++ * relevant information. ++ */ ++ meminfo.addr = 0L; ++ meminfo.areg = 0; ++ meminfo.nsect = 1; ++ meminfo.bank1start = 0; ++ meminfo.bank2start = 0; ++ ++ meminfo.sec[0].size = 8192; ++ meminfo.sec[0].base = 0x00000; ++ meminfo.sec[0].bank = 1; ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ ++ device_id = flash_get_device_id(); ++ ++ switch (device_id) { ++ case ID_I28F160C3B: ++ case ID_I28F320C3B: ++ case ID_I28F160C3T: ++ case ID_I28F320C3T: ++ flashFamily = FLASH_INTEL; ++ break; ++ case ID_AM29DL800B: ++ case ID_AM29LV800B: ++ case ID_AM29LV400B: ++ case ID_AM29LV160B: ++ case ID_AM29LV320B: ++ case ID_MX29LV320AB: ++ case ID_AM29LV320MB: ++ case ID_AM29DL800T: ++ case ID_AM29LV800T: ++ case ID_AM29LV160T: ++ case ID_AM29LV320T: ++ case ID_MX29LV320AT: ++ case ID_AM29LV320MT: ++ flashFamily = FLASH_AMD; ++ break; ++ case ID_SST39VF1601: ++ case ID_SST39VF3201: ++ flashFamily = FLASH_SST; ++ break; ++ default: ++ printk("Flash memory not supported! Device id = %x\n", device_id); ++ return -1; ++ } ++ ++ if (flash_get_cfi(&query, 0, flashFamily) == -1) { ++ switch(device_id) { ++ case ID_AM29LV160T: ++ case ID_AM29LV160B: ++ flash_get_cfi(&query, cfi_data_struct_29W160, flashFamily); ++ break; ++ default: ++ printk("CFI data structure not found. Device id = %x\n", device_id); ++ return -1; ++ } ++ } ++ ++ // need to determine if it top or bottom boot here ++ switch (device_id) ++ { ++ case ID_AM29DL800B: ++ case ID_AM29LV800B: ++ case ID_AM29LV400B: ++ case ID_AM29LV160B: ++ case ID_AM29LV320B: ++ case ID_MX29LV320AB: ++ case ID_AM29LV320MB: ++ case ID_I28F160C3B: ++ case ID_I28F320C3B: ++ case ID_I28F160C3T: ++ case ID_I28F320C3T: ++ case ID_SST39VF1601: ++ case ID_SST39VF3201: ++ flipCFIGeometry = FALSE; ++ break; ++ case ID_AM29DL800T: ++ case ID_AM29LV800T: ++ case ID_AM29LV160T: ++ case ID_AM29LV320T: ++ case ID_MX29LV320AT: ++ case ID_AM29LV320MT: ++ flipCFIGeometry = TRUE; ++ break; ++ default: ++ printk("Flash memory not supported! Device id = %x\n", device_id); ++ return -1; ++ } ++ ++ count=0;basecount=0L; ++ ++ if (!flipCFIGeometry) ++ { ++ for (i=0; i= 0; i--) { ++ for(j=0; j relative_addr ) ++ { ++ blk_start--; // last blk, dec by 1 ++ } ++ else ++ if( blk_start == last_blk ) ++ { ++ printk("Address is too big.\n"); ++ blk_start = -1; ++ } ++ ++ return( blk_start ); ++} ++ ++/************************************************************************/ ++/* The purpose of flash_get_total_size() is to return the total size of */ ++/* the flash */ ++/************************************************************************/ ++int flash_get_total_size() ++{ ++ return totalSize; ++} ++ ++/*********************************************************************/ ++/* Flash_command() is the main driver function. It performs */ ++/* every possible command available to AMD B revision */ ++/* flash parts. Note that this command is not used directly, but */ ++/* rather called through the API wrapper functions provided below. */ ++/*********************************************************************/ ++static void flash_command(int command, WORD sector, int offset, UINT16 data) ++{ ++ volatile UINT16 *flashptr; ++ volatile UINT16 *flashbase; ++ ++ flashptr = (UINT16 *) flash_get_memptr(sector); ++ flashbase = (UINT16 *) flash_get_memptr(0); ++ ++ switch (flashFamily) { ++ case FLASH_UNDEFINED: ++ /* These commands should work for AMD, Intel and SST flashes */ ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xF0; ++ flashptr[0] = 0xFF; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0x5555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AAA] = 0x55; /* unlock 2 */ ++ flashptr[0x5555] = 0x90; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_AMD: ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xF0; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashptr[0x55] = 0x98; ++ break; ++ case FLASH_UB: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x20; ++ break; ++ case FLASH_PROG: ++ flashptr[0] = 0xA0; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_UBRESET: ++ flashptr[0] = 0x90; ++ flashptr[0] = 0x00; ++ break; ++ case FLASH_SERASE: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x80; ++ flashptr[0x555] = 0xAA; ++ flashptr[0x2AA] = 0x55; ++ flashptr[0] = 0x30; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_INTEL: ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xFF; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashptr[0] = 0x98; ++ break; ++ case FLASH_PROG: ++ flashptr[0] = 0x40; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_SERASE: ++ flashptr[0] = 0x60; ++ flashptr[0] = 0xD0; ++ flashptr[0] = 0x20; ++ flashptr[0] = 0xD0; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_SST: ++ switch (command) { ++ case FLASH_RESET: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0xf0; ++ break; ++ case FLASH_READ_ID: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x98; ++ break; ++ case FLASH_UB: ++ break; ++ case FLASH_PROG: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0xa0; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_UBRESET: ++ break; ++ case FLASH_SERASE: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x80; ++ flashbase[0x5555] = 0xAA; ++ flashbase[0x2AAA] = 0x55; ++ flashptr[0] = 0x30; ++ break; ++ default: ++ break; ++ } ++ break; ++ default: ++ break; ++ } ++} ++ ++/*********************************************************************/ ++/* flash_write extends the functionality of flash_program() by */ ++/* providing an faster way to program multiple data words, without */ ++/* needing the function overhead of looping algorithms which */ ++/* program word by word. This function utilizes fast pointers */ ++/* to quickly loop through bulk data. */ ++/*********************************************************************/ ++static int flash_write(WORD sector, int offset, byte *buf, int nbytes) ++{ ++ UINT16 *src; ++ src = (UINT16 *)buf; ++ ++ if ((nbytes | offset) & 1) { ++ return -1; ++ } ++ ++ flash_command(FLASH_UB, 0, 0, 0); ++ while (nbytes > 0) { ++ flash_command(FLASH_PROG, sector, offset, *src); ++ if (flash_wait(sector, offset, *src) != STATUS_READY) ++ break; ++ offset +=2; ++ nbytes -=2; ++ src++; ++ } ++ flash_command(FLASH_UBRESET, 0, 0, 0); ++ ++ return (byte*)src - buf; ++} ++ ++/*********************************************************************/ ++/* flash_wait utilizes the DQ6, DQ5, and DQ2 polling algorithms */ ++/* described in the flash data book. It can quickly ascertain the */ ++/* operational status of the flash device, and return an */ ++/* appropriate status code (defined in flash.h) */ ++/*********************************************************************/ ++static int flash_wait(WORD sector, int offset, UINT16 data) ++{ ++ volatile UINT16 *flashptr; /* flash window */ ++ UINT16 d1; ++ ++ flashptr = (UINT16 *) flash_get_memptr(sector); ++ ++ if (flashFamily == FLASH_AMD || flashFamily == FLASH_SST) { ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ do { ++ d1 = flashptr[offset/2]; ++ if (d1 == data) ++ return STATUS_READY; ++ } while (!(d1 & 0x20)); ++ ++ d1 = flashptr[offset/2]; ++ ++ if (d1 != data) { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++#else ++ do { ++ d1 = *flashptr; /* read data */ ++ d1 ^= *flashptr; /* read it again and see what toggled */ ++ if (d1 == 0) /* no toggles, nothing's happening */ ++ return STATUS_READY; ++ } while (!(d1 & 0x20)); ++ ++ d1 = *flashptr; /* read data */ ++ d1 ^= *flashptr; /* read it again and see what toggled */ ++ ++ if (d1 != 0) { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++#endif ++ } else if (flashFamily == FLASH_INTEL) { ++ flashptr[0] = 0x70; ++ /* Wait for completion */ ++ while(!(*flashptr & 0x80)); ++ if (*flashptr & 0x30) { ++ flashptr[0] = 0x50; ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++ flashptr[0] = 0x50; ++ flash_command(FLASH_RESET, 0, 0, 0); ++ } ++ ++ return STATUS_READY; ++} ++ ++/*********************************************************************/ ++/* flash_get_device_id() will perform an autoselect sequence on the */ ++/* flash device, and return the device id of the component. */ ++/* This function automatically resets to read mode. */ ++/*********************************************************************/ ++static UINT16 flash_get_device_id() ++{ ++ volatile UINT16 *fwp; /* flash window */ ++ UINT16 answer; ++ ++ fwp = (UINT16 *)flash_get_memptr(0); ++ ++ flash_command(FLASH_READ_ID, 0, 0, 0); ++ answer = *(fwp + 1); ++ if (answer == ID_AM29LV320M) { ++ answer = *(fwp + 0xe); ++ answer = *(fwp + 0xf); ++ } ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return( (UINT16) answer ); ++} ++ ++/*********************************************************************/ ++/* flash_get_cfi() is the main CFI workhorse function. Due to it's */ ++/* complexity and size it need only be called once upon */ ++/* initializing the flash system. Once it is called, all operations */ ++/* are performed by looking at the meminfo structure. */ ++/* All possible care was made to make this algorithm as efficient as */ ++/* possible. 90% of all operations are memory reads, and all */ ++/* calculations are done using bit-shifts when possible */ ++/*********************************************************************/ ++static int flash_get_cfi(struct cfi_query *query, UINT16 *cfi_struct, int flashFamily) ++{ ++ volatile UINT16 *fwp; /* flash window */ ++ int i=0; ++ ++ flash_command(FLASH_CFIQUERY, 0, 0, 0); ++ ++ if (cfi_struct == 0) ++ fwp = (UINT16 *)flash_get_memptr(0); ++ else ++ fwp = cfi_struct; ++ ++ /* Initial house-cleaning */ ++ for(i=0; i < 8; i++) { ++ query->erase_block[i].sector_size = 0; ++ query->erase_block[i].num_sectors = 0; ++ } ++ ++ /* If not 'QRY', then we dont have a CFI enabled device in the socket */ ++ if( fwp[0x10] != 'Q' && ++ fwp[0x11] != 'R' && ++ fwp[0x12] != 'Y') { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return(-1); ++ } ++ ++ query->num_erase_blocks = fwp[0x2C]; ++ if(flashFamily == FLASH_SST) ++ query->num_erase_blocks = 1; ++ ++ for(i=0; i < query->num_erase_blocks; i++) { ++ query->erase_block[i].num_sectors = fwp[(0x2D+(4*i))] + (fwp[0x2E + (4*i)] << 8); ++ query->erase_block[i].num_sectors++; ++ query->erase_block[i].sector_size = 256 * (256 * fwp[(0x30+(4*i))] + fwp[(0x2F+(4*i))]); ++ } ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return(1); ++} +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.h +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/bcm96348/cfiflash.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,150 @@ ++/************************************************************************/ ++/* */ ++/* AMD CFI Enabled Flash Memory Drivers */ ++/* File name: CFIFLASH.H */ ++/* Revision: 1.0 5/07/98 */ ++/* */ ++/* Copyright (c) 1998 ADVANCED MICRO DEVICES, INC. All Rights Reserved. */ ++/* This software is unpublished and contains the trade secrets and */ ++/* confidential proprietary information of AMD. Unless otherwise */ ++/* provided in the Software Agreement associated herewith, it is */ ++/* licensed in confidence "AS IS" and is not to be reproduced in whole */ ++/* or part by any means except for backup. Use, duplication, or */ ++/* disclosure by the Government is subject to the restrictions in */ ++/* paragraph (b) (3) (B) of the Rights in Technical Data and Computer */ ++/* Software clause in DFAR 52.227-7013 (a) (Oct 1988). */ ++/* Software owned by */ ++/* Advanced Micro Devices, Inc., */ ++/* One AMD Place, */ ++/* P.O. Box 3453 */ ++/* Sunnyvale, CA 94088-3453. */ ++/************************************************************************/ ++/* This software constitutes a basic shell of source code for */ ++/* programming all AMD Flash components. AMD */ ++/* will not be responsible for misuse or illegal use of this */ ++/* software for devices not supported herein. AMD is providing */ ++/* this source code "AS IS" and will not be responsible for */ ++/* issues arising from incorrect user implementation of the */ ++/* source code herein. It is the user's responsibility to */ ++/* properly design-in this source code. */ ++/* */ ++/************************************************************************/ ++#ifndef _CFIFLASH_H ++#define _CFIFLASH_H ++ ++#if defined __cplusplus ++extern "C" { ++#endif ++ ++/* include board/CPU specific definitions */ ++#include "bcmtypes.h" ++#include "board.h" ++ ++#define FLASH_BASE_ADDR_REG FLASH_BASE ++ ++#ifndef NULL ++#define NULL 0 ++#endif ++ ++#define MAXSECTORS 1024 /* maximum number of sectors supported */ ++ ++/* A structure for identifying a flash part. There is one for each ++ * of the flash part definitions. We need to keep track of the ++ * sector organization, the address register used, and the size ++ * of the sectors. ++ */ ++struct flashinfo { ++ char *name; /* "Am29DL800T", etc. */ ++ unsigned long addr; /* physical address, once translated */ ++ int areg; /* Can be set to zero for all parts */ ++ int nsect; /* # of sectors -- 19 in LV, 22 in DL */ ++ int bank1start; /* first sector # in bank 1 */ ++ int bank2start; /* first sector # in bank 2, if DL part */ ++ struct { ++ long size; /* # of bytes in this sector */ ++ long base; /* offset from beginning of device */ ++ int bank; /* 1 or 2 for DL; 1 for LV */ ++ } sec[MAXSECTORS]; /* per-sector info */ ++}; ++ ++/* ++ * This structure holds all CFI query information as defined ++ * in the JEDEC standard. All information up to ++ * primary_extended_query is standard among all manufactures ++ * with CFI enabled devices. ++ */ ++ ++struct cfi_query { ++ int num_erase_blocks; /* Number of sector defs. */ ++ struct { ++ unsigned long sector_size; /* byte size of sector */ ++ int num_sectors; /* Num sectors of this size */ ++ } erase_block[8]; /* Max of 256, but 8 is good */ ++}; ++ ++/* Standard Boolean declarations */ ++#define TRUE 1 ++#define FALSE 0 ++ ++/* Define different type of flash */ ++#define FLASH_UNDEFINED 0 ++#define FLASH_AMD 1 ++#define FLASH_INTEL 2 ++#define FLASH_SST 3 ++ ++/* Command codes for the flash_command routine */ ++#define FLASH_RESET 0 /* reset to read mode */ ++#define FLASH_READ_ID 1 /* read device ID */ ++#define FLASH_CFIQUERY 2 /* CFI query */ ++#define FLASH_UB 3 /* go into unlock bypass mode */ ++#define FLASH_PROG 4 /* program a word */ ++#define FLASH_UBRESET 5 /* reset to read mode from unlock bypass mode */ ++#define FLASH_SERASE 6 /* sector erase */ ++ ++/* Return codes from flash_status */ ++#define STATUS_READY 0 /* ready for action */ ++#define STATUS_TIMEOUT 1 /* operation timed out */ ++ ++/* A list of AMD compatible device ID's - add others as needed */ ++#define ID_AM29DL800T 0x224A ++#define ID_AM29DL800B 0x22CB ++#define ID_AM29LV800T 0x22DA ++#define ID_AM29LV800B 0x225B ++#define ID_AM29LV400B 0x22BA ++ ++#define ID_AM29LV160B 0x2249 ++#define ID_AM29LV160T 0x22C4 ++ ++#define ID_AM29LV320T 0x22F6 ++#define ID_MX29LV320AT 0x22A7 ++#define ID_AM29LV320B 0x22F9 ++#define ID_MX29LV320AB 0x22A8 ++ ++#define ID_AM29LV320M 0x227E ++#define ID_AM29LV320MB 0x2200 ++#define ID_AM29LV320MT 0x2201 ++ ++#define ID_SST39VF1601 0x234B ++#define ID_SST39VF3201 0x235B ++ ++/* A list of Intel compatible device ID's - add others as needed */ ++#define ID_I28F160C3T 0x88C2 ++#define ID_I28F160C3B 0x88C3 ++#define ID_I28F320C3T 0x88C4 ++#define ID_I28F320C3B 0x88C5 ++ ++extern byte flash_init(void); ++extern int flash_write_buf(WORD sector, int offset, byte *buffer, int numbytes); ++extern int flash_read_buf(WORD sector, int offset, byte *buffer, int numbytes); ++extern byte flash_sector_erase_int(WORD sector); ++extern int flash_get_numsectors(void); ++extern int flash_get_sector_size(WORD sector); ++extern int flash_get_total_size(void); ++extern unsigned char *flash_get_memptr(WORD sector); ++extern int flash_get_blk(int addr); ++ ++#if defined __cplusplus ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/Makefile +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,17 @@ ++# Makefile for the bcm963xx board drivers ++# ++ ++ ++obj-y := board.o cfiflash.o bcm63xx_flash.o bcm63xx_led.o ++ ++EXTRA_CFLAGS += -I. -I$(INC_BRCMBOARDPARMS_PATH)/$(BRCM_BOARD) -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++ ++ifeq ($(strip $(WIRELESS)),1) ++ EXTRA_CFLAGS += -DWIRELESS ++endif ++ ++-include $(TOPDIR)/Rules.make ++ ++clean: ++ rm -f core *.o *.a *.s ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_flash.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_flash.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_flash.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_flash.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,775 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/* ++ *************************************************************************** ++ * File Name : bcm63xx_flash.c ++ * ++ * Description: This file contains the flash device driver APIs for bcm63xx board. ++ * ++ * Created on : 8/10/2002 seanl: use cfiflash.c, cfliflash.h (AMD specific) ++ * ++ ***************************************************************************/ ++ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#define BCMTAG_EXE_USE ++#include ++#include "cfiflash.h" ++#include "boardparms.h" ++ ++//#define DEBUG_FLASH ++ ++static FLASH_ADDR_INFO fInfo; ++static int flashInitialized = 0; ++ ++void *retriedKmalloc(size_t size) ++{ ++ void *pBuf; ++ int tryCount = 0; ++ ++ // try 1000 times before quit ++ while (((pBuf = kmalloc(size, GFP_KERNEL)) == NULL) && (tryCount++ < 1000)) ++ { ++ current->state = TASK_INTERRUPTIBLE; ++ schedule_timeout(HZ/10); ++ } ++ if (tryCount >= 1000) ++ pBuf = NULL; ++ else ++ memset(pBuf, 0, size); ++ ++ return pBuf; ++} ++ ++void retriedKfree(void *pBuf) ++{ ++ kfree(pBuf); ++} ++ ++/*************************************************************************** ++// Function Name: getCrc32 ++// Description : caculate the CRC 32 of the given data. ++// Parameters : pdata - array of data. ++// size - number of input data bytes. ++// crc - either CRC32_INIT_VALUE or previous return value. ++// Returns : crc. ++****************************************************************************/ ++UINT32 getCrc32(byte *pdata, UINT32 size, UINT32 crc) ++{ ++ while (size-- > 0) ++ crc = (crc >> 8) ^ Crc32_table[(crc ^ *pdata++) & 0xff]; ++ ++ return crc; ++} ++ ++// get the nvram start addr ++// ++unsigned long get_nvram_start_addr(void) ++{ ++ return ((unsigned long) ++ (flash_get_memptr(fInfo.flash_nvram_start_blk) + fInfo.flash_nvram_blk_offset)); ++} ++ ++// get the scratch_pad start addr ++// ++unsigned long get_scratch_pad_start_addr(void) ++{ ++ return ((unsigned long) ++ (flash_get_memptr(fInfo.flash_scratch_pad_start_blk) + fInfo.flash_scratch_pad_blk_offset)); ++} ++ ++ ++ ++/* ********************************************************************* ++ * kerSysImageTagGet() ++ * Get the image tag ++ * Input parameters: ++ * none ++ * Return value: ++ * point to tag -- Found ++ * NULL -- failed ++ ********************************************************************* */ ++PFILE_TAG kerSysImageTagGet(void) ++{ ++ int i; ++ int totalBlks = flash_get_numsectors(); ++ UINT32 crc; ++ unsigned char *sectAddr; ++ PFILE_TAG pTag; ++ ++#if defined(DEBUG_FLASH) ++ printk("totalblks in tagGet=%d\n", totalBlks); ++#endif ++ ++ // start from 2nd blk, assume 1st one is always CFE ++ for (i = 1; i < totalBlks; i++) ++ { ++ sectAddr = flash_get_memptr((byte) i); ++ crc = CRC32_INIT_VALUE; ++ crc = getCrc32(sectAddr, (UINT32)TAG_LEN-TOKEN_LEN, crc); ++ pTag = (PFILE_TAG) sectAddr; ++ ++#if defined(DEBUG_FLASH) ++ printk("Check Tag crc on blk [%d]\n", i); ++#endif ++ ++ if (crc == (UINT32)(*(UINT32*)(pTag->tagValidationToken))) ++ return pTag; ++ } ++ ++ return (PFILE_TAG) NULL; ++} ++ ++// Initialize the flash and fill out the fInfo structure ++void kerSysFlashInit( void ) ++{ ++ int i = 0; ++ int totalBlks = 0; ++ int totalSize = 0; ++ int startAddr = 0; ++ int usedBlkSize = 0; ++ NVRAM_DATA nvramData; ++ UINT32 crc = CRC32_INIT_VALUE, savedCrc; ++ PFILE_TAG pTag = NULL; ++ unsigned long kernelEndAddr = 0; ++ unsigned long spAddr = 0; ++ ++ if (flashInitialized) ++ return; ++ ++ flashInitialized = 1; ++ flash_init(); ++ ++ totalBlks = flash_get_numsectors(); ++ totalSize = flash_get_total_size(); ++ ++ printk("Total Flash size: %dK with %d sectors\n", totalSize/1024, totalBlks); ++ ++ /* nvram is always at the end of flash */ ++ fInfo.flash_nvram_length = FLASH45_LENGTH_NVRAM; ++ fInfo.flash_nvram_start_blk = 0; /* always the first block */ ++ fInfo.flash_nvram_number_blk = 1; /*always fits in the first block */ ++ fInfo.flash_nvram_blk_offset = NVRAM_DATA_OFFSET; ++ ++ // check nvram CRC ++ memcpy((char *)&nvramData, (char *)get_nvram_start_addr(), sizeof(NVRAM_DATA)); ++ savedCrc = nvramData.ulCheckSum; ++ nvramData.ulCheckSum = 0; ++ crc = getCrc32((char *)&nvramData, (UINT32) sizeof(NVRAM_DATA), crc); ++ ++ BpSetBoardId( nvramData.szBoardId ); ++ ++ fInfo.flash_persistent_length = NVRAM_PSI_DEFAULT; ++ if (savedCrc != crc) ++ { ++ printk("***Board is not initialized****: Using the default PSI size: %d\n", ++ fInfo.flash_persistent_length); ++ } ++ else ++ { ++ unsigned long ulPsiSize; ++ if( BpGetPsiSize( &ulPsiSize ) == BP_SUCCESS ) ++ fInfo.flash_persistent_length = ulPsiSize; ++ else ++ { ++ printk("***Board id is not set****: Using the default PSI size: %d\n", ++ fInfo.flash_persistent_length); ++ } ++ } ++ ++ fInfo.flash_persistent_length *= ONEK; ++ startAddr = totalSize - fInfo.flash_persistent_length; ++ fInfo.flash_persistent_start_blk = flash_get_blk(startAddr+FLASH_BASE_ADDR_REG); ++ fInfo.flash_persistent_number_blk = totalBlks - fInfo.flash_persistent_start_blk; ++ // save abs SP address (Scratch Pad). it is before PSI ++ spAddr = startAddr - SP_MAX_LEN ; ++ // find out the offset in the start_blk ++ usedBlkSize = 0; ++ for (i = fInfo.flash_persistent_start_blk; ++ i < (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk); i++) ++ { ++ usedBlkSize += flash_get_sector_size((byte) i); ++ } ++ fInfo.flash_persistent_blk_offset = usedBlkSize - fInfo.flash_persistent_length; ++ ++ // get the info for sp ++ if (!(pTag = kerSysImageTagGet())) ++ { ++ printk("Failed to read image tag from flash\n"); ++ return; ++ } ++ kernelEndAddr = (unsigned long) simple_strtoul(pTag->kernelAddress, NULL, 10) + \ ++ (unsigned long) simple_strtoul(pTag->kernelLen, NULL, 10); ++ ++ // make suer sp does not share kernel block ++ fInfo.flash_scratch_pad_start_blk = flash_get_blk(spAddr+FLASH_BASE_ADDR_REG); ++ if (fInfo.flash_scratch_pad_start_blk != flash_get_blk(kernelEndAddr)) ++ { ++ fInfo.flash_scratch_pad_length = SP_MAX_LEN; ++ if (fInfo.flash_persistent_start_blk == fInfo.flash_scratch_pad_start_blk) // share blk ++ { ++#if 1 /* do not used scratch pad unless it's in its own sector */ ++ printk("Scratch pad is not used for this flash part.\n"); ++ fInfo.flash_scratch_pad_length = 0; // no sp ++#else /* allow scratch pad to share a sector with another section such as PSI */ ++ fInfo.flash_scratch_pad_number_blk = 1; ++ fInfo.flash_scratch_pad_blk_offset = fInfo.flash_persistent_blk_offset - fInfo.flash_scratch_pad_length; ++#endif ++ } ++ else // on different blk ++ { ++ fInfo.flash_scratch_pad_number_blk = fInfo.flash_persistent_start_blk\ ++ - fInfo.flash_scratch_pad_start_blk; ++ // find out the offset in the start_blk ++ usedBlkSize = 0; ++ for (i = fInfo.flash_scratch_pad_start_blk; ++ i < (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk); i++) ++ usedBlkSize += flash_get_sector_size((byte) i); ++ fInfo.flash_scratch_pad_blk_offset = usedBlkSize - fInfo.flash_scratch_pad_length; ++ } ++ } ++ else ++ { ++ printk("No flash for scratch pad!\n"); ++ fInfo.flash_scratch_pad_length = 0; // no sp ++ } ++ ++#if defined(DEBUG_FLASH) ++ printk("fInfo.flash_scratch_pad_start_blk = %d\n", fInfo.flash_scratch_pad_start_blk); ++ printk("fInfo.flash_scratch_pad_number_blk = %d\n", fInfo.flash_scratch_pad_number_blk); ++ printk("fInfo.flash_scratch_pad_length = 0x%x\n", fInfo.flash_scratch_pad_length); ++ printk("fInfo.flash_scratch_pad_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_scratch_pad_blk_offset); ++ ++ printk("fInfo.flash_nvram_start_blk = %d\n", fInfo.flash_nvram_start_blk); ++ printk("fInfo.flash_nvram_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_nvram_blk_offset); ++ printk("fInfo.flash_nvram_number_blk = %d\n", fInfo.flash_nvram_number_blk); ++ ++ printk("psi startAddr = %x\n", startAddr+FLASH_BASE_ADDR_REG); ++ printk("fInfo.flash_persistent_start_blk = %d\n", fInfo.flash_persistent_start_blk); ++ printk("fInfo.flash_persistent_blk_offset = 0x%x\n", (unsigned int)fInfo.flash_persistent_blk_offset); ++ printk("fInfo.flash_persistent_number_blk = %d\n", fInfo.flash_persistent_number_blk); ++#endif ++ ++} ++ ++ ++ ++/*********************************************************************** ++ * Function Name: kerSysFlashAddrInfoGet ++ * Description : Fills in a structure with information about the NVRAM ++ * and persistent storage sections of flash memory. ++ * Fro physmap.c to mount the fs vol. ++ * Returns : None. ++ ***********************************************************************/ ++void kerSysFlashAddrInfoGet(PFLASH_ADDR_INFO pflash_addr_info) ++{ ++ pflash_addr_info->flash_nvram_blk_offset = fInfo.flash_nvram_blk_offset; ++ pflash_addr_info->flash_nvram_length = fInfo.flash_nvram_length; ++ pflash_addr_info->flash_nvram_number_blk = fInfo.flash_nvram_number_blk; ++ pflash_addr_info->flash_nvram_start_blk = fInfo.flash_nvram_start_blk; ++ pflash_addr_info->flash_persistent_blk_offset = fInfo.flash_persistent_blk_offset; ++ pflash_addr_info->flash_persistent_length = fInfo.flash_persistent_length; ++ pflash_addr_info->flash_persistent_number_blk = fInfo.flash_persistent_number_blk; ++ pflash_addr_info->flash_persistent_start_blk = fInfo.flash_persistent_start_blk; ++} ++ ++ ++// get shared blks into *** pTempBuf *** which has to be released bye the caller! ++// return: if pTempBuf != NULL, poits to the data with the dataSize of the buffer ++// !NULL -- ok ++// NULL -- fail ++static char *getSharedBlks(int start_blk, int end_blk) ++{ ++ int i = 0; ++ int usedBlkSize = 0; ++ int sect_size = 0; ++ char *pTempBuf = NULL; ++ char *pBuf = NULL; ++ ++ for (i = start_blk; i < end_blk; i++) ++ usedBlkSize += flash_get_sector_size((byte) i); ++ ++#if defined(DEBUG_FLASH) ++ printk("usedBlkSize = %d\n", usedBlkSize); ++#endif ++ ++ if ((pTempBuf = (char *) retriedKmalloc(usedBlkSize)) == NULL) ++ { ++ printk("failed to allocate memory with size: %d\n", usedBlkSize); ++ return pTempBuf; ++ } ++ ++ pBuf = pTempBuf; ++ for (i = start_blk; i < end_blk; i++) ++ { ++ sect_size = flash_get_sector_size((byte) i); ++ ++#if defined(DEBUG_FLASH) ++ printk("i = %d, sect_size = %d, end_blk = %d\n", i, sect_size, end_blk); ++#endif ++ flash_read_buf((byte)i, 0, pBuf, sect_size); ++ pBuf += sect_size; ++ } ++ ++ return pTempBuf; ++} ++ ++ ++ ++// Set the pTempBuf to flash from start_blk to end_blk ++// return: ++// 0 -- ok ++// -1 -- fail ++static int setSharedBlks(int start_blk, int end_blk, char *pTempBuf) ++{ ++ int i = 0; ++ int sect_size = 0; ++ int sts = 0; ++ char *pBuf = pTempBuf; ++ ++ for (i = start_blk; i < end_blk; i++) ++ { ++ sect_size = flash_get_sector_size((byte) i); ++ flash_sector_erase_int(i); ++ if (flash_write_buf(i, 0, pBuf, sect_size) != sect_size) ++ { ++ printk("Error writing flash sector %d.", i); ++ sts = -1; ++ break; ++ } ++ pBuf += sect_size; ++ } ++ ++ return sts; ++} ++ ++ ++ ++/******************************************************************************* ++ * NVRAM functions ++ *******************************************************************************/ ++ ++// get nvram data ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysNvRamGet(char *string, int strLen, int offset) ++{ ++ char *pBuf = NULL; ++ ++ if (!flashInitialized) ++ kerSysFlashInit(); ++ ++ if (strLen > FLASH45_LENGTH_NVRAM) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_start_blk + fInfo.flash_nvram_number_blk))) == NULL) ++ return -1; ++ ++ // get string off the memory buffer ++ memcpy(string, (pBuf + fInfo.flash_nvram_blk_offset + offset), strLen); ++ ++ retriedKfree(pBuf); ++ ++ return 0; ++} ++ ++ ++// set nvram ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysNvRamSet(char *string, int strLen, int offset) ++{ ++ int sts = 0; ++ char *pBuf = NULL; ++ ++ if (strLen > FLASH45_LENGTH_NVRAM) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_start_blk + fInfo.flash_nvram_number_blk))) == NULL) ++ return -1; ++ ++ // set string to the memory buffer ++ memcpy((pBuf + fInfo.flash_nvram_blk_offset + offset), string, strLen); ++ ++ if (setSharedBlks(fInfo.flash_nvram_start_blk, ++ (fInfo.flash_nvram_number_blk + fInfo.flash_nvram_start_blk), pBuf) != 0) ++ sts = -1; ++ ++ retriedKfree(pBuf); ++ ++ return sts; ++} ++ ++ ++/*********************************************************************** ++ * Function Name: kerSysEraseNvRam ++ * Description : Erase the NVRAM storage section of flash memory. ++ * Returns : 1 -- ok, 0 -- fail ++ ***********************************************************************/ ++int kerSysEraseNvRam(void) ++{ ++ int sts = 1; ++ char *tempStorage = retriedKmalloc(FLASH45_LENGTH_NVRAM); ++ ++ // just write the whole buf with '0xff' to the flash ++ if (!tempStorage) ++ sts = 0; ++ else ++ { ++ memset(tempStorage, 0xff, FLASH45_LENGTH_NVRAM); ++ if (kerSysNvRamSet(tempStorage, FLASH45_LENGTH_NVRAM, 0) != 0) ++ sts = 0; ++ retriedKfree(tempStorage); ++ } ++ ++ return sts; ++} ++ ++ ++/******************************************************************************* ++ * PSI functions ++ *******************************************************************************/ ++// get psi data ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysPersistentGet(char *string, int strLen, int offset) ++{ ++ char *pBuf = NULL; ++ ++ if (strLen > fInfo.flash_persistent_length) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk))) == NULL) ++ return -1; ++ ++ // get string off the memory buffer ++ memcpy(string, (pBuf + fInfo.flash_persistent_blk_offset + offset), strLen); ++ ++ retriedKfree(pBuf); ++ ++ return 0; ++} ++ ++ ++// set psi ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysPersistentSet(char *string, int strLen, int offset) ++{ ++ int sts = 0; ++ char *pBuf = NULL; ++ ++ if (strLen > fInfo.flash_persistent_length) ++ return -1; ++ ++ if ((pBuf = getSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_start_blk + fInfo.flash_persistent_number_blk))) == NULL) ++ return -1; ++ ++ // set string to the memory buffer ++ memcpy((pBuf + fInfo.flash_persistent_blk_offset + offset), string, strLen); ++ ++ if (setSharedBlks(fInfo.flash_persistent_start_blk, ++ (fInfo.flash_persistent_number_blk + fInfo.flash_persistent_start_blk), pBuf) != 0) ++ sts = -1; ++ ++ retriedKfree(pBuf); ++ ++ return sts; ++} ++ ++ ++// flash bcm image ++// return: ++// 0 - ok ++// !0 - the sector number fail to be flashed (should not be 0) ++int kerSysBcmImageSet( int flash_start_addr, char *string, int size) ++{ ++ int sts; ++ int sect_size; ++ int blk_start; ++ int i; ++ char *pTempBuf = NULL; ++ int whole_image = 0; ++ ++ blk_start = flash_get_blk(flash_start_addr); ++ if( blk_start < 0 ) ++ return( -1 ); ++ ++ if (flash_start_addr == FLASH_BASE && size > FLASH45_LENGTH_BOOT_ROM) ++ whole_image = 1; ++ ++ /* write image to flash memory */ ++ do ++ { ++ sect_size = flash_get_sector_size(blk_start); ++// NOTE: for memory problem in multiple PVC configuration, temporary get rid of kmalloc this 64K for now. ++// if ((pTempBuf = (char *)retriedKmalloc(sect_size)) == NULL) ++// { ++// printk("Failed to allocate memory with size: %d. Reset the router...\n", sect_size); ++// kerSysMipsSoftReset(); // reset the board right away. ++// } ++ // for whole image, no check on psi ++ if (!whole_image && blk_start == fInfo.flash_persistent_start_blk) // share the blk with psi ++ { ++ if (size > (sect_size - fInfo.flash_persistent_length)) ++ { ++ printk("Image is too big\n"); ++ break; // image is too big. Can not overwrite to nvram ++ } ++ if ((pTempBuf = (char *)retriedKmalloc(sect_size)) == NULL) ++ { ++ printk("Failed to allocate memory with size: %d. Reset the router...\n", sect_size); ++ kerSysMipsSoftReset(); // reset the board right away. ++ } ++ flash_read_buf((byte)blk_start, 0, pTempBuf, sect_size); ++ if (copy_from_user((void *)pTempBuf,(void *)string, size) != 0) ++ break; // failed ? ++ flash_sector_erase_int(blk_start); // erase blk before flash ++ if (flash_write_buf(blk_start, 0, pTempBuf, sect_size) == sect_size) ++ size = 0; // break out and say all is ok ++ retriedKfree(pTempBuf); ++ break; ++ } ++ ++ flash_sector_erase_int(blk_start); // erase blk before flash ++ ++ if (sect_size > size) ++ { ++ if (size & 1) ++ size++; ++ sect_size = size; ++ } ++ ++ if ((i = flash_write_buf(blk_start, 0, string, sect_size)) != sect_size) { ++ break; ++ } ++ blk_start++; ++ string += sect_size; ++ size -= sect_size; ++ } while (size > 0); ++ ++ if (whole_image) ++ { ++ // If flashing a whole image, erase to end of flash. ++ int total_blks = flash_get_numsectors(); ++ while( blk_start < total_blks ) ++ { ++ flash_sector_erase_int(blk_start); ++ blk_start++; ++ } ++ } ++ if (pTempBuf) ++ retriedKfree(pTempBuf); ++ ++ if( size == 0 ) ++ sts = 0; // ok ++ else ++ sts = blk_start; // failed to flash this sector ++ ++ return sts; ++} ++ ++/******************************************************************************* ++ * SP functions ++ *******************************************************************************/ ++// get sp data. NOTE: memcpy work here -- not using copy_from/to_user ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysScratchPadGet(char *tokenId, char *tokBuf, int bufLen) ++{ ++ PSP_HEADER pHead = NULL; ++ PSP_TOKEN pToken = NULL; ++ char *pBuf = NULL; ++ char *pShareBuf = NULL; ++ char *startPtr = NULL; ++ char *endPtr = NULL; ++ char *spEndPtr = NULL; ++ int sts = -1; ++ ++ if (fInfo.flash_scratch_pad_length == 0) ++ return sts; ++ ++ if (bufLen >= (fInfo.flash_scratch_pad_length - sizeof(SP_HEADER) - sizeof(SP_TOKEN))) ++ { ++ printk("Exceed scratch pad space by %d\n", bufLen - fInfo.flash_scratch_pad_length \ ++ - sizeof(SP_HEADER) - sizeof(SP_TOKEN)); ++ return sts; ++ } ++ ++ if ((pShareBuf = getSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk))) == NULL) ++ return sts; ++ ++ // pBuf points to SP buf ++ pBuf = pShareBuf + fInfo.flash_scratch_pad_blk_offset; ++ ++ pHead = (PSP_HEADER) pBuf; ++ if (memcmp(pHead->SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN) != 0) ++ { ++ printk("Scrap pad is not initialized.\n"); ++ return sts; ++ } ++ ++ // search up to SPUsedLen for the token ++ startPtr = pBuf + sizeof(SP_HEADER); ++ endPtr = pBuf + pHead->SPUsedLen; ++ spEndPtr = pBuf + SP_MAX_LEN; ++ while (startPtr < endPtr && startPtr < spEndPtr) ++ { ++ pToken = (PSP_TOKEN) startPtr; ++ if (strncmp(pToken->tokenName, tokenId, TOKEN_NAME_LEN) == 0) ++ { ++ memcpy(tokBuf, startPtr + sizeof(SP_TOKEN), bufLen); ++ sts = 0; ++ break; ++ } ++ // get next token ++ startPtr += sizeof(SP_TOKEN) + pToken->tokenLen; ++ } ++ ++ retriedKfree(pShareBuf); ++ ++ return sts; ++} ++ ++ ++// set sp. NOTE: memcpy work here -- not using copy_from/to_user ++// return: ++// 0 - ok ++// -1 - fail ++int kerSysScratchPadSet(char *tokenId, char *tokBuf, int bufLen) ++{ ++ PSP_TOKEN pToken = NULL; ++ PSP_HEADER pHead = NULL; ++ char *pShareBuf = NULL; ++ char *pBuf = NULL; ++ SP_HEADER SPHead; ++ SP_TOKEN SPToken; ++ char *curPtr; ++ int sts = -1; ++ ++ if (fInfo.flash_scratch_pad_length == 0) ++ return sts; ++ ++ if (bufLen >= (fInfo.flash_scratch_pad_length - sizeof(SP_HEADER) - sizeof(SP_TOKEN))) ++ { ++ printk("Exceed scratch pad space by %d\n", bufLen - fInfo.flash_scratch_pad_length \ ++ - sizeof(SP_HEADER) - sizeof(SP_TOKEN)); ++ return sts; ++ } ++ ++ if ((pShareBuf = getSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_start_blk + fInfo.flash_scratch_pad_number_blk))) == NULL) ++ return sts; ++ ++ // pBuf points to SP buf ++ pBuf = pShareBuf + fInfo.flash_scratch_pad_blk_offset; ++ pHead = (PSP_HEADER) pBuf; ++ ++ // form header info. SPUsedLen later on... ++ memset((char *)&SPHead, 0, sizeof(SP_HEADER)); ++ memcpy(SPHead.SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN); ++ SPHead.SPVersion = SP_VERSION; ++ ++ // form token info. ++ memset((char*)&SPToken, 0, sizeof(SP_TOKEN)); ++ strncpy(SPToken.tokenName, tokenId, TOKEN_NAME_LEN - 1); ++ SPToken.tokenLen = bufLen; ++ if (memcmp(pHead->SPMagicNum, MAGIC_NUMBER, MAGIC_NUM_LEN) != 0) ++ { ++ // new sp, so just flash the token ++ printk("No Scrap pad found. Initialize scratch pad...\n"); ++ SPHead.SPUsedLen = sizeof(SP_HEADER) + sizeof(SP_TOKEN) + bufLen; ++ memcpy(pBuf, (char *)&SPHead, sizeof(SP_HEADER)); ++ curPtr = pBuf + sizeof(SP_HEADER); ++ memcpy(curPtr, (char *)&SPToken, sizeof(SP_TOKEN)); ++ curPtr += sizeof(SP_TOKEN); ++ memcpy(curPtr, tokBuf, bufLen); ++ } ++ else ++ { ++ // need search for the token, if exist with same size overwrite it. if sizes differ, ++ // move over the later token data over and put the new one at the end ++ char *endPtr = pBuf + pHead->SPUsedLen; ++ char *spEndPtr = pBuf + SP_MAX_LEN; ++ curPtr = pBuf + sizeof(SP_HEADER); ++ while (curPtr < endPtr && curPtr < spEndPtr) ++ { ++ pToken = (PSP_TOKEN) curPtr; ++ if (strncmp(pToken->tokenName, tokenId, TOKEN_NAME_LEN) == 0) ++ { ++ if (pToken->tokenLen == bufLen) // overwirte it ++ { ++ memcpy((curPtr+sizeof(SP_TOKEN)), tokBuf, bufLen); ++ break; ++ } ++ else // move later data over and put the new token at the end ++ { ++ memcpy((curPtr+sizeof(SP_TOKEN)), tokBuf, bufLen); // ~~~ ++ break; ++ } ++ } ++ else // not same token ~~~ ++ { ++ } ++ // get next token ++ curPtr += sizeof(SP_TOKEN) + pToken->tokenLen; ++ } // end while ++ SPHead.SPUsedLen = sizeof(SP_HEADER) + sizeof(SP_TOKEN) + bufLen; // ~~~ ++ if (SPHead.SPUsedLen > SP_MAX_LEN) ++ { ++ printk("No more Scratch pad space left! Over limit by %d bytes\n", SPHead.SPUsedLen - SP_MAX_LEN); ++ return sts; ++ } ++ ++ } // else if not new sp ++ ++ sts = setSharedBlks(fInfo.flash_scratch_pad_start_blk, ++ (fInfo.flash_scratch_pad_number_blk + fInfo.flash_scratch_pad_start_blk), pShareBuf); ++ ++ retriedKfree(pShareBuf); ++ ++ return sts; ++ ++ ++} ++ ++int kerSysFlashSizeGet(void) ++{ ++ return flash_get_total_size(); ++} ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_led.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_led.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_led.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/bcm63xx_led.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,582 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/*************************************************************************** ++ * File Name : bcm63xx_led.c ++ * ++ * Description: ++ * ++ * This file contains bcm963xx board led control API functions. ++ * ++ * To use it, do the following ++ * ++ * 1). define in the board.c the following led mappping (this is for 6345GW board): ++ * const LED_MAP_PAIR cLedMapping45GW[] = ++ * { // led name Initial state physical pin (ledMask) ++ * {kLedUsb, kLedStateOff, GPIO_LED_PIN_7}, ++ * {kLedAdsl, kLedStateOff, GPIO_LED_PIN_8}, ++ * {kLedPPP, kLedStateOff, GPIO_LED_PIN_9}, // PPP and WanData share PIN_9 ++ * {kLedWanData, kLedStateOff, GPIO_LED_PIN_9}, ++ * {kLedWireless, kLedStateOff, GPIO_LED_PIN_10}, ++ * {kLedEnd, kLedStateOff, 0 } // NOTE: kLedEnd has to be at the end. ++ * ++ * 2). };To initialize led API and initial state of the leds, call the following function with the mapping ++ * pointer from the above struct ++ * ++ * boardLedInit((PLED_MAP_PAIR) &cLedMapping45R); ++ * ++ * 3). Sample call for kernel mode: ++ * ++ * kerSysLedCtrl(kLedAdsl, kLedStateBlinkOnce); // kLedxxx defines in board.h ++ * ++ * 4). Sample call for user mode ++ * ++ * sysLedCtrl(kLedAdsl, kLedStateBlinkOnce); // kLedxxx defines in board_api.h ++ * ++ * ++ * Created on : 10/28/2002 seanl ++ * ++ ***************************************************************************/ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++ ++#define k100ms (HZ / 10) // ~100 ms ++#define kFastBlinkCount 0 // ~100ms ++#define kSlowBlinkCount 5 // ~600ms ++ ++#define MAX_VIRT_LEDS 12 ++ ++// uncomment // for debug led ++//#define DEBUG_LED ++ ++// global variables: ++struct timer_list gLedTimer; ++int gTimerOn = FALSE; ++int gLedCount = 0; ++ ++typedef struct ledinfo ++{ ++ unsigned short ledMask; // mask for led: ie. giop 10 = 0x0400 ++ unsigned short ledActiveLow; // GPIO bit reset to turn on LED ++ unsigned short ledMaskFail; // mask for led: ie. giop 10 = 0x0400 ++ unsigned short ledActiveLowFail;// GPIO bit reset to turn on LED ++ BOARD_LED_STATE ledState; // current led state ++ BOARD_LED_STATE savedLedState; // used in blink once for restore to the orignal ledState ++ int blinkCountDown; // if == 0, do blink (toggle). Is assgined value and dec by 1 at each timer. ++} LED_INFO, *PLED_INFO; ++ ++static PLED_INFO gLed = NULL; ++static PLED_INFO gpVirtLeds[MAX_VIRT_LEDS]; ++static HANDLE_LED_FUNC gLedHwFunc[MAX_VIRT_LEDS]; ++static HANDLE_LED_FUNC gLedHwFailFunc[MAX_VIRT_LEDS]; ++ ++#if 0 /* BROKEN */ ++#if defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++static int gLedOffInBridgeMode = 1; ++#elif defined(CONFIG_BCM96345) ++static int gLedOffInBridgeMode = 0; ++#endif ++#endif ++ ++void ledTimerExpire(void); ++int initLedInfo( PLED_MAP_PAIR pCurMap, PLED_INFO pCurLed ); ++ ++//************************************************************************************** ++// LED operations ++//************************************************************************************** ++ ++// turn led on and set the ledState ++void ledOn(PLED_INFO pLed) ++{ ++ if( pLed->ledMask ) ++ { ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLow ) ++ GPIO->GPIOio &= ~pLed->ledMask; // turn on the led ++ else ++ GPIO->GPIOio |= pLed->ledMask; // turn on the led ++ pLed->ledState = pLed->savedLedState = kLedStateOn; ++ } ++} ++ ++ ++// turn led off and set the ledState ++void ledOff(PLED_INFO pLed) ++{ ++ if( pLed->ledMask ) ++ { ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLow ) ++ GPIO->GPIOio |= pLed->ledMask; // turn off the led ++ else ++ GPIO->GPIOio &= ~pLed->ledMask; // turn off the led ++ pLed->ledState = pLed->savedLedState = kLedStateOff; ++ } ++} ++ ++// turn led on and set the ledState ++void ledOnFail(PLED_INFO pLed) ++{ ++ if( pLed->ledMaskFail ) ++ { ++ GPIO->GPIODir |= pLed->ledMaskFail; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLowFail ) ++ GPIO->GPIOio &= ~pLed->ledMaskFail;// turn on the led ++ else ++ GPIO->GPIOio |= pLed->ledMaskFail; // turn on the led ++ pLed->ledState = pLed->savedLedState = kLedStateFail; ++ } ++} ++ ++ ++// turn led off and set the ledState ++void ledOffFail(PLED_INFO pLed) ++{ ++ if( pLed->ledMaskFail ) ++ { ++ GPIO->GPIODir |= pLed->ledMaskFail; // turn on the direction bit in case was turned off by some one ++ if( pLed->ledActiveLowFail ) ++ GPIO->GPIOio |= pLed->ledMaskFail; // turn off the led ++ else ++ GPIO->GPIOio &= ~pLed->ledMaskFail;// turn off the led ++ pLed->ledState = pLed->savedLedState = kLedStateOff; ++ } ++} ++ ++ ++// toggle the led and return the current ledState ++BOARD_LED_STATE ledToggle(PLED_INFO pLed) ++{ ++ GPIO->GPIODir |= pLed->ledMask; // turn on the direction bit in case was turned off by some one ++ if (GPIO->GPIOio & pLed->ledMask) ++ { ++ GPIO->GPIOio &= ~(pLed->ledMask); ++ return( (pLed->ledActiveLow) ? kLedStateOn : kLedStateOff ); ++ } ++ else ++ { ++ GPIO->GPIOio |= pLed->ledMask; ++ return( (pLed->ledActiveLow) ? kLedStateOff : kLedStateOn ); ++ } ++} ++ ++ ++// led timer. Will return if timer is already on ++void ledTimerStart(void) ++{ ++ if (gTimerOn) ++ return; ++ ++#if defined(DEBUG_LED) ++ printk("led: add_timer\n"); ++#endif ++ ++ init_timer(&gLedTimer); ++ gLedTimer.function = (void*)ledTimerExpire; ++ gLedTimer.expires = jiffies + k100ms; // timer expires in ~100ms ++ add_timer (&gLedTimer); ++ gTimerOn = TRUE; ++} ++ ++ ++// led timer expire kicks in about ~100ms and perform the led operation according to the ledState and ++// restart the timer according to ledState ++void ledTimerExpire(void) ++{ ++ int i; ++ PLED_INFO pCurLed; ++ ++ gTimerOn = FALSE; ++ ++ for (i = 0, pCurLed = gLed; i < gLedCount; i++, pCurLed++) ++ { ++#if defined(DEBUG_LED) ++ printk("led[%d]: Mask=0x%04x, State = %d, blcd=%d\n", i, pCurLed->ledMask, pCurLed->ledState, pCurLed->blinkCountDown); ++#endif ++ switch (pCurLed->ledState) ++ { ++ case kLedStateOn: ++ case kLedStateOff: ++ case kLedStateFail: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ break; ++ ++ case kLedStateBlinkOnce: ++ ledToggle(pCurLed); ++ pCurLed->blinkCountDown = 0; // reset to 0 ++ pCurLed->ledState = pCurLed->savedLedState; ++ if (pCurLed->ledState == kLedStateSlowBlinkContinues || ++ pCurLed->ledState == kLedStateFastBlinkContinues) ++ ledTimerStart(); // start timer if in blinkContinues stats ++ break; ++ ++ case kLedStateSlowBlinkContinues: ++ if (pCurLed->blinkCountDown-- == 0) ++ { ++ pCurLed->blinkCountDown = kSlowBlinkCount; ++ ledToggle(pCurLed); ++ } ++ ledTimerStart(); ++ break; ++ ++ case kLedStateFastBlinkContinues: ++ if (pCurLed->blinkCountDown-- == 0) ++ { ++ pCurLed->blinkCountDown = kFastBlinkCount; ++ ledToggle(pCurLed); ++ } ++ ledTimerStart(); ++ break; ++ ++ default: ++ printk("Invalid state = %d\n", pCurLed->ledState); ++ } ++ } ++} ++ ++// initialize the gLedCount and allocate and fill gLed struct ++void __init boardLedInit(PLED_MAP_PAIR cLedMapping) ++{ ++ PLED_MAP_PAIR p1, p2; ++ PLED_INFO pCurLed; ++ int needTimer = FALSE; ++ int alreadyUsed = 0; ++ ++#if defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++ /* Set blink rate for BCM6348/BCM6338 hardware LEDs. */ ++ GPIO->LEDCtrl &= ~LED_INTERVAL_SET_MASK; ++ GPIO->LEDCtrl |= LED_INTERVAL_SET_80MS; ++#endif ++ ++ memset( gpVirtLeds, 0x00, sizeof(gpVirtLeds) ); ++ memset( gLedHwFunc, 0x00, sizeof(gLedHwFunc) ); ++ memset( gLedHwFailFunc, 0x00, sizeof(gLedHwFailFunc) ); ++ ++ gLedCount = 0; ++ ++ // Check for multiple LED names and multiple LED GPIO pins that share the ++ // same physical board LED. ++ for( p1 = cLedMapping; p1->ledName != kLedEnd; p1++ ) ++ { ++ alreadyUsed = 0; ++ for( p2 = cLedMapping; p2 != p1; p2++ ) ++ { ++ if( (p1->ledMask && p1->ledMask == p2->ledMask) || ++ (p1->ledMaskFail && p1->ledMaskFail == p2->ledMaskFail) ) ++ { ++ alreadyUsed = 1; ++ break; ++ } ++ } ++ ++ if( alreadyUsed == 0 ) ++ gLedCount++; ++ } ++ ++ gLed = (PLED_INFO) kmalloc((gLedCount * sizeof(LED_INFO)), GFP_KERNEL); ++ if( gLed == NULL ) ++ { ++ printk( "LED memory allocation error.\n" ); ++ return; ++ } ++ ++ memset( gLed, 0x00, gLedCount * sizeof(LED_INFO) ); ++ ++ // initial the gLed with unique ledMask and initial state. If more than 1 ledNames share the physical led ++ // (ledMask) the first defined led's ledInitState will be used. ++ pCurLed = gLed; ++ for( p1 = cLedMapping; p1->ledName != kLedEnd; p1++ ) ++ { ++ if( (int) p1->ledName > MAX_VIRT_LEDS ) ++ continue; ++ ++ alreadyUsed = 0; ++ for( p2 = cLedMapping; p2 != p1; p2++ ) ++ { ++ if( (p1->ledMask && p1->ledMask == p2->ledMask) || ++ (p1->ledMaskFail && p1->ledMaskFail == p2->ledMaskFail) ) ++ { ++ alreadyUsed = 1; ++ break; ++ } ++ } ++ ++ if( alreadyUsed == 0 ) ++ { ++ // Initialize the board LED for the first time. ++ needTimer = initLedInfo( p1, pCurLed ); ++ gpVirtLeds[(int) p1->ledName] = pCurLed; ++ pCurLed++; ++ } ++ else ++ { ++ PLED_INFO pLed; ++ for( pLed = gLed; pLed != pCurLed; pLed++ ) ++ { ++ // Find the LED_INFO structure that has already been initialized. ++ if((pLed->ledMask && pLed->ledMask == p1->ledMask) || ++ (pLed->ledMaskFail && pLed->ledMaskFail==p1->ledMaskFail)) ++ { ++ // The board LED has already been initialized but possibly ++ // not completely initialized. ++ if( p1->ledMask ) ++ { ++ pLed->ledMask = p1->ledMask; ++ pLed->ledActiveLow = p1->ledActiveLow; ++ } ++ if( p1->ledMaskFail ) ++ { ++ pLed->ledMaskFail = p1->ledMaskFail; ++ pLed->ledActiveLowFail = p1->ledActiveLowFail; ++ } ++ gpVirtLeds[(int) p1->ledName] = pLed; ++ break; ++ } ++ } ++ } ++ } ++ ++ if (needTimer) ++ ledTimerStart(); ++ ++#if defined(DEBUG_LED) ++ int i; ++ for (i=0; i < gLedCount; i++) ++ printk("initLed: led[%d]: mask=0x%04x, state=%d\n", i,(gLed+i)->ledMask, (gLed+i)->ledState); ++#endif ++ ++} ++ ++// Initialize a structure that contains information about a physical board LED ++// control. The board LED may contain more than one GPIO pin to control a ++// normal condition (green) or a failure condition (red). ++int initLedInfo( PLED_MAP_PAIR pCurMap, PLED_INFO pCurLed ) ++{ ++ int needTimer = FALSE; ++ pCurLed->ledState = pCurLed->savedLedState = pCurMap->ledInitState; ++ pCurLed->ledMask = pCurMap->ledMask; ++ pCurLed->ledActiveLow = pCurMap->ledActiveLow; ++ pCurLed->ledMaskFail = pCurMap->ledMaskFail; ++ pCurLed->ledActiveLowFail = pCurMap->ledActiveLowFail; ++ ++ switch (pCurLed->ledState) ++ { ++ case kLedStateOn: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOn(pCurLed); ++ break; ++ case kLedStateOff: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOff(pCurLed); ++ break; ++ case kLedStateFail: ++ pCurLed->blinkCountDown = 0; // reset the blink count down ++ ledOnFail(pCurLed); ++ break; ++ case kLedStateBlinkOnce: ++ pCurLed->blinkCountDown = 1; ++ needTimer = TRUE; ++ break; ++ case kLedStateSlowBlinkContinues: ++ pCurLed->blinkCountDown = kSlowBlinkCount; ++ needTimer = TRUE; ++ break; ++ case kLedStateFastBlinkContinues: ++ pCurLed->blinkCountDown = kFastBlinkCount; ++ needTimer = TRUE; ++ break; ++ default: ++ printk("Invalid state = %d\n", pCurLed->ledState); ++ } ++ ++ return( needTimer ); ++} ++ ++#if 0 /* BROKEN */ ++// Determines if there is at least one interface in bridge mode. Bridge mode ++// is determined by the cfm convention of naming bridge interfaces nas17 ++// through nas24. ++static int isBridgedProtocol(void) ++{ ++ extern int dev_get(const char *name); ++ const int firstBridgeId = 17; ++ const int lastBridgeId = 24; ++ int i; ++ int ret = FALSE; ++ char name[16]; ++ ++ for( i = firstBridgeId; i <= lastBridgeId; i++ ) ++ { ++ sprintf( name, "nas%d", i ); ++ ++ if( dev_get(name) ) ++ { ++ ret = TRUE; ++ break; ++ } ++ } ++ ++ return(ret); ++} ++#endif ++ ++// led ctrl. Maps the ledName to the corresponding ledInfoPtr and perform the led operation ++void boardLedCtrl(BOARD_LED_NAME ledName, BOARD_LED_STATE ledState) ++{ ++ PLED_INFO ledInfoPtr; ++ ++ // do the mapping from virtual to physical led ++ if( (int) ledName < MAX_VIRT_LEDS ) ++ ledInfoPtr = gpVirtLeds[(int) ledName]; ++ else ++ ledInfoPtr = NULL; ++ ++ if (ledInfoPtr == NULL) ++ return; ++ ++ if( ledState != kLedStateFail && gLedHwFunc[(int) ledName] ) ++ { ++ (*gLedHwFunc[(int) ledName]) (ledName, ledState); ++ ledOffFail(ledInfoPtr); ++ return; ++ } ++ else ++ if( ledState == kLedStateFail && gLedHwFailFunc[(int) ledName] ) ++ { ++ (*gLedHwFailFunc[(int) ledName]) (ledName, ledState); ++ ledOff(ledInfoPtr); ++ return; ++ } ++ ++#if 0 /* BROKEN */ ++ // Do not blink the WAN Data LED if at least one interface is in bridge mode. ++ if(gLedOffInBridgeMode == 1 && (ledName == kLedWanData || ledName == kLedPPP)) ++ { ++ static int BridgedProtocol = -1; ++ ++ if( BridgedProtocol == -1 ) ++ BridgedProtocol = isBridgedProtocol(); ++ ++ if( BridgedProtocol == TRUE ) ++ return; ++ } ++#endif ++ ++ // If the state is kLedStateFail and there is not a failure LED defined ++ // in the board parameters, change the state to kLedStateFastBlinkContinues. ++ if( ledState == kLedStateFail && ledInfoPtr->ledMaskFail == 0 ) ++ ledState = kLedStateFastBlinkContinues; ++ ++ switch (ledState) ++ { ++ case kLedStateOn: ++ // First, turn off the complimentary (failure) LED GPIO. ++ if( ledInfoPtr->ledMaskFail ) ++ ledOffFail(ledInfoPtr); ++ else ++ if( gLedHwFailFunc[(int) ledName] ) ++ (*gLedHwFailFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn on the specified LED GPIO. ++ ledOn(ledInfoPtr); ++ break; ++ ++ case kLedStateOff: ++ // First, turn off the complimentary (failure) LED GPIO. ++ if( ledInfoPtr->ledMaskFail ) ++ ledOffFail(ledInfoPtr); ++ else ++ if( gLedHwFailFunc[(int) ledName] ) ++ (*gLedHwFailFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn off the specified LED GPIO. ++ ledOff(ledInfoPtr); ++ break; ++ ++ case kLedStateFail: ++ // First, turn off the complimentary (normal) LED GPIO. ++ if( ledInfoPtr->ledMask ) ++ ledOff(ledInfoPtr); ++ else ++ if( gLedHwFunc[(int) ledName] ) ++ (*gLedHwFunc[(int) ledName]) (ledName, kLedStateOff); ++ ++ // Next, turn on (red) the specified LED GPIO. ++ ledOnFail(ledInfoPtr); ++ break; ++ ++ case kLedStateBlinkOnce: ++ // skip blinkOnce if it is already in Slow/Fast blink continues state ++ if (ledInfoPtr->savedLedState == kLedStateSlowBlinkContinues || ++ ledInfoPtr->savedLedState == kLedStateFastBlinkContinues) ++ ; ++ else ++ { ++ if (ledInfoPtr->blinkCountDown == 0) // skip the call if it is 1 ++ { ++ ledToggle(ledInfoPtr); ++ ledInfoPtr->blinkCountDown = 1; // it will be reset to 0 when timer expires ++ ledInfoPtr->ledState = kLedStateBlinkOnce; ++ ledTimerStart(); ++ } ++ } ++ break; ++ ++ case kLedStateSlowBlinkContinues: ++ ledInfoPtr->blinkCountDown = kSlowBlinkCount; ++ ledInfoPtr->ledState = kLedStateSlowBlinkContinues; ++ ledInfoPtr->savedLedState = kLedStateSlowBlinkContinues; ++ ledTimerStart(); ++ break; ++ ++ case kLedStateFastBlinkContinues: ++ ledInfoPtr->blinkCountDown = kFastBlinkCount; ++ ledInfoPtr->ledState = kLedStateFastBlinkContinues; ++ ledInfoPtr->savedLedState = kLedStateFastBlinkContinues; ++ ledTimerStart(); ++ break; ++ ++ default: ++ printk("Invalid led state\n"); ++ } ++} ++ ++// This function is called for an LED that is controlled by hardware. ++void kerSysLedRegisterHwHandler( BOARD_LED_NAME ledName, ++ HANDLE_LED_FUNC ledHwFunc, int ledFailType ) ++{ ++ if( (int) ledName < MAX_VIRT_LEDS ) ++ { ++ if( ledFailType == 1 ) ++ gLedHwFailFunc[(int) ledName] = ledHwFunc; ++ else ++ gLedHwFunc[(int) ledName] = ledHwFunc; ++ } ++} ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/board.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/board.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/board.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/board.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,1570 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/*************************************************************************** ++ * File Name : board.c ++ * ++ * Description: This file contains Linux character device driver entry ++ * for the board related ioctl calls: flash, get free kernel ++ * page and dump kernel memory, etc. ++ * ++ * Created on : 2/20/2002 seanl: use cfiflash.c, cfliflash.h (AMD specific) ++ * ++ ***************************************************************************/ ++ ++ ++/* Includes. */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include "boardparms.h" ++#include "cfiflash.h" ++#include "bcm_intr.h" ++#include "board.h" ++#include "bcm_map_part.h" ++ ++/* Typedefs. */ ++#if defined (NON_CONSECUTIVE_MAC) ++// used to be the last octet. Now changed to the first 5 bits of the the forth octet ++// to reduced the duplicated MAC addresses. ++#define CHANGED_OCTET 3 ++#define SHIFT_BITS 3 ++#else ++#define CHANGED_OCTET 1 ++#define SHIFT_BITS 0 ++#endif ++ ++#if defined (WIRELESS) ++#define SES_BTN_PRESSED 0x00000001 ++#define SES_EVENTS SES_BTN_PRESSED /*OR all values if any*/ ++#define SES_LED_OFF 0 ++#define SES_LED_ON 1 ++#define SES_LED_BLINK 2 ++#endif ++ ++typedef struct ++{ ++ unsigned long ulId; ++ char chInUse; ++ char chReserved[3]; ++} MAC_ADDR_INFO, *PMAC_ADDR_INFO; ++ ++typedef struct ++{ ++ unsigned long ulSdramSize; ++ unsigned long ulPsiSize; ++ unsigned long ulNumMacAddrs; ++ unsigned long ucaBaseMacAddr[NVRAM_MAC_ADDRESS_LEN]; ++ MAC_ADDR_INFO MacAddrs[1]; ++} NVRAM_INFO, *PNVRAM_INFO; ++ ++typedef struct ++{ ++ unsigned long eventmask; ++} BOARD_IOC, *PBOARD_IOC; ++ ++ ++/*Dyinggasp callback*/ ++typedef void (*cb_dgasp_t)(void *arg); ++typedef struct _CB_DGASP__LIST ++{ ++ struct list_head list; ++ char name[IFNAMSIZ]; ++ cb_dgasp_t cb_dgasp_fn; ++ void *context; ++}CB_DGASP_LIST , *PCB_DGASP_LIST; ++ ++ ++static LED_MAP_PAIR LedMapping[] = ++{ // led name Initial state physical pin (ledMask) ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0}, ++ {kLedEnd, kLedStateOff, 0, 0, 0, 0} // NOTE: kLedEnd has to be at the end. ++}; ++ ++/* Externs. */ ++extern struct file fastcall *fget_light(unsigned int fd, int *fput_needed); ++extern unsigned int nr_free_pages (void); ++extern const char *get_system_type(void); ++extern void kerSysFlashInit(void); ++extern unsigned long get_nvram_start_addr(void); ++extern unsigned long get_scratch_pad_start_addr(void); ++extern unsigned long getMemorySize(void); ++extern void __init boardLedInit(PLED_MAP_PAIR); ++extern void boardLedCtrl(BOARD_LED_NAME, BOARD_LED_STATE); ++extern void kerSysLedRegisterHandler( BOARD_LED_NAME ledName, ++ HANDLE_LED_FUNC ledHwFunc, int ledFailType ); ++ ++/* Prototypes. */ ++void __init InitNvramInfo( void ); ++static int board_open( struct inode *inode, struct file *filp ); ++static int board_ioctl( struct inode *inode, struct file *flip, unsigned int command, unsigned long arg ); ++static ssize_t board_read(struct file *filp, char __user *buffer, size_t count, loff_t *ppos); ++static unsigned int board_poll(struct file *filp, struct poll_table_struct *wait); ++static int board_release(struct inode *inode, struct file *filp); ++ ++static BOARD_IOC* borad_ioc_alloc(void); ++static void borad_ioc_free(BOARD_IOC* board_ioc); ++ ++/* DyingGasp function prototype */ ++static void __init kerSysDyingGaspMapIntr(void); ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++static irqreturn_t kerSysDyingGaspIsr(int irq, void * dev_id, struct pt_regs * regs); ++#else ++static unsigned int kerSysDyingGaspIsr(void); ++#endif ++static void __init kerSysInitDyingGaspHandler( void ); ++static void __exit kerSysDeinitDyingGaspHandler( void ); ++/* -DyingGasp function prototype - */ ++ ++ ++#if defined (WIRELESS) ++static irqreturn_t sesBtn_isr(int irq, void *dev_id, struct pt_regs *ptregs); ++static void __init sesBtn_mapGpio(void); ++static void __init sesBtn_mapIntr(int context); ++static unsigned int sesBtn_poll(struct file *file, struct poll_table_struct *wait); ++static ssize_t sesBtn_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos); ++static void __init sesLed_mapGpio(void); ++static void sesLed_ctrl(int action); ++static void __init ses_board_init(void); ++static void __exit ses_board_deinit(void); ++#endif ++ ++static PNVRAM_INFO g_pNvramInfo = NULL; ++static int g_ledInitialized = 0; ++static wait_queue_head_t g_board_wait_queue; ++static CB_DGASP_LIST *g_cb_dgasp_list_head = NULL; ++ ++static int g_wakeup_monitor = 0; ++static struct file *g_monitor_file = NULL; ++static struct task_struct *g_monitor_task = NULL; ++static unsigned int (*g_orig_fop_poll) ++ (struct file *, struct poll_table_struct *) = NULL; ++ ++static struct file_operations board_fops = ++{ ++ open: board_open, ++ ioctl: board_ioctl, ++ poll: board_poll, ++ read: board_read, ++ release: board_release, ++}; ++ ++uint32 board_major = 0; ++ ++#if defined (WIRELESS) ++static unsigned short sesBtn_irq = BP_NOT_DEFINED; ++static unsigned short sesBtn_gpio = BP_NOT_DEFINED; ++static unsigned short sesLed_gpio = BP_NOT_DEFINED; ++#endif ++ ++#if defined(MODULE) ++int init_module(void) ++{ ++ return( brcm_board_init() ); ++} ++ ++void cleanup_module(void) ++{ ++ if (MOD_IN_USE) ++ printk("brcm flash: cleanup_module failed because module is in use\n"); ++ else ++ brcm_board_cleanup(); ++} ++#endif //MODULE ++ ++ ++ ++static int __init brcm_board_init( void ) ++{ ++ typedef int (*BP_LED_FUNC) (unsigned short *); ++ static struct BpLedInformation ++ { ++ BOARD_LED_NAME ledName; ++ BP_LED_FUNC bpFunc; ++ BP_LED_FUNC bpFuncFail; ++ } bpLedInfo[] = ++ {{kLedAdsl, BpGetAdslLedGpio, BpGetAdslFailLedGpio}, ++ {kLedWireless, BpGetWirelessLedGpio, NULL}, ++ {kLedUsb, BpGetUsbLedGpio, NULL}, ++ {kLedHpna, BpGetHpnaLedGpio, NULL}, ++ {kLedWanData, BpGetWanDataLedGpio, NULL}, ++ {kLedPPP, BpGetPppLedGpio, BpGetPppFailLedGpio}, ++ {kLedVoip, BpGetVoipLedGpio, NULL}, ++ {kLedSes, BpGetWirelessSesLedGpio, NULL}, ++ {kLedEnd, NULL, NULL} ++ }; ++ ++ int ret; ++ ++ ret = register_chrdev(BOARD_DRV_MAJOR, "bcrmboard", &board_fops ); ++ if (ret < 0) ++ printk( "brcm_board_init(major %d): fail to register device.\n",BOARD_DRV_MAJOR); ++ else ++ { ++ PLED_MAP_PAIR pLedMap = LedMapping; ++ unsigned short gpio; ++ struct BpLedInformation *pInfo; ++ ++ printk("brcmboard: brcm_board_init entry\n"); ++ board_major = BOARD_DRV_MAJOR; ++ InitNvramInfo(); ++ ++ for( pInfo = bpLedInfo; pInfo->ledName != kLedEnd; pInfo++ ) ++ { ++ if( pInfo->bpFunc && (*pInfo->bpFunc) (&gpio) == BP_SUCCESS ) ++ { ++ pLedMap->ledName = pInfo->ledName; ++ pLedMap->ledMask = GPIO_NUM_TO_MASK(gpio); ++ pLedMap->ledActiveLow = (gpio & BP_ACTIVE_LOW) ? 1 : 0; ++ } ++ if( pInfo->bpFuncFail && (*pInfo->bpFuncFail) (&gpio) == BP_SUCCESS ) ++ { ++ pLedMap->ledName = pInfo->ledName; ++ pLedMap->ledMaskFail = GPIO_NUM_TO_MASK(gpio); ++ pLedMap->ledActiveLowFail = (gpio & BP_ACTIVE_LOW) ? 1 : 0; ++ } ++ if( pLedMap->ledName != kLedEnd ) ++ pLedMap++; ++ } ++ ++ init_waitqueue_head(&g_board_wait_queue); ++#if defined (WIRELESS) ++ ses_board_init(); ++#endif ++ kerSysInitDyingGaspHandler(); ++ kerSysDyingGaspMapIntr(); ++ ++ boardLedInit(LedMapping); ++ g_ledInitialized = 1; ++ } ++ ++ return ret; ++} ++ ++void __init InitNvramInfo( void ) ++{ ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ unsigned long ulNumMacAddrs = pNvramData->ulNumMacAddrs; ++ ++ if( ulNumMacAddrs > 0 && ulNumMacAddrs <= NVRAM_MAC_COUNT_MAX ) ++ { ++ unsigned long ulNvramInfoSize = ++ sizeof(NVRAM_INFO) + ((sizeof(MAC_ADDR_INFO) - 1) * ulNumMacAddrs); ++ ++ g_pNvramInfo = (PNVRAM_INFO) kmalloc( ulNvramInfoSize, GFP_KERNEL ); ++ ++ if( g_pNvramInfo ) ++ { ++ unsigned long ulPsiSize; ++ if( BpGetPsiSize( &ulPsiSize ) != BP_SUCCESS ) ++ ulPsiSize = NVRAM_PSI_DEFAULT; ++ memset( g_pNvramInfo, 0x00, ulNvramInfoSize ); ++ g_pNvramInfo->ulPsiSize = ulPsiSize * 1024; ++ g_pNvramInfo->ulNumMacAddrs = pNvramData->ulNumMacAddrs; ++ memcpy( g_pNvramInfo->ucaBaseMacAddr, pNvramData->ucaBaseMacAddr, ++ NVRAM_MAC_ADDRESS_LEN ); ++ g_pNvramInfo->ulSdramSize = getMemorySize(); ++ } ++ else ++ printk("ERROR - Could not allocate memory for NVRAM data\n"); ++ } ++ else ++ printk("ERROR - Invalid number of MAC addresses (%ld) is configured.\n", ++ ulNumMacAddrs); ++} ++ ++void __exit brcm_board_cleanup( void ) ++{ ++ printk("brcm_board_cleanup()\n"); ++ ++ if (board_major != -1) ++ { ++#if defined (WIRELESS) ++ ses_board_deinit(); ++#endif ++ kerSysDeinitDyingGaspHandler(); ++ unregister_chrdev(board_major, "board_ioctl"); ++ } ++} ++ ++static BOARD_IOC* borad_ioc_alloc(void) ++{ ++ BOARD_IOC *board_ioc =NULL; ++ board_ioc = (BOARD_IOC*) kmalloc( sizeof(BOARD_IOC) , GFP_KERNEL ); ++ if(board_ioc) ++ { ++ memset(board_ioc, 0, sizeof(BOARD_IOC)); ++ } ++ return board_ioc; ++} ++ ++static void borad_ioc_free(BOARD_IOC* board_ioc) ++{ ++ if(board_ioc) ++ { ++ kfree(board_ioc); ++ } ++} ++ ++ ++static int board_open( struct inode *inode, struct file *filp ) ++{ ++ filp->private_data = borad_ioc_alloc(); ++ ++ if (filp->private_data == NULL) ++ return -ENOMEM; ++ ++ return( 0 ); ++} ++ ++static int board_release(struct inode *inode, struct file *filp) ++{ ++ BOARD_IOC *board_ioc = filp->private_data; ++ ++ wait_event_interruptible(g_board_wait_queue, 1); ++ borad_ioc_free(board_ioc); ++ ++ return( 0 ); ++} ++ ++ ++static unsigned int board_poll(struct file *filp, struct poll_table_struct *wait) ++{ ++ unsigned int mask = 0; ++#if defined (WIRELESS) ++ BOARD_IOC *board_ioc = filp->private_data; ++#endif ++ ++ poll_wait(filp, &g_board_wait_queue, wait); ++#if defined (WIRELESS) ++ if(board_ioc->eventmask & SES_EVENTS){ ++ mask |= sesBtn_poll(filp, wait); ++ } ++#endif ++ ++ return mask; ++} ++ ++ ++static ssize_t board_read(struct file *filp, char __user *buffer, size_t count, loff_t *ppos) ++{ ++#if defined (WIRELESS) ++ BOARD_IOC *board_ioc = filp->private_data; ++ if(board_ioc->eventmask & SES_EVENTS){ ++ return sesBtn_read(filp, buffer, count, ppos); ++ } ++#endif ++ return 0; ++} ++ ++//************************************************************************************** ++// Utitlities for dump memory, free kernel pages, mips soft reset, etc. ++//************************************************************************************** ++ ++/*********************************************************************** ++ * Function Name: dumpaddr ++ * Description : Display a hex dump of the specified address. ++ ***********************************************************************/ ++void dumpaddr( unsigned char *pAddr, int nLen ) ++{ ++ static char szHexChars[] = "0123456789abcdef"; ++ char szLine[80]; ++ char *p = szLine; ++ unsigned char ch, *q; ++ int i, j; ++ unsigned long ul; ++ ++ while( nLen > 0 ) ++ { ++ sprintf( szLine, "%8.8lx: ", (unsigned long) pAddr ); ++ p = szLine + strlen(szLine); ++ ++ for(i = 0; i < 16 && nLen > 0; i += sizeof(long), nLen -= sizeof(long)) ++ { ++ ul = *(unsigned long *) &pAddr[i]; ++ q = (unsigned char *) &ul; ++ for( j = 0; j < sizeof(long); j++ ) ++ { ++ *p++ = szHexChars[q[j] >> 4]; ++ *p++ = szHexChars[q[j] & 0x0f]; ++ *p++ = ' '; ++ } ++ } ++ ++ for( j = 0; j < 16 - i; j++ ) ++ *p++ = ' ', *p++ = ' ', *p++ = ' '; ++ ++ *p++ = ' ', *p++ = ' ', *p++ = ' '; ++ ++ for( j = 0; j < i; j++ ) ++ { ++ ch = pAddr[j]; ++ *p++ = (ch > ' ' && ch < '~') ? ch : '.'; ++ } ++ ++ *p++ = '\0'; ++ printk( "%s\r\n", szLine ); ++ ++ pAddr += i; ++ } ++ printk( "\r\n" ); ++} /* dumpaddr */ ++ ++ ++void kerSysMipsSoftReset(void) ++{ ++#if defined(CONFIG_BCM96348) ++ if (PERF->RevID == 0x634800A1) { ++ typedef void (*FNPTR) (void); ++ FNPTR bootaddr = (FNPTR) FLASH_BASE; ++ int i; ++ ++ /* Disable interrupts. */ ++ cli(); ++ ++ /* Reset all blocks. */ ++ PERF->BlockSoftReset &= ~BSR_ALL_BLOCKS; ++ for( i = 0; i < 1000000; i++ ) ++ ; ++ PERF->BlockSoftReset |= BSR_ALL_BLOCKS; ++ /* Jump to the power on address. */ ++ (*bootaddr) (); ++ } ++ else ++ PERF->pll_control |= SOFT_RESET; // soft reset mips ++#else ++ PERF->pll_control |= SOFT_RESET; // soft reset mips ++#endif ++} ++ ++ ++int kerSysGetMacAddress( unsigned char *pucaMacAddr, unsigned long ulId ) ++{ ++ int nRet = 0; ++ PMAC_ADDR_INFO pMai = NULL; ++ PMAC_ADDR_INFO pMaiFreeNoId = NULL; ++ PMAC_ADDR_INFO pMaiFreeId = NULL; ++ unsigned long i = 0, ulIdxNoId = 0, ulIdxId = 0, shiftedIdx = 0; ++ ++ for( i = 0, pMai = g_pNvramInfo->MacAddrs; i < g_pNvramInfo->ulNumMacAddrs; ++ i++, pMai++ ) ++ { ++ if( ulId == pMai->ulId || ulId == MAC_ADDRESS_ANY ) ++ { ++ /* This MAC address has been used by the caller in the past. */ ++ memcpy( pucaMacAddr, g_pNvramInfo->ucaBaseMacAddr, ++ NVRAM_MAC_ADDRESS_LEN ); ++ shiftedIdx = i; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMai->chInUse = 1; ++ pMaiFreeNoId = pMaiFreeId = NULL; ++ break; ++ } ++ else ++ if( pMai->chInUse == 0 ) ++ { ++ if( pMai->ulId == 0 && pMaiFreeNoId == NULL ) ++ { ++ /* This is an available MAC address that has never been ++ * used. ++ */ ++ pMaiFreeNoId = pMai; ++ ulIdxNoId = i; ++ } ++ else ++ if( pMai->ulId != 0 && pMaiFreeId == NULL ) ++ { ++ /* This is an available MAC address that has been used ++ * before. Use addresses that have never been used ++ * first, before using this one. ++ */ ++ pMaiFreeId = pMai; ++ ulIdxId = i; ++ } ++ } ++ } ++ ++ if( pMaiFreeNoId || pMaiFreeId ) ++ { ++ /* An available MAC address was found. */ ++ memcpy(pucaMacAddr, g_pNvramInfo->ucaBaseMacAddr,NVRAM_MAC_ADDRESS_LEN); ++ if( pMaiFreeNoId ) ++ { ++ shiftedIdx = ulIdxNoId; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMaiFreeNoId->ulId = ulId; ++ pMaiFreeNoId->chInUse = 1; ++ } ++ else ++ { ++ shiftedIdx = ulIdxId; ++ pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] += (shiftedIdx << SHIFT_BITS); ++ pMaiFreeId->ulId = ulId; ++ pMaiFreeId->chInUse = 1; ++ } ++ } ++ else ++ if( i == g_pNvramInfo->ulNumMacAddrs ) ++ nRet = -EADDRNOTAVAIL; ++ ++ return( nRet ); ++} /* kerSysGetMacAddr */ ++ ++int kerSysReleaseMacAddress( unsigned char *pucaMacAddr ) ++{ ++ int nRet = -EINVAL; ++ unsigned long ulIdx = 0; ++ int idx = (pucaMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET] - ++ g_pNvramInfo->ucaBaseMacAddr[NVRAM_MAC_ADDRESS_LEN - CHANGED_OCTET]); ++ ++ // if overflow 255 (negitive), add 256 to have the correct index ++ if (idx < 0) ++ idx += 256; ++ ulIdx = (unsigned long) (idx >> SHIFT_BITS); ++ ++ if( ulIdx < g_pNvramInfo->ulNumMacAddrs ) ++ { ++ PMAC_ADDR_INFO pMai = &g_pNvramInfo->MacAddrs[ulIdx]; ++ if( pMai->chInUse == 1 ) ++ { ++ pMai->chInUse = 0; ++ nRet = 0; ++ } ++ } ++ ++ return( nRet ); ++} /* kerSysReleaseMacAddr */ ++ ++int kerSysGetSdramSize( void ) ++{ ++ return( (int) g_pNvramInfo->ulSdramSize ); ++} /* kerSysGetSdramSize */ ++ ++ ++void kerSysLedCtrl(BOARD_LED_NAME ledName, BOARD_LED_STATE ledState) ++{ ++ if (g_ledInitialized) ++ boardLedCtrl(ledName, ledState); ++} ++ ++unsigned int kerSysMonitorPollHook( struct file *f, struct poll_table_struct *t) ++{ ++ int mask = (*g_orig_fop_poll) (f, t); ++ ++ if( g_wakeup_monitor == 1 && g_monitor_file == f ) ++ { ++ /* If g_wakeup_monitor is non-0, the user mode application needs to ++ * return from a blocking select function. Return POLLPRI which will ++ * cause the select to return with the exception descriptor set. ++ */ ++ mask |= POLLPRI; ++ g_wakeup_monitor = 0; ++ } ++ ++ return( mask ); ++} ++ ++/* Put the user mode application that monitors link state on a run queue. */ ++void kerSysWakeupMonitorTask( void ) ++{ ++ g_wakeup_monitor = 1; ++ if( g_monitor_task ) ++ wake_up_process( g_monitor_task ); ++} ++ ++//******************************************************************************************** ++// misc. ioctl calls come to here. (flash, led, reset, kernel memory access, etc.) ++//******************************************************************************************** ++static int board_ioctl( struct inode *inode, struct file *flip, ++ unsigned int command, unsigned long arg ) ++{ ++ int ret = 0; ++ BOARD_IOCTL_PARMS ctrlParms; ++ unsigned char ucaMacAddr[NVRAM_MAC_ADDRESS_LEN]; ++ int allowedSize; ++ ++ switch (command) ++ { ++ case BOARD_IOCTL_FLASH_INIT: ++ // not used for now. kerSysBcmImageInit(); ++ break; ++ ++ ++ case BOARD_IOCTL_FLASH_WRITE: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ NVRAM_DATA SaveNvramData; ++ PNVRAM_DATA pNvramData = (PNVRAM_DATA) get_nvram_start_addr(); ++ ++ switch (ctrlParms.action) ++ { ++ case SCRATCH_PAD: ++ ret = kerSysScratchPadSet(ctrlParms.string, ctrlParms.buf, ctrlParms.offset); ++ break; ++ ++ case PERSISTENT: ++ ret = kerSysPersistentSet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case NVRAM: ++ ret = kerSysNvRamSet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case BCM_IMAGE_CFE: ++ if( ctrlParms.strLen <= 0 || ctrlParms.strLen > FLASH45_LENGTH_BOOT_ROM ) ++ { ++ printk("Illegal CFE size [%d]. Size allowed: [%d]\n", ++ ctrlParms.strLen, FLASH45_LENGTH_BOOT_ROM); ++ ret = -1; ++ break; ++ } ++ ++ // save NVRAM data into a local structure ++ memcpy( &SaveNvramData, pNvramData, sizeof(NVRAM_DATA) ); ++ ++ // set memory type field ++ BpGetSdramSize( (unsigned long *) &ctrlParms.string[SDRAM_TYPE_ADDRESS_OFFSET] ); ++ ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ ++ // if nvram is not valid, restore the current nvram settings ++ if( BpSetBoardId( pNvramData->szBoardId ) != BP_SUCCESS && ++ *(unsigned long *) pNvramData == NVRAM_DATA_ID ) ++ { ++ kerSysNvRamSet((char *) &SaveNvramData, sizeof(SaveNvramData), 0); ++ } ++ break; ++ ++ case BCM_IMAGE_FS: ++ allowedSize = (int) flash_get_total_size() - \ ++ FLASH_RESERVED_AT_END - TAG_LEN - FLASH45_LENGTH_BOOT_ROM; ++ if( ctrlParms.strLen <= 0 || ctrlParms.strLen > allowedSize) ++ { ++ printk("Illegal root file system size [%d]. Size allowed: [%d]\n", ++ ctrlParms.strLen, allowedSize); ++ ret = -1; ++ break; ++ } ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ kerSysMipsSoftReset(); ++ break; ++ ++ case BCM_IMAGE_KERNEL: // not used for now. ++ break; ++ case BCM_IMAGE_WHOLE: ++ if(ctrlParms.strLen <= 0) ++ { ++ printk("Illegal flash image size [%d].\n", ctrlParms.strLen); ++ ret = -1; ++ break; ++ } ++ ++ // save NVRAM data into a local structure ++ memcpy( &SaveNvramData, pNvramData, sizeof(NVRAM_DATA) ); ++ ++ ret = kerSysBcmImageSet(ctrlParms.offset, ctrlParms.string, ctrlParms.strLen); ++ ++ // if nvram is not valid, restore the current nvram settings ++ if( BpSetBoardId( pNvramData->szBoardId ) != BP_SUCCESS && ++ *(unsigned long *) pNvramData == NVRAM_DATA_ID ) ++ { ++ kerSysNvRamSet((char *) &SaveNvramData, sizeof(SaveNvramData), 0); ++ } ++ ++ kerSysMipsSoftReset(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ printk("flash_ioctl_command: invalid command %d\n", ctrlParms.action); ++ break; ++ } ++ ctrlParms.result = ret; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_FLASH_READ: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ switch (ctrlParms.action) ++ { ++ case SCRATCH_PAD: ++ ret = kerSysScratchPadGet(ctrlParms.string, ctrlParms.buf, ctrlParms.offset); ++ break; ++ ++ case PERSISTENT: ++ ret = kerSysPersistentGet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case NVRAM: ++ ret = kerSysNvRamGet(ctrlParms.string, ctrlParms.strLen, ctrlParms.offset); ++ break; ++ ++ case FLASH_SIZE: ++ ret = kerSysFlashSizeGet(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ printk("Not supported. invalid command %d\n", ctrlParms.action); ++ break; ++ } ++ ctrlParms.result = ret; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_NR_PAGES: ++ ctrlParms.result = nr_free_pages() + get_page_cache_size(); ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_DUMP_ADDR: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ dumpaddr( (unsigned char *) ctrlParms.string, ctrlParms.strLen ); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_SET_MEMORY: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ unsigned long *pul = (unsigned long *) ctrlParms.string; ++ unsigned short *pus = (unsigned short *) ctrlParms.string; ++ unsigned char *puc = (unsigned char *) ctrlParms.string; ++ switch( ctrlParms.strLen ) ++ { ++ case 4: ++ *pul = (unsigned long) ctrlParms.offset; ++ break; ++ case 2: ++ *pus = (unsigned short) ctrlParms.offset; ++ break; ++ case 1: ++ *puc = (unsigned char) ctrlParms.offset; ++ break; ++ } ++ dumpaddr( (unsigned char *) ctrlParms.string, sizeof(long) ); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_MIPS_SOFT_RESET: ++ kerSysMipsSoftReset(); ++ break; ++ ++ case BOARD_IOCTL_LED_CTRL: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ kerSysLedCtrl((BOARD_LED_NAME)ctrlParms.strLen, (BOARD_LED_STATE)ctrlParms.offset); ++ ret = 0; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_ID: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, ++ sizeof(ctrlParms)) == 0) ++ { ++ if( ctrlParms.string ) ++ { ++ char *p = (char *) get_system_type(); ++ if( strlen(p) + 1 < ctrlParms.strLen ) ++ ctrlParms.strLen = strlen(p) + 1; ++ __copy_to_user(ctrlParms.string, p, ctrlParms.strLen); ++ } ++ ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ ctrlParms.result = kerSysGetMacAddress( ucaMacAddr, ++ ctrlParms.offset ); ++ ++ if( ctrlParms.result == 0 ) ++ { ++ __copy_to_user(ctrlParms.string, ucaMacAddr, ++ sizeof(ucaMacAddr)); ++ } ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_RELEASE_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ if (copy_from_user((void*)ucaMacAddr, (void*)ctrlParms.string, \ ++ NVRAM_MAC_ADDRESS_LEN) == 0) ++ { ++ ctrlParms.result = kerSysReleaseMacAddress( ucaMacAddr ); ++ } ++ else ++ { ++ ctrlParms.result = -EACCES; ++ } ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_PSI_SIZE: ++ ctrlParms.result = (int) g_pNvramInfo->ulPsiSize; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_SDRAM_SIZE: ++ ctrlParms.result = (int) g_pNvramInfo->ulSdramSize; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_BASE_MAC_ADDRESS: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) ++ { ++ __copy_to_user(ctrlParms.string, g_pNvramInfo->ucaBaseMacAddr, NVRAM_MAC_ADDRESS_LEN); ++ ctrlParms.result = 0; ++ ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, ++ sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else ++ ret = -EFAULT; ++ break; ++ ++ case BOARD_IOCTL_GET_CHIP_ID: ++ ctrlParms.result = (int) (PERF->RevID & 0xFFFF0000) >> 16; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ break; ++ ++ case BOARD_IOCTL_GET_NUM_ENET: { ++ ETHERNET_MAC_INFO EnetInfos[BP_MAX_ENET_MACS]; ++ int i, numeth = 0; ++ if (BpGetEthernetMacInfo(EnetInfos, BP_MAX_ENET_MACS) == BP_SUCCESS) { ++ for( i = 0; i < BP_MAX_ENET_MACS; i++) { ++ if (EnetInfos[i].ucPhyType != BP_ENET_NO_PHY) { ++ numeth++; ++ } ++ } ++ ctrlParms.result = numeth; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ ++ case BOARD_IOCTL_GET_CFE_VER: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ char *vertag = (char *)(FLASH_BASE + CFE_VERSION_OFFSET); ++ if (ctrlParms.strLen < CFE_VERSION_SIZE) { ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = -EFAULT; ++ } ++ else if (strncmp(vertag, "cfe-v", 5)) { // no tag info in flash ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ else { ++ ctrlParms.result = 1; ++ __copy_to_user(ctrlParms.string, vertag+CFE_VERSION_MARK_SIZE, CFE_VERSION_SIZE); ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_ENET_CFG: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ ETHERNET_MAC_INFO EnetInfos[BP_MAX_ENET_MACS]; ++ if (BpGetEthernetMacInfo(EnetInfos, BP_MAX_ENET_MACS) == BP_SUCCESS) { ++ if (ctrlParms.strLen == sizeof(EnetInfos)) { ++ __copy_to_user(ctrlParms.string, EnetInfos, sizeof(EnetInfos)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++#if defined (WIRELESS) ++ case BOARD_IOCTL_GET_WLAN_ANT_INUSE: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ unsigned short antInUse = 0; ++ if (BpGetWirelessAntInUse(&antInUse) == BP_SUCCESS) { ++ if (ctrlParms.strLen == sizeof(antInUse)) { ++ __copy_to_user(ctrlParms.string, &antInUse, sizeof(antInUse)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#endif ++ case BOARD_IOCTL_SET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ ctrlParms.result = -EFAULT; ++ ret = -EFAULT; ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ board_ioc->eventmask |= *((int*)ctrlParms.string); ++#if defined (WIRELESS) ++ if((board_ioc->eventmask & SES_EVENTS)) { ++ if(sesBtn_irq != BP_NOT_DEFINED) { ++ BcmHalInterruptEnable(sesBtn_irq); ++ ctrlParms.result = 0; ++ ret = 0; ++ } ++ } ++#endif ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ } ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_GET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ __copy_to_user(ctrlParms.string, &board_ioc->eventmask, sizeof(unsigned long)); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++ ++ case BOARD_IOCTL_UNSET_TRIGGER_EVENT: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ if (ctrlParms.strLen == sizeof(unsigned long)) { ++ BOARD_IOC *board_ioc = (BOARD_IOC *)flip->private_data; ++ board_ioc->eventmask &= (~(*((int*)ctrlParms.string))); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#if defined (WIRELESS) ++ case BOARD_IOCTL_SET_SES_LED: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ if (ctrlParms.strLen == sizeof(int)) { ++ sesLed_ctrl(*(int*)ctrlParms.string); ++ ctrlParms.result = 0; ++ __copy_to_user((BOARD_IOCTL_PARMS*)arg, &ctrlParms, sizeof(BOARD_IOCTL_PARMS)); ++ ret = 0; ++ } else ++ ret = -EFAULT; ++ ++ break; ++ } ++ else { ++ ret = -EFAULT; ++ } ++ break; ++#endif ++ ++ case BOARD_IOCTL_SET_MONITOR_FD: ++ if (copy_from_user((void*)&ctrlParms, (void*)arg, sizeof(ctrlParms)) == 0) { ++ int fput_needed = 0; ++ ++ g_monitor_file = fget_light( ctrlParms.offset, &fput_needed ); ++ if( g_monitor_file ) { ++ /* Hook this file descriptor's poll function in order to set ++ * the exception descriptor when there is a change in link ++ * state. ++ */ ++ g_monitor_task = current; ++ g_orig_fop_poll = g_monitor_file->f_op->poll; ++ g_monitor_file->f_op->poll = kerSysMonitorPollHook; ++ } ++ } ++ break; ++ ++ case BOARD_IOCTL_WAKEUP_MONITOR_TASK: ++ kerSysWakeupMonitorTask(); ++ break; ++ ++ default: ++ ret = -EINVAL; ++ ctrlParms.result = 0; ++ printk("board_ioctl: invalid command %x, cmd %d .\n",command,_IOC_NR(command)); ++ break; ++ ++ } /* switch */ ++ ++ return (ret); ++ ++} /* board_ioctl */ ++ ++/*************************************************************************** ++ * SES Button ISR/GPIO/LED functions. ++ ***************************************************************************/ ++#if defined (WIRELESS) ++static irqreturn_t sesBtn_isr(int irq, void *dev_id, struct pt_regs *ptregs) ++{ ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined(CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if (!(*gpio_reg & gpio_mask)){ ++ wake_up_interruptible(&g_board_wait_queue); ++ return IRQ_RETVAL(1); ++ } else { ++ return IRQ_RETVAL(0); ++ } ++} ++ ++static void __init sesBtn_mapGpio() ++{ ++ if( BpGetWirelessSesBtnGpio(&sesBtn_gpio) == BP_SUCCESS ) ++ { ++ printk("SES: Button GPIO 0x%x is enabled\n", sesBtn_gpio); ++ } ++} ++ ++static void __init sesBtn_mapIntr(int context) ++{ ++ if( BpGetWirelessSesExtIntr(&sesBtn_irq) == BP_SUCCESS ) ++ { ++ printk("SES: Button Interrupt 0x%x is enabled\n", sesBtn_irq); ++ } ++ else ++ return; ++ ++ sesBtn_irq += INTERRUPT_ID_EXTERNAL_0; ++ ++ if (BcmHalMapInterrupt((FN_HANDLER)sesBtn_isr, context, sesBtn_irq)) { ++ printk("SES: Interrupt mapping failed\n"); ++ } ++ BcmHalInterruptEnable(sesBtn_irq); ++} ++ ++ ++static unsigned int sesBtn_poll(struct file *file, struct poll_table_struct *wait) ++{ ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined(CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if (!(*gpio_reg & gpio_mask)){ ++ return POLLIN; ++ } ++ return 0; ++} ++ ++static ssize_t sesBtn_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos) ++{ ++ volatile unsigned int event=0; ++ ssize_t ret=0; ++ ++#if defined(_BCM96338_) || defined (CONFIG_BCM96338) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96345_) || defined (CONFIG_BCM96345) ++ unsigned short gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned short *gpio_reg = &GPIO->GPIOio; ++#endif ++#if defined(_BCM96348_) || defined (CONFIG_BCM96348) ++ unsigned long gpio_mask = GPIO_NUM_TO_MASK(sesBtn_gpio); ++ volatile unsigned long *gpio_reg = &GPIO->GPIOio; ++ ++ if( (sesBtn_gpio & ~BP_ACTIVE_MASK) >= 32 ) ++ { ++ gpio_mask = GPIO_NUM_TO_MASK_HIGH(sesBtn_gpio); ++ gpio_reg = &GPIO->GPIOio_high; ++ } ++#endif ++ ++ if(*gpio_reg & gpio_mask){ ++ BcmHalInterruptEnable(sesBtn_irq); ++ return ret; ++ } ++ event = SES_EVENTS; ++ __copy_to_user((char*)buffer, (char*)&event, sizeof(event)); ++ BcmHalInterruptEnable(sesBtn_irq); ++ count -= sizeof(event); ++ buffer += sizeof(event); ++ ret += sizeof(event); ++ return ret; ++} ++ ++static void __init sesLed_mapGpio() ++{ ++ if( BpGetWirelessSesBtnGpio(&sesLed_gpio) == BP_SUCCESS ) ++ { ++ printk("SES: LED GPIO 0x%x is enabled\n", sesBtn_gpio); ++ } ++} ++ ++static void sesLed_ctrl(int action) ++{ ++ ++ //char status = ((action >> 8) & 0xff); /* extract status */ ++ //char event = ((action >> 16) & 0xff); /* extract event */ ++ //char blinktype = ((action >> 24) & 0xff); /* extract blink type for SES_LED_BLINK */ ++ ++ BOARD_LED_STATE led; ++ ++ if(sesLed_gpio == BP_NOT_DEFINED) ++ return; ++ ++ action &= 0xff; /* extract led */ ++ ++ //printk("blinktype=%d, event=%d, status=%d\n",(int)blinktype, (int)event, (int)status); ++ ++ switch (action) ++ { ++ case SES_LED_ON: ++ //printk("SES: led on\n"); ++ led = kLedStateOn; ++ break; ++ case SES_LED_BLINK: ++ //printk("SES: led blink\n"); ++ led = kLedStateSlowBlinkContinues; ++ break; ++ case SES_LED_OFF: ++ default: ++ //printk("SES: led off\n"); ++ led = kLedStateOff; ++ } ++ ++ kerSysLedCtrl(kLedSes, led); ++} ++ ++static void __init ses_board_init() ++{ ++ sesBtn_mapGpio(); ++ sesBtn_mapIntr(0); ++ sesLed_mapGpio(); ++} ++static void __exit ses_board_deinit() ++{ ++ if(sesBtn_irq) ++ BcmHalInterruptDisable(sesBtn_irq); ++} ++#endif ++ ++/*************************************************************************** ++ * Dying gasp ISR and functions. ++ ***************************************************************************/ ++#define KERSYS_DBG printk ++ ++#if defined(CONFIG_BCM96345) ++#define CYCLE_PER_US 70 ++#elif defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338) ++/* The BCM6348 cycles per microsecond is really variable since the BCM6348 ++ * MIPS speed can vary depending on the PLL settings. However, an appoximate ++ * value of 120 will still work OK for the test being done. ++ */ ++#define CYCLE_PER_US 120 ++#endif ++#define DG_GLITCH_TO (100*CYCLE_PER_US) ++ ++static void __init kerSysDyingGaspMapIntr() ++{ ++ unsigned long ulIntr; ++ ++#if defined(CONFIG_BCM96348) || defined(_BCM96348_) || defined(CONFIG_BCM96338) || defined(_BCM96338_) ++ if( BpGetAdslDyingGaspExtIntr( &ulIntr ) == BP_SUCCESS ) { ++ BcmHalMapInterrupt((FN_HANDLER)kerSysDyingGaspIsr, 0, INTERRUPT_ID_DG); ++ BcmHalInterruptEnable( INTERRUPT_ID_DG ); ++ } ++#elif defined(CONFIG_BCM96345) || defined(_BCM96345_) ++ if( BpGetAdslDyingGaspExtIntr( &ulIntr ) == BP_SUCCESS ) { ++ ulIntr += INTERRUPT_ID_EXTERNAL_0; ++ BcmHalMapInterrupt((FN_HANDLER)kerSysDyingGaspIsr, 0, ulIntr); ++ BcmHalInterruptEnable( ulIntr ); ++ } ++#endif ++ ++} ++ ++void kerSysSetWdTimer(ulong timeUs) ++{ ++ TIMER->WatchDogDefCount = timeUs * (FPERIPH/1000000); ++ TIMER->WatchDogCtl = 0xFF00; ++ TIMER->WatchDogCtl = 0x00FF; ++} ++ ++ulong kerSysGetCycleCount(void) ++{ ++ ulong cnt; ++#ifdef _WIN32_WCE ++ cnt = 0; ++#else ++ __asm volatile("mfc0 %0, $9":"=d"(cnt)); ++#endif ++ return(cnt); ++} ++ ++static Bool kerSysDyingGaspCheckPowerLoss(void) ++{ ++ ulong clk0; ++ ulong ulIntr; ++ ++ ulIntr = 0; ++ clk0 = kerSysGetCycleCount(); ++ ++ UART->Data = 'D'; ++ UART->Data = '%'; ++ UART->Data = 'G'; ++ ++#if defined(CONFIG_BCM96345) ++ BpGetAdslDyingGaspExtIntr( &ulIntr ); ++ ++ do { ++ ulong clk1; ++ ++ clk1 = kerSysGetCycleCount(); /* time cleared */ ++ /* wait a little to get new reading */ ++ while ((kerSysGetCycleCount()-clk1) < CYCLE_PER_US*2) ++ ; ++ } while ((0 == (PERF->ExtIrqCfg & (1 << (ulIntr + EI_STATUS_SHFT)))) && ((kerSysGetCycleCount() - clk0) < DG_GLITCH_TO)); ++ ++ if (PERF->ExtIrqCfg & (1 << (ulIntr + EI_STATUS_SHFT))) { /* power glitch */ ++ BcmHalInterruptEnable( ulIntr + INTERRUPT_ID_EXTERNAL_0); ++ KERSYS_DBG(" - Power glitch detected. Duration: %ld us\n", (kerSysGetCycleCount() - clk0)/CYCLE_PER_US); ++ return 0; ++ } ++#elif (defined(CONFIG_BCM96348) || defined(CONFIG_BCM96338)) && !defined(VXWORKS) ++ do { ++ ulong clk1; ++ ++ clk1 = kerSysGetCycleCount(); /* time cleared */ ++ /* wait a little to get new reading */ ++ while ((kerSysGetCycleCount()-clk1) < CYCLE_PER_US*2) ++ ; ++ } while ((PERF->IrqStatus & (1 << (INTERRUPT_ID_DG - INTERNAL_ISR_TABLE_OFFSET))) && ((kerSysGetCycleCount() - clk0) < DG_GLITCH_TO)); ++ ++ if (!(PERF->IrqStatus & (1 << (INTERRUPT_ID_DG - INTERNAL_ISR_TABLE_OFFSET)))) { ++ BcmHalInterruptEnable( INTERRUPT_ID_DG ); ++ KERSYS_DBG(" - Power glitch detected. Duration: %ld us\n", (kerSysGetCycleCount() - clk0)/CYCLE_PER_US); ++ return 0; ++ } ++#endif ++ return 1; ++} ++ ++static void kerSysDyingGaspShutdown( void ) ++{ ++ kerSysSetWdTimer(1000000); ++#if defined(CONFIG_BCM96345) ++ PERF->blkEnables &= ~(EMAC_CLK_EN | USB_CLK_EN | CPU_CLK_EN); ++#elif defined(CONFIG_BCM96348) ++ PERF->blkEnables &= ~(EMAC_CLK_EN | USBS_CLK_EN | USBH_CLK_EN | SAR_CLK_EN); ++#endif ++} ++ ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++static irqreturn_t kerSysDyingGaspIsr(int irq, void * dev_id, struct pt_regs * regs) ++#else ++static unsigned int kerSysDyingGaspIsr(void) ++#endif ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp, *dsl = NULL; ++ ++ if (kerSysDyingGaspCheckPowerLoss()) { ++ ++ /* first to turn off everything other than dsl */ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ if(strncmp(tmp->name, "dsl", 3)) { ++ (tmp->cb_dgasp_fn)(tmp->context); ++ }else { ++ dsl = tmp; ++ } ++ } ++ ++ /* now send dgasp */ ++ if(dsl) ++ (dsl->cb_dgasp_fn)(dsl->context); ++ ++ /* reset and shutdown system */ ++ kerSysDyingGaspShutdown(); ++ } ++#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) ++return( IRQ_HANDLED ); ++#else ++ return( 1 ); ++#endif ++} ++ ++static void __init kerSysInitDyingGaspHandler( void ) ++{ ++ CB_DGASP_LIST *new_node; ++ ++ if( g_cb_dgasp_list_head != NULL) { ++ printk("Error: kerSysInitDyingGaspHandler: list head is not null\n"); ++ return; ++ } ++ new_node= (CB_DGASP_LIST *)kmalloc(sizeof(CB_DGASP_LIST), GFP_KERNEL); ++ memset(new_node, 0x00, sizeof(CB_DGASP_LIST)); ++ INIT_LIST_HEAD(&new_node->list); ++ g_cb_dgasp_list_head = new_node; ++ ++} /* kerSysInitDyingGaspHandler */ ++ ++static void __exit kerSysDeinitDyingGaspHandler( void ) ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp; ++ ++ if(g_cb_dgasp_list_head == NULL) ++ return; ++ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ list_del(pos); ++ kfree(tmp); ++ } ++ ++ kfree(g_cb_dgasp_list_head); ++ g_cb_dgasp_list_head = NULL; ++ ++} /* kerSysDeinitDyingGaspHandler */ ++ ++void kerSysRegisterDyingGaspHandler(char *devname, void *cbfn, void *context) ++{ ++ CB_DGASP_LIST *new_node; ++ ++ if( g_cb_dgasp_list_head == NULL) { ++ printk("Error: kerSysRegisterDyingGaspHandler: list head is null\n"); ++ return; ++ } ++ ++ if( devname == NULL || cbfn == NULL ) { ++ printk("Error: kerSysRegisterDyingGaspHandler: register info not enough (%s,%x,%x)\n", devname, (unsigned int)cbfn, (unsigned int)context); ++ return; ++ } ++ ++ new_node= (CB_DGASP_LIST *)kmalloc(sizeof(CB_DGASP_LIST), GFP_KERNEL); ++ memset(new_node, 0x00, sizeof(CB_DGASP_LIST)); ++ INIT_LIST_HEAD(&new_node->list); ++ strncpy(new_node->name, devname, IFNAMSIZ); ++ new_node->cb_dgasp_fn = (cb_dgasp_t)cbfn; ++ new_node->context = context; ++ list_add(&new_node->list, &g_cb_dgasp_list_head->list); ++ ++ printk("dgasp: kerSysRegisterDyingGaspHandler: %s registered \n", devname); ++ ++} /* kerSysRegisterDyingGaspHandler */ ++ ++void kerSysDeregisterDyingGaspHandler(char *devname) ++{ ++ struct list_head *pos; ++ CB_DGASP_LIST *tmp; ++ ++ if(g_cb_dgasp_list_head == NULL) { ++ printk("Error: kerSysDeregisterDyingGaspHandler: list head is null\n"); ++ return; ++ } ++ ++ if(devname == NULL) { ++ printk("Error: kerSysDeregisterDyingGaspHandler: devname is null\n"); ++ return; ++ } ++ ++ printk("kerSysDeregisterDyingGaspHandler: %s is deregistering\n", devname); ++ ++ list_for_each(pos, &g_cb_dgasp_list_head->list) { ++ tmp = list_entry(pos, CB_DGASP_LIST, list); ++ if(!strcmp(tmp->name, devname)) { ++ list_del(pos); ++ kfree(tmp); ++ printk("kerSysDeregisterDyingGaspHandler: %s is deregistered\n", devname); ++ return; ++ } ++ } ++ printk("kerSysDeregisterDyingGaspHandler: %s not (de)registered\n", devname); ++ ++} /* kerSysDeregisterDyingGaspHandler */ ++ ++/*************************************************************************** ++ * MACRO to call driver initialization and cleanup functions. ++ ***************************************************************************/ ++module_init( brcm_board_init ); ++module_exit( brcm_board_cleanup ); ++ ++EXPORT_SYMBOL(kerSysNvRamGet); ++EXPORT_SYMBOL(dumpaddr); ++EXPORT_SYMBOL(kerSysGetMacAddress); ++EXPORT_SYMBOL(kerSysReleaseMacAddress); ++EXPORT_SYMBOL(kerSysGetSdramSize); ++EXPORT_SYMBOL(kerSysLedCtrl); ++EXPORT_SYMBOL(kerSysLedRegisterHwHandler); ++EXPORT_SYMBOL(BpGetBoardIds); ++EXPORT_SYMBOL(BpGetSdramSize); ++EXPORT_SYMBOL(BpGetPsiSize); ++EXPORT_SYMBOL(BpGetEthernetMacInfo); ++EXPORT_SYMBOL(BpGetRj11InnerOuterPairGpios); ++EXPORT_SYMBOL(BpGetPressAndHoldResetGpio); ++EXPORT_SYMBOL(BpGetVoipResetGpio); ++EXPORT_SYMBOL(BpGetVoipIntrGpio); ++EXPORT_SYMBOL(BpGetPcmciaResetGpio); ++EXPORT_SYMBOL(BpGetRtsCtsUartGpios); ++EXPORT_SYMBOL(BpGetAdslLedGpio); ++EXPORT_SYMBOL(BpGetAdslFailLedGpio); ++EXPORT_SYMBOL(BpGetWirelessLedGpio); ++EXPORT_SYMBOL(BpGetUsbLedGpio); ++EXPORT_SYMBOL(BpGetHpnaLedGpio); ++EXPORT_SYMBOL(BpGetWanDataLedGpio); ++EXPORT_SYMBOL(BpGetPppLedGpio); ++EXPORT_SYMBOL(BpGetPppFailLedGpio); ++EXPORT_SYMBOL(BpGetVoipLedGpio); ++EXPORT_SYMBOL(BpGetWirelessExtIntr); ++EXPORT_SYMBOL(BpGetAdslDyingGaspExtIntr); ++EXPORT_SYMBOL(BpGetVoipExtIntr); ++EXPORT_SYMBOL(BpGetHpnaExtIntr); ++EXPORT_SYMBOL(BpGetHpnaChipSelect); ++EXPORT_SYMBOL(BpGetVoipChipSelect); ++EXPORT_SYMBOL(BpGetWirelessSesBtnGpio); ++EXPORT_SYMBOL(BpGetWirelessSesExtIntr); ++EXPORT_SYMBOL(BpGetWirelessSesLedGpio); ++EXPORT_SYMBOL(kerSysRegisterDyingGaspHandler); ++EXPORT_SYMBOL(kerSysDeregisterDyingGaspHandler); ++EXPORT_SYMBOL(kerSysGetCycleCount); ++EXPORT_SYMBOL(kerSysSetWdTimer); ++EXPORT_SYMBOL(kerSysWakeupMonitorTask); ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,692 @@ ++/************************************************************************/ ++/* */ ++/* AMD CFI Enabled Flash Memory Drivers */ ++/* File name: CFIFLASH.C */ ++/* Revision: 1.0 5/07/98 */ ++/* */ ++/* Copyright (c) 1998 ADVANCED MICRO DEVICES, INC. All Rights Reserved. */ ++/* This software is unpublished and contains the trade secrets and */ ++/* confidential proprietary information of AMD. Unless otherwise */ ++/* provided in the Software Agreement associated herewith, it is */ ++/* licensed in confidence "AS IS" and is not to be reproduced in whole */ ++/* or part by any means except for backup. Use, duplication, or */ ++/* disclosure by the Government is subject to the restrictions in */ ++/* paragraph (b) (3) (B) of the Rights in Technical Data and Computer */ ++/* Software clause in DFAR 52.227-7013 (a) (Oct 1988). */ ++/* Software owned by */ ++/* Advanced Micro Devices, Inc., */ ++/* One AMD Place, */ ++/* P.O. Box 3453 */ ++/* Sunnyvale, CA 94088-3453. */ ++/************************************************************************/ ++/* This software constitutes a basic shell of source code for */ ++/* programming all AMD Flash components. AMD */ ++/* will not be responsible for misuse or illegal use of this */ ++/* software for devices not supported herein. AMD is providing */ ++/* this source code "AS IS" and will not be responsible for */ ++/* issues arising from incorrect user implementation of the */ ++/* source code herein. It is the user's responsibility to */ ++/* properly design-in this source code. */ ++/* */ ++/************************************************************************/ ++#ifdef _CFE_ ++#include "lib_types.h" ++#include "lib_printf.h" ++#include "lib_string.h" ++#include "cfe_timer.h" ++#define printk printf ++#else // linux ++#include ++#include ++#include ++#endif ++ ++#include "cfiflash.h" ++ ++static int flash_wait(WORD sector, int offset, UINT16 data); ++static UINT16 flash_get_device_id(void); ++static int flash_get_cfi(struct cfi_query *query, UINT16 *cfi_struct, int flashFamily); ++static int flash_write(WORD sector, int offset, byte *buf, int nbytes); ++static void flash_command(int command, WORD sector, int offset, UINT16 data); ++ ++/*********************************************************************/ ++/* 'meminfo' should be a pointer, but most C compilers will not */ ++/* allocate static storage for a pointer without calling */ ++/* non-portable functions such as 'new'. We also want to avoid */ ++/* the overhead of passing this pointer for every driver call. */ ++/* Systems with limited heap space will need to do this. */ ++/*********************************************************************/ ++struct flashinfo meminfo; /* Flash information structure */ ++static int flashFamily = FLASH_UNDEFINED; ++static int totalSize = 0; ++static struct cfi_query query; ++ ++static UINT16 cfi_data_struct_29W160[] = { ++ 0x0020, 0x0049, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0x0051, 0x0052, 0x0059, 0x0002, 0x0000, 0x0040, 0x0000, 0x0000, ++ 0x0000, 0x0000, 0x0000, 0x0027, 0x0036, 0x0000, 0x0000, 0x0004, ++ 0x0000, 0x000a, 0x0000, 0x0004, 0x0000, 0x0003, 0x0000, 0x0015, ++ 0x0002, 0x0000, 0x0000, 0x0000, 0x0004, 0x0000, 0x0000, 0x0040, ++ 0x0000, 0x0001, 0x0000, 0x0020, 0x0000, 0x0000, 0x0000, 0x0080, ++ 0x0000, 0x001e, 0x0000, 0x0000, 0x0001, 0xffff, 0xffff, 0xffff, ++ 0x0050, 0x0052, 0x0049, 0x0031, 0x0030, 0x0000, 0x0002, 0x0001, ++ 0x0001, 0x0004, 0x0000, 0x0000, 0x0000, 0xffff, 0xffff, 0x0002, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0x0888, 0x252b, 0x8c84, 0x7dbc, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, ++ 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff ++}; ++ ++ ++/*********************************************************************/ ++/* Init_flash is used to build a sector table from the information */ ++/* provided through the CFI query. This information is translated */ ++/* from erase_block information to base:offset information for each */ ++/* individual sector. This information is then stored in the meminfo */ ++/* structure, and used throughout the driver to access sector */ ++/* information. */ ++/* */ ++/* This is more efficient than deriving the sector base:offset */ ++/* information every time the memory map switches (since on the */ ++/* development platform can only map 64k at a time). If the entire */ ++/* flash memory array can be mapped in, then the addition static */ ++/* allocation for the meminfo structure can be eliminated, but the */ ++/* drivers will have to be re-written. */ ++/* */ ++/* The meminfo struct occupies 653 bytes of heap space, depending */ ++/* on the value of the define MAXSECTORS. Adjust to suit */ ++/* application */ ++/*********************************************************************/ ++byte flash_init(void) ++{ ++ int i=0, j=0, count=0; ++ int basecount=0L; ++ UINT16 device_id; ++ int flipCFIGeometry = FALSE; ++ ++ /* First, assume ++ * a single 8k sector for sector 0. This is to allow ++ * the system to perform memory mapping to the device, ++ * even though the actual physical layout is unknown. ++ * Once mapped in, the CFI query will produce all ++ * relevant information. ++ */ ++ meminfo.addr = 0L; ++ meminfo.areg = 0; ++ meminfo.nsect = 1; ++ meminfo.bank1start = 0; ++ meminfo.bank2start = 0; ++ ++ meminfo.sec[0].size = 8192; ++ meminfo.sec[0].base = 0x00000; ++ meminfo.sec[0].bank = 1; ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ ++ device_id = flash_get_device_id(); ++ ++ switch (device_id) { ++ case ID_I28F160C3B: ++ case ID_I28F320C3B: ++ case ID_I28F160C3T: ++ case ID_I28F320C3T: ++ flashFamily = FLASH_INTEL; ++ break; ++ case ID_AM29DL800B: ++ case ID_AM29LV800B: ++ case ID_AM29LV400B: ++ case ID_AM29LV160B: ++ case ID_AM29LV320B: ++ case ID_MX29LV320AB: ++ case ID_AM29LV320MB: ++ case ID_AM29DL800T: ++ case ID_AM29LV800T: ++ case ID_AM29LV160T: ++ case ID_AM29LV320T: ++ case ID_MX29LV320AT: ++ case ID_AM29LV320MT: ++ flashFamily = FLASH_AMD; ++ break; ++ case ID_SST39VF1601: ++ case ID_SST39VF3201: ++ flashFamily = FLASH_SST; ++ break; ++ default: ++ printk("Flash memory not supported! Device id = %x\n", device_id); ++ return -1; ++ } ++ ++ if (flash_get_cfi(&query, 0, flashFamily) == -1) { ++ switch(device_id) { ++ case ID_AM29LV160T: ++ case ID_AM29LV160B: ++ flash_get_cfi(&query, cfi_data_struct_29W160, flashFamily); ++ break; ++ default: ++ printk("CFI data structure not found. Device id = %x\n", device_id); ++ return -1; ++ } ++ } ++ ++ // need to determine if it top or bottom boot here ++ switch (device_id) ++ { ++ case ID_AM29DL800B: ++ case ID_AM29LV800B: ++ case ID_AM29LV400B: ++ case ID_AM29LV160B: ++ case ID_AM29LV320B: ++ case ID_MX29LV320AB: ++ case ID_AM29LV320MB: ++ case ID_I28F160C3B: ++ case ID_I28F320C3B: ++ case ID_I28F160C3T: ++ case ID_I28F320C3T: ++ case ID_SST39VF1601: ++ case ID_SST39VF3201: ++ flipCFIGeometry = FALSE; ++ break; ++ case ID_AM29DL800T: ++ case ID_AM29LV800T: ++ case ID_AM29LV160T: ++ case ID_AM29LV320T: ++ case ID_MX29LV320AT: ++ case ID_AM29LV320MT: ++ flipCFIGeometry = TRUE; ++ break; ++ default: ++ printk("Flash memory not supported! Device id = %x\n", device_id); ++ return -1; ++ } ++ ++ count=0;basecount=0L; ++ ++ if (!flipCFIGeometry) ++ { ++ for (i=0; i= 0; i--) { ++ for(j=0; j relative_addr ) ++ { ++ blk_start--; // last blk, dec by 1 ++ } ++ else ++ if( blk_start == last_blk ) ++ { ++ printk("Address is too big.\n"); ++ blk_start = -1; ++ } ++ ++ return( blk_start ); ++} ++ ++/************************************************************************/ ++/* The purpose of flash_get_total_size() is to return the total size of */ ++/* the flash */ ++/************************************************************************/ ++int flash_get_total_size() ++{ ++ return totalSize; ++} ++ ++/*********************************************************************/ ++/* Flash_command() is the main driver function. It performs */ ++/* every possible command available to AMD B revision */ ++/* flash parts. Note that this command is not used directly, but */ ++/* rather called through the API wrapper functions provided below. */ ++/*********************************************************************/ ++static void flash_command(int command, WORD sector, int offset, UINT16 data) ++{ ++ volatile UINT16 *flashptr; ++ volatile UINT16 *flashbase; ++ ++ flashptr = (UINT16 *) flash_get_memptr(sector); ++ flashbase = (UINT16 *) flash_get_memptr(0); ++ ++ switch (flashFamily) { ++ case FLASH_UNDEFINED: ++ /* These commands should work for AMD, Intel and SST flashes */ ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xF0; ++ flashptr[0] = 0xFF; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0x5555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AAA] = 0x55; /* unlock 2 */ ++ flashptr[0x5555] = 0x90; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_AMD: ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xF0; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashptr[0x55] = 0x98; ++ break; ++ case FLASH_UB: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x20; ++ break; ++ case FLASH_PROG: ++ flashptr[0] = 0xA0; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_UBRESET: ++ flashptr[0] = 0x90; ++ flashptr[0] = 0x00; ++ break; ++ case FLASH_SERASE: ++ flashptr[0x555] = 0xAA; /* unlock 1 */ ++ flashptr[0x2AA] = 0x55; /* unlock 2 */ ++ flashptr[0x555] = 0x80; ++ flashptr[0x555] = 0xAA; ++ flashptr[0x2AA] = 0x55; ++ flashptr[0] = 0x30; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_INTEL: ++ switch (command) { ++ case FLASH_RESET: ++ flashptr[0] = 0xFF; ++ break; ++ case FLASH_READ_ID: ++ flashptr[0] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashptr[0] = 0x98; ++ break; ++ case FLASH_PROG: ++ flashptr[0] = 0x40; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_SERASE: ++ flashptr[0] = 0x60; ++ flashptr[0] = 0xD0; ++ flashptr[0] = 0x20; ++ flashptr[0] = 0xD0; ++ break; ++ default: ++ break; ++ } ++ break; ++ case FLASH_SST: ++ switch (command) { ++ case FLASH_RESET: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0xf0; ++ break; ++ case FLASH_READ_ID: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x90; ++ break; ++ case FLASH_CFIQUERY: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x98; ++ break; ++ case FLASH_UB: ++ break; ++ case FLASH_PROG: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0xa0; ++ flashptr[offset/2] = data; ++ break; ++ case FLASH_UBRESET: ++ break; ++ case FLASH_SERASE: ++ flashbase[0x5555] = 0xAA; /* unlock 1 */ ++ flashbase[0x2AAA] = 0x55; /* unlock 2 */ ++ flashbase[0x5555] = 0x80; ++ flashbase[0x5555] = 0xAA; ++ flashbase[0x2AAA] = 0x55; ++ flashptr[0] = 0x30; ++ break; ++ default: ++ break; ++ } ++ break; ++ default: ++ break; ++ } ++} ++ ++/*********************************************************************/ ++/* flash_write extends the functionality of flash_program() by */ ++/* providing an faster way to program multiple data words, without */ ++/* needing the function overhead of looping algorithms which */ ++/* program word by word. This function utilizes fast pointers */ ++/* to quickly loop through bulk data. */ ++/*********************************************************************/ ++static int flash_write(WORD sector, int offset, byte *buf, int nbytes) ++{ ++ UINT16 *src; ++ src = (UINT16 *)buf; ++ ++ if ((nbytes | offset) & 1) { ++ return -1; ++ } ++ ++ flash_command(FLASH_UB, 0, 0, 0); ++ while (nbytes > 0) { ++ flash_command(FLASH_PROG, sector, offset, *src); ++ if (flash_wait(sector, offset, *src) != STATUS_READY) ++ break; ++ offset +=2; ++ nbytes -=2; ++ src++; ++ } ++ flash_command(FLASH_UBRESET, 0, 0, 0); ++ ++ return (byte*)src - buf; ++} ++ ++/*********************************************************************/ ++/* flash_wait utilizes the DQ6, DQ5, and DQ2 polling algorithms */ ++/* described in the flash data book. It can quickly ascertain the */ ++/* operational status of the flash device, and return an */ ++/* appropriate status code (defined in flash.h) */ ++/*********************************************************************/ ++static int flash_wait(WORD sector, int offset, UINT16 data) ++{ ++ volatile UINT16 *flashptr; /* flash window */ ++ UINT16 d1; ++ ++ flashptr = (UINT16 *) flash_get_memptr(sector); ++ ++ if (flashFamily == FLASH_AMD || flashFamily == FLASH_SST) { ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++ do { ++ d1 = flashptr[offset/2]; ++ if (d1 == data) ++ return STATUS_READY; ++ } while (!(d1 & 0x20)); ++ ++ d1 = flashptr[offset/2]; ++ ++ if (d1 != data) { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++#else ++ do { ++ d1 = *flashptr; /* read data */ ++ d1 ^= *flashptr; /* read it again and see what toggled */ ++ if (d1 == 0) /* no toggles, nothing's happening */ ++ return STATUS_READY; ++ } while (!(d1 & 0x20)); ++ ++ d1 = *flashptr; /* read data */ ++ d1 ^= *flashptr; /* read it again and see what toggled */ ++ ++ if (d1 != 0) { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++#endif ++ } else if (flashFamily == FLASH_INTEL) { ++ flashptr[0] = 0x70; ++ /* Wait for completion */ ++ while(!(*flashptr & 0x80)); ++ if (*flashptr & 0x30) { ++ flashptr[0] = 0x50; ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return STATUS_TIMEOUT; ++ } ++ flashptr[0] = 0x50; ++ flash_command(FLASH_RESET, 0, 0, 0); ++ } ++ ++ return STATUS_READY; ++} ++ ++/*********************************************************************/ ++/* flash_get_device_id() will perform an autoselect sequence on the */ ++/* flash device, and return the device id of the component. */ ++/* This function automatically resets to read mode. */ ++/*********************************************************************/ ++static UINT16 flash_get_device_id() ++{ ++ volatile UINT16 *fwp; /* flash window */ ++ UINT16 answer; ++ ++ fwp = (UINT16 *)flash_get_memptr(0); ++ ++ flash_command(FLASH_READ_ID, 0, 0, 0); ++ answer = *(fwp + 1); ++ if (answer == ID_AM29LV320M) { ++ answer = *(fwp + 0xe); ++ answer = *(fwp + 0xf); ++ } ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return( (UINT16) answer ); ++} ++ ++/*********************************************************************/ ++/* flash_get_cfi() is the main CFI workhorse function. Due to it's */ ++/* complexity and size it need only be called once upon */ ++/* initializing the flash system. Once it is called, all operations */ ++/* are performed by looking at the meminfo structure. */ ++/* All possible care was made to make this algorithm as efficient as */ ++/* possible. 90% of all operations are memory reads, and all */ ++/* calculations are done using bit-shifts when possible */ ++/*********************************************************************/ ++static int flash_get_cfi(struct cfi_query *query, UINT16 *cfi_struct, int flashFamily) ++{ ++ volatile UINT16 *fwp; /* flash window */ ++ int i=0; ++ ++ flash_command(FLASH_CFIQUERY, 0, 0, 0); ++ ++ if (cfi_struct == 0) ++ fwp = (UINT16 *)flash_get_memptr(0); ++ else ++ fwp = cfi_struct; ++ ++ /* Initial house-cleaning */ ++ for(i=0; i < 8; i++) { ++ query->erase_block[i].sector_size = 0; ++ query->erase_block[i].num_sectors = 0; ++ } ++ ++ /* If not 'QRY', then we dont have a CFI enabled device in the socket */ ++ if( fwp[0x10] != 'Q' && ++ fwp[0x11] != 'R' && ++ fwp[0x12] != 'Y') { ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return(-1); ++ } ++ ++ query->num_erase_blocks = fwp[0x2C]; ++ if(flashFamily == FLASH_SST) ++ query->num_erase_blocks = 1; ++ ++ for(i=0; i < query->num_erase_blocks; i++) { ++ query->erase_block[i].num_sectors = fwp[(0x2D+(4*i))] + (fwp[0x2E + (4*i)] << 8); ++ query->erase_block[i].num_sectors++; ++ query->erase_block[i].sector_size = 256 * (256 * fwp[(0x30+(4*i))] + fwp[(0x2F+(4*i))]); ++ } ++ ++ flash_command(FLASH_RESET, 0, 0, 0); ++ return(1); ++} +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.h +--- linux-2.6.8.1/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/board/bcm963xx/impl1/cfiflash.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,150 @@ ++/************************************************************************/ ++/* */ ++/* AMD CFI Enabled Flash Memory Drivers */ ++/* File name: CFIFLASH.H */ ++/* Revision: 1.0 5/07/98 */ ++/* */ ++/* Copyright (c) 1998 ADVANCED MICRO DEVICES, INC. All Rights Reserved. */ ++/* This software is unpublished and contains the trade secrets and */ ++/* confidential proprietary information of AMD. Unless otherwise */ ++/* provided in the Software Agreement associated herewith, it is */ ++/* licensed in confidence "AS IS" and is not to be reproduced in whole */ ++/* or part by any means except for backup. Use, duplication, or */ ++/* disclosure by the Government is subject to the restrictions in */ ++/* paragraph (b) (3) (B) of the Rights in Technical Data and Computer */ ++/* Software clause in DFAR 52.227-7013 (a) (Oct 1988). */ ++/* Software owned by */ ++/* Advanced Micro Devices, Inc., */ ++/* One AMD Place, */ ++/* P.O. Box 3453 */ ++/* Sunnyvale, CA 94088-3453. */ ++/************************************************************************/ ++/* This software constitutes a basic shell of source code for */ ++/* programming all AMD Flash components. AMD */ ++/* will not be responsible for misuse or illegal use of this */ ++/* software for devices not supported herein. AMD is providing */ ++/* this source code "AS IS" and will not be responsible for */ ++/* issues arising from incorrect user implementation of the */ ++/* source code herein. It is the user's responsibility to */ ++/* properly design-in this source code. */ ++/* */ ++/************************************************************************/ ++#ifndef _CFIFLASH_H ++#define _CFIFLASH_H ++ ++#if defined __cplusplus ++extern "C" { ++#endif ++ ++/* include board/CPU specific definitions */ ++#include "bcmtypes.h" ++#include "board.h" ++ ++#define FLASH_BASE_ADDR_REG FLASH_BASE ++ ++#ifndef NULL ++#define NULL 0 ++#endif ++ ++#define MAXSECTORS 1024 /* maximum number of sectors supported */ ++ ++/* A structure for identifying a flash part. There is one for each ++ * of the flash part definitions. We need to keep track of the ++ * sector organization, the address register used, and the size ++ * of the sectors. ++ */ ++struct flashinfo { ++ char *name; /* "Am29DL800T", etc. */ ++ unsigned long addr; /* physical address, once translated */ ++ int areg; /* Can be set to zero for all parts */ ++ int nsect; /* # of sectors -- 19 in LV, 22 in DL */ ++ int bank1start; /* first sector # in bank 1 */ ++ int bank2start; /* first sector # in bank 2, if DL part */ ++ struct { ++ long size; /* # of bytes in this sector */ ++ long base; /* offset from beginning of device */ ++ int bank; /* 1 or 2 for DL; 1 for LV */ ++ } sec[MAXSECTORS]; /* per-sector info */ ++}; ++ ++/* ++ * This structure holds all CFI query information as defined ++ * in the JEDEC standard. All information up to ++ * primary_extended_query is standard among all manufactures ++ * with CFI enabled devices. ++ */ ++ ++struct cfi_query { ++ int num_erase_blocks; /* Number of sector defs. */ ++ struct { ++ unsigned long sector_size; /* byte size of sector */ ++ int num_sectors; /* Num sectors of this size */ ++ } erase_block[8]; /* Max of 256, but 8 is good */ ++}; ++ ++/* Standard Boolean declarations */ ++#define TRUE 1 ++#define FALSE 0 ++ ++/* Define different type of flash */ ++#define FLASH_UNDEFINED 0 ++#define FLASH_AMD 1 ++#define FLASH_INTEL 2 ++#define FLASH_SST 3 ++ ++/* Command codes for the flash_command routine */ ++#define FLASH_RESET 0 /* reset to read mode */ ++#define FLASH_READ_ID 1 /* read device ID */ ++#define FLASH_CFIQUERY 2 /* CFI query */ ++#define FLASH_UB 3 /* go into unlock bypass mode */ ++#define FLASH_PROG 4 /* program a word */ ++#define FLASH_UBRESET 5 /* reset to read mode from unlock bypass mode */ ++#define FLASH_SERASE 6 /* sector erase */ ++ ++/* Return codes from flash_status */ ++#define STATUS_READY 0 /* ready for action */ ++#define STATUS_TIMEOUT 1 /* operation timed out */ ++ ++/* A list of AMD compatible device ID's - add others as needed */ ++#define ID_AM29DL800T 0x224A ++#define ID_AM29DL800B 0x22CB ++#define ID_AM29LV800T 0x22DA ++#define ID_AM29LV800B 0x225B ++#define ID_AM29LV400B 0x22BA ++ ++#define ID_AM29LV160B 0x2249 ++#define ID_AM29LV160T 0x22C4 ++ ++#define ID_AM29LV320T 0x22F6 ++#define ID_MX29LV320AT 0x22A7 ++#define ID_AM29LV320B 0x22F9 ++#define ID_MX29LV320AB 0x22A8 ++ ++#define ID_AM29LV320M 0x227E ++#define ID_AM29LV320MB 0x2200 ++#define ID_AM29LV320MT 0x2201 ++ ++#define ID_SST39VF1601 0x234B ++#define ID_SST39VF3201 0x235B ++ ++/* A list of Intel compatible device ID's - add others as needed */ ++#define ID_I28F160C3T 0x88C2 ++#define ID_I28F160C3B 0x88C3 ++#define ID_I28F320C3T 0x88C4 ++#define ID_I28F320C3B 0x88C5 ++ ++extern byte flash_init(void); ++extern int flash_write_buf(WORD sector, int offset, byte *buffer, int numbytes); ++extern int flash_read_buf(WORD sector, int offset, byte *buffer, int numbytes); ++extern byte flash_sector_erase_int(WORD sector); ++extern int flash_get_numsectors(void); ++extern int flash_get_sector_size(WORD sector); ++extern int flash_get_total_size(void); ++extern unsigned char *flash_get_memptr(WORD sector); ++extern int flash_get_blk(int addr); ++ ++#if defined __cplusplus ++} ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/serial/bcm96348/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/bcm96348/Makefile +--- linux-2.6.8.1/bcmdrivers/opensource/char/serial/bcm96348/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/bcm96348/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,13 @@ ++# File: bcmdrivers/opensource/char/serial ++# ++# Makefile for the BCM63xx serial/console driver ++ ++obj-$(CONFIG_BCM_SERIAL) += bcm63xx_cons.o ++ ++EXTRA_CFLAGS += -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++ ++-include $(TOPDIR)/Rules.make ++ ++clean: ++ rm -f core *.o *.a *.s ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/serial/bcm96348/bcm63xx_cons.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/bcm96348/bcm63xx_cons.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/serial/bcm96348/bcm63xx_cons.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/bcm96348/bcm63xx_cons.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,1035 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++/* Description: Serial port driver for the BCM963XX. */ ++ ++#define CARDNAME "bcm963xx_serial driver" ++#define VERSION "2.0" ++#define VER_STR CARDNAME " v" VERSION "\n" ++ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++/* for definition of struct console */ ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++ ++extern void _putc(char); ++extern void _puts(const char *); ++ ++typedef struct bcm_serial { ++ volatile Uart * port; ++ int type; ++ int flags; ++ int irq; ++ int baud_base; ++ int blocked_open; ++ unsigned short close_delay; ++ unsigned short closing_wait; ++ unsigned short line; /* port/line number */ ++ unsigned short cflags; /* line configuration flag */ ++ unsigned short x_char; /* xon/xoff character */ ++ unsigned short read_status_mask; /* mask for read condition */ ++ unsigned short ignore_status_mask; /* mask for ignore condition */ ++ unsigned long event; /* mask used in BH */ ++ int xmit_head; /* Position of the head */ ++ int xmit_tail; /* Position of the tail */ ++ int xmit_cnt; /* Count of the chars in the buffer */ ++ int count; /* indicates how many times it has been opened */ ++ int magic; ++ ++ struct async_icount icount; /* keep track of things ... */ ++ struct tty_struct *tty; /* tty associated */ ++ struct termios normal_termios; ++ ++ wait_queue_head_t open_wait; ++ wait_queue_head_t close_wait; ++ ++ long session; /* Session of opening process */ ++ long pgrp; /* pgrp of opening process */ ++ ++ unsigned char is_initialized; ++} Context; ++ ++ ++/*---------------------------------------------------------------------*/ ++/* Define bits in the Interrupt Enable register */ ++/*---------------------------------------------------------------------*/ ++/* Enable receive interrupt */ ++#define RXINT (RXFIFONE|RXOVFERR) ++ ++/* Enable transmit interrupt */ ++#define TXINT (TXFIFOEMT|TXUNDERR|TXOVFERR) ++ ++/* Enable receiver line status interrupt */ ++#define LSINT (RXBRK|RXPARERR|RXFRAMERR) ++ ++#define BCM_NUM_UARTS 1 ++ ++#define BD_BCM63XX_TIMER_CLOCK_INPUT (FPERIPH) ++ ++ ++static struct bcm_serial multi[BCM_NUM_UARTS]; ++static struct bcm_serial *lines[BCM_NUM_UARTS]; ++static struct tty_driver serial_driver; ++static struct tty_struct *serial_table[BCM_NUM_UARTS]; ++static struct termios *serial_termios[BCM_NUM_UARTS]; ++static struct termios *serial_termios_locked[BCM_NUM_UARTS]; ++static int serial_refcount; ++ ++ ++static void bcm_stop (struct tty_struct *tty); ++static void bcm_start (struct tty_struct *tty); ++static inline void receive_chars (struct bcm_serial * info); ++static int startup (struct bcm_serial *info); ++static void shutdown (struct bcm_serial * info); ++static void change_speed( volatile Uart *pUart, tcflag_t cFlag ); ++static void bcm63xx_cons_flush_chars (struct tty_struct *tty); ++static int bcm63xx_cons_write (struct tty_struct *tty, int from_user, ++ const unsigned char *buf, int count); ++static int bcm63xx_cons_write_room (struct tty_struct *tty); ++static int bcm_chars_in_buffer (struct tty_struct *tty); ++static void bcm_flush_buffer (struct tty_struct *tty); ++static void bcm_throttle (struct tty_struct *tty); ++static void bcm_unthrottle (struct tty_struct *tty); ++static void bcm_send_xchar (struct tty_struct *tty, char ch); ++static int get_serial_info(struct bcm_serial *info, struct serial_struct *retinfo); ++static int set_serial_info (struct bcm_serial *info, struct serial_struct *new_info); ++static int get_lsr_info (struct bcm_serial *info, unsigned int *value); ++static void send_break (struct bcm_serial *info, int duration); ++static int bcm_ioctl (struct tty_struct * tty, struct file * file, ++ unsigned int cmd, unsigned long arg); ++static void bcm_set_termios (struct tty_struct *tty, struct termios *old_termios); ++static void bcm63xx_cons_close (struct tty_struct *tty, struct file *filp); ++static void bcm_hangup (struct tty_struct *tty); ++static int block_til_ready (struct tty_struct *tty, struct file *filp, struct bcm_serial *info); ++static int bcm63xx_cons_open (struct tty_struct * tty, struct file * filp); ++static int __init bcm63xx_serialinit(void); ++ ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_stop () and rs_start () ++ * ++ * These routines are called before setting or resetting ++ * tty->stopped. They enable or disable transmitter interrupts, ++ * as necessary. ++ * ------------------------------------------------------------ ++ */ ++static void bcm_stop (struct tty_struct *tty) ++{ ++} ++ ++static void bcm_start (struct tty_struct *tty) ++{ ++ _puts(CARDNAME " Start\n"); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * receive_char () ++ * ++ * This routine deals with inputs from any lines. ++ * ------------------------------------------------------------ ++ */ ++static inline void receive_chars (struct bcm_serial * info) ++{ ++ struct tty_struct *tty = 0; ++ struct async_icount * icount; ++ int ignore = 0; ++ unsigned short status, tmp; ++ UCHAR ch = 0; ++ while ((status = info->port->intStatus) & RXINT) ++ { ++ if (status & RXFIFONE) ++ ch = info->port->Data; // Read the character ++ tty = info->tty; /* now tty points to the proper dev */ ++ icount = &info->icount; ++ if (! tty) ++ break; ++ if (tty->flip.count >= TTY_FLIPBUF_SIZE) ++ break; ++ *tty->flip.char_buf_ptr = ch; ++ *tty->flip.flag_buf_ptr = 0; ++ icount->rx++; ++ if (status & RXBRK) ++ { ++ *tty->flip.flag_buf_ptr = TTY_BREAK; ++ icount->brk++; ++ } ++ // keep track of the statistics ++ if (status & (RXFRAMERR | RXPARERR | RXOVFERR)) ++ { ++ if (status & RXPARERR) /* parity error */ ++ icount->parity++; ++ else ++ if (status & RXFRAMERR) /* frame error */ ++ icount->frame++; ++ if (status & RXOVFERR) ++ { ++ // Overflow. Reset the RX FIFO ++ info->port->fifoctl |= RSTRXFIFOS; ++ icount->overrun++; ++ } ++ // check to see if we should ignore the character ++ // and mask off conditions that should be ignored ++ if (status & info->ignore_status_mask) ++ { ++ if (++ignore > 100 ) ++ break; ++ goto ignore_char; ++ } ++ // Mask off the error conditions we want to ignore ++ tmp = status & info->read_status_mask; ++ if (tmp & RXPARERR) ++ { ++ *tty->flip.flag_buf_ptr = TTY_PARITY; ++ } ++ else ++ if (tmp & RXFRAMERR) ++ { ++ *tty->flip.flag_buf_ptr = TTY_FRAME; ++ } ++ if (tmp & RXOVFERR) ++ { ++ if (tty->flip.count < TTY_FLIPBUF_SIZE) ++ { ++ tty->flip.count++; ++ tty->flip.flag_buf_ptr++; ++ tty->flip.char_buf_ptr++; ++ *tty->flip.flag_buf_ptr = TTY_OVERRUN; ++ } ++ } ++ } ++ tty->flip.flag_buf_ptr++; ++ tty->flip.char_buf_ptr++; ++ tty->flip.count++; ++ } ++ignore_char: ++ if (tty) ++ tty_flip_buffer_push(tty); ++} ++ ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm_interrupt () ++ * ++ * this is the main interrupt routine for the chip. ++ * It deals with the multiple ports. ++ * ------------------------------------------------------------ ++ */ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++static irqreturn_t bcm_interrupt (int irq, void * dev, struct pt_regs * regs) ++#else ++static void bcm_interrupt (int irq, void * dev, struct pt_regs * regs) ++#endif ++{ ++ struct bcm_serial * info = lines[0]; ++ UINT16 intStat; ++ ++ /* get pending interrupt flags from UART */ ++ ++ /* Mask with only the serial interrupts that are enabled */ ++ intStat = info->port->intStatus & info->port->intMask; ++ while (intStat) ++ { ++ if (intStat & RXINT) ++ receive_chars (info); ++ else ++ if (intStat & TXINT) ++ info->port->intStatus = TXINT; ++ else /* don't know what it was, so let's mask it */ ++ info->port->intMask &= ~intStat; ++ ++ intStat = info->port->intStatus & info->port->intMask; ++ } ++ ++ // Clear the interrupt ++ BcmHalInterruptEnable (INTERRUPT_ID_UART); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ return IRQ_HANDLED; ++#endif ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * startup () ++ * ++ * various initialization tasks ++ * ------------------------------------------------------------------- ++ */ ++static int startup (struct bcm_serial *info) ++{ ++ // Port is already started... ++ return 0; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * shutdown () ++ * ++ * This routine will shutdown a serial port; interrupts are disabled, and ++ * DTR is dropped if the hangup on close termio flag is on. ++ * ------------------------------------------------------------------- ++ */ ++static void shutdown (struct bcm_serial * info) ++{ ++ unsigned long flags; ++ if (!info->is_initialized) ++ return; ++ ++ save_flags (flags); ++ cli (); ++ ++ info->port->control &= ~(BRGEN|TXEN|RXEN); ++ if (info->tty) ++ set_bit (TTY_IO_ERROR, &info->tty->flags); ++ info->is_initialized = 0; ++ ++ restore_flags (flags); ++} ++/* ++ * ------------------------------------------------------------------- ++ * change_speed () ++ * ++ * Set the baud rate, character size, parity and stop bits. ++ * ------------------------------------------------------------------- ++ */ ++static void change_speed( volatile Uart *pUart, tcflag_t cFlag ) ++{ ++ unsigned long ulFlags, ulBaud, ulClockFreqHz, ulTmp; ++ save_flags(ulFlags); ++ cli(); ++ switch( cFlag & (CBAUD | CBAUDEX) ) ++ { ++ case B115200: ++ ulBaud = 115200; ++ break; ++ case B57600: ++ ulBaud = 57600; ++ break; ++ case B38400: ++ ulBaud = 38400; ++ break; ++ case B19200: ++ ulBaud = 19200; ++ break; ++ case B9600: ++ ulBaud = 9600; ++ break; ++ case B4800: ++ ulBaud = 4800; ++ break; ++ case B2400: ++ ulBaud = 2400; ++ break; ++ case B1800: ++ ulBaud = 1800; ++ break; ++ case B1200: ++ ulBaud = 1200; ++ break; ++ case B600: ++ ulBaud = 600; ++ break; ++ case B300: ++ ulBaud = 300; ++ break; ++ case B200: ++ ulBaud = 200; ++ break; ++ case B150: ++ ulBaud = 150; ++ break; ++ case B134: ++ ulBaud = 134; ++ break; ++ case B110: ++ ulBaud = 110; ++ break; ++ case B75: ++ ulBaud = 75; ++ break; ++ case B50: ++ ulBaud = 50; ++ break; ++ default: ++ ulBaud = 115200; ++ break; ++ } ++ ++ /* Calculate buad rate. */ ++ ulClockFreqHz = BD_BCM63XX_TIMER_CLOCK_INPUT; ++ ulTmp = (ulClockFreqHz / ulBaud) / 16; ++ if( ulTmp & 0x01 ) ++ ulTmp /= 2; /* Rounding up, so sub is already accounted for */ ++ else ++ ulTmp = (ulTmp / 2) - 1; /* Rounding down so we must sub 1 */ ++ pUart->baudword = ulTmp; ++ ++ /* Set character size, stop bits and parity. */ ++ switch( cFlag & CSIZE ) ++ { ++ case CS5: ++ ulTmp = BITS5SYM; /* select transmit 5 bit data size */ ++ break; ++ case CS6: ++ ulTmp = BITS6SYM; /* select transmit 6 bit data size */ ++ break; ++ case CS7: ++ ulTmp = BITS7SYM; /* select transmit 7 bit data size */ ++ break; ++ /*case CS8:*/ ++ default: ++ ulTmp = BITS8SYM; /* select transmit 8 bit data size */ ++ break; ++ } ++ if( cFlag & CSTOPB ) ++ ulTmp |= TWOSTOP; /* select 2 stop bits */ ++ else ++ ulTmp |= ONESTOP; /* select one stop bit */ ++ ++ /* Write these values into the config reg. */ ++ pUart->config = ulTmp; ++ pUart->control &= ~(RXPARITYEN | TXPARITYEN | RXPARITYEVEN | TXPARITYEVEN); ++ switch( cFlag & (PARENB | PARODD) ) ++ { ++ case PARENB|PARODD: ++ pUart->control |= RXPARITYEN | TXPARITYEN; ++ break; ++ case PARENB: ++ pUart->control |= RXPARITYEN | TXPARITYEN | RXPARITYEVEN | TXPARITYEVEN; ++ break; ++ default: ++ pUart->control |= 0; ++ break; ++ } ++ ++ /* Reset and flush uart */ ++ pUart->fifoctl = RSTTXFIFOS | RSTRXFIFOS; ++ restore_flags( ulFlags ); ++} ++ ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_flush_char () ++ * ++ * Nothing to flush. Polled I/O is used. ++ * ------------------------------------------------------------------- ++ */ ++static void bcm63xx_cons_flush_chars (struct tty_struct *tty) ++{ ++} ++ ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm63xx_cons_write () ++ * ++ * Main output routine using polled I/O. ++ * ------------------------------------------------------------------- ++ */ ++static int bcm63xx_cons_write (struct tty_struct *tty, int from_user, ++ const unsigned char *buf, int count) ++{ ++ int c; ++ ++ for (c = 0; c < count; c++) ++ _putc(buf[c]); ++ return count; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm63xx_cons_write_room () ++ * ++ * Compute the amount of space available for writing. ++ * ------------------------------------------------------------------- ++ */ ++static int bcm63xx_cons_write_room (struct tty_struct *tty) ++{ ++ /* Pick a number. Any number. Polled I/O is used. */ ++ return 1024; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_chars_in_buffer () ++ * ++ * compute the amount of char left to be transmitted ++ * ------------------------------------------------------------------- ++ */ ++static int bcm_chars_in_buffer (struct tty_struct *tty) ++{ ++ return 0; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_flush_buffer () ++ * ++ * Empty the output buffer ++ * ------------------------------------------------------------------- ++ */ ++static void bcm_flush_buffer (struct tty_struct *tty) ++{ ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm_throttle () and bcm_unthrottle () ++ * ++ * This routine is called by the upper-layer tty layer to signal that ++ * incoming characters should be throttled (or not). ++ * ------------------------------------------------------------ ++ */ ++static void bcm_throttle (struct tty_struct *tty) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ if (I_IXOFF(tty)) ++ info->x_char = STOP_CHAR(tty); ++} ++ ++static void bcm_unthrottle (struct tty_struct *tty) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ if (I_IXOFF(tty)) ++ { ++ if (info->x_char) ++ info->x_char = 0; ++ else ++ info->x_char = START_CHAR(tty); ++ } ++} ++ ++static void bcm_send_xchar (struct tty_struct *tty, char ch) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ info->x_char = ch; ++ if (ch) ++ bcm_start (info->tty); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_ioctl () and friends ++ * ------------------------------------------------------------ ++ */ ++static int get_serial_info(struct bcm_serial *info, struct serial_struct *retinfo) ++{ ++ struct serial_struct tmp; ++ ++ if (!retinfo) ++ return -EFAULT; ++ ++ memset (&tmp, 0, sizeof(tmp)); ++ tmp.type = info->type; ++ tmp.line = info->line; ++ tmp.port = (int) info->port; ++ tmp.irq = info->irq; ++ tmp.flags = 0; ++ tmp.baud_base = info->baud_base; ++ tmp.close_delay = info->close_delay; ++ tmp.closing_wait = info->closing_wait; ++ ++ return copy_to_user (retinfo, &tmp, sizeof(*retinfo)); ++} ++ ++static int set_serial_info (struct bcm_serial *info, struct serial_struct *new_info) ++{ ++ struct serial_struct new_serial; ++ struct bcm_serial old_info; ++ int retval = 0; ++ ++ if (!new_info) ++ return -EFAULT; ++ ++ copy_from_user (&new_serial, new_info, sizeof(new_serial)); ++ old_info = *info; ++ ++ if (!capable(CAP_SYS_ADMIN)) ++ return -EPERM; ++ ++ ++ if (info->count > 1) ++ return -EBUSY; ++ ++ /* OK, past this point, all the error checking has been done. ++ * At this point, we start making changes..... ++ */ ++ info->baud_base = new_serial.baud_base; ++ info->type = new_serial.type; ++ info->close_delay = new_serial.close_delay; ++ info->closing_wait = new_serial.closing_wait; ++ retval = startup (info); ++ return retval; ++} ++ ++/* ++ * get_lsr_info - get line status register info ++ * ++ * Purpose: Let user call ioctl() to get info when the UART physically ++ * is emptied. On bus types like RS485, the transmitter must ++ * release the bus after transmitting. This must be done when ++ * the transmit shift register is empty, not be done when the ++ * transmit holding register is empty. This functionality ++ * allows an RS485 driver to be written in user space. ++ */ ++static int get_lsr_info (struct bcm_serial *info, unsigned int *value) ++{ ++ return( 0 ); ++} ++ ++/* ++ * This routine sends a break character out the serial port. ++ */ ++static void send_break (struct bcm_serial *info, int duration) ++{ ++ unsigned long flags; ++ ++ if (!info->port) ++ return; ++ ++ current->state = TASK_INTERRUPTIBLE; ++ ++ save_flags (flags); ++ cli(); ++ ++ info->port->control |= XMITBREAK; ++ schedule_timeout(duration); ++ info->port->control &= ~XMITBREAK; ++ ++ restore_flags (flags); ++} ++ ++static int bcm_ioctl (struct tty_struct * tty, struct file * file, ++ unsigned int cmd, unsigned long arg) ++{ ++ int error; ++ struct bcm_serial * info = (struct bcm_serial *)tty->driver_data; ++ int retval; ++ ++ if ((cmd != TIOCGSERIAL) && (cmd != TIOCSSERIAL) && ++ (cmd != TIOCSERCONFIG) && (cmd != TIOCSERGWILD) && ++ (cmd != TIOCSERSWILD) && (cmd != TIOCSERGSTRUCT)) ++ { ++ if (tty->flags & (1 << TTY_IO_ERROR)) ++ return -EIO; ++ } ++ switch (cmd) ++ { ++ ++ case TCSBRK: /* SVID version: non-zero arg --> no break */ ++ retval = tty_check_change (tty); ++ if (retval) ++ return retval; ++ tty_wait_until_sent (tty, 0); ++ if (!arg) ++ send_break (info, HZ/4); /* 1/4 second */ ++ return 0; ++ ++ case TCSBRKP: /* support for POSIX tcsendbreak() */ ++ retval = tty_check_change (tty); ++ if (retval) ++ return retval; ++ tty_wait_until_sent (tty, 0); ++ send_break (info, arg ? arg*(HZ/10) : HZ/4); ++ return 0; ++ ++ case TIOCGSOFTCAR: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(long)); ++ if (error) ++ return error; ++ put_user (C_CLOCAL(tty) ? 1 : 0, (unsigned long *)arg); ++ return 0; ++ ++ case TIOCSSOFTCAR: ++ error = get_user (arg, (unsigned long *)arg); ++ if (error) ++ return error; ++ tty->termios->c_cflag = ((tty->termios->c_cflag & ~CLOCAL) | (arg ? CLOCAL : 0)); ++ return 0; ++ ++ case TIOCGSERIAL: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(struct serial_struct)); ++ if (error) ++ return error; ++ return get_serial_info (info, (struct serial_struct *)arg); ++ ++ case TIOCSSERIAL: ++ return set_serial_info (info, (struct serial_struct *) arg); ++ ++ case TIOCSERGETLSR: /* Get line status register */ ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(unsigned int)); ++ if (error) ++ return error; ++ else ++ return get_lsr_info (info, (unsigned int *)arg); ++ ++ case TIOCSERGSTRUCT: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(struct bcm_serial)); ++ if (error) ++ return error; ++ copy_to_user((struct bcm_serial *)arg, info, sizeof(struct bcm_serial)); ++ return 0; ++ ++ default: ++ return -ENOIOCTLCMD; ++ } ++ return 0; ++} ++ ++static void bcm_set_termios (struct tty_struct *tty, struct termios *old_termios) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ ++ if( tty->termios->c_cflag != old_termios->c_cflag ) ++ change_speed (info->port, tty->termios->c_cflag); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm63xx_cons_close() ++ * ++ * This routine is called when the serial port gets closed. First, we ++ * wait for the last remaining data to be sent. Then, we turn off ++ * the transmit enable and receive enable flags. ++ * ------------------------------------------------------------ ++ */ ++static void bcm63xx_cons_close (struct tty_struct *tty, struct file *filp) ++{ ++ struct bcm_serial * info = (struct bcm_serial *)tty->driver_data; ++ unsigned long flags; ++ ++ if (!info) ++ return; ++ ++ save_flags (flags); ++ cli(); ++ ++ if (tty_hung_up_p (filp)) ++ { ++ restore_flags (flags); ++ return; ++ } ++ ++ if ((tty->count == 1) && (info->count != 1)) ++ { ++ ++ /* Uh, oh. tty->count is 1, which means that the tty ++ * structure will be freed. Info->count should always ++ * be one in these conditions. If it's greater than ++ * one, we've got real problems, since it means the ++ * serial port won't be shutdown. ++ */ ++ printk("bcm63xx_cons_close: bad serial port count; tty->count is 1, " ++ "info->count is %d\n", info->count); ++ info->count = 1; ++ } ++ ++ if (--info->count < 0) ++ { ++ printk("ds_close: bad serial port count for ttys%d: %d\n", ++ info->line, info->count); ++ info->count = 0; ++ } ++ ++ if (info->count) ++ { ++ restore_flags (flags); ++ return; ++ } ++ ++ /* Now we wait for the transmit buffer to clear; and we notify ++ * the line discipline to only process XON/XOFF characters. ++ */ ++ tty->closing = 1; ++ ++ /* At this point we stop accepting input. To do this, we ++ * disable the receive line status interrupts. ++ */ ++ shutdown (info); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ if (tty->driver->flush_buffer) ++ tty->driver->flush_buffer (tty); ++#else ++ if (tty->driver.flush_buffer) ++ tty->driver.flush_buffer (tty); ++#endif ++ if (tty->ldisc.flush_buffer) ++ tty->ldisc.flush_buffer (tty); ++ ++ tty->closing = 0; ++ info->event = 0; ++ info->tty = 0; ++ if (tty->ldisc.num != ldiscs[N_TTY].num) ++ { ++ if (tty->ldisc.close) ++ (tty->ldisc.close)(tty); ++ tty->ldisc = ldiscs[N_TTY]; ++ tty->termios->c_line = N_TTY; ++ if (tty->ldisc.open) ++ (tty->ldisc.open)(tty); ++ } ++ if (info->blocked_open) ++ { ++ if (info->close_delay) ++ { ++ current->state = TASK_INTERRUPTIBLE; ++ schedule_timeout(info->close_delay); ++ } ++ wake_up_interruptible (&info->open_wait); ++ } ++ wake_up_interruptible (&info->close_wait); ++ ++ restore_flags (flags); ++} ++ ++/* ++ * bcm_hangup () --- called by tty_hangup() when a hangup is signaled. ++ */ ++static void bcm_hangup (struct tty_struct *tty) ++{ ++ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ ++ shutdown (info); ++ info->event = 0; ++ info->count = 0; ++ info->tty = 0; ++ wake_up_interruptible (&info->open_wait); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_open() and friends ++ * ------------------------------------------------------------ ++ */ ++static int block_til_ready (struct tty_struct *tty, struct file *filp, ++ struct bcm_serial *info) ++{ ++ return 0; ++} ++ ++/* ++ * This routine is called whenever a serial port is opened. It ++ * enables interrupts for a serial port. It also performs the ++ * serial-specific initialization for the tty structure. ++ */ ++static int bcm63xx_cons_open (struct tty_struct * tty, struct file * filp) ++{ ++ struct bcm_serial *info; ++ int retval, line; ++ ++ // Make sure we're only opening on of the ports we support ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ line = MINOR(tty->driver->cdev.dev) - tty->driver->minor_start; ++#else ++ line = MINOR(tty->device) - tty->driver.minor_start; ++#endif ++ ++ if ((line < 0) || (line >= BCM_NUM_UARTS)) ++ return -ENODEV; ++ ++ info = lines[line]; ++ ++ info->port->intMask = 0; /* Clear any pending interrupts */ ++ info->port->intMask = RXINT; /* Enable RX */ ++ ++ info->count++; ++ tty->driver_data = info; ++ info->tty = tty; ++ BcmHalInterruptEnable (INTERRUPT_ID_UART); ++ ++ // Start up serial port ++ retval = startup (info); ++ if (retval) ++ return retval; ++ ++ retval = block_til_ready (tty, filp, info); ++ if (retval) ++ return retval; ++ ++ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ info->pgrp = process_group(current); ++ info->session = current->signal->session; ++#else ++ info->session = current->session; ++ info->pgrp = current->pgrp; ++#endif ++ ++ return 0; ++} ++ ++/* -------------------------------------------------------------------------- ++ Name: bcm63xx_serialinit ++ Purpose: Initialize our BCM63xx serial driver ++-------------------------------------------------------------------------- */ ++static int __init bcm63xx_serialinit(void) ++{ ++ int i, flags; ++ struct bcm_serial * info; ++ ++ // Print the driver version information ++ printk(VER_STR); ++ ++ memset(&serial_driver, 0, sizeof(struct tty_driver)); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ serial_driver.owner = THIS_MODULE; ++ serial_driver.devfs_name = "tts/"; ++#endif ++ serial_driver.magic = TTY_DRIVER_MAGIC; ++ serial_driver.name = "ttyS"; ++ serial_driver.major = TTY_MAJOR; ++ serial_driver.minor_start = 64; ++ serial_driver.num = BCM_NUM_UARTS; ++ serial_driver.type = TTY_DRIVER_TYPE_SERIAL; ++ serial_driver.subtype = SERIAL_TYPE_NORMAL; ++ serial_driver.init_termios = tty_std_termios; ++ serial_driver.init_termios.c_cflag = B115200 | CS8 | CREAD | CLOCAL; ++ serial_driver.flags = TTY_DRIVER_REAL_RAW; ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ serial_driver.refcount = serial_refcount; ++ serial_driver.ttys = serial_table; ++#else ++ serial_driver.refcount = &serial_refcount; ++ serial_driver.table = serial_table; ++#endif ++ ++ serial_driver.termios = serial_termios; ++ serial_driver.termios_locked = serial_termios_locked; ++ serial_driver.open = bcm63xx_cons_open; ++ serial_driver.close = bcm63xx_cons_close; ++ serial_driver.write = bcm63xx_cons_write; ++ serial_driver.flush_chars = bcm63xx_cons_flush_chars; ++ serial_driver.write_room = bcm63xx_cons_write_room; ++ serial_driver.chars_in_buffer = bcm_chars_in_buffer; ++ serial_driver.flush_buffer = bcm_flush_buffer; ++ serial_driver.ioctl = bcm_ioctl; ++ serial_driver.throttle = bcm_throttle; ++ serial_driver.unthrottle = bcm_unthrottle; ++ serial_driver.send_xchar = bcm_send_xchar; ++ serial_driver.set_termios = bcm_set_termios; ++ serial_driver.stop = bcm_stop; ++ serial_driver.start = bcm_start; ++ serial_driver.hangup = bcm_hangup; ++ ++ if (tty_register_driver (&serial_driver)) ++ panic("Couldn't register serial driver\n"); ++ ++ save_flags(flags); cli(); ++ for (i = 0; i < BCM_NUM_UARTS; i++) ++ { ++ info = &multi[i]; ++ lines[i] = info; ++ info->port = (Uart *) ((char *)UART_BASE + (i * 0x20)); ++ info->irq = (2 - i) + 8; ++ info->line = i; ++ info->tty = 0; ++ info->close_delay = 50; ++ info->closing_wait = 3000; ++ info->x_char = 0; ++ info->event = 0; ++ info->count = 0; ++ info->blocked_open = 0; ++ info->normal_termios = serial_driver.init_termios; ++ init_waitqueue_head(&info->open_wait); ++ init_waitqueue_head(&info->close_wait); ++ ++ /* If we are pointing to address zero then punt - not correctly ++ * set up in setup.c to handle this. ++ */ ++ if (! info->port) ++ return 0; ++ BcmHalMapInterrupt(bcm_interrupt, 0, INTERRUPT_ID_UART); ++ } ++ ++ /* order matters here... the trick is that flags ++ * is updated... in request_irq - to immediatedly obliterate ++ * it is unwise. ++ */ ++ restore_flags(flags); ++ return 0; ++} ++ ++module_init(bcm63xx_serialinit); ++ ++/* -------------------------------------------------------------------------- ++ Name: bcm_console_print ++ Purpose: bcm_console_print is registered for printk. ++ The console_lock must be held when we get here. ++-------------------------------------------------------------------------- */ ++static void bcm_console_print (struct console * cons, const char * str, ++ unsigned int count) ++{ ++ unsigned int i; ++ //_puts(str); ++ for(i=0; iindex; ++ return &serial_driver; ++} ++ ++static int __init bcm_console_setup(struct console * co, char * options) ++{ ++ return 0; ++} ++ ++static struct console bcm_sercons = { ++ .name = "ttyS", ++ .write = bcm_console_print, ++ .device = bcm_console_device, ++ .setup = bcm_console_setup, ++ .flags = CON_PRINTBUFFER, // CON_CONSDEV, CONSOLE_LINE, ++ .index = -1, ++}; ++ ++static int __init bcm63xx_console_init(void) ++{ ++ register_console(&bcm_sercons); ++ return 0; ++} ++ ++console_initcall(bcm63xx_console_init); +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/serial/impl1/Makefile linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/impl1/Makefile +--- linux-2.6.8.1/bcmdrivers/opensource/char/serial/impl1/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/impl1/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,13 @@ ++# File: bcmdrivers/opensource/char/serial ++# ++# Makefile for the BCM63xx serial/console driver ++ ++obj-$(CONFIG_BCM_SERIAL) += bcm63xx_cons.o ++ ++EXTRA_CFLAGS += -I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) ++ ++-include $(TOPDIR)/Rules.make ++ ++clean: ++ rm -f core *.o *.a *.s ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/char/serial/impl1/bcm63xx_cons.c linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/impl1/bcm63xx_cons.c +--- linux-2.6.8.1/bcmdrivers/opensource/char/serial/impl1/bcm63xx_cons.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/char/serial/impl1/bcm63xx_cons.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,1035 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++/* Description: Serial port driver for the BCM963XX. */ ++ ++#define CARDNAME "bcm963xx_serial driver" ++#define VERSION "2.0" ++#define VER_STR CARDNAME " v" VERSION "\n" ++ ++ ++#include ++#include ++#include ++#include ++#include ++#include ++ ++/* for definition of struct console */ ++#include ++#include ++#include ++#include ++#include ++ ++#include ++#include ++#include ++#include ++ ++extern void _putc(char); ++extern void _puts(const char *); ++ ++typedef struct bcm_serial { ++ volatile Uart * port; ++ int type; ++ int flags; ++ int irq; ++ int baud_base; ++ int blocked_open; ++ unsigned short close_delay; ++ unsigned short closing_wait; ++ unsigned short line; /* port/line number */ ++ unsigned short cflags; /* line configuration flag */ ++ unsigned short x_char; /* xon/xoff character */ ++ unsigned short read_status_mask; /* mask for read condition */ ++ unsigned short ignore_status_mask; /* mask for ignore condition */ ++ unsigned long event; /* mask used in BH */ ++ int xmit_head; /* Position of the head */ ++ int xmit_tail; /* Position of the tail */ ++ int xmit_cnt; /* Count of the chars in the buffer */ ++ int count; /* indicates how many times it has been opened */ ++ int magic; ++ ++ struct async_icount icount; /* keep track of things ... */ ++ struct tty_struct *tty; /* tty associated */ ++ struct termios normal_termios; ++ ++ wait_queue_head_t open_wait; ++ wait_queue_head_t close_wait; ++ ++ long session; /* Session of opening process */ ++ long pgrp; /* pgrp of opening process */ ++ ++ unsigned char is_initialized; ++} Context; ++ ++ ++/*---------------------------------------------------------------------*/ ++/* Define bits in the Interrupt Enable register */ ++/*---------------------------------------------------------------------*/ ++/* Enable receive interrupt */ ++#define RXINT (RXFIFONE|RXOVFERR) ++ ++/* Enable transmit interrupt */ ++#define TXINT (TXFIFOEMT|TXUNDERR|TXOVFERR) ++ ++/* Enable receiver line status interrupt */ ++#define LSINT (RXBRK|RXPARERR|RXFRAMERR) ++ ++#define BCM_NUM_UARTS 1 ++ ++#define BD_BCM63XX_TIMER_CLOCK_INPUT (FPERIPH) ++ ++ ++static struct bcm_serial multi[BCM_NUM_UARTS]; ++static struct bcm_serial *lines[BCM_NUM_UARTS]; ++static struct tty_driver serial_driver; ++static struct tty_struct *serial_table[BCM_NUM_UARTS]; ++static struct termios *serial_termios[BCM_NUM_UARTS]; ++static struct termios *serial_termios_locked[BCM_NUM_UARTS]; ++static int serial_refcount; ++ ++ ++static void bcm_stop (struct tty_struct *tty); ++static void bcm_start (struct tty_struct *tty); ++static inline void receive_chars (struct bcm_serial * info); ++static int startup (struct bcm_serial *info); ++static void shutdown (struct bcm_serial * info); ++static void change_speed( volatile Uart *pUart, tcflag_t cFlag ); ++static void bcm63xx_cons_flush_chars (struct tty_struct *tty); ++static int bcm63xx_cons_write (struct tty_struct *tty, int from_user, ++ const unsigned char *buf, int count); ++static int bcm63xx_cons_write_room (struct tty_struct *tty); ++static int bcm_chars_in_buffer (struct tty_struct *tty); ++static void bcm_flush_buffer (struct tty_struct *tty); ++static void bcm_throttle (struct tty_struct *tty); ++static void bcm_unthrottle (struct tty_struct *tty); ++static void bcm_send_xchar (struct tty_struct *tty, char ch); ++static int get_serial_info(struct bcm_serial *info, struct serial_struct *retinfo); ++static int set_serial_info (struct bcm_serial *info, struct serial_struct *new_info); ++static int get_lsr_info (struct bcm_serial *info, unsigned int *value); ++static void send_break (struct bcm_serial *info, int duration); ++static int bcm_ioctl (struct tty_struct * tty, struct file * file, ++ unsigned int cmd, unsigned long arg); ++static void bcm_set_termios (struct tty_struct *tty, struct termios *old_termios); ++static void bcm63xx_cons_close (struct tty_struct *tty, struct file *filp); ++static void bcm_hangup (struct tty_struct *tty); ++static int block_til_ready (struct tty_struct *tty, struct file *filp, struct bcm_serial *info); ++static int bcm63xx_cons_open (struct tty_struct * tty, struct file * filp); ++static int __init bcm63xx_serialinit(void); ++ ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_stop () and rs_start () ++ * ++ * These routines are called before setting or resetting ++ * tty->stopped. They enable or disable transmitter interrupts, ++ * as necessary. ++ * ------------------------------------------------------------ ++ */ ++static void bcm_stop (struct tty_struct *tty) ++{ ++} ++ ++static void bcm_start (struct tty_struct *tty) ++{ ++ _puts(CARDNAME " Start\n"); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * receive_char () ++ * ++ * This routine deals with inputs from any lines. ++ * ------------------------------------------------------------ ++ */ ++static inline void receive_chars (struct bcm_serial * info) ++{ ++ struct tty_struct *tty = 0; ++ struct async_icount * icount; ++ int ignore = 0; ++ unsigned short status, tmp; ++ UCHAR ch = 0; ++ while ((status = info->port->intStatus) & RXINT) ++ { ++ if (status & RXFIFONE) ++ ch = info->port->Data; // Read the character ++ tty = info->tty; /* now tty points to the proper dev */ ++ icount = &info->icount; ++ if (! tty) ++ break; ++ if (tty->flip.count >= TTY_FLIPBUF_SIZE) ++ break; ++ *tty->flip.char_buf_ptr = ch; ++ *tty->flip.flag_buf_ptr = 0; ++ icount->rx++; ++ if (status & RXBRK) ++ { ++ *tty->flip.flag_buf_ptr = TTY_BREAK; ++ icount->brk++; ++ } ++ // keep track of the statistics ++ if (status & (RXFRAMERR | RXPARERR | RXOVFERR)) ++ { ++ if (status & RXPARERR) /* parity error */ ++ icount->parity++; ++ else ++ if (status & RXFRAMERR) /* frame error */ ++ icount->frame++; ++ if (status & RXOVFERR) ++ { ++ // Overflow. Reset the RX FIFO ++ info->port->fifoctl |= RSTRXFIFOS; ++ icount->overrun++; ++ } ++ // check to see if we should ignore the character ++ // and mask off conditions that should be ignored ++ if (status & info->ignore_status_mask) ++ { ++ if (++ignore > 100 ) ++ break; ++ goto ignore_char; ++ } ++ // Mask off the error conditions we want to ignore ++ tmp = status & info->read_status_mask; ++ if (tmp & RXPARERR) ++ { ++ *tty->flip.flag_buf_ptr = TTY_PARITY; ++ } ++ else ++ if (tmp & RXFRAMERR) ++ { ++ *tty->flip.flag_buf_ptr = TTY_FRAME; ++ } ++ if (tmp & RXOVFERR) ++ { ++ if (tty->flip.count < TTY_FLIPBUF_SIZE) ++ { ++ tty->flip.count++; ++ tty->flip.flag_buf_ptr++; ++ tty->flip.char_buf_ptr++; ++ *tty->flip.flag_buf_ptr = TTY_OVERRUN; ++ } ++ } ++ } ++ tty->flip.flag_buf_ptr++; ++ tty->flip.char_buf_ptr++; ++ tty->flip.count++; ++ } ++ignore_char: ++ if (tty) ++ tty_flip_buffer_push(tty); ++} ++ ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm_interrupt () ++ * ++ * this is the main interrupt routine for the chip. ++ * It deals with the multiple ports. ++ * ------------------------------------------------------------ ++ */ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++static irqreturn_t bcm_interrupt (int irq, void * dev, struct pt_regs * regs) ++#else ++static void bcm_interrupt (int irq, void * dev, struct pt_regs * regs) ++#endif ++{ ++ struct bcm_serial * info = lines[0]; ++ UINT16 intStat; ++ ++ /* get pending interrupt flags from UART */ ++ ++ /* Mask with only the serial interrupts that are enabled */ ++ intStat = info->port->intStatus & info->port->intMask; ++ while (intStat) ++ { ++ if (intStat & RXINT) ++ receive_chars (info); ++ else ++ if (intStat & TXINT) ++ info->port->intStatus = TXINT; ++ else /* don't know what it was, so let's mask it */ ++ info->port->intMask &= ~intStat; ++ ++ intStat = info->port->intStatus & info->port->intMask; ++ } ++ ++ // Clear the interrupt ++ BcmHalInterruptEnable (INTERRUPT_ID_UART); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ return IRQ_HANDLED; ++#endif ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * startup () ++ * ++ * various initialization tasks ++ * ------------------------------------------------------------------- ++ */ ++static int startup (struct bcm_serial *info) ++{ ++ // Port is already started... ++ return 0; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * shutdown () ++ * ++ * This routine will shutdown a serial port; interrupts are disabled, and ++ * DTR is dropped if the hangup on close termio flag is on. ++ * ------------------------------------------------------------------- ++ */ ++static void shutdown (struct bcm_serial * info) ++{ ++ unsigned long flags; ++ if (!info->is_initialized) ++ return; ++ ++ save_flags (flags); ++ cli (); ++ ++ info->port->control &= ~(BRGEN|TXEN|RXEN); ++ if (info->tty) ++ set_bit (TTY_IO_ERROR, &info->tty->flags); ++ info->is_initialized = 0; ++ ++ restore_flags (flags); ++} ++/* ++ * ------------------------------------------------------------------- ++ * change_speed () ++ * ++ * Set the baud rate, character size, parity and stop bits. ++ * ------------------------------------------------------------------- ++ */ ++static void change_speed( volatile Uart *pUart, tcflag_t cFlag ) ++{ ++ unsigned long ulFlags, ulBaud, ulClockFreqHz, ulTmp; ++ save_flags(ulFlags); ++ cli(); ++ switch( cFlag & (CBAUD | CBAUDEX) ) ++ { ++ case B115200: ++ ulBaud = 115200; ++ break; ++ case B57600: ++ ulBaud = 57600; ++ break; ++ case B38400: ++ ulBaud = 38400; ++ break; ++ case B19200: ++ ulBaud = 19200; ++ break; ++ case B9600: ++ ulBaud = 9600; ++ break; ++ case B4800: ++ ulBaud = 4800; ++ break; ++ case B2400: ++ ulBaud = 2400; ++ break; ++ case B1800: ++ ulBaud = 1800; ++ break; ++ case B1200: ++ ulBaud = 1200; ++ break; ++ case B600: ++ ulBaud = 600; ++ break; ++ case B300: ++ ulBaud = 300; ++ break; ++ case B200: ++ ulBaud = 200; ++ break; ++ case B150: ++ ulBaud = 150; ++ break; ++ case B134: ++ ulBaud = 134; ++ break; ++ case B110: ++ ulBaud = 110; ++ break; ++ case B75: ++ ulBaud = 75; ++ break; ++ case B50: ++ ulBaud = 50; ++ break; ++ default: ++ ulBaud = 115200; ++ break; ++ } ++ ++ /* Calculate buad rate. */ ++ ulClockFreqHz = BD_BCM63XX_TIMER_CLOCK_INPUT; ++ ulTmp = (ulClockFreqHz / ulBaud) / 16; ++ if( ulTmp & 0x01 ) ++ ulTmp /= 2; /* Rounding up, so sub is already accounted for */ ++ else ++ ulTmp = (ulTmp / 2) - 1; /* Rounding down so we must sub 1 */ ++ pUart->baudword = ulTmp; ++ ++ /* Set character size, stop bits and parity. */ ++ switch( cFlag & CSIZE ) ++ { ++ case CS5: ++ ulTmp = BITS5SYM; /* select transmit 5 bit data size */ ++ break; ++ case CS6: ++ ulTmp = BITS6SYM; /* select transmit 6 bit data size */ ++ break; ++ case CS7: ++ ulTmp = BITS7SYM; /* select transmit 7 bit data size */ ++ break; ++ /*case CS8:*/ ++ default: ++ ulTmp = BITS8SYM; /* select transmit 8 bit data size */ ++ break; ++ } ++ if( cFlag & CSTOPB ) ++ ulTmp |= TWOSTOP; /* select 2 stop bits */ ++ else ++ ulTmp |= ONESTOP; /* select one stop bit */ ++ ++ /* Write these values into the config reg. */ ++ pUart->config = ulTmp; ++ pUart->control &= ~(RXPARITYEN | TXPARITYEN | RXPARITYEVEN | TXPARITYEVEN); ++ switch( cFlag & (PARENB | PARODD) ) ++ { ++ case PARENB|PARODD: ++ pUart->control |= RXPARITYEN | TXPARITYEN; ++ break; ++ case PARENB: ++ pUart->control |= RXPARITYEN | TXPARITYEN | RXPARITYEVEN | TXPARITYEVEN; ++ break; ++ default: ++ pUart->control |= 0; ++ break; ++ } ++ ++ /* Reset and flush uart */ ++ pUart->fifoctl = RSTTXFIFOS | RSTRXFIFOS; ++ restore_flags( ulFlags ); ++} ++ ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_flush_char () ++ * ++ * Nothing to flush. Polled I/O is used. ++ * ------------------------------------------------------------------- ++ */ ++static void bcm63xx_cons_flush_chars (struct tty_struct *tty) ++{ ++} ++ ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm63xx_cons_write () ++ * ++ * Main output routine using polled I/O. ++ * ------------------------------------------------------------------- ++ */ ++static int bcm63xx_cons_write (struct tty_struct *tty, int from_user, ++ const unsigned char *buf, int count) ++{ ++ int c; ++ ++ for (c = 0; c < count; c++) ++ _putc(buf[c]); ++ return count; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm63xx_cons_write_room () ++ * ++ * Compute the amount of space available for writing. ++ * ------------------------------------------------------------------- ++ */ ++static int bcm63xx_cons_write_room (struct tty_struct *tty) ++{ ++ /* Pick a number. Any number. Polled I/O is used. */ ++ return 1024; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_chars_in_buffer () ++ * ++ * compute the amount of char left to be transmitted ++ * ------------------------------------------------------------------- ++ */ ++static int bcm_chars_in_buffer (struct tty_struct *tty) ++{ ++ return 0; ++} ++ ++/* ++ * ------------------------------------------------------------------- ++ * bcm_flush_buffer () ++ * ++ * Empty the output buffer ++ * ------------------------------------------------------------------- ++ */ ++static void bcm_flush_buffer (struct tty_struct *tty) ++{ ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm_throttle () and bcm_unthrottle () ++ * ++ * This routine is called by the upper-layer tty layer to signal that ++ * incoming characters should be throttled (or not). ++ * ------------------------------------------------------------ ++ */ ++static void bcm_throttle (struct tty_struct *tty) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ if (I_IXOFF(tty)) ++ info->x_char = STOP_CHAR(tty); ++} ++ ++static void bcm_unthrottle (struct tty_struct *tty) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ if (I_IXOFF(tty)) ++ { ++ if (info->x_char) ++ info->x_char = 0; ++ else ++ info->x_char = START_CHAR(tty); ++ } ++} ++ ++static void bcm_send_xchar (struct tty_struct *tty, char ch) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ info->x_char = ch; ++ if (ch) ++ bcm_start (info->tty); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_ioctl () and friends ++ * ------------------------------------------------------------ ++ */ ++static int get_serial_info(struct bcm_serial *info, struct serial_struct *retinfo) ++{ ++ struct serial_struct tmp; ++ ++ if (!retinfo) ++ return -EFAULT; ++ ++ memset (&tmp, 0, sizeof(tmp)); ++ tmp.type = info->type; ++ tmp.line = info->line; ++ tmp.port = (int) info->port; ++ tmp.irq = info->irq; ++ tmp.flags = 0; ++ tmp.baud_base = info->baud_base; ++ tmp.close_delay = info->close_delay; ++ tmp.closing_wait = info->closing_wait; ++ ++ return copy_to_user (retinfo, &tmp, sizeof(*retinfo)); ++} ++ ++static int set_serial_info (struct bcm_serial *info, struct serial_struct *new_info) ++{ ++ struct serial_struct new_serial; ++ struct bcm_serial old_info; ++ int retval = 0; ++ ++ if (!new_info) ++ return -EFAULT; ++ ++ copy_from_user (&new_serial, new_info, sizeof(new_serial)); ++ old_info = *info; ++ ++ if (!capable(CAP_SYS_ADMIN)) ++ return -EPERM; ++ ++ ++ if (info->count > 1) ++ return -EBUSY; ++ ++ /* OK, past this point, all the error checking has been done. ++ * At this point, we start making changes..... ++ */ ++ info->baud_base = new_serial.baud_base; ++ info->type = new_serial.type; ++ info->close_delay = new_serial.close_delay; ++ info->closing_wait = new_serial.closing_wait; ++ retval = startup (info); ++ return retval; ++} ++ ++/* ++ * get_lsr_info - get line status register info ++ * ++ * Purpose: Let user call ioctl() to get info when the UART physically ++ * is emptied. On bus types like RS485, the transmitter must ++ * release the bus after transmitting. This must be done when ++ * the transmit shift register is empty, not be done when the ++ * transmit holding register is empty. This functionality ++ * allows an RS485 driver to be written in user space. ++ */ ++static int get_lsr_info (struct bcm_serial *info, unsigned int *value) ++{ ++ return( 0 ); ++} ++ ++/* ++ * This routine sends a break character out the serial port. ++ */ ++static void send_break (struct bcm_serial *info, int duration) ++{ ++ unsigned long flags; ++ ++ if (!info->port) ++ return; ++ ++ current->state = TASK_INTERRUPTIBLE; ++ ++ save_flags (flags); ++ cli(); ++ ++ info->port->control |= XMITBREAK; ++ schedule_timeout(duration); ++ info->port->control &= ~XMITBREAK; ++ ++ restore_flags (flags); ++} ++ ++static int bcm_ioctl (struct tty_struct * tty, struct file * file, ++ unsigned int cmd, unsigned long arg) ++{ ++ int error; ++ struct bcm_serial * info = (struct bcm_serial *)tty->driver_data; ++ int retval; ++ ++ if ((cmd != TIOCGSERIAL) && (cmd != TIOCSSERIAL) && ++ (cmd != TIOCSERCONFIG) && (cmd != TIOCSERGWILD) && ++ (cmd != TIOCSERSWILD) && (cmd != TIOCSERGSTRUCT)) ++ { ++ if (tty->flags & (1 << TTY_IO_ERROR)) ++ return -EIO; ++ } ++ switch (cmd) ++ { ++ ++ case TCSBRK: /* SVID version: non-zero arg --> no break */ ++ retval = tty_check_change (tty); ++ if (retval) ++ return retval; ++ tty_wait_until_sent (tty, 0); ++ if (!arg) ++ send_break (info, HZ/4); /* 1/4 second */ ++ return 0; ++ ++ case TCSBRKP: /* support for POSIX tcsendbreak() */ ++ retval = tty_check_change (tty); ++ if (retval) ++ return retval; ++ tty_wait_until_sent (tty, 0); ++ send_break (info, arg ? arg*(HZ/10) : HZ/4); ++ return 0; ++ ++ case TIOCGSOFTCAR: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(long)); ++ if (error) ++ return error; ++ put_user (C_CLOCAL(tty) ? 1 : 0, (unsigned long *)arg); ++ return 0; ++ ++ case TIOCSSOFTCAR: ++ error = get_user (arg, (unsigned long *)arg); ++ if (error) ++ return error; ++ tty->termios->c_cflag = ((tty->termios->c_cflag & ~CLOCAL) | (arg ? CLOCAL : 0)); ++ return 0; ++ ++ case TIOCGSERIAL: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(struct serial_struct)); ++ if (error) ++ return error; ++ return get_serial_info (info, (struct serial_struct *)arg); ++ ++ case TIOCSSERIAL: ++ return set_serial_info (info, (struct serial_struct *) arg); ++ ++ case TIOCSERGETLSR: /* Get line status register */ ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(unsigned int)); ++ if (error) ++ return error; ++ else ++ return get_lsr_info (info, (unsigned int *)arg); ++ ++ case TIOCSERGSTRUCT: ++ error = verify_area (VERIFY_WRITE, (void *)arg, sizeof(struct bcm_serial)); ++ if (error) ++ return error; ++ copy_to_user((struct bcm_serial *)arg, info, sizeof(struct bcm_serial)); ++ return 0; ++ ++ default: ++ return -ENOIOCTLCMD; ++ } ++ return 0; ++} ++ ++static void bcm_set_termios (struct tty_struct *tty, struct termios *old_termios) ++{ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ ++ if( tty->termios->c_cflag != old_termios->c_cflag ) ++ change_speed (info->port, tty->termios->c_cflag); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * bcm63xx_cons_close() ++ * ++ * This routine is called when the serial port gets closed. First, we ++ * wait for the last remaining data to be sent. Then, we turn off ++ * the transmit enable and receive enable flags. ++ * ------------------------------------------------------------ ++ */ ++static void bcm63xx_cons_close (struct tty_struct *tty, struct file *filp) ++{ ++ struct bcm_serial * info = (struct bcm_serial *)tty->driver_data; ++ unsigned long flags; ++ ++ if (!info) ++ return; ++ ++ save_flags (flags); ++ cli(); ++ ++ if (tty_hung_up_p (filp)) ++ { ++ restore_flags (flags); ++ return; ++ } ++ ++ if ((tty->count == 1) && (info->count != 1)) ++ { ++ ++ /* Uh, oh. tty->count is 1, which means that the tty ++ * structure will be freed. Info->count should always ++ * be one in these conditions. If it's greater than ++ * one, we've got real problems, since it means the ++ * serial port won't be shutdown. ++ */ ++ printk("bcm63xx_cons_close: bad serial port count; tty->count is 1, " ++ "info->count is %d\n", info->count); ++ info->count = 1; ++ } ++ ++ if (--info->count < 0) ++ { ++ printk("ds_close: bad serial port count for ttys%d: %d\n", ++ info->line, info->count); ++ info->count = 0; ++ } ++ ++ if (info->count) ++ { ++ restore_flags (flags); ++ return; ++ } ++ ++ /* Now we wait for the transmit buffer to clear; and we notify ++ * the line discipline to only process XON/XOFF characters. ++ */ ++ tty->closing = 1; ++ ++ /* At this point we stop accepting input. To do this, we ++ * disable the receive line status interrupts. ++ */ ++ shutdown (info); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ if (tty->driver->flush_buffer) ++ tty->driver->flush_buffer (tty); ++#else ++ if (tty->driver.flush_buffer) ++ tty->driver.flush_buffer (tty); ++#endif ++ if (tty->ldisc.flush_buffer) ++ tty->ldisc.flush_buffer (tty); ++ ++ tty->closing = 0; ++ info->event = 0; ++ info->tty = 0; ++ if (tty->ldisc.num != ldiscs[N_TTY].num) ++ { ++ if (tty->ldisc.close) ++ (tty->ldisc.close)(tty); ++ tty->ldisc = ldiscs[N_TTY]; ++ tty->termios->c_line = N_TTY; ++ if (tty->ldisc.open) ++ (tty->ldisc.open)(tty); ++ } ++ if (info->blocked_open) ++ { ++ if (info->close_delay) ++ { ++ current->state = TASK_INTERRUPTIBLE; ++ schedule_timeout(info->close_delay); ++ } ++ wake_up_interruptible (&info->open_wait); ++ } ++ wake_up_interruptible (&info->close_wait); ++ ++ restore_flags (flags); ++} ++ ++/* ++ * bcm_hangup () --- called by tty_hangup() when a hangup is signaled. ++ */ ++static void bcm_hangup (struct tty_struct *tty) ++{ ++ ++ struct bcm_serial *info = (struct bcm_serial *)tty->driver_data; ++ ++ shutdown (info); ++ info->event = 0; ++ info->count = 0; ++ info->tty = 0; ++ wake_up_interruptible (&info->open_wait); ++} ++ ++/* ++ * ------------------------------------------------------------ ++ * rs_open() and friends ++ * ------------------------------------------------------------ ++ */ ++static int block_til_ready (struct tty_struct *tty, struct file *filp, ++ struct bcm_serial *info) ++{ ++ return 0; ++} ++ ++/* ++ * This routine is called whenever a serial port is opened. It ++ * enables interrupts for a serial port. It also performs the ++ * serial-specific initialization for the tty structure. ++ */ ++static int bcm63xx_cons_open (struct tty_struct * tty, struct file * filp) ++{ ++ struct bcm_serial *info; ++ int retval, line; ++ ++ // Make sure we're only opening on of the ports we support ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ line = MINOR(tty->driver->cdev.dev) - tty->driver->minor_start; ++#else ++ line = MINOR(tty->device) - tty->driver.minor_start; ++#endif ++ ++ if ((line < 0) || (line >= BCM_NUM_UARTS)) ++ return -ENODEV; ++ ++ info = lines[line]; ++ ++ info->port->intMask = 0; /* Clear any pending interrupts */ ++ info->port->intMask = RXINT; /* Enable RX */ ++ ++ info->count++; ++ tty->driver_data = info; ++ info->tty = tty; ++ BcmHalInterruptEnable (INTERRUPT_ID_UART); ++ ++ // Start up serial port ++ retval = startup (info); ++ if (retval) ++ return retval; ++ ++ retval = block_til_ready (tty, filp, info); ++ if (retval) ++ return retval; ++ ++ ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ info->pgrp = process_group(current); ++ info->session = current->signal->session; ++#else ++ info->session = current->session; ++ info->pgrp = current->pgrp; ++#endif ++ ++ return 0; ++} ++ ++/* -------------------------------------------------------------------------- ++ Name: bcm63xx_serialinit ++ Purpose: Initialize our BCM63xx serial driver ++-------------------------------------------------------------------------- */ ++static int __init bcm63xx_serialinit(void) ++{ ++ int i, flags; ++ struct bcm_serial * info; ++ ++ // Print the driver version information ++ printk(VER_STR); ++ ++ memset(&serial_driver, 0, sizeof(struct tty_driver)); ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ serial_driver.owner = THIS_MODULE; ++ serial_driver.devfs_name = "tts/"; ++#endif ++ serial_driver.magic = TTY_DRIVER_MAGIC; ++ serial_driver.name = "ttyS"; ++ serial_driver.major = TTY_MAJOR; ++ serial_driver.minor_start = 64; ++ serial_driver.num = BCM_NUM_UARTS; ++ serial_driver.type = TTY_DRIVER_TYPE_SERIAL; ++ serial_driver.subtype = SERIAL_TYPE_NORMAL; ++ serial_driver.init_termios = tty_std_termios; ++ serial_driver.init_termios.c_cflag = B115200 | CS8 | CREAD | CLOCAL; ++ serial_driver.flags = TTY_DRIVER_REAL_RAW; ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) ++ serial_driver.refcount = serial_refcount; ++ serial_driver.ttys = serial_table; ++#else ++ serial_driver.refcount = &serial_refcount; ++ serial_driver.table = serial_table; ++#endif ++ ++ serial_driver.termios = serial_termios; ++ serial_driver.termios_locked = serial_termios_locked; ++ serial_driver.open = bcm63xx_cons_open; ++ serial_driver.close = bcm63xx_cons_close; ++ serial_driver.write = bcm63xx_cons_write; ++ serial_driver.flush_chars = bcm63xx_cons_flush_chars; ++ serial_driver.write_room = bcm63xx_cons_write_room; ++ serial_driver.chars_in_buffer = bcm_chars_in_buffer; ++ serial_driver.flush_buffer = bcm_flush_buffer; ++ serial_driver.ioctl = bcm_ioctl; ++ serial_driver.throttle = bcm_throttle; ++ serial_driver.unthrottle = bcm_unthrottle; ++ serial_driver.send_xchar = bcm_send_xchar; ++ serial_driver.set_termios = bcm_set_termios; ++ serial_driver.stop = bcm_stop; ++ serial_driver.start = bcm_start; ++ serial_driver.hangup = bcm_hangup; ++ ++ if (tty_register_driver (&serial_driver)) ++ panic("Couldn't register serial driver\n"); ++ ++ save_flags(flags); cli(); ++ for (i = 0; i < BCM_NUM_UARTS; i++) ++ { ++ info = &multi[i]; ++ lines[i] = info; ++ info->port = (Uart *) ((char *)UART_BASE + (i * 0x20)); ++ info->irq = (2 - i) + 8; ++ info->line = i; ++ info->tty = 0; ++ info->close_delay = 50; ++ info->closing_wait = 3000; ++ info->x_char = 0; ++ info->event = 0; ++ info->count = 0; ++ info->blocked_open = 0; ++ info->normal_termios = serial_driver.init_termios; ++ init_waitqueue_head(&info->open_wait); ++ init_waitqueue_head(&info->close_wait); ++ ++ /* If we are pointing to address zero then punt - not correctly ++ * set up in setup.c to handle this. ++ */ ++ if (! info->port) ++ return 0; ++ BcmHalMapInterrupt(bcm_interrupt, 0, INTERRUPT_ID_UART); ++ } ++ ++ /* order matters here... the trick is that flags ++ * is updated... in request_irq - to immediatedly obliterate ++ * it is unwise. ++ */ ++ restore_flags(flags); ++ return 0; ++} ++ ++module_init(bcm63xx_serialinit); ++ ++/* -------------------------------------------------------------------------- ++ Name: bcm_console_print ++ Purpose: bcm_console_print is registered for printk. ++ The console_lock must be held when we get here. ++-------------------------------------------------------------------------- */ ++static void bcm_console_print (struct console * cons, const char * str, ++ unsigned int count) ++{ ++ unsigned int i; ++ //_puts(str); ++ for(i=0; iindex; ++ return &serial_driver; ++} ++ ++static int __init bcm_console_setup(struct console * co, char * options) ++{ ++ return 0; ++} ++ ++static struct console bcm_sercons = { ++ .name = "ttyS", ++ .write = bcm_console_print, ++ .device = bcm_console_device, ++ .setup = bcm_console_setup, ++ .flags = CON_PRINTBUFFER, // CON_CONSDEV, CONSOLE_LINE, ++ .index = -1, ++}; ++ ++static int __init bcm63xx_console_init(void) ++{ ++ register_console(&bcm_sercons); ++ return 0; ++} ++ ++console_initcall(bcm63xx_console_init); +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6338_intr.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6338_intr.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6338_intr.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6338_intr.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,72 @@ ++/* ++<:copyright-gpl ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __6338_INTR_H ++#define __6338_INTR_H ++ ++#ifdef __cplusplus ++ extern "C" { ++#endif ++ ++/*=====================================================================*/ ++/* BCM6338 External Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define INTERRUPT_ID_EXTERNAL_0 3 ++#define INTERRUPT_ID_EXTERNAL_1 4 ++#define INTERRUPT_ID_EXTERNAL_2 5 ++#define INTERRUPT_ID_EXTERNAL_3 6 ++ ++/*=====================================================================*/ ++/* BCM6338 Timer Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define MIPS_TIMER_INT 7 ++ ++/*=====================================================================*/ ++/* Peripheral ISR Table Offset */ ++/*=====================================================================*/ ++#define INTERNAL_ISR_TABLE_OFFSET 8 ++ ++/*=====================================================================*/ ++/* Logical Peripheral Interrupt IDs */ ++/*=====================================================================*/ ++ ++#define INTERRUPT_ID_TIMER (INTERNAL_ISR_TABLE_OFFSET + 0) ++#define INTERRUPT_ID_SPI (INTERNAL_ISR_TABLE_OFFSET + 1) ++#define INTERRUPT_ID_UART (INTERNAL_ISR_TABLE_OFFSET + 2) ++#define INTERRUPT_ID_DG (INTERNAL_ISR_TABLE_OFFSET + 4) ++#define INTERRUPT_ID_ADSL (INTERNAL_ISR_TABLE_OFFSET + 5) ++#define INTERRUPT_ID_ATM (INTERNAL_ISR_TABLE_OFFSET + 6) ++#define INTERRUPT_ID_USBS (INTERNAL_ISR_TABLE_OFFSET + 7) ++#define INTERRUPT_ID_EMAC1 (INTERNAL_ISR_TABLE_OFFSET + 8) ++#define INTERRUPT_ID_EPHY (INTERNAL_ISR_TABLE_OFFSET + 9) ++#define INTERRUPT_ID_SDRAM (INTERNAL_ISR_TABLE_OFFSET + 10) ++#define INTERRUPT_ID_USB_CNTL_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 11) ++#define INTERRUPT_ID_USB_CNTL_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 12) ++#define INTERRUPT_ID_USB_BULK_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 13) ++#define INTERRUPT_ID_USB_BULK_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 14) ++#define INTERRUPT_ID_EMAC1_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 15) ++#define INTERRUPT_ID_EMAC1_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 16) ++#define INTERRUPT_ID_SDIO (INTERNAL_ISR_TABLE_OFFSET + 17) ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif /* __BCM6338_H */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6338_map_part.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6338_map_part.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6338_map_part.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6338_map_part.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,341 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __BCM6338_MAP_H ++#define __BCM6338_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++ ++#define PERF_BASE 0xfffe0000 ++#define TIMR_BASE 0xfffe0200 ++#define UART_BASE 0xfffe0300 ++#define GPIO_BASE 0xfffe0400 ++#define SPI_BASE 0xfffe0c00 ++ ++typedef struct PerfControl { ++ uint32 RevID; ++ uint16 testControl; ++ uint16 blkEnables; ++#define EMAC_CLK_EN 0x0010 ++#define USBS_CLK_EN 0x0010 ++#define SAR_CLK_EN 0x0020 ++ ++#define SPI_CLK_EN 0x0200 ++ ++ uint32 pll_control; ++#define SOFT_RESET 0x00000001 ++ ++ uint32 IrqMask; ++ uint32 IrqStatus; ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 5 ++#define EI_CLEAR_SHFT 10 ++#define EI_MASK_SHFT 15 ++#define EI_INSENS_SHFT 20 ++#define EI_LEVEL_SHFT 25 ++ ++ uint32 unused[4]; /* (18) */ ++ uint32 BlockSoftReset; /* (28) */ ++#define BSR_SPI 0x00000001 ++#define BSR_EMAC 0x00000004 ++#define BSR_USBH 0x00000008 ++#define BSR_USBS 0x00000010 ++#define BSR_ADSL 0x00000020 ++#define BSR_DMAMEM 0x00000040 ++#define BSR_SAR 0x00000080 ++#define BSR_ACLC 0x00000100 ++#define BSR_ADSL_MIPS_PLL 0x00000400 ++#define BSR_ALL_BLOCKS \ ++ (BSR_SPI | BSR_EMAC | BSR_USBH | BSR_USBS | BSR_ADSL | BSR_DMAMEM | \ ++ BSR_SAR | BSR_ACLC | BSR_ADSL_MIPS_PLL) ++} PerfControl; ++ ++#define PERF ((volatile PerfControl * const) PERF_BASE) ++ ++ ++typedef struct Timer { ++ uint16 unused0; ++ byte TimerMask; ++#define TIMER0EN 0x01 ++#define TIMER1EN 0x02 ++#define TIMER2EN 0x04 ++ byte TimerInts; ++#define TIMER0 0x01 ++#define TIMER1 0x02 ++#define TIMER2 0x04 ++#define WATCHDOG 0x08 ++ uint32 TimerCtl0; ++ uint32 TimerCtl1; ++ uint32 TimerCtl2; ++#define TIMERENABLE 0x80000000 ++#define RSTCNTCLR 0x40000000 ++ uint32 TimerCnt0; ++ uint32 TimerCnt1; ++ uint32 TimerCnt2; ++ uint32 WatchDogDefCount; ++ ++ /* Write 0xff00 0x00ff to Start timer ++ * Write 0xee00 0x00ee to Stop and re-load default count ++ * Read from this register returns current watch dog count ++ */ ++ uint32 WatchDogCtl; ++ ++ /* Number of 40-MHz ticks for WD Reset pulse to last */ ++ uint32 WDResetCount; ++} Timer; ++ ++#define TIMER ((volatile Timer * const) TIMR_BASE) ++typedef struct UartChannel { ++ byte unused0; ++ byte control; ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define LOOPBK 0x10 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ ++ byte config; ++#define XMITBREAK 0x40 ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ /* 4-LSBS represent STOP bits/char ++ * in 1/8 bit-time intervals. Zero ++ * represents 1/8 stop bit interval. ++ * Fifteen represents 2 stop bits. ++ */ ++ byte fifoctl; ++#define RSTTXFIFOS 0x80 ++#define RSTRXFIFOS 0x40 ++ /* 5-bit TimeoutCnt is in low bits of this register. ++ * This count represents the number of characters ++ * idle times before setting receive Irq when below threshold ++ */ ++ uint32 baudword; ++ /* When divide SysClk/2/(1+baudword) we should get 32*bit-rate ++ */ ++ ++ byte txf_levl; /* Read-only fifo depth */ ++ byte rxf_levl; /* Read-only fifo depth */ ++ byte fifocfg; /* Upper 4-bits are TxThresh, Lower are ++ * RxThreshold. Irq can be asserted ++ * when rx fifo> thresh, txfifo ++*/ ++ ++#ifndef __6345_INTR_H ++#define __6345_INTR_H ++ ++#ifdef __cplusplus ++ extern "C" { ++#endif ++ ++/*=====================================================================*/ ++/* BCM6345 External Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define INTERRUPT_ID_EXTERNAL_0 3 ++#define INTERRUPT_ID_EXTERNAL_1 4 ++#define INTERRUPT_ID_EXTERNAL_2 5 ++#define INTERRUPT_ID_EXTERNAL_3 6 ++ ++/*=====================================================================*/ ++/* BCM6345 Timer Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define MIPS_TIMER_INT 7 ++ ++/*=====================================================================*/ ++/* Peripheral ISR Table Offset */ ++/*=====================================================================*/ ++#define INTERNAL_ISR_TABLE_OFFSET 8 ++#define DMA_ISR_TABLE_OFFSET (INTERNAL_ISR_TABLE_OFFSET + 13) ++ ++/*=====================================================================*/ ++/* Logical Peripheral Interrupt IDs */ ++/*=====================================================================*/ ++ ++/* Internal peripheral interrupt IDs */ ++#define INTERRUPT_ID_TIMER (INTERNAL_ISR_TABLE_OFFSET + 0) ++#define INTERRUPT_ID_UART (INTERNAL_ISR_TABLE_OFFSET + 2) ++#define INTERRUPT_ID_ADSL (INTERNAL_ISR_TABLE_OFFSET + 3) ++#define INTERRUPT_ID_ATM (INTERNAL_ISR_TABLE_OFFSET + 4) ++#define INTERRUPT_ID_USB (INTERNAL_ISR_TABLE_OFFSET + 5) ++#define INTERRUPT_ID_EMAC (INTERNAL_ISR_TABLE_OFFSET + 8) ++#define INTERRUPT_ID_EPHY (INTERNAL_ISR_TABLE_OFFSET + 12) ++ ++/* DMA channel interrupt IDs */ ++#define INTERRUPT_ID_EMAC_RX_CHAN (DMA_ISR_TABLE_OFFSET + EMAC_RX_CHAN) ++#define INTERRUPT_ID_EMAC_TX_CHAN (DMA_ISR_TABLE_OFFSET + EMAC_TX_CHAN) ++#define INTERRUPT_ID_EBI_RX_CHAN (DMA_ISR_TABLE_OFFSET + EBI_RX_CHAN) ++#define INTERRUPT_ID_EBI_TX_CHAN (DMA_ISR_TABLE_OFFSET + EBI_TX_CHAN) ++#define INTERRUPT_ID_RESERVED_RX_CHAN (DMA_ISR_TABLE_OFFSET + RESERVED_RX_CHAN) ++#define INTERRUPT_ID_RESERVED_TX_CHAN (DMA_ISR_TABLE_OFFSET + RESERVED_TX_CHAN) ++#define INTERRUPT_ID_USB_BULK_RX_CHAN (DMA_ISR_TABLE_OFFSET + USB_BULK_RX_CHAN) ++#define INTERRUPT_ID_USB_BULK_TX_CHAN (DMA_ISR_TABLE_OFFSET + USB_BULK_TX_CHAN) ++#define INTERRUPT_ID_USB_CNTL_RX_CHAN (DMA_ISR_TABLE_OFFSET + USB_CNTL_RX_CHAN) ++#define INTERRUPT_ID_USB_CNTL_TX_CHAN (DMA_ISR_TABLE_OFFSET + USB_CNTL_TX_CHAN) ++#define INTERRUPT_ID_USB_ISO_RX_CHAN (DMA_ISR_TABLE_OFFSET + USB_ISO_RX_CHAN) ++#define INTERRUPT_ID_USB_ISO_TX_CHAN (DMA_ISR_TABLE_OFFSET + USB_ISO_TX_CHAN) ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif /* __BCM6345_H */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6345_map_part.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6345_map_part.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6345_map_part.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6345_map_part.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,169 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __BCM6345_MAP_H ++#define __BCM6345_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++#include "6345_intr.h" ++ ++typedef struct IntControl { ++ uint32 RevID; ++ uint16 testControl; ++ uint16 blkEnables; ++#define USB_CLK_EN 0x0100 ++#define EMAC_CLK_EN 0x0080 ++#define UART_CLK_EN 0x0008 ++#define CPU_CLK_EN 0x0001 ++ ++ uint32 pll_control; ++#define SOFT_RESET 0x00000001 ++ ++ uint32 IrqMask; ++ uint32 IrqStatus; ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 4 ++#define EI_CLEAR_SHFT 8 ++#define EI_MASK_SHFT 12 ++#define EI_INSENS_SHFT 16 ++#define EI_LEVEL_SHFT 20 ++} IntControl; ++ ++#define INTC_BASE 0xfffe0000 ++#define PERF ((volatile IntControl * const) INTC_BASE) ++ ++#define TIMR_BASE 0xfffe0200 ++typedef struct Timer { ++ uint16 unused0; ++ byte TimerMask; ++#define TIMER0EN 0x01 ++#define TIMER1EN 0x02 ++#define TIMER2EN 0x04 ++ byte TimerInts; ++#define TIMER0 0x01 ++#define TIMER1 0x02 ++#define TIMER2 0x04 ++#define WATCHDOG 0x08 ++ uint32 TimerCtl0; ++ uint32 TimerCtl1; ++ uint32 TimerCtl2; ++#define TIMERENABLE 0x80000000 ++#define RSTCNTCLR 0x40000000 ++ uint32 TimerCnt0; ++ uint32 TimerCnt1; ++ uint32 TimerCnt2; ++ uint32 WatchDogDefCount; ++ ++ /* Write 0xff00 0x00ff to Start timer ++ * Write 0xee00 0x00ee to Stop and re-load default count ++ * Read from this register returns current watch dog count ++ */ ++ uint32 WatchDogCtl; ++ ++ /* Number of 40-MHz ticks for WD Reset pulse to last */ ++ uint32 WDResetCount; ++} Timer; ++ ++#define TIMER ((volatile Timer * const) TIMR_BASE) ++ ++typedef struct UartChannel { ++ byte unused0; ++ byte control; ++#define BRGEN 0x80 /* Control register bit defs */ ++#define TXEN 0x40 ++#define RXEN 0x20 ++#define TXPARITYEN 0x08 ++#define TXPARITYEVEN 0x04 ++#define RXPARITYEN 0x02 ++#define RXPARITYEVEN 0x01 ++ byte config; ++#define BITS5SYM 0x00 ++#define BITS6SYM 0x10 ++#define BITS7SYM 0x20 ++#define BITS8SYM 0x30 ++#define XMITBREAK 0x40 ++#define ONESTOP 0x07 ++#define TWOSTOP 0x0f ++ ++ byte fifoctl; ++#define RSTTXFIFOS 0x80 ++#define RSTRXFIFOS 0x40 ++ uint32 baudword; ++ ++ byte txf_levl; ++ byte rxf_levl; ++ byte fifocfg; ++ byte prog_out; ++ ++ byte unused1; ++ byte DeltaIPEdgeNoSense; ++ byte DeltaIPConfig_Mask; ++ byte DeltaIP_SyncIP; ++ uint16 intMask; ++ uint16 intStatus; ++#define TXUNDERR 0x0002 ++#define TXOVFERR 0x0004 ++#define TXFIFOEMT 0x0020 ++#define RXOVFERR 0x0080 ++#define RXFIFONE 0x0800 ++#define RXFRAMERR 0x1000 ++#define RXPARERR 0x2000 ++#define RXBRK 0x4000 ++ ++ uint16 unused2; ++ uint16 Data; ++ uint32 unused3; ++ uint32 unused4; ++} Uart; ++ ++#define UART_BASE 0xfffe0300 ++#define UART ((volatile Uart * const) UART_BASE) ++ ++typedef struct GpioControl { ++ uint16 unused0; ++ byte unused1; ++ byte TBusSel; ++ ++ uint16 unused2; ++ uint16 GPIODir; ++ byte unused3; ++ byte Leds; ++ uint16 GPIOio; ++ ++ uint32 UartCtl; ++} GpioControl; ++ ++#define GPIO_BASE 0xfffe0400 ++#define GPIO ((volatile GpioControl * const) GPIO_BASE) ++ ++#define GPIO_NUM_MAX_BITS_MASK 0x0f ++#define GPIO_NUM_TO_MASK(X) (1 << ((X) & GPIO_NUM_MAX_BITS_MASK)) ++ ++#if __cplusplus ++} ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6348_intr.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6348_intr.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6348_intr.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6348_intr.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,80 @@ ++/* ++<:copyright-gpl ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __6348_INTR_H ++#define __6348_INTR_H ++ ++#ifdef __cplusplus ++ extern "C" { ++#endif ++ ++/*=====================================================================*/ ++/* BCM6348 External Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define INTERRUPT_ID_EXTERNAL_0 3 ++#define INTERRUPT_ID_EXTERNAL_1 4 ++#define INTERRUPT_ID_EXTERNAL_2 5 ++#define INTERRUPT_ID_EXTERNAL_3 6 ++ ++/*=====================================================================*/ ++/* BCM6348 Timer Interrupt Level Assignments */ ++/*=====================================================================*/ ++#define MIPS_TIMER_INT 7 ++ ++/*=====================================================================*/ ++/* Peripheral ISR Table Offset */ ++/*=====================================================================*/ ++#define INTERNAL_ISR_TABLE_OFFSET 8 ++ ++/*=====================================================================*/ ++/* Logical Peripheral Interrupt IDs */ ++/*=====================================================================*/ ++ ++#define INTERRUPT_ID_TIMER (INTERNAL_ISR_TABLE_OFFSET + 0) ++#define INTERRUPT_ID_SPI (INTERNAL_ISR_TABLE_OFFSET + 1) ++#define INTERRUPT_ID_UART (INTERNAL_ISR_TABLE_OFFSET + 2) ++#define INTERRUPT_ID_ADSL (INTERNAL_ISR_TABLE_OFFSET + 4) ++#define INTERRUPT_ID_ATM (INTERNAL_ISR_TABLE_OFFSET + 5) ++#define INTERRUPT_ID_USBS (INTERNAL_ISR_TABLE_OFFSET + 6) ++#define INTERRUPT_ID_EMAC2 (INTERNAL_ISR_TABLE_OFFSET + 7) ++#define INTERRUPT_ID_EMAC1 (INTERNAL_ISR_TABLE_OFFSET + 8) ++#define INTERRUPT_ID_EPHY (INTERNAL_ISR_TABLE_OFFSET + 9) ++#define INTERRUPT_ID_M2M (INTERNAL_ISR_TABLE_OFFSET + 10) ++#define INTERRUPT_ID_ACLC (INTERNAL_ISR_TABLE_OFFSET + 11) ++#define INTERRUPT_ID_USBH (INTERNAL_ISR_TABLE_OFFSET + 12) ++#define INTERRUPT_ID_SDRAM (INTERNAL_ISR_TABLE_OFFSET + 13) ++#define INTERRUPT_ID_USB_CNTL_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 14) ++#define INTERRUPT_ID_USB_CNTL_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 15) ++#define INTERRUPT_ID_USB_BULK_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 16) ++#define INTERRUPT_ID_USB_BULK_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 17) ++#define INTERRUPT_ID_USB_ISO_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 18) ++#define INTERRUPT_ID_USB_ISO_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 19) ++#define INTERRUPT_ID_EMAC1_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 20) ++#define INTERRUPT_ID_EMAC1_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 21) ++#define INTERRUPT_ID_EMAC2_RX_DMA (INTERNAL_ISR_TABLE_OFFSET + 22) ++#define INTERRUPT_ID_EMAC2_TX_DMA (INTERNAL_ISR_TABLE_OFFSET + 23) ++#define INTERRUPT_ID_MPI (INTERNAL_ISR_TABLE_OFFSET + 24) ++#define INTERRUPT_ID_DG (INTERNAL_ISR_TABLE_OFFSET + 25) ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif /* __BCM6348_H */ ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6348_map_part.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6348_map_part.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/6348_map_part.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/6348_map_part.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,508 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __BCM6348_MAP_H ++#define __BCM6348_MAP_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++ ++#include "bcmtypes.h" ++ ++#define PERF_BASE 0xfffe0000 ++#define TIMR_BASE 0xfffe0200 ++#define UART_BASE 0xfffe0300 ++#define GPIO_BASE 0xfffe0400 ++#define MPI_BASE 0xfffe2000 /* MPI control registers */ ++#define USB_HOST_BASE 0xfffe1b00 /* USB host registers */ ++#define USB_HOST_NON_OHCI 0xfffe1c00 /* USB host non-OHCI registers */ ++ ++typedef struct PerfControl { ++ uint32 RevID; ++ uint16 testControl; ++ uint16 blkEnables; ++#define EMAC_CLK_EN 0x0010 ++#define SAR_CLK_EN 0x0020 ++#define USBS_CLK_EN 0x0040 ++#define USBH_CLK_EN 0x0100 ++ ++ uint32 pll_control; ++#define SOFT_RESET 0x00000001 ++ ++ uint32 IrqMask; ++ uint32 IrqStatus; ++ ++ uint32 ExtIrqCfg; ++#define EI_SENSE_SHFT 0 ++#define EI_STATUS_SHFT 5 ++#define EI_CLEAR_SHFT 10 ++#define EI_MASK_SHFT 15 ++#define EI_INSENS_SHFT 20 ++#define EI_LEVEL_SHFT 25 ++ ++ uint32 unused[4]; /* (18) */ ++ uint32 BlockSoftReset; /* (28) */ ++#define BSR_SPI 0x00000001 ++#define BSR_EMAC 0x00000004 ++#define BSR_USBH 0x00000008 ++#define BSR_USBS 0x00000010 ++#define BSR_ADSL 0x00000020 ++#define BSR_DMAMEM 0x00000040 ++#define BSR_SAR 0x00000080 ++#define BSR_ACLC 0x00000100 ++#define BSR_ADSL_MIPS_PLL 0x00000400 ++#define BSR_ALL_BLOCKS \ ++ (BSR_SPI | BSR_EMAC | BSR_USBH | BSR_USBS | BSR_ADSL | BSR_DMAMEM | \ ++ BSR_SAR | BSR_ACLC | BSR_ADSL_MIPS_PLL) ++ uint32 unused2[2]; /* (2c) */ ++ uint32 PllStrap; /* (34) */ ++#define PLL_N1_SHFT 20 ++#define PLL_N1_MASK (7< thresh, txfifo= 32) ? (1 << ((X-32) & GPIO_NUM_MAX_BITS_MASK_HIGH)) : (0) ) ++ ++ ++/* ++** External Bus Interface ++*/ ++typedef struct EbiChipSelect { ++ uint32 base; /* base address in upper 24 bits */ ++#define EBI_SIZE_8K 0 ++#define EBI_SIZE_16K 1 ++#define EBI_SIZE_32K 2 ++#define EBI_SIZE_64K 3 ++#define EBI_SIZE_128K 4 ++#define EBI_SIZE_256K 5 ++#define EBI_SIZE_512K 6 ++#define EBI_SIZE_1M 7 ++#define EBI_SIZE_2M 8 ++#define EBI_SIZE_4M 9 ++#define EBI_SIZE_8M 10 ++#define EBI_SIZE_16M 11 ++#define EBI_SIZE_32M 12 ++#define EBI_SIZE_64M 13 ++#define EBI_SIZE_128M 14 ++#define EBI_SIZE_256M 15 ++ uint32 config; ++#define EBI_ENABLE 0x00000001 /* .. enable this range */ ++#define EBI_WAIT_STATES 0x0000000e /* .. mask for wait states */ ++#define EBI_WTST_SHIFT 1 /* .. for shifting wait states */ ++#define EBI_WORD_WIDE 0x00000010 /* .. 16-bit peripheral, else 8 */ ++#define EBI_WREN 0x00000020 /* enable posted writes */ ++#define EBI_POLARITY 0x00000040 /* .. set to invert something, ++ ** don't know what yet */ ++#define EBI_TS_TA_MODE 0x00000080 /* .. use TS/TA mode */ ++#define EBI_TS_SEL 0x00000100 /* .. drive tsize, not bs_b */ ++#define EBI_FIFO 0x00000200 /* .. use fifo */ ++#define EBI_RE 0x00000400 /* .. Reverse Endian */ ++} EbiChipSelect; ++ ++typedef struct MpiRegisters { ++ EbiChipSelect cs[7]; /* size chip select configuration */ ++#define EBI_CS0_BASE 0 ++#define EBI_CS1_BASE 1 ++#define EBI_CS2_BASE 2 ++#define EBI_CS3_BASE 3 ++#define PCMCIA_COMMON_BASE 4 ++#define PCMCIA_ATTRIBUTE_BASE 5 ++#define PCMCIA_IO_BASE 6 ++ uint32 unused0[2]; /* reserved */ ++ uint32 ebi_control; /* ebi control */ ++ uint32 unused1[4]; /* reserved */ ++#define EBI_ACCESS_TIMEOUT 0x000007FF ++ uint32 pcmcia_cntl1; /* pcmcia control 1 */ ++#define PCCARD_CARD_RESET 0x00040000 ++#define CARDBUS_ENABLE 0x00008000 ++#define PCMCIA_ENABLE 0x00004000 ++#define PCMCIA_GPIO_ENABLE 0x00002000 ++#define CARDBUS_IDSEL 0x00001F00 ++#define VS2_OEN 0x00000080 ++#define VS1_OEN 0x00000040 ++#define VS2_OUT 0x00000020 ++#define VS1_OUT 0x00000010 ++#define VS2_IN 0x00000008 ++#define VS1_IN 0x00000004 ++#define CD2_IN 0x00000002 ++#define CD1_IN 0x00000001 ++#define VS_MASK 0x0000000C ++#define CD_MASK 0x00000003 ++ uint32 unused2; /* reserved */ ++ uint32 pcmcia_cntl2; /* pcmcia control 2 */ ++#define PCMCIA_BYTESWAP_DIS 0x00000002 ++#define PCMCIA_HALFWORD_EN 0x00000001 ++#define RW_ACTIVE_CNT_BIT 2 ++#define INACTIVE_CNT_BIT 8 ++#define CE_SETUP_CNT_BIT 16 ++#define CE_HOLD_CNT_BIT 24 ++ uint32 unused3[40]; /* reserved */ ++ ++ uint32 sp0range; /* PCI to internal system bus address space */ ++ uint32 sp0remap; ++ uint32 sp0cfg; ++ uint32 sp1range; ++ uint32 sp1remap; ++ uint32 sp1cfg; ++ ++ uint32 EndianCfg; ++ ++ uint32 l2pcfgctl; /* internal system bus to PCI IO/Cfg control */ ++#define DIR_CFG_SEL 0x80000000 /* change from PCI I/O access to PCI config access */ ++#define DIR_CFG_USEREG 0x40000000 /* use this register info for PCI configuration access */ ++#define DEVICE_NUMBER 0x00007C00 /* device number for the PCI configuration access */ ++#define FUNC_NUMBER 0x00000300 /* function number for the PCI configuration access */ ++#define REG_NUMBER 0x000000FC /* register number for the PCI configuration access */ ++#define CONFIG_TYPE 0x00000003 /* configuration type for the PCI configuration access */ ++ ++ uint32 l2pmrange1; /* internal system bus to PCI memory space */ ++#define PCI_SIZE_64K 0xFFFF0000 ++#define PCI_SIZE_128K 0xFFFE0000 ++#define PCI_SIZE_256K 0xFFFC0000 ++#define PCI_SIZE_512K 0xFFF80000 ++#define PCI_SIZE_1M 0xFFF00000 ++#define PCI_SIZE_2M 0xFFE00000 ++#define PCI_SIZE_4M 0xFFC00000 ++#define PCI_SIZE_8M 0xFF800000 ++#define PCI_SIZE_16M 0xFF000000 ++#define PCI_SIZE_32M 0xFE000000 ++ uint32 l2pmbase1; /* kseg0 or kseg1 address & 0x1FFFFFFF */ ++ uint32 l2pmremap1; ++#define CARDBUS_MEM 0x00000004 ++#define MEM_WINDOW_EN 0x00000001 ++ uint32 l2pmrange2; ++ uint32 l2pmbase2; ++ uint32 l2pmremap2; ++ uint32 l2piorange; /* internal system bus to PCI I/O space */ ++ uint32 l2piobase; ++ uint32 l2pioremap; ++ ++ uint32 pcimodesel; ++#define PCI2_INT_BUS_RD_PREFECH 0x000000F0 ++#define PCI_BAR2_NOSWAP 0x00000002 /* BAR at offset 0x20 */ ++#define PCI_BAR1_NOSWAP 0x00000001 /* BAR at affset 0x1c */ ++ ++ uint32 pciintstat; /* PCI interrupt mask/status */ ++#define MAILBOX1_SENT 0x08 ++#define MAILBOX0_SENT 0x04 ++#define MAILBOX1_MSG_RCV 0x02 ++#define MAILBOX0_MSG_RCV 0x01 ++ uint32 locbuscntrl; /* internal system bus control */ ++#define DIR_U2P_NOSWAP 0x00000002 ++#define EN_PCI_GPIO 0x00000001 ++ uint32 locintstat; /* internal system bus interrupt mask/status */ ++#define CSERR 0x0200 ++#define SERR 0x0100 ++#define EXT_PCI_INT 0x0080 ++#define DIR_FAILED 0x0040 ++#define DIR_COMPLETE 0x0020 ++#define PCI_CFG 0x0010 ++ uint32 unused5[7]; ++ ++ uint32 mailbox0; ++ uint32 mailbox1; ++ ++ uint32 pcicfgcntrl; /* internal system bus PCI configuration control */ ++#define PCI_CFG_REG_WRITE_EN 0x00000080 ++#define PCI_CFG_ADDR 0x0000003C ++ uint32 pcicfgdata; /* internal system bus PCI configuration data */ ++ ++ uint32 locch2ctl; /* PCI to interrnal system bus DMA (downstream) local control */ ++#define MPI_DMA_HALT 0x00000008 /* idle after finish current memory burst */ ++#define MPI_DMA_PKT_HALT 0x00000004 /* idle after an EOP flag is detected */ ++#define MPI_DMA_STALL 0x00000002 /* idle after an EOP flag is detected */ ++#define MPI_DMA_ENABLE 0x00000001 /* set to enable channel */ ++ uint32 locch2intStat; ++#define MPI_DMA_NO_DESC 0x00000004 /* no valid descriptors */ ++#define MPI_DMA_DONE 0x00000002 /* packet xfer complete */ ++#define MPI_DMA_BUFF_DONE 0x00000001 /* buffer done */ ++ uint32 locch2intMask; ++ uint32 unused6; ++ uint32 locch2descaddr; ++ uint32 locch2status1; ++#define LOCAL_DESC_STATE 0xE0000000 ++#define PCI_DESC_STATE 0x1C000000 ++#define BYTE_DONE 0x03FFC000 ++#define RING_ADDR 0x00003FFF ++ uint32 locch2status2; ++#define BUFPTR_OFFSET 0x1FFF0000 ++#define PCI_MASTER_STATE 0x000000C0 ++#define LOC_MASTER_STATE 0x00000038 ++#define CONTROL_STATE 0x00000007 ++ uint32 unused7; ++ ++ uint32 locch1Ctl; /*internal system bus to PCI DMA (upstream) local control */ ++#define DMA_U2P_LE 0x00000200 /* local bus is little endian */ ++#define DMA_U2P_NOSWAP 0x00000100 /* lccal bus is little endian but no data swapped */ ++ uint32 locch1intstat; ++ uint32 locch1intmask; ++ uint32 unused8; ++ uint32 locch1descaddr; ++ uint32 locch1status1; ++ uint32 locch1status2; ++ uint32 unused9; ++ ++ uint32 pcich1ctl; /* internal system bus to PCI DMA PCI control */ ++ uint32 pcich1intstat; ++ uint32 pcich1intmask; ++ uint32 pcich1descaddr; ++ uint32 pcich1status1; ++ uint32 pcich1status2; ++ ++ uint32 pcich2Ctl; /* PCI to internal system bus DMA PCI control */ ++ uint32 pcich2intstat; ++ uint32 pcich2intmask; ++ uint32 pcich2descaddr; ++ uint32 pcich2status1; ++ uint32 pcich2status2; ++ ++ uint32 perm_id; /* permanent device and vendor id */ ++ uint32 perm_rev; /* permanent revision id */ ++} MpiRegisters; ++ ++#define MPI ((volatile MpiRegisters * const) MPI_BASE) ++ ++/* PCI configuration address space start offset 0x40 */ ++#define BRCM_PCI_CONFIG_TIMER 0x40 ++#define BRCM_PCI_CONFIG_TIMER_RETRY_MASK 0x0000FF00 ++#define BRCM_PCI_CONFIG_TIMER_TRDY_MASK 0x000000FF ++ ++/* USB host non-Open HCI register, USB_HOST_NON_OHCI, bit definitions. */ ++#define NON_OHCI_ENABLE_PORT1 0x00000001 /* Use USB port 1 for host, not dev */ ++#define NON_OHCI_BYTE_SWAP 0x00000008 /* Swap USB host registers */ ++ ++#define USBH_NON_OHCI ((volatile unsigned long * const) USB_HOST_NON_OHCI) ++ ++#if __cplusplus ++} ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmTag.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmTag.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmTag.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmTag.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,153 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++//************************************************************************************** ++// File Name : bcmTag.h ++// ++// Description: add tag with validation system to the firmware image file to be uploaded ++// via http ++// ++// Created : 02/28/2002 seanl ++//************************************************************************************** ++ ++#ifndef _BCMTAG_H_ ++#define _BCMTAG_H_ ++ ++ ++#define BCM_SIG_1 "Broadcom Corporation" ++#define BCM_SIG_2 "ver. 2.0" // was "firmware version 2.0" now it is split 6 char out for chip id. ++ ++#define BCM_TAG_VER "6" ++#define BCM_TAG_VER_LAST "26" ++ ++// file tag (head) structure all is in clear text except validationTokens (crc, md5, sha1, etc). Total: 128 unsigned chars ++#define TAG_LEN 256 ++#define TAG_VER_LEN 4 ++#define SIG_LEN 20 ++#define SIG_LEN_2 14 // Original second SIG = 20 is now devided into 14 for SIG_LEN_2 and 6 for CHIP_ID ++#define CHIP_ID_LEN 6 ++#define IMAGE_LEN 10 ++#define ADDRESS_LEN 12 ++#define FLAG_LEN 2 ++#define TOKEN_LEN 20 ++#define BOARD_ID_LEN 16 ++#define RESERVED_LEN (TAG_LEN - TAG_VER_LEN - SIG_LEN - SIG_LEN_2 - CHIP_ID_LEN - BOARD_ID_LEN - \ ++ (4*IMAGE_LEN) - (3*ADDRESS_LEN) - (3*FLAG_LEN) - (2*TOKEN_LEN)) ++ ++ ++// TAG for downloadable image (kernel plus file system) ++typedef struct _FILE_TAG ++{ ++ unsigned char tagVersion[TAG_VER_LEN]; // tag version. Will be 2 here. ++ unsigned char signiture_1[SIG_LEN]; // text line for company info ++ unsigned char signiture_2[SIG_LEN_2]; // additional info (can be version number) ++ unsigned char chipId[CHIP_ID_LEN]; // chip id ++ unsigned char boardId[BOARD_ID_LEN]; // board id ++ unsigned char bigEndian[FLAG_LEN]; // if = 1 - big, = 0 - little endia of the host ++ unsigned char totalImageLen[IMAGE_LEN]; // the sum of all the following length ++ unsigned char cfeAddress[ADDRESS_LEN]; // if non zero, cfe starting address ++ unsigned char cfeLen[IMAGE_LEN]; // if non zero, cfe size in clear ASCII text. ++ unsigned char rootfsAddress[ADDRESS_LEN]; // if non zero, filesystem starting address ++ unsigned char rootfsLen[IMAGE_LEN]; // if non zero, filesystem size in clear ASCII text. ++ unsigned char kernelAddress[ADDRESS_LEN]; // if non zero, kernel starting address ++ unsigned char kernelLen[IMAGE_LEN]; // if non zero, kernel size in clear ASCII text. ++ unsigned char dualImage[FLAG_LEN]; // if 1, dual image ++ unsigned char inactiveLen[FLAG_LEN]; // if 1, the image is INACTIVE; if 0, active ++ unsigned char reserved[RESERVED_LEN]; // reserved for later use ++ unsigned char imageValidationToken[TOKEN_LEN];// image validation token - can be crc, md5, sha; for ++ // now will be 4 unsigned char crc ++ unsigned char tagValidationToken[TOKEN_LEN]; // validation token for tag(from signiture_1 to end of // mageValidationToken) ++} FILE_TAG, *PFILE_TAG; ++ ++#define CRC32_INIT_VALUE 0xffffffff /* Initial CRC32 checksum value */ ++#define CRC_LEN 4 ++ ++// only included if for bcmTag.exe program ++#ifdef BCMTAG_EXE_USE ++ ++static unsigned long Crc32_table[256] = { ++ 0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA, ++ 0x076DC419, 0x706AF48F, 0xE963A535, 0x9E6495A3, ++ 0x0EDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988, ++ 0x09B64C2B, 0x7EB17CBD, 0xE7B82D07, 0x90BF1D91, ++ 0x1DB71064, 0x6AB020F2, 0xF3B97148, 0x84BE41DE, ++ 0x1ADAD47D, 0x6DDDE4EB, 0xF4D4B551, 0x83D385C7, ++ 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC, ++ 0x14015C4F, 0x63066CD9, 0xFA0F3D63, 0x8D080DF5, ++ 0x3B6E20C8, 0x4C69105E, 0xD56041E4, 0xA2677172, ++ 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B, ++ 0x35B5A8FA, 0x42B2986C, 0xDBBBC9D6, 0xACBCF940, ++ 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59, ++ 0x26D930AC, 0x51DE003A, 0xC8D75180, 0xBFD06116, ++ 0x21B4F4B5, 0x56B3C423, 0xCFBA9599, 0xB8BDA50F, ++ 0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924, ++ 0x2F6F7C87, 0x58684C11, 0xC1611DAB, 0xB6662D3D, ++ 0x76DC4190, 0x01DB7106, 0x98D220BC, 0xEFD5102A, ++ 0x71B18589, 0x06B6B51F, 0x9FBFE4A5, 0xE8B8D433, ++ 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818, ++ 0x7F6A0DBB, 0x086D3D2D, 0x91646C97, 0xE6635C01, ++ 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E, ++ 0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457, ++ 0x65B0D9C6, 0x12B7E950, 0x8BBEB8EA, 0xFCB9887C, ++ 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65, ++ 0x4DB26158, 0x3AB551CE, 0xA3BC0074, 0xD4BB30E2, ++ 0x4ADFA541, 0x3DD895D7, 0xA4D1C46D, 0xD3D6F4FB, ++ 0x4369E96A, 0x346ED9FC, 0xAD678846, 0xDA60B8D0, ++ 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9, ++ 0x5005713C, 0x270241AA, 0xBE0B1010, 0xC90C2086, ++ 0x5768B525, 0x206F85B3, 0xB966D409, 0xCE61E49F, ++ 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4, ++ 0x59B33D17, 0x2EB40D81, 0xB7BD5C3B, 0xC0BA6CAD, ++ 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A, ++ 0xEAD54739, 0x9DD277AF, 0x04DB2615, 0x73DC1683, ++ 0xE3630B12, 0x94643B84, 0x0D6D6A3E, 0x7A6A5AA8, ++ 0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1, ++ 0xF00F9344, 0x8708A3D2, 0x1E01F268, 0x6906C2FE, ++ 0xF762575D, 0x806567CB, 0x196C3671, 0x6E6B06E7, ++ 0xFED41B76, 0x89D32BE0, 0x10DA7A5A, 0x67DD4ACC, ++ 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5, ++ 0xD6D6A3E8, 0xA1D1937E, 0x38D8C2C4, 0x4FDFF252, ++ 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B, ++ 0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60, ++ 0xDF60EFC3, 0xA867DF55, 0x316E8EEF, 0x4669BE79, ++ 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236, ++ 0xCC0C7795, 0xBB0B4703, 0x220216B9, 0x5505262F, ++ 0xC5BA3BBE, 0xB2BD0B28, 0x2BB45A92, 0x5CB36A04, ++ 0xC2D7FFA7, 0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D, ++ 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A, ++ 0x9C0906A9, 0xEB0E363F, 0x72076785, 0x05005713, ++ 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, 0x0CB61B38, ++ 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21, ++ 0x86D3D2D4, 0xF1D4E242, 0x68DDB3F8, 0x1FDA836E, ++ 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777, ++ 0x88085AE6, 0xFF0F6A70, 0x66063BCA, 0x11010B5C, ++ 0x8F659EFF, 0xF862AE69, 0x616BFFD3, 0x166CCF45, ++ 0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2, ++ 0xA7672661, 0xD06016F7, 0x4969474D, 0x3E6E77DB, ++ 0xAED16A4A, 0xD9D65ADC, 0x40DF0B66, 0x37D83BF0, ++ 0xA9BCAE53, 0xDEBB9EC5, 0x47B2CF7F, 0x30B5FFE9, ++ 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6, ++ 0xBAD03605, 0xCDD70693, 0x54DE5729, 0x23D967BF, ++ 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94, ++ 0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D ++}; ++#endif // BCMTAG_USE ++ ++ ++#endif // _BCMTAG_H_ ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcm_intr.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcm_intr.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcm_intr.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcm_intr.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,59 @@ ++/* ++<:copyright-gpl ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __BCM_INTR_H ++#define __BCM_INTR_H ++ ++#ifdef __cplusplus ++ extern "C" { ++#endif ++ ++#if defined(CONFIG_BCM96338) ++#include <6338_intr.h> ++#endif ++#if defined(CONFIG_BCM96345) ++#include <6345_intr.h> ++#endif ++#if defined(CONFIG_BCM96348) ++#include <6348_intr.h> ++#endif ++ ++/* defines */ ++struct pt_regs; ++typedef int (*FN_HANDLER) (int, void *, struct pt_regs *); ++ ++/* prototypes */ ++extern void enable_brcm_irq(unsigned int irq); ++extern void disable_brcm_irq(unsigned int irq); ++extern int request_external_irq(unsigned int irq, ++ FN_HANDLER handler, unsigned long irqflags, ++ const char * devname, void *dev_id); ++extern unsigned int BcmHalMapInterrupt(FN_HANDLER isr, unsigned int param, ++ unsigned int interruptId); ++extern void dump_intr_regs(void); ++ ++/* compatibility definitions */ ++#define BcmHalInterruptEnable(irq) enable_brcm_irq( irq ) ++#define BcmHalInterruptDisable(irq) disable_brcm_irq( irq ) ++ ++#ifdef __cplusplus ++ } ++#endif ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcm_map_part.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcm_map_part.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcm_map_part.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcm_map_part.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,34 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++#ifndef __BCM_MAP_PART_H ++#define __BCM_MAP_PART_H ++ ++#if defined(CONFIG_BCM96338) ++#include <6338_map_part.h> ++#endif ++#if defined(CONFIG_BCM96345) ++#include <6345_map_part.h> ++#endif ++#if defined(CONFIG_BCM96348) ++#include <6348_map_part.h> ++#endif ++ ++#endif ++ +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmpci.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmpci.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmpci.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmpci.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,87 @@ ++/* ++<:copyright-gpl ++ Copyright 2004 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++// ++// bcmpci.h - bcm96348 PCI, Cardbus, and PCMCIA definition ++// ++#ifndef BCMPCI_H ++#define BCMPCI_H ++ ++/* Memory window in internal system bus address space */ ++#define BCM_PCI_MEM_BASE 0x08000000 ++/* IO window in internal system bus address space */ ++#define BCM_PCI_IO_BASE 0x0C000000 ++ ++#define BCM_PCI_ADDR_MASK 0x1fffffff ++ ++/* Memory window size (range) */ ++#define BCM_PCI_MEM_SIZE_16MB 0x01000000 ++/* IO window size (range) */ ++#define BCM_PCI_IO_SIZE_64KB 0x00010000 ++ ++/* PCI Configuration and I/O space acesss */ ++#define BCM_PCI_CFG(d, f, o) ( (d << 11) | (f << 8) | (o/4 << 2) ) ++ ++/* fake USB PCI slot */ ++#define USB_HOST_SLOT 9 ++#define USB_BAR0_MEM_SIZE 0x0800 ++ ++#define BCM_HOST_MEM_SPACE1 0x10000000 ++#define BCM_HOST_MEM_SPACE2 0x00000000 ++ ++/* ++ * EBI bus clock is 33MHz and share with PCI bus ++ * each clock cycle is 30ns. ++ */ ++/* attribute memory access wait cnt for 4306 */ ++#define PCMCIA_ATTR_CE_HOLD 3 // data hold time 70ns ++#define PCMCIA_ATTR_CE_SETUP 3 // data setup time 50ns ++#define PCMCIA_ATTR_INACTIVE 6 // time between read/write cycles 180ns. For the total cycle time 600ns (cnt1+cnt2+cnt3+cnt4) ++#define PCMCIA_ATTR_ACTIVE 10 // OE/WE pulse width 300ns ++ ++/* common memory access wait cnt for 4306 */ ++#define PCMCIA_MEM_CE_HOLD 1 // data hold time 30ns ++#define PCMCIA_MEM_CE_SETUP 1 // data setup time 30ns ++#define PCMCIA_MEM_INACTIVE 2 // time between read/write cycles 40ns. For the total cycle time 250ns (cnt1+cnt2+cnt3+cnt4) ++#define PCMCIA_MEM_ACTIVE 5 // OE/WE pulse width 150ns ++ ++#define PCCARD_VCC_MASK 0x00070000 // Mask Reset also ++#define PCCARD_VCC_33V 0x00010000 ++#define PCCARD_VCC_50V 0x00020000 ++ ++typedef enum { ++ MPI_CARDTYPE_NONE, // No Card in slot ++ MPI_CARDTYPE_PCMCIA, // 16-bit PCMCIA card in slot ++ MPI_CARDTYPE_CARDBUS, // 32-bit CardBus card in slot ++} CardType; ++ ++#define CARDBUS_SLOT 0 // Slot 0 is default for CardBus ++ ++#define pcmciaAttrOffset 0x00200000 ++#define pcmciaMemOffset 0x00000000 ++// Needs to be right above PCI I/O space. Give 0x8000 (32K) to PCMCIA. ++#define pcmciaIoOffset (BCM_PCI_IO_BASE + 0x80000) ++// Base Address is that mapped into the MPI ChipSelect registers. ++// UBUS bridge MemoryWindow 0 outputs a 0x00 for the base. ++#define pcmciaBase 0xbf000000 ++#define pcmciaAttr (pcmciaAttrOffset | pcmciaBase) ++#define pcmciaMem (pcmciaMemOffset | pcmciaBase) ++#define pcmciaIo (pcmciaIoOffset | pcmciaBase) ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmtypes.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmtypes.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/bcmtypes.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/bcmtypes.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,163 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++ ++// ++// bcmtypes.h - misc useful typedefs ++// ++#ifndef BCMTYPES_H ++#define BCMTYPES_H ++ ++// These are also defined in typedefs.h in the application area, so I need to ++// protect against re-definition. ++ ++#ifndef _TYPEDEFS_H_ ++typedef unsigned char uint8; ++typedef unsigned short uint16; ++typedef unsigned long uint32; ++typedef signed char int8; ++typedef signed short int16; ++typedef signed long int32; ++#if !defined(__cplusplus) ++typedef int bool; ++#endif ++#endif ++ ++typedef unsigned char byte; ++// typedef unsigned long sem_t; ++ ++typedef unsigned long HANDLE,*PULONG,DWORD,*PDWORD; ++typedef signed long LONG,*PLONG; ++ ++typedef unsigned int *PUINT; ++typedef signed int INT; ++ ++typedef unsigned short *PUSHORT; ++typedef signed short SHORT,*PSHORT; ++typedef unsigned short WORD,*PWORD; ++ ++typedef unsigned char *PUCHAR; ++typedef signed char *PCHAR; ++ ++typedef void *PVOID; ++ ++typedef unsigned char BOOLEAN, *PBOOL, *PBOOLEAN; ++ ++typedef unsigned char BYTE,*PBYTE; ++ ++//#ifndef __GNUC__ ++//The following has been defined in Vxworks internally: vxTypesOld.h ++//redefine under vxworks will cause error ++typedef signed int *PINT; ++ ++typedef signed char INT8; ++typedef signed short INT16; ++typedef signed long INT32; ++ ++typedef unsigned char UINT8; ++typedef unsigned short UINT16; ++typedef unsigned long UINT32; ++ ++typedef unsigned char UCHAR; ++typedef unsigned short USHORT; ++typedef unsigned int UINT; ++typedef unsigned long ULONG; ++ ++typedef void VOID; ++typedef unsigned char BOOL; ++ ++//#endif /* __GNUC__ */ ++ ++ ++// These are also defined in typedefs.h in the application area, so I need to ++// protect against re-definition. ++#ifndef TYPEDEFS_H ++ ++// Maximum and minimum values for a signed 16 bit integer. ++#define MAX_INT16 32767 ++#define MIN_INT16 -32768 ++ ++// Useful for true/false return values. This uses the ++// Taligent notation (k for constant). ++typedef enum ++{ ++ kFalse = 0, ++ kTrue = 1 ++} Bool; ++ ++#endif ++ ++/* macros to protect against unaligned accesses */ ++ ++#if 0 ++/* first arg is an address, second is a value */ ++#define PUT16( a, d ) { \ ++ *((byte *)a) = (byte)((d)>>8); \ ++ *(((byte *)a)+1) = (byte)(d); \ ++} ++ ++#define PUT32( a, d ) { \ ++ *((byte *)a) = (byte)((d)>>24); \ ++ *(((byte *)a)+1) = (byte)((d)>>16); \ ++ *(((byte *)a)+2) = (byte)((d)>>8); \ ++ *(((byte *)a)+3) = (byte)(d); \ ++} ++ ++/* first arg is an address, returns a value */ ++#define GET16( a ) ( \ ++ (*((byte *)a) << 8) | \ ++ (*(((byte *)a)+1)) \ ++) ++ ++#define GET32( a ) ( \ ++ (*((byte *)a) << 24) | \ ++ (*(((byte *)a)+1) << 16) | \ ++ (*(((byte *)a)+2) << 8) | \ ++ (*(((byte *)a)+3)) \ ++) ++#endif ++ ++#ifndef YES ++#define YES 1 ++#endif ++ ++#ifndef NO ++#define NO 0 ++#endif ++ ++#ifndef IN ++#define IN ++#endif ++ ++#ifndef OUT ++#define OUT ++#endif ++ ++#ifndef TRUE ++#define TRUE 1 ++#endif ++ ++#ifndef FALSE ++#define FALSE 0 ++#endif ++ ++#define READ32(addr) (*(volatile UINT32 *)((ULONG)&addr)) ++#define READ16(addr) (*(volatile UINT16 *)((ULONG)&addr)) ++#define READ8(addr) (*(volatile UINT8 *)((ULONG)&addr)) ++ ++#endif +diff -urN linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/board.h linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/board.h +--- linux-2.6.8.1/bcmdrivers/opensource/include/bcm963xx/board.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/bcmdrivers/opensource/include/bcm963xx/board.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,368 @@ ++/* ++<:copyright-gpl ++ Copyright 2002 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++:> ++*/ ++/***********************************************************************/ ++/* */ ++/* MODULE: board.h */ ++/* DATE: 97/02/18 */ ++/* PURPOSE: Board specific information. This module should include */ ++/* all base device addresses and board specific macros. */ ++/* */ ++/***********************************************************************/ ++#ifndef _BOARD_H ++#define _BOARD_H ++ ++#if __cplusplus ++extern "C" { ++#endif ++/*****************************************************************************/ ++/* Misc board definitions */ ++/*****************************************************************************/ ++ ++#define DYING_GASP_API ++ ++/*****************************************************************************/ ++/* Physical Memory Map */ ++/*****************************************************************************/ ++ ++#define PHYS_DRAM_BASE 0x00000000 /* Dynamic RAM Base */ ++#define PHYS_FLASH_BASE 0x1FC00000 /* Flash Memory */ ++ ++/*****************************************************************************/ ++/* Note that the addresses above are physical addresses and that programs */ ++/* have to use converted addresses defined below: */ ++/*****************************************************************************/ ++#define DRAM_BASE (0x80000000 | PHYS_DRAM_BASE) /* cached DRAM */ ++#define DRAM_BASE_NOCACHE (0xA0000000 | PHYS_DRAM_BASE) /* uncached DRAM */ ++#define FLASH_BASE (0xA0000000 | PHYS_FLASH_BASE) /* uncached Flash */ ++ ++/*****************************************************************************/ ++/* Select the PLL value to get the desired CPU clock frequency. */ ++/* */ ++/* */ ++/*****************************************************************************/ ++#define FPERIPH 50000000 ++ ++#define ONEK 1024 ++#define BLK64K (64*ONEK) ++#define FLASH45_BLKS_BOOT_ROM 1 ++#define FLASH45_LENGTH_BOOT_ROM (FLASH45_BLKS_BOOT_ROM * BLK64K) ++#define FLASH_RESERVED_AT_END (64*ONEK) /*reserved for PSI, scratch pad*/ ++ ++/*****************************************************************************/ ++/* Note that the addresses above are physical addresses and that programs */ ++/* have to use converted addresses defined below: */ ++/*****************************************************************************/ ++#define DRAM_BASE (0x80000000 | PHYS_DRAM_BASE) /* cached DRAM */ ++#define DRAM_BASE_NOCACHE (0xA0000000 | PHYS_DRAM_BASE) /* uncached DRAM */ ++#define FLASH_BASE (0xA0000000 | PHYS_FLASH_BASE) /* uncached Flash */ ++ ++/*****************************************************************************/ ++/* Select the PLL value to get the desired CPU clock frequency. */ ++/* */ ++/* */ ++/*****************************************************************************/ ++#define FPERIPH 50000000 ++ ++#define SDRAM_TYPE_ADDRESS_OFFSET 16 ++#define NVRAM_DATA_OFFSET 0x0580 ++#define NVRAM_DATA_ID 0x0f1e2d3c ++#define BOARD_SDRAM_TYPE *(unsigned long *) \ ++ (FLASH_BASE + SDRAM_TYPE_ADDRESS_OFFSET) ++ ++#define ONEK 1024 ++#define BLK64K (64*ONEK) ++ ++// nvram and psi flash definitions for 45 ++#define FLASH45_LENGTH_NVRAM ONEK // 1k nvram ++#define NVRAM_PSI_DEFAULT 24 // default psi in K byes ++ ++/*****************************************************************************/ ++/* NVRAM Offset and definition */ ++/*****************************************************************************/ ++ ++#define NVRAM_VERSION_NUMBER 2 ++#define NVRAM_VERSION_NUMBER_ADDRESS 0 ++ ++#define NVRAM_BOOTLINE_LEN 256 ++#define NVRAM_BOARD_ID_STRING_LEN 16 ++#define NVRAM_MAC_ADDRESS_LEN 6 ++#define NVRAM_MAC_COUNT_MAX 32 ++ ++/*****************************************************************************/ ++/* Misc Offsets */ ++/*****************************************************************************/ ++ ++#define CFE_VERSION_OFFSET 0x0570 ++#define CFE_VERSION_MARK_SIZE 5 ++#define CFE_VERSION_SIZE 5 ++ ++typedef struct ++{ ++ unsigned long ulVersion; ++ char szBootline[NVRAM_BOOTLINE_LEN]; ++ char szBoardId[NVRAM_BOARD_ID_STRING_LEN]; ++ unsigned long ulReserved1[2]; ++ unsigned long ulNumMacAddrs; ++ unsigned char ucaBaseMacAddr[NVRAM_MAC_ADDRESS_LEN]; ++ char chReserved[2]; ++ unsigned long ulCheckSum; ++} NVRAM_DATA, *PNVRAM_DATA; ++ ++ ++/*****************************************************************************/ ++/* board ioctl calls for flash, led and some other utilities */ ++/*****************************************************************************/ ++ ++ ++/* Defines. for board driver */ ++#define BOARD_IOCTL_MAGIC 'B' ++#define BOARD_DRV_MAJOR 206 ++ ++#define MAC_ADDRESS_ANY (unsigned long) -1 ++ ++#define BOARD_IOCTL_FLASH_INIT \ ++ _IOWR(BOARD_IOCTL_MAGIC, 0, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_FLASH_WRITE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 1, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_FLASH_READ \ ++ _IOWR(BOARD_IOCTL_MAGIC, 2, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_NR_PAGES \ ++ _IOWR(BOARD_IOCTL_MAGIC, 3, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_DUMP_ADDR \ ++ _IOWR(BOARD_IOCTL_MAGIC, 4, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_SET_MEMORY \ ++ _IOWR(BOARD_IOCTL_MAGIC, 5, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_MIPS_SOFT_RESET \ ++ _IOWR(BOARD_IOCTL_MAGIC, 6, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_LED_CTRL \ ++ _IOWR(BOARD_IOCTL_MAGIC, 7, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_ID \ ++ _IOWR(BOARD_IOCTL_MAGIC, 8, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_MAC_ADDRESS \ ++ _IOWR(BOARD_IOCTL_MAGIC, 9, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_RELEASE_MAC_ADDRESS \ ++ _IOWR(BOARD_IOCTL_MAGIC, 10, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_PSI_SIZE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 11, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_SDRAM_SIZE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 12, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_SET_MONITOR_FD \ ++ _IOWR(BOARD_IOCTL_MAGIC, 13, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_WAKEUP_MONITOR_TASK \ ++ _IOWR(BOARD_IOCTL_MAGIC, 14, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_BOOTLINE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 15, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_SET_BOOTLINE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 16, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_BASE_MAC_ADDRESS \ ++ _IOWR(BOARD_IOCTL_MAGIC, 17, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_CHIP_ID \ ++ _IOWR(BOARD_IOCTL_MAGIC, 18, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_NUM_ENET \ ++ _IOWR(BOARD_IOCTL_MAGIC, 19, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_CFE_VER \ ++ _IOWR(BOARD_IOCTL_MAGIC, 20, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_ENET_CFG \ ++ _IOWR(BOARD_IOCTL_MAGIC, 21, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_WLAN_ANT_INUSE \ ++ _IOWR(BOARD_IOCTL_MAGIC, 22, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_SET_TRIGGER_EVENT \ ++ _IOWR(BOARD_IOCTL_MAGIC, 23, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_GET_TRIGGER_EVENT \ ++ _IOWR(BOARD_IOCTL_MAGIC, 24, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_UNSET_TRIGGER_EVENT \ ++ _IOWR(BOARD_IOCTL_MAGIC, 25, BOARD_IOCTL_PARMS) ++ ++#define BOARD_IOCTL_SET_SES_LED \ ++ _IOWR(BOARD_IOCTL_MAGIC, 26, BOARD_IOCTL_PARMS) ++ ++ ++// for the action in BOARD_IOCTL_PARMS for flash operation ++typedef enum ++{ ++ PERSISTENT, ++ NVRAM, ++ BCM_IMAGE_CFE, ++ BCM_IMAGE_FS, ++ BCM_IMAGE_KERNEL, ++ BCM_IMAGE_WHOLE, ++ SCRATCH_PAD, ++ FLASH_SIZE, ++} BOARD_IOCTL_ACTION; ++ ++ ++typedef struct boardIoctParms ++{ ++ char *string; ++ char *buf; ++ int strLen; ++ int offset; ++ BOARD_IOCTL_ACTION action; /* flash read/write: nvram, persistent, bcm image */ ++ int result; ++} BOARD_IOCTL_PARMS; ++ ++ ++// LED defines ++typedef enum ++{ ++ kLedAdsl, ++ kLedWireless, ++ kLedUsb, ++ kLedHpna, ++ kLedWanData, ++ kLedPPP, ++ kLedVoip, ++ kLedSes, ++ kLedEnd, // NOTE: Insert the new led name before this one. Alway stay at the end. ++} BOARD_LED_NAME; ++ ++typedef enum ++{ ++ kLedStateOff, /* turn led off */ ++ kLedStateOn, /* turn led on */ ++ kLedStateFail, /* turn led on red */ ++ kLedStateBlinkOnce, /* blink once, ~100ms and ignore the same call during the 100ms period */ ++ kLedStateSlowBlinkContinues, /* slow blink continues at ~600ms interval */ ++ kLedStateFastBlinkContinues, /* fast blink continues at ~200ms interval */ ++} BOARD_LED_STATE; ++ ++ ++// virtual and physical map pair defined in board.c ++typedef struct ledmappair ++{ ++ BOARD_LED_NAME ledName; // virtual led name ++ BOARD_LED_STATE ledInitState; // initial led state when the board boots. ++ unsigned short ledMask; // physical GPIO pin mask ++ unsigned short ledActiveLow; // reset bit to turn on LED ++ unsigned short ledMaskFail; // physical GPIO pin mask for state failure ++ unsigned short ledActiveLowFail;// reset bit to turn on LED ++} LED_MAP_PAIR, *PLED_MAP_PAIR; ++ ++typedef void (*HANDLE_LED_FUNC)(BOARD_LED_NAME ledName, BOARD_LED_STATE ledState); ++ ++/* Flash storage address information that is determined by the flash driver. */ ++typedef struct flashaddrinfo ++{ ++ int flash_persistent_start_blk; ++ int flash_persistent_number_blk; ++ int flash_persistent_length; ++ unsigned long flash_persistent_blk_offset; ++ int flash_scratch_pad_start_blk; // start before psi (SP_BUF_LEN) ++ int flash_scratch_pad_number_blk; ++ int flash_scratch_pad_length; ++ unsigned long flash_scratch_pad_blk_offset; ++ int flash_nvram_start_blk; ++ int flash_nvram_number_blk; ++ int flash_nvram_length; ++ unsigned long flash_nvram_blk_offset; ++} FLASH_ADDR_INFO, *PFLASH_ADDR_INFO; ++ ++// scratch pad defines ++/* SP - Persisten Scratch Pad format: ++ sp header : 32 bytes ++ tokenId-1 : 8 bytes ++ tokenId-1 len : 4 bytes ++ tokenId-1 data ++ .... ++ tokenId-n : 8 bytes ++ tokenId-n len : 4 bytes ++ tokenId-n data ++*/ ++ ++#define MAGIC_NUM_LEN 8 ++#define MAGIC_NUMBER "gOGoBrCm" ++#define TOKEN_NAME_LEN 16 ++#define SP_VERSION 1 ++#define SP_MAX_LEN 8 * 1024 // 8k buf before psi ++#define SP_RESERVERD 16 ++ ++typedef struct _SP_HEADER ++{ ++ char SPMagicNum[MAGIC_NUM_LEN]; // 8 bytes of magic number ++ int SPVersion; // version number ++ int SPUsedLen; // used sp len ++ char SPReserved[SP_RESERVERD]; // reservied, total 32 bytes ++} SP_HEADER, *PSP_HEADER; ++ ++typedef struct _TOKEN_DEF ++{ ++ char tokenName[TOKEN_NAME_LEN]; ++ int tokenLen; ++} SP_TOKEN, *PSP_TOKEN; ++ ++ ++/*****************************************************************************/ ++/* Function Prototypes */ ++/*****************************************************************************/ ++#if !defined(__ASM_ASM_H) ++void dumpaddr( unsigned char *pAddr, int nLen ); ++ ++void kerSysFlashAddrInfoGet(PFLASH_ADDR_INFO pflash_addr_info); ++int kerSysNvRamGet(char *string, int strLen, int offset); ++int kerSysNvRamSet(char *string, int strLen, int offset); ++int kerSysPersistentGet(char *string, int strLen, int offset); ++int kerSysPersistentSet(char *string, int strLen, int offset); ++int kerSysScratchPadGet(char *tokName, char *tokBuf, int tokLen); ++int kerSysScratchPadSet(char *tokName, char *tokBuf, int tokLen); ++int kerSysBcmImageSet( int flash_start_addr, char *string, int size); ++int kerSysGetMacAddress( unsigned char *pucaAddr, unsigned long ulId ); ++int kerSysReleaseMacAddress( unsigned char *pucaAddr ); ++int kerSysGetSdramSize( void ); ++void kerSysGetBootline(char *string, int strLen); ++void kerSysSetBootline(char *string, int strLen); ++void kerSysMipsSoftReset(void); ++void kerSysLedCtrl(BOARD_LED_NAME, BOARD_LED_STATE); ++void kerSysLedRegisterHwHandler( BOARD_LED_NAME, HANDLE_LED_FUNC, int ); ++int kerSysFlashSizeGet(void); ++void kerSysRegisterDyingGaspHandler(char *devname, void *cbfn, void *context); ++void kerSysDeregisterDyingGaspHandler(char *devname); ++void kerSysWakeupMonitorTask( void ); ++#endif ++ ++#if __cplusplus ++} ++#endif ++ ++#endif /* _BOARD_H */ ++ +diff -urN linux-2.6.8.1/boardparams/bcm963xx/Makefile linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/Makefile +--- linux-2.6.8.1/boardparams/bcm963xx/Makefile 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/Makefile 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,16 @@ ++ ++ifeq ($(CONFIG_MIPS_BRCM),y) ++ ++# Linux ++obj-y += boardparms.o ++EXTRA_CFLAGS += -DCONFIG_BCM9$(BRCM_CHIP) ++-include $(TOPDIR)/Rules.make ++ ++else ++ ++# CFE ++BSPOBJS += boardparms.o ++ ++endif ++ ++ +diff -urN linux-2.6.8.1/boardparams/bcm963xx/boardparms.c linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/boardparms.c +--- linux-2.6.8.1/boardparams/bcm963xx/boardparms.c 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/boardparms.c 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,2382 @@ ++/* ++<:copyright-gpl ++ ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++ ++:> ++*/ ++/************************************************************************** ++ * File Name : boardparms.c ++ * ++ * Description: This file contains the implementation for the BCM63xx board ++ * parameter access functions. ++ * ++ * Updates : 07/14/2003 Created. ++ ***************************************************************************/ ++ ++/* Includes. */ ++#include "boardparms.h" ++ ++/* Defines. */ ++ ++/* Default psi size in K bytes */ ++#define BP_PSI_DEFAULT_SIZE 24 ++ ++/* Typedefs */ ++typedef struct boardparameters ++{ ++ char szBoardId[BP_BOARD_ID_LEN]; /* board id string */ ++ ETHERNET_MAC_INFO EnetMacInfos[BP_MAX_ENET_MACS]; ++ VOIP_DSP_INFO VoIPDspInfo[BP_MAX_VOIP_DSP]; ++ unsigned short usSdramSize; /* SDRAM size and type */ ++ unsigned short usPsiSize; /* persistent storage in K bytes */ ++ unsigned short usGpioRj11InnerPair; /* GPIO pin or not defined */ ++ unsigned short usGpioRj11OuterPair; /* GPIO pin or not defined */ ++ unsigned short usGpioPressAndHoldReset; /* GPIO pin or not defined */ ++ unsigned short usGpioPcmciaReset; /* GPIO pin or not defined */ ++ unsigned short usGpioUartRts; /* GPIO pin or not defined */ ++ unsigned short usGpioUartCts; /* GPIO pin or not defined */ ++ unsigned short usGpioLedAdsl; /* GPIO pin or not defined */ ++ unsigned short usGpioLedAdslFail; /* GPIO pin or not defined */ ++ unsigned short usGpioLedWireless; /* GPIO pin or not defined */ ++ unsigned short usGpioLedUsb; /* GPIO pin or not defined */ ++ unsigned short usGpioLedHpna; /* GPIO pin or not defined */ ++ unsigned short usGpioLedWanData; /* GPIO pin or not defined */ ++ unsigned short usGpioLedPpp; /* GPIO pin or not defined */ ++ unsigned short usGpioLedPppFail; /* GPIO pin or not defined */ ++ unsigned short usGpioLedBlPowerOn; /* GPIO pin or not defined */ ++ unsigned short usGpioLedBlAlarm; /* GPIO pin or not defined */ ++ unsigned short usGpioLedBlResetCfg; /* GPIO pin or not defined */ ++ unsigned short usGpioLedBlStop; /* GPIO pin or not defined */ ++ unsigned short usExtIntrWireless; /* ext intr or not defined */ ++ unsigned short usExtIntrAdslDyingGasp; /* ext intr or not defined */ ++ unsigned short usExtIntrHpna; /* ext intr or not defined */ ++ unsigned short usCsHpna; /* chip select not defined */ ++ unsigned short usAntInUseWireless; /* antenna in use or not defined */ ++ unsigned short usGpioSesBtnWireless; /* GPIO pin or not defined */ ++ unsigned short usExtIntrSesBtnWireless; /* ext intr or not defined */ ++ unsigned short usGpioLedSesWireless; /* GPIO pin or not defined */ ++} BOARD_PARAMETERS, *PBOARD_PARAMETERS; ++ ++/* Variables */ ++#if defined(_BCM96338_) || defined(CONFIG_BCM96338) ++static BOARD_PARAMETERS g_bcm96338sv = ++{ ++ "96338SV", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_NOT_DEFINED, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_NOT_DEFINED, /* usGpioLedWanData */ ++ BP_NOT_DEFINED, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_NOT_DEFINED, /* usGpioLedBlResetCfg */ ++ BP_NOT_DEFINED, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++static BOARD_PARAMETERS g_bcm96338l2m8m = ++{ ++ "96338L-2M-8M", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_NOT_DEFINED, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++static PBOARD_PARAMETERS g_BoardParms[] = ++ {&g_bcm96338sv, &g_bcm96338l2m8m, 0}; ++#endif ++ ++#if defined(_BCM96345_) || defined(CONFIG_BCM96345) ++static BOARD_PARAMETERS g_bcm96345r = ++{ ++ "96345R", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_GPIO_11_AH, /* usGpioRj11InnerPair */ ++ BP_GPIO_12_AH, /* usGpioRj11OuterPair */ ++ BP_GPIO_13_AH, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_GPIO_8_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_8_AH, /* usGpioLedWanData */ ++ BP_GPIO_9_AH, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_10_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_9_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_8_AH, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_EXT_INTR_0, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96345gw2 = ++{ ++ /* A hardware jumper determines whether GPIO 13 is used for Press and Hold ++ * Reset or RTS. ++ */ ++ "96345GW2", /* szBoardId */ ++ {{BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_GPIO_0_AH, /* usGpioPhySpiSck */ ++ BP_GPIO_4_AH, /* usGpioPhySpiSs */ ++ BP_GPIO_12_AH, /* usGpioPhySpiMosi */ ++ BP_GPIO_11_AH, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x04, /* numSwitchPorts */ ++ BP_ENET_CONFIG_GPIO, /* usConfigType */ ++ BP_ENET_REVERSE_MII}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_1, /* usExtIntrVoip */ ++ BP_GPIO_6_AH, /* usGpioVoipReset */ ++ BP_GPIO_15_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_13_AH, /* usGpioPressAndHoldReset */ ++ BP_GPIO_2_AH, /* usGpioPcmciaReset */ ++ BP_GPIO_13_AH, /* usGpioUartRts */ ++ BP_GPIO_9_AH, /* usGpioUartCts */ ++ BP_GPIO_8_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_GPIO_7_AH, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_8_AH, /* usGpioLedWanData */ ++ BP_NOT_DEFINED, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_10_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_7_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_8_AH, /* usGpioLedBlStop */ ++ BP_EXT_INTR_2, /* usExtIntrWireless */ ++ BP_EXT_INTR_0, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_WLAN_ANT_MAIN, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96345gw = ++{ ++ "96345GW", /* szBoardId */ ++ {{BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x04, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_ENET_NO_REVERSE_MII}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_1, /* usExtIntrVoip */ ++ BP_GPIO_6_AH, /* usGpioVoipReset */ ++ BP_GPIO_15_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_GPIO_11_AH, /* usGpioRj11InnerPair */ ++ BP_GPIO_1_AH, /* usGpioRj11OuterPair */ ++ BP_GPIO_13_AH, /* usGpioPressAndHoldReset */ ++ BP_GPIO_2_AH, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_GPIO_8_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_GPIO_10_AH, /* usGpioLedWireless */ ++ BP_GPIO_7_AH, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_8_AH, /* usGpioLedWanData */ ++ BP_NOT_DEFINED, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_9_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_10_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_8_AH, /* usGpioLedBlStop */ ++ BP_EXT_INTR_2, /* usExtIntrWireless */ ++ BP_EXT_INTR_0, /* usExtIntrAdslDyingGasp */ ++ BP_EXT_INTR_3, /* usExtIntrHpna */ ++ BP_CS_1, /* usCsHpna */ ++ BP_WLAN_ANT_MAIN, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96335r = ++{ ++ "96335R", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_14_AH, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_GPIO_9_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_9_AH, /* usGpioLedWanData */ ++ BP_GPIO_8_AH, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_10_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_8_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_9_AH, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_NOT_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96345r0 = ++{ ++ "96345R0", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_NOT_DEFINED, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_GPIO_8_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_9_AH, /* usGpioLedWanData */ ++ BP_GPIO_9_AH, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_9_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_8_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_8_AH, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_NOT_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96345rs = ++{ ++ "96345RS", /* szBoardId */ ++ {{BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_ENET_NO_REVERSE_MII}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_GPIO_11_AH, /* usGpioRj11InnerPair */ ++ BP_GPIO_12_AH, /* usGpioRj11OuterPair */ ++ BP_GPIO_13_AH, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_GPIO_8_AH, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_8_AH, /* usGpioLedWanData */ ++ BP_GPIO_9_AH, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_GPIO_10_AH, /* usGpioLedBlAlarm */ ++ BP_GPIO_9_AH, /* usGpioLedBlResetCfg */ ++ BP_GPIO_8_AH, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_EXT_INTR_0, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static PBOARD_PARAMETERS g_BoardParms[] = ++ {&g_bcm96345r, &g_bcm96345gw2, &g_bcm96345gw, &g_bcm96335r, &g_bcm96345r0, ++ &g_bcm96345rs, 0}; ++#endif ++ ++#if defined(_BCM96348_) || defined(CONFIG_BCM96348) ++ ++static BOARD_PARAMETERS g_bcm96348r = ++{ ++ "96348R", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY}}, /* ucPhyType */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_8MB_1_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_7_AH, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96348lv = ++{ ++ "96348LV", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_EXTERNAL_PHY, /* ucPhyType */ ++ 0x02, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_GPIO_5_AL, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}}, /* usReverseMii */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_7_AH, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_NOT_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96348gw = ++{ ++ "96348GW", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x03, /* numSwitchPorts */ ++ BP_ENET_CONFIG_SPI_SSB_0, /* usConfigType */ ++ BP_ENET_REVERSE_MII}}, /* usReverseMii */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_2, /* usExtIntrVoip */ ++ BP_GPIO_6_AH, /* usGpioVoipReset */ ++ BP_GPIO_34_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_33_AL, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_WLAN_ANT_MAIN, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* BP_GPIO_35_AH, */ /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* BP_EXT_INTR_3, */ /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* BP_GPIO_0_AL */ /* usGpioLedSesWireless */ ++}; ++ ++ ++static BOARD_PARAMETERS g_bcm96348gw_10 = ++{ ++ "96348GW-10", /* szBoardId */ ++ {{BP_ENET_NO_PHY}, /* ucPhyType */ ++ {BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x04, /* numSwitchPorts */ ++ BP_ENET_CONFIG_SPI_SSB_1, /* usConfigType */ ++ BP_ENET_REVERSE_MII}}, /* usReverseMii */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_2, /* usExtIntrVoip */ ++ BP_GPIO_6_AH, /* usGpioVoipReset */ ++ BP_GPIO_34_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_33_AL, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_WLAN_ANT_MAIN, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96348gw_11 = ++{ ++ "96348GW-11", /* szBoardId */ ++ {{BP_ENET_NO_PHY}, /* ucPhyType */ ++ {BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x04, /* numSwitchPorts */ ++ BP_ENET_CONFIG_SPI_SSB_1, /* usConfigType */ ++ BP_ENET_REVERSE_MII}}, /* usReverseMii */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_33_AL, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static BOARD_PARAMETERS g_bcm96348sv = ++{ ++ "96348SV", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_EXTERNAL_PHY, /* ucPhyType */ ++ 0x1f, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}}, /* usReverseMii */ ++ {{BP_VOIP_NO_DSP}, /* ucDspType */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_32MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_NOT_DEFINED, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_NOT_DEFINED, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_NOT_DEFINED, /* usGpioLedWanData */ ++ BP_NOT_DEFINED, /* usGpioLedPpp */ ++ BP_NOT_DEFINED, /* usGpioLedPppFail */ ++ BP_NOT_DEFINED, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_NOT_DEFINED, /* usGpioLedBlResetCfg */ ++ BP_NOT_DEFINED, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++ ++static BOARD_PARAMETERS g_bcm96348gw_dualDsp = ++{ ++ "96348GW-DualDSP", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_EXTERNAL_SWITCH, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x03, /* numSwitchPorts */ ++ BP_ENET_CONFIG_SPI_SSB_1, /* usConfigType */ ++ BP_ENET_REVERSE_MII}}, /* usReverseMii */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_2, /* usExtIntrVoip */ ++ BP_UNEQUIPPED, /* usGpioVoipReset */ ++ BP_GPIO_34_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_DSP, /* ucDspType */ ++ 0x01, /* ucDspAddress */ ++ BP_EXT_INTR_3, /* usExtIntrVoip */ ++ BP_UNEQUIPPED , /* usGpioVoipReset */ ++ BP_GPIO_35_AH, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_3}}, /* usCsVoip */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_33_AL, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_HW_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_WLAN_ANT_MAIN, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++ ++static BOARD_PARAMETERS g_bcmCustom_01 = ++{ ++ "BCMCUST_01", /* szBoardId */ ++ {{BP_ENET_INTERNAL_PHY, /* ucPhyType */ ++ 0x01, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_MDIO, /* usConfigType */ ++ BP_NOT_DEFINED}, /* usReverseMii */ ++ {BP_ENET_NO_PHY, /* ucPhyType */ ++ 0x00, /* ucPhyAddress */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSck */ ++ BP_NOT_DEFINED, /* usGpioPhySpiSs */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMosi */ ++ BP_NOT_DEFINED, /* usGpioPhySpiMiso */ ++ BP_NOT_DEFINED, /* usGpioPhyReset */ ++ 0x01, /* numSwitchPorts */ ++ BP_ENET_CONFIG_SPI_SSB_1, /* usConfigType */ ++ BP_ENET_REVERSE_MII}}, /* usReverseMii */ ++ {{BP_VOIP_DSP, /* ucDspType */ ++ 0x00, /* ucDspAddress */ ++ BP_EXT_INTR_2, /* usExtIntrVoip */ ++ BP_GPIO_36_AH, /* usGpioVoipReset */ ++ BP_GPIO_34_AL, /* usGpioVoipIntr */ ++ BP_NOT_DEFINED, /* usGpioLedVoip */ ++ BP_CS_2}, /* usCsVoip */ ++ {BP_VOIP_NO_DSP}}, /* ucDspType */ ++ BP_MEMORY_16MB_2_CHIP, /* usSdramSize */ ++ BP_PSI_DEFAULT_SIZE, /* usPsiSize */ ++ BP_NOT_DEFINED, /* usGpioRj11InnerPair */ ++ BP_NOT_DEFINED, /* usGpioRj11OuterPair */ ++ BP_GPIO_33_AL, /* usGpioPressAndHoldReset */ ++ BP_NOT_DEFINED, /* usGpioPcmciaReset */ ++ BP_NOT_DEFINED, /* usGpioUartRts */ ++ BP_NOT_DEFINED, /* usGpioUartCts */ ++ BP_NOT_DEFINED, /* usGpioLedAdsl */ ++ BP_GPIO_2_AL, /* usGpioLedAdslFail */ ++ BP_NOT_DEFINED, /* usGpioLedWireless */ ++ BP_NOT_DEFINED, /* usGpioLedUsb */ ++ BP_NOT_DEFINED, /* usGpioLedHpna */ ++ BP_GPIO_3_AL, /* usGpioLedWanData */ ++ BP_GPIO_3_AL, /* usGpioLedPpp */ ++ BP_GPIO_4_AL, /* usGpioLedPppFail */ ++ BP_GPIO_0_AL, /* usGpioLedBlPowerOn */ ++ BP_NOT_DEFINED, /* usGpioLedBlAlarm */ ++ BP_GPIO_3_AL, /* usGpioLedBlResetCfg */ ++ BP_GPIO_1_AL, /* usGpioLedBlStop */ ++ BP_NOT_DEFINED, /* usExtIntrWireless */ ++ BP_NOT_DEFINED, /* usExtIntrAdslDyingGasp */ ++ BP_NOT_DEFINED, /* usExtIntrHpna */ ++ BP_NOT_DEFINED, /* usCsHpna */ ++ BP_NOT_DEFINED, /* usAntInUseWireless */ ++ BP_NOT_DEFINED, /* usGpioSesBtnWireless */ ++ BP_NOT_DEFINED, /* usExtIntrSesBtnWireless */ ++ BP_NOT_DEFINED /* usGpioLedSesWireless */ ++}; ++ ++static PBOARD_PARAMETERS g_BoardParms[] = ++ {&g_bcm96348r, &g_bcm96348lv, &g_bcm96348gw, &g_bcm96348gw_10, ++ &g_bcm96348gw_11, &g_bcm96348sv, &g_bcm96348gw_dualDsp, ++ &g_bcmCustom_01, 0}; ++#endif ++ ++static PBOARD_PARAMETERS g_pCurrentBp = 0; ++ ++/************************************************************************** ++ * Name : bpstrcmp ++ * ++ * Description: String compare for this file so it does not depend on an OS. ++ * (Linux kernel and CFE share this source file.) ++ * ++ * Parameters : [IN] dest - destination string ++ * [IN] src - source string ++ * ++ * Returns : -1 - dest < src, 1 - dest > src, 0 dest == src ++ ***************************************************************************/ ++static int bpstrcmp(const char *dest,const char *src); ++static int bpstrcmp(const char *dest,const char *src) ++{ ++ while (*src && *dest) ++ { ++ if (*dest < *src) return -1; ++ if (*dest > *src) return 1; ++ dest++; ++ src++; ++ } ++ ++ if (*dest && !*src) return 1; ++ if (!*dest && *src) return -1; ++ return 0; ++} /* bpstrcmp */ ++ ++/************************************************************************** ++ * Name : BpGetVoipDspConfig ++ * ++ * Description: Gets the DSP configuration from the board parameter ++ * structure for a given DSP index. ++ * ++ * Parameters : [IN] dspNum - DSP index (number) ++ * ++ * Returns : Pointer to DSP configuration block if found/valid, NULL ++ * otherwise. ++ ***************************************************************************/ ++VOIP_DSP_INFO *BpGetVoipDspConfig( unsigned char dspNum ); ++VOIP_DSP_INFO *BpGetVoipDspConfig( unsigned char dspNum ) ++{ ++ VOIP_DSP_INFO *pDspConfig = 0; ++ int i; ++ ++ if( g_pCurrentBp ) ++ { ++ for( i = 0 ; i < BP_MAX_VOIP_DSP ; i++ ) ++ { ++ if( g_pCurrentBp->VoIPDspInfo[i].ucDspType != BP_VOIP_NO_DSP && ++ g_pCurrentBp->VoIPDspInfo[i].ucDspAddress == dspNum ) ++ { ++ pDspConfig = &g_pCurrentBp->VoIPDspInfo[i]; ++ break; ++ } ++ } ++ } ++ ++ return pDspConfig; ++} ++ ++ ++/************************************************************************** ++ * Name : BpSetBoardId ++ * ++ * Description: This function find the BOARD_PARAMETERS structure for the ++ * specified board id string and assigns it to a global, static ++ * variable. ++ * ++ * Parameters : [IN] pszBoardId - Board id string that is saved into NVRAM. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_FOUND - Error, board id input string does not ++ * have a board parameters configuration record. ++ ***************************************************************************/ ++int BpSetBoardId( char *pszBoardId ) ++{ ++ int nRet = BP_BOARD_ID_NOT_FOUND; ++ PBOARD_PARAMETERS *ppBp; ++ ++ for( ppBp = g_BoardParms; *ppBp; ppBp++ ) ++ { ++ if( !bpstrcmp((*ppBp)->szBoardId, pszBoardId) ) ++ { ++ g_pCurrentBp = *ppBp; ++ nRet = BP_SUCCESS; ++ break; ++ } ++ } ++ ++ return( nRet ); ++} /* BpSetBoardId */ ++ ++/************************************************************************** ++ * Name : BpGetBoardIds ++ * ++ * Description: This function returns all of the supported board id strings. ++ * ++ * Parameters : [OUT] pszBoardIds - Address of a buffer that the board id ++ * strings are returned in. Each id starts at BP_BOARD_ID_LEN ++ * boundary. ++ * [IN] nBoardIdsSize - Number of BP_BOARD_ID_LEN elements that ++ * were allocated in pszBoardIds. ++ * ++ * Returns : Number of board id strings returned. ++ ***************************************************************************/ ++int BpGetBoardIds( char *pszBoardIds, int nBoardIdsSize ) ++{ ++ PBOARD_PARAMETERS *ppBp; ++ int i; ++ char *src; ++ char *dest; ++ ++ for( i = 0, ppBp = g_BoardParms; *ppBp && nBoardIdsSize; ++ i++, ppBp++, nBoardIdsSize--, pszBoardIds += BP_BOARD_ID_LEN ) ++ { ++ dest = pszBoardIds; ++ src = (*ppBp)->szBoardId; ++ while( *src ) ++ *dest++ = *src++; ++ *dest = '\0'; ++ } ++ ++ return( i ); ++} /* BpGetBoardIds */ ++ ++/************************************************************************** ++ * Name : BpGetEthernetMacInfo ++ * ++ * Description: This function returns all of the supported board id strings. ++ * ++ * Parameters : [OUT] pEnetInfos - Address of an array of ETHERNET_MAC_INFO ++ * buffers. ++ * [IN] nNumEnetInfos - Number of ETHERNET_MAC_INFO elements that ++ * are pointed to by pEnetInfos. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetEthernetMacInfo( PETHERNET_MAC_INFO pEnetInfos, int nNumEnetInfos ) ++{ ++ int i, nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ for( i = 0; i < nNumEnetInfos; i++, pEnetInfos++ ) ++ { ++ if( i < BP_MAX_ENET_MACS ) ++ { ++ unsigned char *src = (unsigned char *) ++ &g_pCurrentBp->EnetMacInfos[i]; ++ unsigned char *dest = (unsigned char *) pEnetInfos; ++ int len = sizeof(ETHERNET_MAC_INFO); ++ while( len-- ) ++ *dest++ = *src++; ++ } ++ else ++ pEnetInfos->ucPhyType = BP_ENET_NO_PHY; ++ } ++ ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ for( i = 0; i < nNumEnetInfos; i++, pEnetInfos++ ) ++ pEnetInfos->ucPhyType = BP_ENET_NO_PHY; ++ ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetEthernetMacInfo */ ++ ++/************************************************************************** ++ * Name : BpGetSdramSize ++ * ++ * Description: This function returns a constant that describees the board's ++ * SDRAM type and size. ++ * ++ * Parameters : [OUT] pulSdramSize - Address of short word that the SDRAM size ++ * is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetSdramSize( unsigned long *pulSdramSize ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulSdramSize = g_pCurrentBp->usSdramSize; ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ *pulSdramSize = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetSdramSize */ ++ ++/************************************************************************** ++ * Name : BpGetPsiSize ++ * ++ * Description: This function returns the persistent storage size in K bytes. ++ * ++ * Parameters : [OUT] pulPsiSize - Address of short word that the persistent ++ * storage size is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetPsiSize( unsigned long *pulPsiSize ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulPsiSize = g_pCurrentBp->usPsiSize; ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ *pulPsiSize = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetPsiSize */ ++ ++/************************************************************************** ++ * Name : BpGetRj11InnerOuterPairGpios ++ * ++ * Description: This function returns the GPIO pin assignments for changing ++ * between the RJ11 inner pair and RJ11 outer pair. ++ * ++ * Parameters : [OUT] pusInner - Address of short word that the RJ11 inner pair ++ * GPIO pin is returned in. ++ * [OUT] pusOuter - Address of short word that the RJ11 outer pair ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, values are returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetRj11InnerOuterPairGpios( unsigned short *pusInner, ++ unsigned short *pusOuter ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusInner = g_pCurrentBp->usGpioRj11InnerPair; ++ *pusOuter = g_pCurrentBp->usGpioRj11OuterPair; ++ ++ if( g_pCurrentBp->usGpioRj11InnerPair != BP_NOT_DEFINED && ++ g_pCurrentBp->usGpioRj11OuterPair != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusInner = *pusOuter = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetRj11InnerOuterPairGpios */ ++ ++/************************************************************************** ++ * Name : BpGetPressAndHoldResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the press ++ * and hold reset button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the press and hold ++ * reset button GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPressAndHoldResetGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioPressAndHoldReset; ++ ++ if( g_pCurrentBp->usGpioPressAndHoldReset != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetPressAndHoldResetGpio */ ++ ++/************************************************************************** ++ * Name : BpGetVoipResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the VOIP ++ * Reset operation. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP reset ++ * GPIO pin is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipResetGpio( unsigned char dspNum, unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ VOIP_DSP_INFO *pDspInfo = BpGetVoipDspConfig( dspNum ); ++ ++ if( pDspInfo ) ++ { ++ *pusValue = pDspInfo->usGpioVoipReset; ++ ++ if( *pusValue != BP_NOT_DEFINED || ++ *pusValue == BP_UNEQUIPPED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_FOUND; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetVoipResetGpio */ ++ ++/************************************************************************** ++ * Name : BpGetVoipIntrGpio ++ * ++ * Description: This function returns the GPIO pin assignment for VoIP interrupt. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP interrupt ++ * GPIO pin is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipIntrGpio( unsigned char dspNum, unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ VOIP_DSP_INFO *pDspInfo = BpGetVoipDspConfig( dspNum ); ++ ++ if( pDspInfo ) ++ { ++ *pusValue = pDspInfo->usGpioVoipIntr; ++ ++ if( *pusValue != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_FOUND; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetVoipIntrGpio */ ++ ++/************************************************************************** ++ * Name : BpGetPcmciaResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PCMCIA ++ * Reset operation. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PCMCIA reset ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPcmciaResetGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioPcmciaReset; ++ ++ if( g_pCurrentBp->usGpioPcmciaReset != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetPcmciaResetGpio */ ++ ++/************************************************************************** ++ * Name : BpGetUartRtsCtsGpios ++ * ++ * Description: This function returns the GPIO pin assignments for RTS and CTS ++ * UART signals. ++ * ++ * Parameters : [OUT] pusRts - Address of short word that the UART RTS GPIO ++ * pin is returned in. ++ * [OUT] pusCts - Address of short word that the UART CTS GPIO ++ * pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, values are returned. ++ * BP_BOARD_ID_NOT_SET - Error, board id input string does not ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetRtsCtsUartGpios( unsigned short *pusRts, unsigned short *pusCts ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusRts = g_pCurrentBp->usGpioUartRts; ++ *pusCts = g_pCurrentBp->usGpioUartCts; ++ ++ if( g_pCurrentBp->usGpioUartRts != BP_NOT_DEFINED && ++ g_pCurrentBp->usGpioUartCts != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusRts = *pusCts = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetUartRtsCtsGpios */ ++ ++/************************************************************************** ++ * Name : BpGetAdslLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the ADSL ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the ADSL LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedAdsl; ++ ++ if( g_pCurrentBp->usGpioLedAdsl != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetAdslLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetAdslFailLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the ADSL ++ * LED that is used when there is a DSL connection failure. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the ADSL LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslFailLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedAdslFail; ++ ++ if( g_pCurrentBp->usGpioLedAdslFail != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetAdslFailLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedWireless; ++ ++ if( g_pCurrentBp->usGpioLedWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetWirelessLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessAntInUse ++ * ++ * Description: This function returns the antennas in use for wireless ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Antenna ++ * is in use. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessAntInUse( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usAntInUseWireless; ++ ++ if( g_pCurrentBp->usAntInUseWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetWirelessAntInUse */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesBtnGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * Ses Button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesBtnGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioSesBtnWireless; ++ ++ if( g_pCurrentBp->usGpioSesBtnWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetWirelessSesBtnGpio */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesExtIntr ++ * ++ * Description: This function returns the external interrupt number for the ++ * Wireless Ses Button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Ses ++ * external interrup is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesExtIntr( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usExtIntrSesBtnWireless; ++ ++ if( g_pCurrentBp->usExtIntrSesBtnWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++ ++} /* BpGetWirelessSesExtIntr */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * Ses Led. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Ses ++ * Led GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedSesWireless; ++ ++ if( g_pCurrentBp->usGpioLedSesWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++ ++} /* BpGetWirelessSesLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetUsbLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the USB ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the USB LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetUsbLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedUsb; ++ ++ if( g_pCurrentBp->usGpioLedUsb != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetUsbLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetHpnaLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the HPNA ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the HPNA LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedHpna; ++ ++ if( g_pCurrentBp->usGpioLedHpna != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetHpnaLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetWanDataLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the WAN Data ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the WAN Data LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWanDataLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedWanData; ++ ++ if( g_pCurrentBp->usGpioLedWanData != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetWanDataLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetPppLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PPP ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PPP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPppLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedPpp; ++ ++ if( g_pCurrentBp->usGpioLedPpp != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetPppLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetPppFailLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PPP ++ * LED that is used when there is a PPP connection failure. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PPP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPppFailLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedPppFail; ++ ++ if( g_pCurrentBp->usGpioLedPppFail != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetPppFailLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetBootloaderPowerOnLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the power ++ * on LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the alarm LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderPowerOnLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedBlPowerOn; ++ ++ if( g_pCurrentBp->usGpioLedBlPowerOn != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetBootloaderPowerOn */ ++ ++/************************************************************************** ++ * Name : BpGetBootloaderAlarmLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the alarm ++ * LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the alarm LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderAlarmLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedBlAlarm; ++ ++ if( g_pCurrentBp->usGpioLedBlAlarm != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetBootloaderAlarmLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetBootloaderResetCfgLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the reset ++ * configuration LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the reset ++ * configuration LED GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderResetCfgLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedBlResetCfg; ++ ++ if( g_pCurrentBp->usGpioLedBlResetCfg != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetBootloaderResetCfgLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetBootloaderStopLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the break ++ * into bootloader LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the break into ++ * bootloader LED GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderStopLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pusValue = g_pCurrentBp->usGpioLedBlStop; ++ ++ if( g_pCurrentBp->usGpioLedBlStop != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetBootloaderStopLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetVoipLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the VOIP ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ * ++ * Note : The VoIP structure would allow for having one LED per DSP ++ * however, the board initialization function assumes only one ++ * LED per functionality (ie one LED for VoIP). Therefore in ++ * order to keep this tidy and simple we do not make usage of the ++ * one-LED-per-DSP function. Instead, we assume that the LED for ++ * VoIP is unique and associated with DSP 0 (always present on ++ * any VoIP platform). If changing this to a LED-per-DSP function ++ * then one need to update the board initialization driver in ++ * bcmdrivers\opensource\char\board\bcm963xx\impl1 ++ ***************************************************************************/ ++int BpGetVoipLedGpio( unsigned short *pusValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ VOIP_DSP_INFO *pDspInfo = BpGetVoipDspConfig( 0 ); ++ ++ if( pDspInfo ) ++ { ++ *pusValue = pDspInfo->usGpioLedVoip; ++ ++ if( *pusValue != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_FOUND; ++ } ++ } ++ else ++ { ++ *pusValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetVoipLedGpio */ ++ ++/************************************************************************** ++ * Name : BpGetWirelessExtIntr ++ * ++ * Description: This function returns the Wireless external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the wireless ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessExtIntr( unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulValue = g_pCurrentBp->usExtIntrWireless; ++ ++ if( g_pCurrentBp->usExtIntrWireless != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetWirelessExtIntr */ ++ ++/************************************************************************** ++ * Name : BpGetAdslDyingGaspExtIntr ++ * ++ * Description: This function returns the ADSL Dying Gasp external interrupt ++ * number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the ADSL Dying Gasp ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslDyingGaspExtIntr( unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulValue = g_pCurrentBp->usExtIntrAdslDyingGasp; ++ ++ if( g_pCurrentBp->usExtIntrAdslDyingGasp != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetAdslDyingGaspExtIntr */ ++ ++/************************************************************************** ++ * Name : BpGetVoipExtIntr ++ * ++ * Description: This function returns the VOIP external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the VOIP ++ * external interrupt number is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipExtIntr( unsigned char dspNum, unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ VOIP_DSP_INFO *pDspInfo = BpGetVoipDspConfig( dspNum ); ++ ++ if( pDspInfo ) ++ { ++ *pulValue = pDspInfo->usExtIntrVoip; ++ ++ if( *pulValue != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_FOUND; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetVoipExtIntr */ ++ ++/************************************************************************** ++ * Name : BpGetHpnaExtIntr ++ * ++ * Description: This function returns the HPNA external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the HPNA ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaExtIntr( unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulValue = g_pCurrentBp->usExtIntrHpna; ++ ++ if( g_pCurrentBp->usExtIntrHpna != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetHpnaExtIntr */ ++ ++/************************************************************************** ++ * Name : BpGetHpnaChipSelect ++ * ++ * Description: This function returns the HPNA chip select number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the HPNA ++ * chip select number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaChipSelect( unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ *pulValue = g_pCurrentBp->usCsHpna; ++ ++ if( g_pCurrentBp->usCsHpna != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetHpnaChipSelect */ ++ ++/************************************************************************** ++ * Name : BpGetVoipChipSelect ++ * ++ * Description: This function returns the VOIP chip select number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the VOIP ++ * chip select number is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipChipSelect( unsigned char dspNum, unsigned long *pulValue ) ++{ ++ int nRet; ++ ++ if( g_pCurrentBp ) ++ { ++ VOIP_DSP_INFO *pDspInfo = BpGetVoipDspConfig( dspNum ); ++ ++ if( pDspInfo ) ++ { ++ *pulValue = pDspInfo->usCsVoip; ++ ++ if( *pulValue != BP_NOT_DEFINED ) ++ { ++ nRet = BP_SUCCESS; ++ } ++ else ++ { ++ nRet = BP_VALUE_NOT_DEFINED; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_FOUND; ++ } ++ } ++ else ++ { ++ *pulValue = BP_NOT_DEFINED; ++ nRet = BP_BOARD_ID_NOT_SET; ++ } ++ ++ return( nRet ); ++} /* BpGetVoipChipSelect */ ++ +diff -urN linux-2.6.8.1/boardparams/bcm963xx/boardparms.h linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/boardparms.h +--- linux-2.6.8.1/boardparams/bcm963xx/boardparms.h 1970-01-01 01:00:00.000000000 +0100 ++++ linux-2.6.8.1-brcm63xx/boardparms/bcm963xx/boardparms.h 2006-06-26 09:07:10.000000000 +0200 +@@ -0,0 +1,766 @@ ++/* ++<:copyright-gpl ++ ++ Copyright 2003 Broadcom Corp. All Rights Reserved. ++ ++ This program is free software; you can distribute it and/or modify it ++ under the terms of the GNU General Public License (Version 2) as ++ published by the Free Software Foundation. ++ ++ This program is distributed in the hope it will be useful, but WITHOUT ++ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ for more details. ++ ++ You should have received a copy of the GNU General Public License along ++ with this program; if not, write to the Free Software Foundation, Inc., ++ 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. ++ ++:> ++*/ ++/************************************************************************** ++ * File Name : boardparms.h ++ * ++ * Description: This file contains definitions and function prototypes for ++ * the BCM63xx board parameter access functions. ++ * ++ * Updates : 07/14/2003 Created. ++ ***************************************************************************/ ++ ++#if !defined(_BOARDPARMS_H) ++#define _BOARDPARMS_H ++#define CONFIG_BCM96348 ++#if __cplusplus ++extern "C" { ++#endif ++ ++/* Return codes. */ ++#define BP_SUCCESS 0 ++#define BP_BOARD_ID_NOT_FOUND 1 ++#define BP_VALUE_NOT_DEFINED 2 ++#define BP_BOARD_ID_NOT_SET 3 ++ ++/* Values for BpGetSdramSize. */ ++#define BP_MEMORY_8MB_1_CHIP 0 ++#define BP_MEMORY_16MB_1_CHIP 1 ++#define BP_MEMORY_32MB_1_CHIP 2 ++#define BP_MEMORY_64MB_2_CHIP 3 ++#define BP_MEMORY_32MB_2_CHIP 4 ++#define BP_MEMORY_16MB_2_CHIP 5 ++ ++/* Values for EthernetMacInfo PhyType. */ ++#define BP_ENET_NO_PHY 0 ++#define BP_ENET_INTERNAL_PHY 1 ++#define BP_ENET_EXTERNAL_PHY 2 ++#define BP_ENET_EXTERNAL_SWITCH 3 ++ ++/* Values for EthernetMacInfo Configuration type. */ ++#define BP_ENET_CONFIG_MDIO 0 /* Internal PHY, External PHY, Switch+(no GPIO, no SPI, no MDIO Pseudo phy */ ++#define BP_ENET_CONFIG_GPIO 1 /* Bcm96345GW board + Bcm5325M/E */ ++#define BP_ENET_CONFIG_MDIO_PSEUDO_PHY 2 /* Bcm96348GW board + Bcm5325E */ ++#define BP_ENET_CONFIG_SPI_SSB_0 3 /* Bcm96348GW board + Bcm5325M/E */ ++#define BP_ENET_CONFIG_SPI_SSB_1 4 /* Bcm96348GW board + Bcm5325M/E */ ++#define BP_ENET_CONFIG_SPI_SSB_2 5 /* Bcm96348GW board + Bcm5325M/E */ ++#define BP_ENET_CONFIG_SPI_SSB_3 6 /* Bcm96348GW board + Bcm5325M/E */ ++ ++/* Values for EthernetMacInfo Reverse MII. */ ++#define BP_ENET_NO_REVERSE_MII 0 ++#define BP_ENET_REVERSE_MII 1 ++ ++/* Values for VoIPDSPInfo DSPType. */ ++#define BP_VOIP_NO_DSP 0 ++#define BP_VOIP_DSP 1 ++ ++ ++/* Values for GPIO pin assignments (AH = Active High, AL = Active Low). */ ++#define BP_ACTIVE_MASK 0x8000 ++#define BP_ACTIVE_HIGH 0x0000 ++#define BP_ACTIVE_LOW 0x8000 ++#define BP_GPIO_0_AH (0 | BP_ACTIVE_HIGH) ++#define BP_GPIO_0_AL (0 | BP_ACTIVE_LOW) ++#define BP_GPIO_1_AH (1 | BP_ACTIVE_HIGH) ++#define BP_GPIO_1_AL (1 | BP_ACTIVE_LOW) ++#define BP_GPIO_2_AH (2 | BP_ACTIVE_HIGH) ++#define BP_GPIO_2_AL (2 | BP_ACTIVE_LOW) ++#define BP_GPIO_3_AH (3 | BP_ACTIVE_HIGH) ++#define BP_GPIO_3_AL (3 | BP_ACTIVE_LOW) ++#define BP_GPIO_4_AH (4 | BP_ACTIVE_HIGH) ++#define BP_GPIO_4_AL (4 | BP_ACTIVE_LOW) ++#define BP_GPIO_5_AH (5 | BP_ACTIVE_HIGH) ++#define BP_GPIO_5_AL (5 | BP_ACTIVE_LOW) ++#define BP_GPIO_6_AH (6 | BP_ACTIVE_HIGH) ++#define BP_GPIO_6_AL (6 | BP_ACTIVE_LOW) ++#define BP_GPIO_7_AH (7 | BP_ACTIVE_HIGH) ++#define BP_GPIO_7_AL (7 | BP_ACTIVE_LOW) ++#define BP_GPIO_8_AH (8 | BP_ACTIVE_HIGH) ++#define BP_GPIO_8_AL (8 | BP_ACTIVE_LOW) ++#define BP_GPIO_9_AH (9 | BP_ACTIVE_HIGH) ++#define BP_GPIO_9_AL (9 | BP_ACTIVE_LOW) ++#define BP_GPIO_10_AH (10 | BP_ACTIVE_HIGH) ++#define BP_GPIO_10_AL (10 | BP_ACTIVE_LOW) ++#define BP_GPIO_11_AH (11 | BP_ACTIVE_HIGH) ++#define BP_GPIO_11_AL (11 | BP_ACTIVE_LOW) ++#define BP_GPIO_12_AH (12 | BP_ACTIVE_HIGH) ++#define BP_GPIO_12_AL (12 | BP_ACTIVE_LOW) ++#define BP_GPIO_13_AH (13 | BP_ACTIVE_HIGH) ++#define BP_GPIO_13_AL (13 | BP_ACTIVE_LOW) ++#define BP_GPIO_14_AH (14 | BP_ACTIVE_HIGH) ++#define BP_GPIO_14_AL (14 | BP_ACTIVE_LOW) ++#define BP_GPIO_15_AH (15 | BP_ACTIVE_HIGH) ++#define BP_GPIO_15_AL (15 | BP_ACTIVE_LOW) ++#define BP_GPIO_16_AH (16 | BP_ACTIVE_HIGH) ++#define BP_GPIO_16_AL (16 | BP_ACTIVE_LOW) ++#define BP_GPIO_17_AH (17 | BP_ACTIVE_HIGH) ++#define BP_GPIO_17_AL (17 | BP_ACTIVE_LOW) ++#define BP_GPIO_18_AH (18 | BP_ACTIVE_HIGH) ++#define BP_GPIO_18_AL (18 | BP_ACTIVE_LOW) ++#define BP_GPIO_19_AH (19 | BP_ACTIVE_HIGH) ++#define BP_GPIO_19_AL (19 | BP_ACTIVE_LOW) ++#define BP_GPIO_20_AH (20 | BP_ACTIVE_HIGH) ++#define BP_GPIO_20_AL (20 | BP_ACTIVE_LOW) ++#define BP_GPIO_21_AH (21 | BP_ACTIVE_HIGH) ++#define BP_GPIO_21_AL (21 | BP_ACTIVE_LOW) ++#define BP_GPIO_22_AH (22 | BP_ACTIVE_HIGH) ++#define BP_GPIO_22_AL (22 | BP_ACTIVE_LOW) ++#define BP_GPIO_23_AH (23 | BP_ACTIVE_HIGH) ++#define BP_GPIO_23_AL (23 | BP_ACTIVE_LOW) ++#define BP_GPIO_24_AH (24 | BP_ACTIVE_HIGH) ++#define BP_GPIO_24_AL (24 | BP_ACTIVE_LOW) ++#define BP_GPIO_25_AH (25 | BP_ACTIVE_HIGH) ++#define BP_GPIO_25_AL (25 | BP_ACTIVE_LOW) ++#define BP_GPIO_26_AH (26 | BP_ACTIVE_HIGH) ++#define BP_GPIO_26_AL (26 | BP_ACTIVE_LOW) ++#define BP_GPIO_27_AH (27 | BP_ACTIVE_HIGH) ++#define BP_GPIO_27_AL (27 | BP_ACTIVE_LOW) ++#define BP_GPIO_28_AH (28 | BP_ACTIVE_HIGH) ++#define BP_GPIO_28_AL (28 | BP_ACTIVE_LOW) ++#define BP_GPIO_29_AH (29 | BP_ACTIVE_HIGH) ++#define BP_GPIO_29_AL (29 | BP_ACTIVE_LOW) ++#define BP_GPIO_30_AH (30 | BP_ACTIVE_HIGH) ++#define BP_GPIO_30_AL (30 | BP_ACTIVE_LOW) ++#define BP_GPIO_31_AH (31 | BP_ACTIVE_HIGH) ++#define BP_GPIO_31_AL (31 | BP_ACTIVE_LOW) ++#define BP_GPIO_32_AH (32 | BP_ACTIVE_HIGH) ++#define BP_GPIO_32_AL (32 | BP_ACTIVE_LOW) ++#define BP_GPIO_33_AH (33 | BP_ACTIVE_HIGH) ++#define BP_GPIO_33_AL (33 | BP_ACTIVE_LOW) ++#define BP_GPIO_34_AH (34 | BP_ACTIVE_HIGH) ++#define BP_GPIO_34_AL (34 | BP_ACTIVE_LOW) ++#define BP_GPIO_35_AH (35 | BP_ACTIVE_HIGH) ++#define BP_GPIO_35_AL (35 | BP_ACTIVE_LOW) ++#define BP_GPIO_36_AH (36 | BP_ACTIVE_HIGH) ++#define BP_GPIO_36_AL (36 | BP_ACTIVE_LOW) ++ ++/* Values for external interrupt assignments. */ ++#define BP_EXT_INTR_0 0 ++#define BP_EXT_INTR_1 1 ++#define BP_EXT_INTR_2 2 ++#define BP_EXT_INTR_3 3 ++ ++/* Values for chip select assignments. */ ++#define BP_CS_0 0 ++#define BP_CS_1 1 ++#define BP_CS_2 2 ++#define BP_CS_3 3 ++ ++/* Value for GPIO and external interrupt fields that are not used. */ ++#define BP_NOT_DEFINED 0xffff ++#define BP_HW_DEFINED 0xfff0 ++#define BP_UNEQUIPPED 0xfff1 ++ ++/* Maximum size of the board id string. */ ++#define BP_BOARD_ID_LEN 16 ++ ++/* Maximum number of Ethernet MACs. */ ++#define BP_MAX_ENET_MACS 2 ++ ++/* Maximum number of VoIP DSPs. */ ++#define BP_MAX_VOIP_DSP 2 ++ ++/* Wireless Antenna Settings. */ ++#define BP_WLAN_ANT_MAIN 0 ++#define BP_WLAN_ANT_AUX 1 ++#define BP_WLAN_ANT_BOTH 3 ++ ++#if !defined(__ASSEMBLER__) ++ ++/* Information about an Ethernet MAC. If ucPhyType is BP_ENET_NO_PHY, ++ * then the other fields are not valid. ++ */ ++typedef struct EthernetMacInfo ++{ ++ unsigned char ucPhyType; /* BP_ENET_xxx */ ++ unsigned char ucPhyAddress; /* 0 to 31 */ ++ unsigned short usGpioPhySpiSck; /* GPIO pin or not defined */ ++ unsigned short usGpioPhySpiSs; /* GPIO pin or not defined */ ++ unsigned short usGpioPhySpiMosi; /* GPIO pin or not defined */ ++ unsigned short usGpioPhySpiMiso; /* GPIO pin or not defined */ ++ unsigned short usGpioPhyReset; /* GPIO pin or not defined (96348LV) */ ++ unsigned short numSwitchPorts; /* Number of PHY ports */ ++ unsigned short usConfigType; /* Configuration type */ ++ unsigned short usReverseMii; /* Reverse MII */ ++} ETHERNET_MAC_INFO, *PETHERNET_MAC_INFO; ++ ++ ++/* Information about VoIP DSPs. If ucDspType is BP_VOIP_NO_DSP, ++ * then the other fields are not valid. ++ */ ++typedef struct VoIPDspInfo ++{ ++ unsigned char ucDspType; ++ unsigned char ucDspAddress; ++ unsigned short usExtIntrVoip; ++ unsigned short usGpioVoipReset; ++ unsigned short usGpioVoipIntr; ++ unsigned short usGpioLedVoip; ++ unsigned short usCsVoip; ++ ++} VOIP_DSP_INFO; ++ ++ ++/************************************************************************** ++ * Name : BpSetBoardId ++ * ++ * Description: This function find the BOARD_PARAMETERS structure for the ++ * specified board id string and assigns it to a global, static ++ * variable. ++ * ++ * Parameters : [IN] pszBoardId - Board id string that is saved into NVRAM. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_FOUND - Error, board id input string does not ++ * have a board parameters configuration record. ++ ***************************************************************************/ ++int BpSetBoardId( char *pszBoardId ); ++ ++/************************************************************************** ++ * Name : BpGetBoardIds ++ * ++ * Description: This function returns all of the supported board id strings. ++ * ++ * Parameters : [OUT] pszBoardIds - Address of a buffer that the board id ++ * strings are returned in. Each id starts at BP_BOARD_ID_LEN ++ * boundary. ++ * [IN] nBoardIdsSize - Number of BP_BOARD_ID_LEN elements that ++ * were allocated in pszBoardIds. ++ * ++ * Returns : Number of board id strings returned. ++ ***************************************************************************/ ++int BpGetBoardIds( char *pszBoardIds, int nBoardIdsSize ); ++ ++/************************************************************************** ++ * Name : BpGetEthernetMacInfo ++ * ++ * Description: This function returns all of the supported board id strings. ++ * ++ * Parameters : [OUT] pEnetInfos - Address of an array of ETHERNET_MAC_INFO ++ * buffers. ++ * [IN] nNumEnetInfos - Number of ETHERNET_MAC_INFO elements that ++ * are pointed to by pEnetInfos. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetEthernetMacInfo( PETHERNET_MAC_INFO pEnetInfos, int nNumEnetInfos ); ++ ++/************************************************************************** ++ * Name : BpGetSdramSize ++ * ++ * Description: This function returns a constant that describees the board's ++ * SDRAM type and size. ++ * ++ * Parameters : [OUT] pulSdramSize - Address of short word that the SDRAM size ++ * is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetSdramSize( unsigned long *pulSdramSize ); ++ ++/************************************************************************** ++ * Name : BpGetPsiSize ++ * ++ * Description: This function returns the persistent storage size in K bytes. ++ * ++ * Parameters : [OUT] pulPsiSize - Address of short word that the persistent ++ * storage size is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ ***************************************************************************/ ++int BpGetPsiSize( unsigned long *pulPsiSize ); ++ ++/************************************************************************** ++ * Name : BpGetRj11InnerOuterPairGpios ++ * ++ * Description: This function returns the GPIO pin assignments for changing ++ * between the RJ11 inner pair and RJ11 outer pair. ++ * ++ * Parameters : [OUT] pusInner - Address of short word that the RJ11 inner pair ++ * GPIO pin is returned in. ++ * [OUT] pusOuter - Address of short word that the RJ11 outer pair ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, values are returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetRj11InnerOuterPairGpios( unsigned short *pusInner, ++ unsigned short *pusOuter ); ++ ++/************************************************************************** ++ * Name : BpGetPressAndHoldResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the press ++ * and hold reset button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the press and hold ++ * reset button GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPressAndHoldResetGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetVoipResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the VOIP ++ * Reset operation. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP reset ++ * GPIO pin is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipResetGpio( unsigned char dspNum, unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetVoipIntrGpio ++ * ++ * Description: This function returns the GPIO pin assignment for VoIP interrupt. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP interrupt ++ * GPIO pin is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipIntrGpio( unsigned char dspNum, unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetPcmciaResetGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PCMCIA ++ * Reset operation. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PCMCIA reset ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPcmciaResetGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetUartRtsCtsGpios ++ * ++ * Description: This function returns the GPIO pin assignments for RTS and CTS ++ * UART signals. ++ * ++ * Parameters : [OUT] pusRts - Address of short word that the UART RTS GPIO ++ * pin is returned in. ++ * [OUT] pusCts - Address of short word that the UART CTS GPIO ++ * pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, values are returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetRtsCtsUartGpios( unsigned short *pusRts, unsigned short *pusCts ); ++ ++/************************************************************************** ++ * Name : BpGetAdslLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the ADSL ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the ADSL LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetAdslFailLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the ADSL ++ * LED that is used when there is a DSL connection failure. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the ADSL LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslFailLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessAntInUse ++ * ++ * Description: This function returns the antennas in use for wireless ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Antenna ++ * is in use. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessAntInUse( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesBtnGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * Ses Button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Ses ++ * Button GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesBtnGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesExtIntr ++ * ++ * Description: This function returns the external interrupt number for the ++ * Wireless Ses Button. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Ses ++ * external interrup is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesExtIntr( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessSesLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the Wireless ++ * Ses Led. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the Wireless Ses ++ * Led GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessSesLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetUsbLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the USB ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the USB LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetUsbLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetHpnaLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the HPNA ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the HPNA LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWanDataLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the WAN Data ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the WAN Data LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWanDataLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetPppLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PPP ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PPP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPppLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetPppFailLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the PPP ++ * LED that is used when there is a PPP connection failure. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the PPP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetPppFailLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetVoipLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the VOIP ++ * LED. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the VOIP LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetBootloaderPowerOnLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the power ++ * on LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the alarm LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderPowerOnLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetBootloaderAlarmLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the alarm ++ * LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the alarm LED ++ * GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderAlarmLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetBootloaderResetCfgLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the reset ++ * configuration LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the reset ++ * configuration LED GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderResetCfgLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetBootloaderStopLedGpio ++ * ++ * Description: This function returns the GPIO pin assignment for the break ++ * into bootloader LED that is set by the bootloader. ++ * ++ * Parameters : [OUT] pusValue - Address of short word that the break into ++ * bootloader LED GPIO pin is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetBootloaderStopLedGpio( unsigned short *pusValue ); ++ ++/************************************************************************** ++ * Name : BpGetWirelessExtIntr ++ * ++ * Description: This function returns the Wireless external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the wireless ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetWirelessExtIntr( unsigned long *pulValue ); ++ ++/************************************************************************** ++ * Name : BpGetAdslDyingGaspExtIntr ++ * ++ * Description: This function returns the ADSL Dying Gasp external interrupt ++ * number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the ADSL Dying Gasp ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetAdslDyingGaspExtIntr( unsigned long *pulValue ); ++ ++/************************************************************************** ++ * Name : BpGetVoipExtIntr ++ * ++ * Description: This function returns the VOIP external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the VOIP ++ * external interrupt number is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipExtIntr( unsigned char dspNum, unsigned long *pulValue ); ++ ++/************************************************************************** ++ * Name : BpGetHpnaExtIntr ++ * ++ * Description: This function returns the HPNA external interrupt number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the HPNA ++ * external interrupt number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaExtIntr( unsigned long *pulValue ); ++ ++/************************************************************************** ++ * Name : BpGetHpnaChipSelect ++ * ++ * Description: This function returns the HPNA chip select number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the HPNA ++ * chip select number is returned in. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetHpnaChipSelect( unsigned long *pulValue ); ++ ++/************************************************************************** ++ * Name : BpGetVoipChipSelect ++ * ++ * Description: This function returns the VOIP chip select number. ++ * ++ * Parameters : [OUT] pulValue - Address of short word that the VOIP ++ * chip select number is returned in. ++ * [IN] dspNum - Address of the DSP to query. ++ * ++ * Returns : BP_SUCCESS - Success, value is returned. ++ * BP_BOARD_ID_NOT_SET - Error, BpSetBoardId has not been called. ++ * BP_VALUE_NOT_DEFINED - At least one return value is not defined ++ * for the board. ++ ***************************************************************************/ ++int BpGetVoipChipSelect( unsigned char dspNum, unsigned long *pulValue ); ++ ++#endif /* __ASSEMBLER__ */ ++ ++#if __cplusplus ++} ++#endif ++ ++#endif /* _BOARDPARMS_H */ ++ +--- linux-2.6.8.1/scripts/kconfig/mconf.c 2004-08-14 12:54:51.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/scripts/kconfig/mconf.c 2006-06-26 10:07:52.000000000 +0200 +@@ -88,7 +88,7 @@ + static int indent; + static struct termios ios_org; + static int rows = 0, cols = 0; +-static struct menu *current_menu; ++struct menu *current_menu; /* Fails while cross-compiling if keeping static */ + static int child_count; + static int do_resize; + static int single_menu_mode; +--- linux-2.6.8.1/Makefile 2004-08-14 12:55:35.000000000 +0200 ++++ linux-2.6.8.1-brcm63xx/Makefile 2006-06-26 10:43:09.000000000 +0200 +@@ -149,9 +149,7 @@ + # then ARCH is assigned, getting whatever value it gets normally, and + # SUBARCH is subsequently ignored. + +-SUBARCH := $(shell uname -m | sed -e s/i.86/i386/ -e s/sun4u/sparc64/ \ +- -e s/arm.*/arm/ -e s/sa110/arm/ \ +- -e s/s390x/s390/ -e s/parisc64/parisc/ ) ++SUBARCH := mips + + # Cross compiling and selecting different set of gcc/bin-utils + # --------------------------------------------------------------------------- +@@ -294,7 +292,7 @@ + + NOSTDINC_FLAGS = -nostdinc -iwithprefix include + +-CPPFLAGS := -D__KERNEL__ -Iinclude \ ++CPPFLAGS := -D__KERNEL__ -Iinclude -Ibcmdrivers/opensource/include/bcm963xx/ -Iboardparms/bcm963xx/ -Ibcmdrivers/broadcom/include/bcm963xx/ -Ibcmdrivers/broadcom/char/adsl/bcm96348\ + $(if $(KBUILD_SRC),-Iinclude2 -I$(srctree)/include) + + CFLAGS := -Wall -Wstrict-prototypes -Wno-trigraphs \ +@@ -405,6 +403,13 @@ + core-y := usr/ + endif # KBUILD_EXTMOD + ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++BRCMDRIVERS_DIR := $(TOPDIR)/bcmdrivers ++export HPATH := $(TOPDIR)/include ++brcmdrivers-y := $(TOPDIR)/boardparms/bcm963xx/ $(BRCMDRIVERS_DIR)/ ++BRCMDRIVERS := $(brcmdrivers-y) ++# CONFIG_MIPS_BRCM End Broadcom changed code. ++ + ifeq ($(dot-config),1) + # In this section, we need .config + +@@ -473,6 +478,10 @@ + # makefile but the arguement can be passed to make if needed. + # + ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++INSTALL_MOD_PATH := $(PROFILE_DIR)/modules ++# CONFIG_MIPS_BRCM End Broadcom changed code. ++ + MODLIB := $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE) + export MODLIB + +@@ -480,18 +489,25 @@ + ifeq ($(KBUILD_EXTMOD),) + core-y += kernel/ mm/ fs/ ipc/ security/ crypto/ + ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. + vmlinux-dirs := $(patsubst %/,%,$(filter %/, $(init-y) $(init-m) \ + $(core-y) $(core-m) $(drivers-y) $(drivers-m) \ ++ $(brcmdrivers-y) $(brcmdrivers-m) \ + $(net-y) $(net-m) $(libs-y) $(libs-m))) + + vmlinux-alldirs := $(sort $(vmlinux-dirs) $(patsubst %/,%,$(filter %/, \ + $(init-n) $(init-) \ + $(core-n) $(core-) $(drivers-n) $(drivers-) \ ++ $(brcmdrivers-n) $(brcmdrivers-) \ + $(net-n) $(net-) $(libs-n) $(libs-)))) ++# CONFIG_MIPS_BRCM End Broadcom changed code. + + init-y := $(patsubst %/, %/built-in.o, $(init-y)) + core-y := $(patsubst %/, %/built-in.o, $(core-y)) + drivers-y := $(patsubst %/, %/built-in.o, $(drivers-y)) ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++brcmdrivers-y := $(patsubst %/, %/built-in.o, $(brcmdrivers-y)) ++# CONFIG_MIPS_BRCM End Broadcom changed code. + net-y := $(patsubst %/, %/built-in.o, $(net-y)) + libs-y1 := $(patsubst %/, %/lib.a, $(libs-y)) + libs-y2 := $(patsubst %/, %/built-in.o, $(libs-y)) +@@ -507,7 +523,8 @@ + # we cannot yet know if we will need to relink vmlinux. + # So we descend into init/ inside the rule for vmlinux again. + head-y += $(HEAD) +-vmlinux-objs := $(head-y) $(init-y) $(core-y) $(libs-y) $(drivers-y) $(net-y) ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++vmlinux-objs := $(head-y) $(init-y) $(core-y) $(libs-y) $(drivers-y) $(brcmdrivers-y) $(net-y) + + quiet_cmd_vmlinux__ = LD $@ + define cmd_vmlinux__ +@@ -516,11 +533,13 @@ + $(core-y) \ + $(libs-y) \ + $(drivers-y) \ ++ $(brcmdrivers-y) \ + $(net-y) \ + --end-group \ + $(filter .tmp_kallsyms%,$^) \ + -o $@ + endef ++# CONFIG_MIPS_BRCM End Broadcom changed code. + + # set -e makes the rule exit immediately on error + +@@ -603,9 +622,12 @@ + $(rule_verify_kallsyms) + endef + +-vmlinux: $(vmlinux-objs) $(kallsyms.o) arch/$(ARCH)/kernel/vmlinux.lds.s FORCE ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++vmlinux: preparebrcmdriver $(vmlinux-objs) $(kallsyms.o) arch/$(ARCH)/kernel/vmlinux.lds.s FORCE + $(call if_changed_rule,vmlinux) + ++# CONFIG_MIPS_BRCM End Broadcom changed code. ++ + # The actual objects are generated when descending, + # make sure no implicit rule kicks in + +@@ -626,7 +648,13 @@ + # A multi level approach is used. prepare1 is updated first, then prepare0. + # prepare-all is the collection point for the prepare targets. + +-.PHONY: prepare-all prepare prepare0 prepare1 prepare2 ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++.PHONY: prepare-all prepare prepare0 prepare1 prepare2 preparebrcmdriver ++ ++preparebrcmdriver: ++# $(Q)$(MAKE) -C $(BRCMDRIVERS_DIR)/opensource symlinks ++ $(Q)$(MAKE) -C $(BRCMDRIVERS_DIR)/broadcom symlinks ++# CONFIG_MIPS_BRCM End Broadcom changed code. + + # prepare 2 generate Makefile to be placed in output directory, if + # using a seperate output directory. This allows convinient use +@@ -743,7 +771,10 @@ + # Build modules + + .PHONY: modules +-modules: $(vmlinux-dirs) $(if $(KBUILD_BUILTIN),vmlinux) ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++modules: preparebrcmdriver $(vmlinux-dirs) $(if $(KBUILD_BUILTIN),vmlinux) ++#modules: $(vmlinux-dirs) $(if $(KBUILD_BUILTIN),vmlinux) ++# CONFIG_MIPS_BRCM End Broadcom changed code. + @echo ' Building modules, stage 2.'; + $(Q)$(MAKE) -rR -f $(srctree)/scripts/Makefile.modpost + +@@ -754,23 +785,31 @@ + + # Target to install modules + .PHONY: modules_install +-modules_install: _modinst_ _modinst_post ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++#modules_install: _modinst_ _modinst_post ++#We have no need for it "_modinst_post" ++modules_install: _modinst_ ++# CONFIG_MIPS_BRCM End Broadcom changed code. + + .PHONY: _modinst_ + _modinst_: +- @if [ -z "`$(DEPMOD) -V | grep module-init-tools`" ]; then \ +- echo "Warning: you may need to install module-init-tools"; \ +- echo "See http://www.codemonkey.org.uk/docs/post-halloween-2.6.txt";\ +- sleep 1; \ +- fi ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. ++# @if [ -z "`$(DEPMOD) -V | grep module-init-tools`" ]; then \ ++# echo "Warning: you may need to install module-init-tools"; \ ++# echo "See http://www.codemonkey.org.uk/docs/post-halloween-2.6.txt";\ ++# sleep 1; \ ++# fi ++# CONFIG_MIPS_BRCM End Broadcom changed code. + @rm -rf $(MODLIB)/kernel + @rm -f $(MODLIB)/source + @mkdir -p $(MODLIB)/kernel +- @ln -s $(srctree) $(MODLIB)/source +- @if [ ! $(objtree) -ef $(MODLIB)/build ]; then \ +- rm -f $(MODLIB)/build ; \ +- ln -s $(objtree) $(MODLIB)/build ; \ +- fi ++# CONFIG_MIPS_BRCM Begin Broadcom changed code ++# @ln -s $(srctree) $(MODLIB)/source ++# @if [ ! $(objtree) -ef $(MODLIB)/build ]; then \ ++# rm -f $(MODLIB)/build ; \ ++# ln -s $(objtree) $(MODLIB)/build ; \ ++# fi ++# CONFIG_MIPS_BRCM End Broadcom changed code. + $(Q)$(MAKE) -rR -f $(srctree)/scripts/Makefile.modinst + + # If System.map exists, run depmod. This deliberately does not have a +@@ -853,10 +892,12 @@ + clean: archclean $(clean-dirs) + $(call cmd,rmdirs) + $(call cmd,rmfiles) ++# CONFIG_MIPS_BRCM Begin Broadcom changed code. + @find . $(RCS_FIND_IGNORE) \ + \( -name '*.[oas]' -o -name '*.ko' -o -name '.*.cmd' \ + -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \) \ + -type f -print | xargs rm -f ++# CONFIG_MIPS_BRCM End Broadcom changed code. + + # mrproper - Delete all generated files, including .config + # +@@ -883,7 +924,7 @@ + -o -name '.*.rej' -o -size 0 \ + -o -name '*%' -o -name '.*.cmd' -o -name 'core' \) \ + -type f -print | xargs rm -f +- ++ rm vmlinux.bin vmlinux.lz + + # Packaging of the kernel to various formats + # --------------------------------------------------------------------------- -- 2.25.1