summaryrefslogtreecommitdiffstats
path: root/qemu/roms/SLOF/lib/libbcm
diff options
context:
space:
mode:
Diffstat (limited to 'qemu/roms/SLOF/lib/libbcm')
-rw-r--r--qemu/roms/SLOF/lib/libbcm/Makefile53
-rw-r--r--qemu/roms/SLOF/lib/libbcm/bcm.code57
-rw-r--r--qemu/roms/SLOF/lib/libbcm/bcm.in20
-rw-r--r--qemu/roms/SLOF/lib/libbcm/bcm57xx.c3461
-rw-r--r--qemu/roms/SLOF/lib/libbcm/bcm57xx.h323
5 files changed, 0 insertions, 3914 deletions
diff --git a/qemu/roms/SLOF/lib/libbcm/Makefile b/qemu/roms/SLOF/lib/libbcm/Makefile
deleted file mode 100644
index 1aead4c5e..000000000
--- a/qemu/roms/SLOF/lib/libbcm/Makefile
+++ /dev/null
@@ -1,53 +0,0 @@
-# *****************************************************************************
-# * Copyright (c) 2004, 2008, 2013 IBM Corporation
-# * All rights reserved.
-# * This program and the accompanying materials
-# * are made available under the terms of the BSD License
-# * which accompanies this distribution, and is available at
-# * http://www.opensource.org/licenses/bsd-license.php
-# *
-# * Contributors:
-# * IBM Corporation - initial implementation
-# ****************************************************************************/
-
-TOPCMNDIR ?= ../..
-
-include $(TOPCMNDIR)/make.rules
-
-CPPFLAGS = -I../libc/include $(CPUARCHDEF) -I$(INCLBRDDIR) \
- -I$(INCLCMNDIR) -I$(INCLCMNDIR)/$(CPUARCH)
-
-#CFLAGS += -O2 -I. -I../common -I$(TOP)/clients/net-snk/include -I$(TOP)/lib/libc/include -fno-builtin -ffreestanding -msoft-float -Wall -nostdinc
-
-LDFLAGS = -nostdlib
-
-TARGET = ../libbcm.a
-
-
-all: $(TARGET) Makefile.dep
-
-SRCS = bcm57xx.c
-
-OBJS = $(SRCS:%.c=%.o)
-
-$(TARGET): $(OBJS)
- $(AR) -rc $@ $(OBJS)
- $(RANLIB) $@
-
-clean:
- $(RM) $(TARGET) $(OBJS)
-
-distclean: clean
- $(RM) Makefile.dep
-
-
-# Rules for creating the dependency file:
-depend:
- $(RM) Makefile.dep
- $(MAKE) Makefile.dep
-
-Makefile.dep: Makefile
- $(CC) -M $(CPPFLAGS) $(CFLAGS) $(SRCS) $(SRCSS) > Makefile.dep
-
-# Include dependency file if available:
--include Makefile.dep
diff --git a/qemu/roms/SLOF/lib/libbcm/bcm.code b/qemu/roms/SLOF/lib/libbcm/bcm.code
deleted file mode 100644
index 308ebbaa2..000000000
--- a/qemu/roms/SLOF/lib/libbcm/bcm.code
+++ /dev/null
@@ -1,57 +0,0 @@
-/******************************************************************************
- * Copyright (c) 2013 IBM Corporation
- * All rights reserved.
- * This program and the accompanying materials
- * are made available under the terms of the BSD License
- * which accompanies this distribution, and is available at
- * http://www.opensource.org/licenses/bsd-license.php
- *
- * Contributors:
- * IBM Corporation - initial implementation
- *****************************************************************************/
-
-/*
- * libbcm Forth wrapper
- */
-
-#include <bcm57xx.h>
-
-// : bcm57xx-open ( -- false | [ driver true ] )
-PRIM(BCM57XX_X2d_OPEN)
-{
- net_driver_t *net_driver = bcm57xx_open();
- if (net_driver) {
- PUSH;
- TOS.u = (unsigned long)net_driver; PUSH;
- TOS.n = -1;
- } else {
- PUSH;
- TOS.n = 0;
- }
-}
-MIRP
-
-// : bcm57xx-close ( driver -- )
-PRIM(BCM57XX_X2d_CLOSE)
-{
- net_driver_t *driver = TOS.a; POP;
- bcm57xx_close(driver);
-}
-MIRP
-
-
-// : bcm57xx-read ( addr len -- actual )
-PRIM(BCM57XX_X2d_READ)
-{
- int len = TOS.u; POP;
- TOS.n = bcm57xx_read(TOS.a, len);
-}
-MIRP
-
-// : bcm57xx-write ( addr len -- actual )
-PRIM(BCM57XX_X2d_WRITE)
-{
- int len = TOS.u; POP;
- TOS.n = bcm57xx_write(TOS.a, len);
-}
-MIRP
diff --git a/qemu/roms/SLOF/lib/libbcm/bcm.in b/qemu/roms/SLOF/lib/libbcm/bcm.in
deleted file mode 100644
index ee50a6e65..000000000
--- a/qemu/roms/SLOF/lib/libbcm/bcm.in
+++ /dev/null
@@ -1,20 +0,0 @@
-/******************************************************************************
- * Copyright (c) 2013 IBM Corporation
- * All rights reserved.
- * This program and the accompanying materials
- * are made available under the terms of the BSD License
- * which accompanies this distribution, and is available at
- * http://www.opensource.org/licenses/bsd-license.php
- *
- * Contributors:
- * IBM Corporation - initial implementation
- *****************************************************************************/
-
-/*
- * libbcm bindings for Forth - definitions
- */
-
-cod(BCM57XX-OPEN)
-cod(BCM57XX-CLOSE)
-cod(BCM57XX-READ)
-cod(BCM57XX-WRITE)
diff --git a/qemu/roms/SLOF/lib/libbcm/bcm57xx.c b/qemu/roms/SLOF/lib/libbcm/bcm57xx.c
deleted file mode 100644
index 2ecb517f1..000000000
--- a/qemu/roms/SLOF/lib/libbcm/bcm57xx.c
+++ /dev/null
@@ -1,3461 +0,0 @@
-/******************************************************************************
- * Copyright (c) 2004, 2008 IBM Corporation
- * All rights reserved.
- * This program and the accompanying materials
- * are made available under the terms of the BSD License
- * which accompanies this distribution, and is available at
- * http://www.opensource.org/licenses/bsd-license.php
- *
- * Contributors:
- * IBM Corporation - initial implementation
- *****************************************************************************/
-
-/*
- *
- ******************************************************************************
- * reference:
- * Broadcom 57xx
- * Host Programmer Interface Specification for the
- * NetXtreme Family of Highly-Integrated Media Access Controlers
- */
-#include <stdint.h>
-#include <stdio.h>
-#include <string.h>
-#include <byteorder.h>
-#include <helpers.h>
-#include <netdriver.h>
-#include "bcm57xx.h"
-
-/*
- * local defines
- ******************************************************************************
- */
-
-
-// #define BCM_VLAN_TAG ( (uint32_t) 0x1 )
-
-// number of tx/rx rings
-// NOTE: 5714 only uses 1 rx/tx ring, but memory
-// for the other rings is cleaned anyways for
-// sanity & future use
-#define BCM_MAX_TX_RING 16
-#define BCM_MAX_RXRET_RING 16
-#define BCM_MAX_RXPROD_RCB 3
-
-// bd descriptions
-#define BCM_RXPROD_RING_SIZE 512 // don't change
-#define BCM_RXRET_RING_SIZE 512 // don't change
-#define BCM_TX_RING_SIZE 512 // don't change
-#define BCM_BUF_SIZE 1536 // don't change
-#define BCM_MTU_MAX_LEN 1522
-#define BCM_MAX_RX_BUF 64
-#define BCM_MAX_TX_BUF 16
-
-// number of MAC addresses in NIC
-#define BCM_NUM_MAC_ADDR 4
-#define BCM_NUM_MAC5704_ADDR 12
-// offset of mac address field(s) in bcm register space
-#define MAC5704_ADDR_OFFS ( (uint16_t) 0x0530 )
-
-// offset of NIC memory start address from base address
-#define BCM_MEMORY_OFFS ( (uint64_t) 0x8000 )
-
-// offset of statistics block in NIC memory
-#define BCM_STATISTIC_OFFS ( (uint64_t) 0x0300 )
-// size of statistic block in NIC memory
-#define BCM_STATISTIC_SIZE 0x800
-
-// offsets of NIC rx/tx rings in NIC memory
-#define BCM_NIC_TX_OFFS ( (uint16_t) 0x4000 )
-#define BCM_NIC_RX_OFFS ( (uint16_t) 0x6000 )
-#define BCM_NIC_TX_SIZE ( (uint16_t) ( ( BCM_TX_RING_SIZE * BCM_RCB_SIZE_u16 ) / 4 ) )
-
-// device mailboxes
-#define BCM_FW_MBX ( (uint16_t) 0x0b50 )
-#define BCM_FW_MBX_CMD ( (uint16_t) 0x0b78 )
-#define BCM_FW_MBX_LEN ( (uint16_t) 0x0b7c )
-#define BCM_FW_MBX_DATA ( (uint16_t) 0x0b80 )
-#define BCM_NICDRV_STATE_MBX ( (uint16_t) 0x0c04 )
-
-// device mailbox commands
-#define BCM_NICDRV_ALIVE ( (uint32_t) 0x00000001 )
-#define BCM_NICDRV_PAUSE_FW ( (uint32_t) 0x00000002 )
-
-// device values
-#define BCM_MAGIC_NUMBER ( (uint32_t) 0x4b657654 )
-
-// device states
-#define NIC_FWDRV_STATE_START ( (uint32_t) 0x00000001 )
-#define NIC_FWDRV_STATE_START_DONE ( (uint32_t) 0x80000001 )
-#define NIC_FWDRV_STATE_UNLOAD ( (uint32_t) 0x00000002 )
-#define NIC_FWDRV_STATE_UNLOAD_DONE ( (uint32_t) 0x80000002 )
-#define NIC_FWDRV_STATE_SUSPEND ( (uint32_t) 0x00000004 )
-
-// timer prescaler value
-#define BCM_TMR_PRESCALE ( (uint32_t) 0x41 )
-
-// offset of transmit rcb's in NIC memory
-#define BCM_TX_RCB_OFFS ( (uint16_t) 0x0100 )
-// offset of receive return rcb's in NIC memory
-#define BCM_RXRET_RCB_OFFS ( (uint16_t) 0x0200 )
-
-// register offsets for ring indices
-#define TX_PROD_IND ( (uint16_t) 0x0304 )
-#define TX_CONS_IND ( (uint16_t) 0x3cc0 )
-#define RXPROD_PROD_IND ( (uint16_t) 0x026c )
-#define RXPROD_CONS_IND ( (uint16_t) 0x3c54 )
-#define RXRET_PROD_IND ( (uint16_t) 0x3c80 )
-#define RXRET_CONS_IND ( (uint16_t) 0x0284 )
-// NIC producer index only needed for initialization
-#define TX_NIC_PROD_IND ( (uint16_t) 0x0384 )
-
-/*
- * predefined register values used during initialization
- * may be adapted by user
- */
-#define DMA_RW_CTRL_VAL_5714 ( (uint32_t) 0x76144000 )
-#define DMA_RW_CTRL_VAL ( (uint32_t) 0x760F0000 )
-#define TX_MAC_LEN_VAL ( (uint32_t) 0x00002620 )
-
-#define RX_LST_PLC_CFG_VAL ( (uint32_t) 0x00000109 )
-#define RX_LST_PLC_STAT_EN_VAL ( (uint32_t) 0x007e000f )
-#define NVM_ADDR_MSK ( (uint32_t) 0x000fffff )
-
-// Number of Receive Rules /w or /wo SOL enabled
-#define RX_RULE_CFG_VAL ( (uint32_t) 0x00000008 )
-#define NUM_RX_RULE ( (uint32_t) 16 )
-#define NUM_RX_RULE_ASF ( (uint32_t) ( NUM_RX_RULE - 4 ) )
-
-// RCB register offsets
-#define BCM_RXPROD_RCB_JUM ( (uint16_t) 0x2440 )
-#define BCM_RXPROD_RCB_STD ( (uint16_t) 0x2450 )
-#define BCM_RXPROD_RCB_MIN ( (uint16_t) 0x2460 )
-
-// macros needed for new addressing method
-#define BCM_RCB_HOSTADDR_HI_u16( rcb ) ( (uint16_t) rcb + 0x00 )
-#define BCM_RCB_HOSTADDR_LOW_u16( rcb ) ( (uint16_t) rcb + 0x04 )
-#define BCM_RCB_LENFLAG_u16( rcb ) ( (uint16_t) rcb + 0x08 )
-#define BCM_RCB_NICADDR_u16( rcb ) ( (uint16_t) rcb + 0x0c )
-#define BCM_RCB_SIZE_u16 ( (uint16_t) 0x0010 )
-
-// RCB flags
-#define RCB_FLAG_RING_DISABLED BIT32( 1 )
-
-// BCM device ID masks
-#define BCM_DEV_5714 ( (uint64_t) 0x1 )
-#define BCM_DEV_5704 ( (uint64_t) 0x2 )
-#define BCM_DEV_5703 ( (uint64_t) 0x4 )
-#define BCM_DEV_SERDES ( (uint64_t) 0x80000000 )
-#define BCM_DEV_COPPER ( (uint64_t) 0x40000000 )
-
-#define IS_5714 ( ( bcm_device_u64 & BCM_DEV_5714 ) != 0 )
-#define IS_5704 ( ( bcm_device_u64 & BCM_DEV_5704 ) != 0 )
-#define IS_5703 ( ( bcm_device_u64 & BCM_DEV_5703 ) != 0 )
-#define IS_SERDES ( ( bcm_device_u64 & BCM_DEV_SERDES ) != 0 )
-#define IS_COPPER_PHY ( ( bcm_device_u64 & BCM_DEV_COPPER ) != 0 )
-
-#define BUFFERED_FLASH_PAGE_POS 9
-#define BUFFERED_FLASH_BYTE_ADDR_MASK ((<<BUFFERED_FLASH_PAGE_POS) - 1)
-#define BUFFERED_FLASH_PAGE_SIZE 264
-#define BUFFERED_FLASH_PHY_SIZE 512
-#define MANUFACTURING_INFO_SIZE 140
-#define CRC32_POLYNOMIAL 0xEDB88320
-
-/*
- * local types
- ******************************************************************************
- */
-typedef struct {
- uint32_t m_dev_u32;
- uint64_t m_devmsk_u64;
-} bcm_dev_t;
-
-/*
- * BCM common data structures
- * BCM57xx Programmer's Guide: Section 5
- */
-
-/*
- * 64bit host address in a way the NIC is able to understand it
- */
-typedef struct {
- uint32_t m_hi_u32;
- uint32_t m_lo_u32;
-} bcm_addr64_t;
-/*
- * ring control block
- */
-typedef struct {
- bcm_addr64_t m_hostaddr_st;
- uint32_t m_lenflags_u32; // upper 16b: len, lower 16b: flags
- uint32_t m_nicaddr_u32;
-} bcm_rcb_t;
-
-/*
- * tx buffer descriptor
- */
-typedef struct {
- bcm_addr64_t m_hostaddr_st;
- uint32_t m_lenflags_u32; // upper 16b: len, lower 16b: flags
- uint32_t m_VLANtag_u32; // lower 16b: vtag
-} bcm_txbd_t;
-
-/*
- * rx buffer descriptor
- */
-typedef struct {
- bcm_addr64_t m_hostaddr_st;
- uint32_t m_idxlen_u32; // upper 16b: idx, lower 16b: len
- uint32_t m_typeflags_u32; // upper 16b: type, lower 16b: flags
- uint32_t m_chksum_u32; // upper 16b: ip, lower 16b: tcp/udp
- uint32_t m_errvlan_u32; // upper 16b: err, lower 16b: vlan tag
- uint32_t m_reserved_u32;
- uint32_t m_opaque_u32;
-} bcm_rxbd_t;
-
-/*
- * bcm status block
- * NOTE: in fact the status block is not used and configured
- * so that it is not updated by the NIC. Still it has to be
- * set up so the NIC is satisfied
- */
-typedef struct {
- uint32_t m_st_word_u32;
- uint32_t m_st_tag_u32;
- uint16_t m_rxprod_cons_u16;
- uint16_t m_unused_u16;
- uint32_t m_unused_u32;
- uint16_t m_tx_cons_u16;
- uint16_t m_rxret_prod_u16;
-} bcm_status_t;
-
-/*
- * local constants
- ******************************************************************************
- */
-static const bcm_dev_t bcm_dev[] = {
- { 0x166b, BCM_DEV_5714 },
- { 0x1668, BCM_DEV_5714 },
- { 0x1669, BCM_DEV_5714 },
- { 0x166a, BCM_DEV_5714 },
- { 0x1648, BCM_DEV_5704 },
- { 0x1649, BCM_DEV_5704 | BCM_DEV_SERDES },
- { 0x16a8, BCM_DEV_5704 | BCM_DEV_SERDES },
- { 0x16a7, BCM_DEV_5703 | BCM_DEV_SERDES },
- { 0x16c7, BCM_DEV_5703 | BCM_DEV_SERDES },
- { 0 , 0 }
-};
-
-/*
- * local variables
- ******************************************************************************
- */
-static uint64_t bcm_device_u64;
-static uint32_t bcm_rxret_ring_sz;
-static uint64_t bcm_baseaddr_u64;
-static uint64_t bcm_memaddr_u64;
-
-/*
- * rings & their buffers
- */
-// the rings made of buffer descriptors
-static bcm_txbd_t bcm_tx_ring[BCM_TX_RING_SIZE];
-static bcm_rxbd_t bcm_rxprod_ring[BCM_RXPROD_RING_SIZE];
-static bcm_rxbd_t bcm_rxret_ring[BCM_RXRET_RING_SIZE*2];
-
-// the buffers used in the rings
-static uint8_t bcm_tx_buffer_pu08[BCM_MAX_TX_BUF][BCM_BUF_SIZE];
-static uint8_t bcm_rx_buffer_pu08[BCM_MAX_RX_BUF][BCM_BUF_SIZE];
-
-// tx ring index of first/last bd
-static uint32_t bcm_tx_start_u32;
-static uint32_t bcm_tx_stop_u32;
-static uint32_t bcm_tx_bufavail_u32;
-
-/*
- * status block
- */
-static bcm_status_t bcm_status;
-
-/*
- * implementation
- ******************************************************************************
- */
-
-
-/*
- * global functions
- ******************************************************************************
- */
-
-
-/*
- * local helper functions
- ******************************************************************************
- */
-#if 0
-static char *
-memcpy( char *dest, const char *src, size_t n )
-{
- char *ret = dest;
- while( n-- ) {
- *dest++ = *src++;
- }
-
- return( ret );
-}
-#endif
-
-static char *
-memset_ci( char *dest, int c, size_t n )
-{
- char *ret = dest;
-
- while( n-- ) {
- wr08( dest, c );
- dest++;
- }
-
- return( ret );
-}
-
-#if 0
-static char *
-memset( char *dest, int c, size_t n )
-{
- char *ret = dest;
- while( n-- ) {
- *dest++ = (char) c;
- }
-
- return( ret );
-}
-#endif
-
-static uint32_t
-bcm_nvram_logical_to_physical_address(uint32_t address)
-{
- uint32_t page_no = address / BUFFERED_FLASH_PAGE_SIZE;
- uint32_t page_addr = address % BUFFERED_FLASH_PAGE_SIZE;
-
- return (page_no << BUFFERED_FLASH_PAGE_POS) + page_addr;
-}
-
-/*
- * read/write functions to access NIC registers & memory
- * NOTE: all functions are executed with cache inhibitation (dead slow :-) )
- */
-static uint32_t
-bcm_read_mem32( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- return rd32( bcm_memaddr_u64 + (uint64_t) f_offs_u16 );
-}
-
-/* not used so far
-static uint16_t
-bcm_read_mem16( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- return rd16( bcm_memaddr_u64 + (uint64_t) f_offs_u16 );
-}*/
-/* not used so far
-static uint8_t
-bcm_read_mem08( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- return rd08( bcm_memaddr_u64 + (uint64_t) f_offs_u16 );
-}*/
-
-static uint32_t
-bcm_read_reg32_indirect( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- SLOF_pci_config_write32(REG_BASE_ADDR_REG, f_offs_u16);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- REG_BASE_ADDR_REG,
- f_offs_u16 );*/
- return bswap_32(SLOF_pci_config_read32(REG_DATA_REG));
- /*return (uint32_t) bswap_32( snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- REG_DATA_REG ) ) ;*/
-}
-
-static uint32_t
-bcm_read_reg32( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- if(f_offs_u16 >= 0x200 && f_offs_u16 <0x400)
- return bcm_read_reg32_indirect( f_offs_u16 + 0x5600 );
- return rd32( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
-}
-
-static uint16_t
-bcm_read_reg16( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- return rd16( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
-}
-/* not used so far
-static uint8_t
-bcm_read_reg08( uint16_t f_offs_u16 )
-{ // caution: shall only be used after initialization!
- return rd08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
-}*/
-
-static void
-bcm_write_mem32_indirect( uint16_t f_offs_u16, uint32_t f_val_u32 )
-{ // caution: shall only be used after initialization!
- SLOF_pci_config_write32(MEM_BASE_ADDR_REG, f_offs_u16);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- MEM_BASE_ADDR_REG,
- f_offs_u16 );*/
- SLOF_pci_config_write32(MEM_DATA_REG, bswap_32(f_val_u32));
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- MEM_DATA_REG,
- bswap_32 ( f_val_u32 ) );*/
-}
-
-static void
-bcm_write_mem32( uint16_t f_offs_u16, uint32_t f_val_u32 )
-{ // caution: shall only be used after initialization!
- if(f_offs_u16 >= BCM_RXRET_RCB_OFFS &&
- f_offs_u16 < BCM_RXRET_RCB_OFFS + (BCM_MAX_RXRET_RING*BCM_RCB_SIZE_u16))
- bcm_write_mem32_indirect( f_offs_u16, f_val_u32 );
- else if(f_offs_u16 >= BCM_TX_RCB_OFFS &&
- f_offs_u16 < BCM_TX_RCB_OFFS + (BCM_MAX_TX_RING*BCM_RCB_SIZE_u16))
- bcm_write_mem32_indirect( f_offs_u16, f_val_u32 );
- else
- wr32( bcm_memaddr_u64 + (uint64_t) f_offs_u16, f_val_u32 );
-}
-/* not used so far
-static void
-bcm_write_mem16( uint16_t f_offs_u16, uint16_t f_val_u16 )
-{ // caution: shall only be used after initialization!
- wr16( bcm_memaddr_u64 + (uint64_t) f_offs_u16, f_val_u16 );
-}*/
-/* not used so far
-static void
-bcm_write_mem08( uint16_t f_offs_u16, uint8_t f_val_u08 )
-{ // caution: shall only be used after initialization!
- wr08( bcm_memaddr_u64 + (uint64_t) f_offs_u16, f_val_u08 );
-}*/
-
-static void
-bcm_write_reg32_indirect( uint16_t f_offs_u16, uint32_t f_val_u32 )
-{ // caution: shall only be used after initialization!
- SLOF_pci_config_write32(REG_BASE_ADDR_REG, f_offs_u16);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- REG_BASE_ADDR_REG,
- f_offs_u16 );*/
- SLOF_pci_config_write32(REG_DATA_REG, bswap_32(f_val_u32));
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- REG_DATA_REG,
- bswap_32 ( f_val_u32 ) );*/
-}
-
-static void
-bcm_write_reg32( uint16_t f_offs_u16, uint32_t f_val_u32 )
-{ // caution: shall only be used after initialization!
- if(f_offs_u16 >= 0x200 && f_offs_u16 <0x400)
- bcm_write_reg32_indirect( f_offs_u16 + 0x5600, f_val_u32 );
- else
- wr32( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, f_val_u32 );
-}
-
-static void
-bcm_write_reg16( uint16_t f_offs_u16, uint16_t f_val_u16 )
-{ // caution: shall only be used after initialization!
- wr16( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, f_val_u16 );
-}
-/* not used so far
-static void
-bcm_write_reg08( uint16_t f_offs_u16, uint8_t f_val_u08 )
-{ // caution: shall only be used after initialization!
- wr08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, f_val_u08 );
-}*/
-
-static void
-bcm_setb_reg32( uint16_t f_offs_u16, uint32_t f_mask_u32 )
-{
- uint32_t v;
-
- v = bcm_read_reg32( f_offs_u16 );
- v |= f_mask_u32;
- bcm_write_reg32( f_offs_u16, v );
-}
-/* not used so far
-static void
-bcm_setb_reg16( uint16_t f_offs_u16, uint16_t f_mask_u16 )
-{
- uint16_t v;
- v = rd16( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
- v |= f_mask_u16;
- wr16( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, v );
-}*/
-/* not used so far
-static void
-bcm_setb_reg08( uint16_t f_offs_u16, uint8_t f_mask_u08 )
-{
- uint8_t v;
- v = rd08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
- v |= f_mask_u08;
- wr08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, v );
-}*/
-
-static void
-bcm_clrb_reg32( uint16_t f_offs_u16, uint32_t f_mask_u32 )
-{
- uint32_t v;
-
- v = bcm_read_reg32( f_offs_u16 );
- v &= ~f_mask_u32;
- bcm_write_reg32( f_offs_u16, v );
-}
-
-static void
-bcm_clrb_reg16( uint16_t f_offs_u16, uint16_t f_mask_u16 )
-{
- uint16_t v;
-
- v = bcm_read_reg16( f_offs_u16 );
- v &= ~f_mask_u16;
- bcm_write_reg16( f_offs_u16, v );
-}
-/* not used so far
-static void
-bcm_clrb_reg08( uint16_t f_offs_u16, uint8_t f_mask_u08 )
-{
- uint8_t v;
- v = rd08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16 );
- v &= ~f_mask_u32;
- wr08( bcm_baseaddr_u64 + (uint64_t) f_offs_u16, v );
-}*/
-
-static void
-bcm_clr_wait_bit32( uint16_t r, uint32_t b )
-{
- uint32_t i;
-
- bcm_clrb_reg32( r, b );
-
- i = 1000;
- while( --i ) {
-
- if( ( bcm_read_reg32( r ) & b ) == 0 ) {
- break;
- }
-
- SLOF_usleep( 10 );
- }
-#ifdef BCM_DEBUG
- if( ( bcm_read_reg32( r ) & b ) != 0 ) {
- printf( "bcm57xx: bcm_clear_wait_bit32 failed (0x%04X)!\n", r );
- }
-#endif
-}
-
-/*
- * (g)mii bus access
- */
-#if 0
-// not used so far
-static int32_t
-bcm_mii_write16( uint32_t f_reg_u32, uint16_t f_value_u16 )
-{
- static const uint32_t WR_VAL = ( ( ((uint32_t) 0x1) << 21 ) | BIT32( 29 ) | BIT32( 26 ) );
- int32_t l_autopoll_i32 = 0;
- uint32_t l_wrval_u32;
- uint32_t i;
-
- /*
- * only 0x00-0x1f are valid registers
- */
- if( f_reg_u32 > (uint32_t) 0x1f ) {
- return -1;
- }
-
- /*
- * disable auto polling if enabled
- */
- if( ( bcm_read_reg32( MI_MODE_R ) & BIT32( 4 ) ) != 0 ) {
- l_autopoll_i32 = (int32_t) !0;
- bcm_clrb_reg32( MI_MODE_R, BIT32( 4 ) );
- SLOF_usleep( 40 );
- }
-
- /*
- * construct & write mi com register value
- */
- l_wrval_u32 = ( WR_VAL | ( f_reg_u32 << 16 ) | (uint32_t) f_value_u16 );
- bcm_write_reg32( MI_COM_R, l_wrval_u32 );
-
- /*
- * wait for transaction to complete
- */
- i = 25;
- while( ( --i ) &&
- ( ( bcm_read_reg32( MI_COM_R ) & BIT32( 29 ) ) != 0 ) ) {
- SLOF_usleep( 10 );
- }
-
- /*
- * re-enable auto polling if necessary
- */
- if( l_autopoll_i32 ) {
- bcm_setb_reg32( MI_MODE_R, BIT32( 4 ) );
- }
-
- // return on error
- if( i == 0 ) {
- return -1;
- }
-
- return 0;
-}
-#endif
-
-static int32_t
-bcm_mii_read16( uint32_t f_reg_u32, uint16_t *f_value_pu16 )
-{
- static const uint32_t RD_VAL = ( ( ((uint32_t) 0x1) << 21 ) | BIT32( 29 ) | BIT32( 27 ) );
- int32_t l_autopoll_i32 = 0;
- uint32_t l_rdval_u32;
- uint32_t i;
- uint16_t first_not_busy;
-
- /*
- * only 0x00-0x1f are valid registers
- */
- if( f_reg_u32 > (uint32_t) 0x1f ) {
- return -1;
- }
-
- /*
- * disable auto polling if enabled
- */
- if( ( bcm_read_reg32( MI_MODE_R ) & BIT32( 4 ) ) != 0 ) {
- l_autopoll_i32 = ( int32_t ) !0;
- bcm_clrb_reg32( MI_MODE_R, BIT32( 4 ) );
- SLOF_usleep( 40 );
- }
-
- /*
- * construct & write mi com register value
- */
- l_rdval_u32 = ( RD_VAL | ( f_reg_u32 << 16 ) );
- bcm_write_reg32( MI_COM_R, l_rdval_u32 );
-
- /*
- * wait for transaction to complete
- * ERRATA workaround: must read two "not busy" states to indicate transaction complete
- */
- i = 25;
- first_not_busy = 0;
- l_rdval_u32 = bcm_read_reg32( MI_COM_R );
- while( ( --i ) &&
- ( (first_not_busy == 0) || ( ( l_rdval_u32 & BIT32( 29 ) ) != 0 ) ) ) {
- /* Is this the first clear BUSY state? */
- if ( ( l_rdval_u32 & BIT32( 29 ) ) == 0 )
- first_not_busy++;
- SLOF_usleep( 10 );
- l_rdval_u32 = bcm_read_reg32( MI_COM_R );
- }
-
- /*
- * re-enable autopolling if necessary
- */
- if( l_autopoll_i32 ) {
- bcm_setb_reg32( MI_MODE_R, BIT32( 4 ) );
- }
-
- /*
- * return on read transaction error
- * (check read failed bit)
- */
- if( ( i == 0 ) ||
- ( ( l_rdval_u32 & BIT32( 28 ) ) != 0 ) ) {
- return -1;
- }
-
- /*
- * return read value
- */
- *f_value_pu16 = (uint16_t) ( l_rdval_u32 & (uint32_t) 0xffff );
-
- return 0;
-}
-
-/*
- * ht2000 dump (not complete)
- */
-#if 0
-static void
-bcm_dump( void )
-{
- uint32_t i, j;
-
- printf( "*** DUMP ***********************************************************************\n\n" );
-
- printf( "* PCI Configuration Registers:\n" );
- for( i = 0, j = 0; i < 0x40; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Private PCI Configuration Registers:\n" );
- for( i = 0x68, j = 0; i < 0x88; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* VPD Config:\n" );
- printf( "%04X: %08X \n", 0x94, bcm_read_reg32( 0x94 ) );
-
- printf( "\n* Dual MAC Control Registers:\n" );
- for( i = 0xb8, j = 0; i < 0xd0; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Ethernet MAC Control Registers:\n" );
- for( i = 0x400, j = 0; i < 0x590; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Send Data Initiator Control:\n" );
- for( i = 0xc00, j = 0; i < 0xc10; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Send Data Completion Control:\n" );
- printf( "%04X: %08X ", 0x1000, bcm_read_reg32( 0x1000 ) );
- printf( "%04X: %08X \n", 0x1008, bcm_read_reg32( 0x1008 ) );
-
- printf( "\n* Send BD Ring Selector Control:\n" );
- printf( "%04X: %08X ", 0x1400, bcm_read_reg32( 0x1400 ) );
- printf( "%04X: %08X ", 0x1404, bcm_read_reg32( 0x1404 ) );
- printf( "%04X: %08X \n", 0x1408, bcm_read_reg32( 0x1408 ) );
-
- printf( "\n* Send BD Initiator Control:\n" );
- printf( "%04X: %08X ", 0x1800, bcm_read_reg32( 0x1800 ) );
- printf( "%04X: %08X \n", 0x1804, bcm_read_reg32( 0x1804 ) );
-
- printf( "\n* Send BD Completion Control:\n" );
- printf( "%04X: %08X ", 0x1c00, bcm_read_reg32( 0x1c00 ) );
-
- printf( "\n* Receive List Placement Control:\n" );
- for( i = 0x2000, j = 0; i < 0x2020; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Receive Data & Receive BD Initiator Control:\n" );
- printf( "%04X: %08X ", 0x2400, bcm_read_reg32( 0x2400 ) );
- printf( "%04X: %08X \n", 0x2404, bcm_read_reg32( 0x2404 ) );
-
- printf( "\n* Jumbo Receive BD Ring RCB:\n" );
- for( i = 0x2440, j = 0; i < 0x2450; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Standard Receive BD Ring RCB:\n" );
- for( i = 0x2450, j = 0; i < 0x2460; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Mini Receive BD Ring RCB:\n" );
- for( i = 0x2460, j = 0; i < 0x2470; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\nRDI Timer Mode Register:\n" );
- printf( "%04X: %08X \n", 0x24f0, bcm_read_reg32( 0x24f0 ) );
-
- printf( "\n* Receive BD Initiator Control:\n" );
- for( i = 0x2c00, j = 0; i < 0x2c20; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-
- printf( "\n* Receive BD Completion Control:\n" );
- for( i = 0x3000, j = 0; i < 0x3014; i += 4 ) {
-
- printf( "%04X: %08X ", i, bcm_read_reg32( i ) );
-
- if( ( ++j & 0x3 ) == 0 ) {
- printf( "\n" );
- }
-
- }
-}
-#endif
-
-
-
-/*
- * NVRAM access
- */
-
-static int
-bcm_nvram_lock( void )
-{
- int i;
-
- /*
- * Acquire NVRam lock (REQ0) & wait for arbitration won (ARB0_WON)
- */
-// bcm_setb_reg32( SW_ARB_R, BIT32( 0 ) );
- bcm_setb_reg32( SW_ARB_R, BIT32( 1 ) );
-
- i = 2000;
- while( ( --i ) &&
-// ( bcm_read_reg32( SW_ARB_R ) & BIT32( 8 ) ) == 0 ) {
- ( bcm_read_reg32( SW_ARB_R ) & BIT32( 9 ) ) == 0 ) {
- SLOF_msleep( 1 );
- }
-
- // return on error
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf("bcm57xx: failed to lock nvram");
-#endif
- return -1;
- }
-
- return 0;
-}
-
-static void
-bcm_nvram_unlock( void )
-{
- /*
- * release NVRam lock (CLR0)
- */
-// bcm_setb_reg32( SW_ARB_R, BIT32( 4 ) );
- bcm_setb_reg32( SW_ARB_R, BIT32( 5 ) );
-}
-
-static void
-bcm_nvram_init( void )
-{
- /*
- * enable access to NVRAM registers
- */
- if(IS_5714) {
- bcm_setb_reg32( NVM_ACC_R, BIT32( 1 ) | BIT32( 0 ) );
- }
-
- /*
- * disable bit-bang method 19& disable interface bypass
- */
- bcm_clrb_reg32( NVM_CFG1_R, BIT32( 31 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 14 ) | BIT32( 16 ) );
- bcm_setb_reg32( NVM_CFG1_R, BIT32 ( 13 ) | BIT32 ( 17 ));
-
- /*
- * enable Auto SEEPROM Access
- */
- bcm_setb_reg32( MISC_LOCAL_CTRL_R, BIT32 ( 24 ) );
-
- /*
- * NVRAM write enable
- */
- bcm_setb_reg32( MODE_CTRL_R, BIT32 ( 21 ) );
-}
-
-static int32_t
-bcm_nvram_read( uint32_t f_addr_u32, uint32_t *f_val_pu32, uint32_t lock )
-{
- uint32_t i;
-
- /*
- * parameter check
- */
- if( f_addr_u32 > NVM_ADDR_MSK ) {
- return -1;
- }
-
- /*
- * Acquire NVRam lock (REQ0) & wait for arbitration won (ARB0_WON)
- */
- if( lock && (bcm_nvram_lock() == -1) ) {
- return -1;
- }
-
- /*
- * setup address to read
- */
- bcm_write_reg32( NVM_ADDR_R,
- bcm_nvram_logical_to_physical_address(f_addr_u32) );
-// bcm_write_reg32( NVM_ADDR_R, f_addr_u32 );
-
- /*
- * get the command going
- */
- bcm_write_reg32( NVM_COM_R, BIT32( 8 ) | BIT32( 7 ) |
- BIT32( 4 ) | BIT32( 3 ) );
-
- /*
- * wait for command completion
- */
- i = 2000;
- while( ( --i ) &&
- ( ( bcm_read_reg32( NVM_COM_R ) & BIT32( 3 ) ) == 0 ) ) {
- SLOF_msleep( 1 );
- }
-
- /*
- * read back data if no error
- */
- if( i != 0 ) {
- /*
- * read back data
- */
- *f_val_pu32 = bcm_read_reg32( NVM_READ_R );
- }
-
- if(lock)
- bcm_nvram_unlock();
-
- // error
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf("bcm57xx: reading from NVRAM failed\n");
-#endif
- return -1;
- }
-
- // success
- return 0;
-}
-
-static int32_t
-bcm_nvram_write( uint32_t f_addr_u32, uint32_t f_value_u32, uint32_t lock )
-{
- uint32_t i;
-
- /*
- * parameter check
- */
- if( f_addr_u32 > NVM_ADDR_MSK ) {
- return -1;
- }
-
- /*
- * Acquire NVRam lock (REQ0) & wait for arbitration won (ARB0_WON)
- */
- if( lock && (bcm_nvram_lock() == -1) ) {
- return -1;
- }
-
- /*
- * setup address to write
- */
- bcm_write_reg32( NVM_ADDR_R, bcm_nvram_logical_to_physical_address( f_addr_u32 ) );
-
- /*
- * setup write data
- */
- bcm_write_reg32( NVM_WRITE_R, f_value_u32 );
-
- /*
- * get the command going
- */
- bcm_write_reg32( NVM_COM_R, BIT32( 8 ) | BIT32( 7 ) |
- BIT32( 5 ) | BIT32( 4 ) | BIT32( 3 ) );
-
- /*
- * wait for command completion
- */
- i = 2000;
- while( ( --i ) &&
- ( ( bcm_read_reg32( NVM_COM_R ) & BIT32( 3 ) ) == 0 ) ) {
- SLOF_msleep( 1 );
- }
-
- /*
- * release NVRam lock (CLR0)
- */
- if(lock)
- bcm_nvram_unlock();
-
- // error
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf("bcm57xx: writing to NVRAM failed\n");
-#endif
- return -1;
- }
-
- // success
- return 0;
-}
-
-/*
- * PHY initialization
- */
-static int32_t
-bcm_mii_phy_init( void )
-{
- static const uint32_t PHY_STAT_R = (uint32_t) 0x01;
- static const uint32_t AUX_STAT_R = (uint32_t) 0x19;
- static const uint32_t MODE_GMII = BIT32( 3 );
- static const uint32_t MODE_MII = BIT32( 2 );
- static const uint32_t NEG_POLARITY = BIT32( 10 );
- static const uint32_t MII_MSK = ( MODE_GMII | MODE_MII );
- static const uint16_t GIGA_ETH = ( BIT16( 10 ) | BIT16( 9 ) );
- int32_t i;
- uint16_t v;
-
- /*
- * enable MDI communication
- */
- bcm_write_reg32( MDI_CTRL_R, (uint32_t) 0x0 );
-
- /*
- * check link up
- */
- i = 2500;
- do {
- SLOF_msleep( 1 );
- // register needs to be read twice!
- bcm_mii_read16( PHY_STAT_R, &v );
- bcm_mii_read16( PHY_STAT_R, &v );
- } while( ( --i ) &&
- ( ( v & BIT16( 2 ) ) == 0 ) );
-
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: link is down\n" );
-#endif
- return -1;
- }
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: link is up\n" );
-#endif
- if( !IS_COPPER_PHY ) {
- return 0;
- }
-
- /*
- * setup GMII or MII interface
- */
- i = bcm_read_reg32( ETH_MAC_MODE_R );
- /*
- * read status register twice, since the first
- * read fails once between here and the moon...
- */
- bcm_mii_read16( AUX_STAT_R, &v );
- bcm_mii_read16( AUX_STAT_R, &v );
-
- if( ( v & GIGA_ETH ) == GIGA_ETH ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: running PHY in GMII mode (1000BaseT)\n" );
-#endif
- // GMII device
- if( ( i & MII_MSK ) != MODE_GMII ) {
- i &= ~MODE_MII;
- i |= MODE_GMII;
- }
-
- } else {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: running PHY in MII mode (10/100BaseT)\n" );
-#endif
- // MII device
- if( ( i & MII_MSK ) != MODE_MII ) {
- i &= ~MODE_GMII;
- i |= MODE_MII;
- }
-
- }
-
- if( IS_5704 && !IS_SERDES ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: set the link ready signal for 5704C to negative polarity\n" );
-#endif
- i |= NEG_POLARITY; // set the link ready signal for 5704C to negative polarity
- }
-
- bcm_write_reg32( ETH_MAC_MODE_R, i );
-
- return 0;
-}
-
-static int32_t
-bcm_tbi_phy_init( void )
-{
- int32_t i;
-#if 0
- /*
- * set TBI mode full duplex
- */
- bcm_clrb_reg32( ETH_MAC_MODE_R, BIT32( 1 ) );
- bcm_setb_reg32( ETH_MAC_MODE_R, BIT32( 2 ) | BIT32( 3 ) );
-
- /*
- * enable MDI communication
- */
- bcm_write_reg32( MDI_CTRL_R, (uint32_t) 0x0 );
-
- /* Disable link change interrupt. */
- bcm_write_reg32( ETH_MAC_EVT_EN_R, 0 );
-
- /*
- * set link polarity
- */
- bcm_clrb_reg32( ETH_MAC_MODE_R, BIT32( 10 ) );
-
- /*
- * wait for sync/config changes
- */
- for( i = 0; i < 100; i++ ) {
- bcm_write_reg32( ETH_MAC_STAT_R,
- BIT32( 3 ) | BIT32( 4 ) );
-
- SLOF_usleep( 20 );
-
- if( ( bcm_read_reg32( ETH_MAC_STAT_R ) &
- ( BIT32( 3 ) | BIT32( 4 ) ) ) == 0 ) {
- break;
- }
-
- }
-#endif
- /*
- * wait for sync to come up
- */
- for( i = 0; i < 100; i++ ) {
-
- if( ( bcm_read_reg32( ETH_MAC_STAT_R ) & BIT32( 0 ) ) != 0 ) {
- break;
- }
-
- SLOF_usleep( 20 );
- }
-
- if( ( bcm_read_reg32( ETH_MAC_STAT_R ) & BIT32( 0 ) ) == 0) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: link is down\n" );
-#endif
- return -1;
- }
-#if 0
- /*
- * clear all attentions
- */
- bcm_write_reg32( ETH_MAC_STAT_R, (uint32_t) ~0 );
-#endif
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: link is up\n" );
-#endif
- return 0;
-}
-
-static int32_t
-bcm_phy_init( void )
-{
- static const uint16_t SRAM_HW_CFG = (uint16_t) 0x0b58;
- uint32_t l_val_u32;
- int32_t l_ret_i32 = 0;
-
- /*
- * get HW configuration from SRAM
- */
- l_val_u32 = bcm_read_mem32( SRAM_HW_CFG );
- l_val_u32 &= ( BIT32( 5 ) | BIT32( 4 ) );
-
- switch( l_val_u32 ) {
- case 0x10: {
- #ifdef BCM_DEBUG
- printf( "bcm57xx: copper PHY detected\n" );
- #endif
-
- bcm_device_u64 |= BCM_DEV_COPPER;
- l_ret_i32 = bcm_mii_phy_init();
- } break;
-
- case 0x20: {
- #ifdef BCM_DEBUG
- printf( "bcm57xx: fiber PHY detected\n" );
- #endif
-
- if( !IS_SERDES ) {
- #ifdef BCM_DEBUG
- printf( "bcm57xx: running PHY in gmii/mii mode\n" );
- #endif
- l_ret_i32 = bcm_mii_phy_init();
- } else {
- #ifdef BCM_DEBUG
- printf( "bcm57xx: running PHY in tbi mode\n" );
- #endif
- l_ret_i32 = bcm_tbi_phy_init();
- }
-
- } break;
-
- default: {
- #ifdef BCM_DEBUG
- printf( "bcm57xx: unknown PHY type detected, terminating\n" );
- #endif
- l_ret_i32 = -1;
- }
-
- }
-
- return l_ret_i32;
-}
-
-/*
- * ring initialization
- */
-static void
-bcm_init_rxprod_ring( void )
-{
- uint32_t v;
- uint32_t i;
-
- /*
- * clear out the whole rx prod ring for sanity
- */
- memset( (void *) &bcm_rxprod_ring,
- 0,
- BCM_RXPROD_RING_SIZE * sizeof( bcm_rxbd_t ) );
- mb();
-
- /*
- * assign buffers & indices to the ring members
- */
- for( i = 0; i < BCM_MAX_RX_BUF; i++ ) {
- bcm_rxprod_ring[i].m_hostaddr_st.m_hi_u32 =
- (uint32_t) ( (uint64_t) &bcm_rx_buffer_pu08[i] >> 32 );
- bcm_rxprod_ring[i].m_hostaddr_st.m_lo_u32 =
- (uint32_t) ( (uint64_t) &bcm_rx_buffer_pu08[i] &
- (uint64_t) 0xffffffff );
- bcm_rxprod_ring[i].m_idxlen_u32 = ( i << 16 );
- bcm_rxprod_ring[i].m_idxlen_u32 += BCM_BUF_SIZE;
- }
-
- /*
- * clear rcb registers & disable rings
- * NOTE: mini & jumbo rings are not supported,
- * still rcb's are cleaned out for sanity
- */
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_JUM ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_JUM ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_JUM ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_JUM ), 0 );
-
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_STD ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_STD ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_STD ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_STD ), 0 );
-
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_MIN ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_MIN ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_MIN ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_MIN ), 0 );
-
- /*
- * clear rx producer index of std producer ring
- */
- bcm_write_reg32( RXPROD_PROD_IND, 0 );
-
- /*
- * setup rx standard rcb using recommended NIC addr (hard coded)
- */
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_STD ),
- (uint32_t) ( (uint64_t) &bcm_rxprod_ring >> 32 ) );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_STD ),
- (uint32_t) ( (uint64_t) &bcm_rxprod_ring & (uint64_t) 0xffffffff ) );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_STD ),
- (uint32_t) BCM_NIC_RX_OFFS );
-
- if( IS_5704 || IS_5703 ) {
- // 5704: length field = max buffer len
- v = (uint32_t) BCM_BUF_SIZE << 16;
- } else {
- // 5714: length field = number of ring entries
- v = (uint32_t) BCM_RXPROD_RING_SIZE << 16;
- }
-
- v &= (uint32_t) ~RCB_FLAG_RING_DISABLED;
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_STD ), v );
-}
-
-static void
-bcm_init_rxret_ring( void )
-{
- uint32_t i;
- uint16_t v;
-
- /*
- * clear out the whole rx ret ring for sanity
- */
- memset( (void *) &bcm_rxret_ring,
- 0,
- 2 * BCM_RXRET_RING_SIZE * sizeof( bcm_rxbd_t ) );
- mb();
-
- /*
- * setup return ring size dependent on installed device
- */
- bcm_rxret_ring_sz = BCM_RXRET_RING_SIZE;
- if( IS_5704 || IS_5703 ) {
- bcm_rxret_ring_sz *= 2;
- }
-
- /*
- * clear rcb memory & disable rings
- * NOTE: 5714 only supports one return ring,
- * still all possible rcb's are cleaned out for sanity
- */
- v = BCM_RXRET_RCB_OFFS;
- for( i = 0; i < BCM_MAX_RXRET_RING; i++ ) {
- bcm_write_mem32( BCM_RCB_LENFLAG_u16( v ), RCB_FLAG_RING_DISABLED );
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( v ), 0 );
-
- v += BCM_RCB_SIZE_u16;
- }
-
- /*
- * clear rx consumer index of return ring
- */
- bcm_write_reg32( RXRET_CONS_IND, 0 );
-
- /*
- * setup rx ret rcb
- * NOTE: NIC address not aplicable in return rings
- */
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXRET_RCB_OFFS ),
- (uint32_t) ( (uint64_t) &bcm_rxret_ring >> 32 ) );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXRET_RCB_OFFS ),
- (uint32_t) ( (uint64_t) &bcm_rxret_ring &
- (uint64_t) 0xffffffff ) );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( BCM_RXRET_RCB_OFFS ), 0 );
-
- i = bcm_rxret_ring_sz;
- i <<= 16;
- i &= (uint32_t) ~RCB_FLAG_RING_DISABLED;
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXRET_RCB_OFFS ), i );
-}
-
-static void
-bcm_init_tx_ring( void )
-{
- uint32_t i;
- uint16_t v;
-
- /*
- * clear out the whole tx ring for sanity
- */
- memset( (void *) &bcm_tx_ring,
- 0,
- BCM_TX_RING_SIZE * sizeof( bcm_txbd_t ) );
- mb();
-
- /*
- * assign buffers to the ring members & setup invariant flags
- */
- for( i = 0; i < BCM_MAX_TX_BUF; i++ ) {
- bcm_tx_ring[i].m_hostaddr_st.m_hi_u32 =
- (uint32_t) ( (uint64_t) &bcm_tx_buffer_pu08[i] >> 32 );
- bcm_tx_ring[i].m_hostaddr_st.m_lo_u32 =
- (uint32_t) ( (uint64_t) &bcm_tx_buffer_pu08[i] &
- (uint64_t) 0xffffffff );
- // flags: indicate last packet & coal now
- // -last packet is always true (only one send packet supported)
- // -coal now needed to always get the consumed bd's (since
- // only a few bd's are set up which permanently are recycled)
- bcm_tx_ring[i].m_lenflags_u32 = ( BIT32( 2 ) | BIT32( 7 ) );
- bcm_tx_ring[i].m_VLANtag_u32 = (uint32_t) 0; // not used
- }
-
- /*
- * clear rcb memory & disable rings
- * NOTE: 5714 only supports one send ring,
- * still all possible rcb's are cleaned out for sanity
- */
- v = BCM_TX_RCB_OFFS;
- for( i = 0; i < BCM_MAX_TX_RING; i++ ) {
- bcm_write_mem32( BCM_RCB_LENFLAG_u16( v ), RCB_FLAG_RING_DISABLED );
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( v ), 0 );
-
- v += BCM_RCB_SIZE_u16;
- }
-
- /*
- * clear host/nic producer indices
- */
- bcm_write_reg32( TX_NIC_PROD_IND, 0 );
- bcm_write_reg32( TX_PROD_IND, 0 );
-
- /*
- * setup tx rcb using recommended NIC addr (hard coded)
- */
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( BCM_TX_RCB_OFFS ),
- (uint32_t) ( (uint64_t) &bcm_tx_ring >> 32 ) );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( BCM_TX_RCB_OFFS ),
- (uint32_t) ( (uint64_t) &bcm_tx_ring &
- (uint64_t) 0xffffffff ) );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( BCM_TX_RCB_OFFS ),
- (uint32_t) BCM_NIC_TX_OFFS );
-
- if( IS_5704 || IS_5703 ) {
- // 5704: length field = max buffer len
- i = (uint32_t) BCM_BUF_SIZE << 16;
- } else {
- // 5714: length field = number of ring entries
- i = (uint32_t) BCM_TX_RING_SIZE << 16;
- }
-
- i &= ( uint32_t ) ~RCB_FLAG_RING_DISABLED;
- bcm_write_mem32( BCM_RCB_LENFLAG_u16( BCM_TX_RCB_OFFS ), i );
-
- /*
- * remember the next bd index to be used
- * & number of available buffers
- */
- bcm_tx_stop_u32 = BCM_MAX_TX_BUF;
- bcm_tx_bufavail_u32 = BCM_MAX_TX_BUF;
-}
-
-static int32_t
-bcm_mac_init( uint8_t *f_mac_pu08 )
-{
- static const uint16_t MEM_MAC_LO = (uint16_t) 0x0c18;
- static const uint16_t MEM_MAC_HI = (uint16_t) 0x0c14;
-
- uint32_t NVR_MAC_LO = (uint16_t) 0x80;
- uint32_t NVR_MAC_HI = (uint16_t) 0x7c;
-
- bcm_addr64_t l_mac_st;
- uint32_t i;
- uint32_t v;
-
- /*
- * Use MAC address from device tree if possible
- */
- for( i = 0, v = 0; i < 6; i++ ) {
- v += (uint32_t) f_mac_pu08[i];
- }
-
- if( v != 0 ) {
- l_mac_st.m_hi_u32 = ( ( (uint32_t) f_mac_pu08[0]) << 8 );
- l_mac_st.m_hi_u32 |= ( ( (uint32_t) f_mac_pu08[1]) << 0 );
- l_mac_st.m_lo_u32 = ( ( (uint32_t) f_mac_pu08[2]) << 24 );
- l_mac_st.m_lo_u32 |= ( ( (uint32_t) f_mac_pu08[3]) << 16 );
- l_mac_st.m_lo_u32 |= ( ( (uint32_t) f_mac_pu08[4]) << 8 );
- l_mac_st.m_lo_u32 |= ( ( (uint32_t) f_mac_pu08[5]) << 0 );
- } else {
- /*
- * try to read MAC address from MAC mailbox
- */
- l_mac_st.m_hi_u32 = bcm_read_mem32( MEM_MAC_HI );
-
- if( ( l_mac_st.m_hi_u32 >> 16 ) == (uint32_t) 0x484b ) {
- l_mac_st.m_hi_u32 &= (uint32_t) 0xffff;
- l_mac_st.m_lo_u32 = bcm_read_mem32( MEM_MAC_LO );
- } else {
- int32_t l_err_i32;
-
- /*
- * otherwise retrieve MAC address from NVRam
- */
- if( ( bcm_read_reg32( MAC_FUNC_R ) & BIT32( 2 ) ) != 0 ) {
- // secondary MAC is in use, address in NVRAM changes
- NVR_MAC_LO += 0x50;
- NVR_MAC_HI += 0x50;
- }
-
- l_err_i32 = bcm_nvram_read( NVR_MAC_LO, &l_mac_st.m_lo_u32, 1 );
- l_err_i32 += bcm_nvram_read( NVR_MAC_HI, &l_mac_st.m_hi_u32, 1 );
-
- // return on read error
- if( l_err_i32 < 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: failed to retrieve MAC address\n" );
-#endif
- return -1;
- }
- }
- }
-
- /*
- * write the mac addr into the NIC's register area
- */
- bcm_write_reg32( MAC_ADDR_OFFS_HI(0), l_mac_st.m_hi_u32 );
- bcm_write_reg32( MAC_ADDR_OFFS_LO(0), l_mac_st.m_lo_u32 );
- for( i = 1; i < BCM_NUM_MAC_ADDR; i++ ) {
- bcm_write_reg32( MAC_ADDR_OFFS_HI(i), 0 );
- bcm_write_reg32( MAC_ADDR_OFFS_LO(i), 0 );
- }
-
- /*
- * WY 26.01.07
- * not needed anymore, s.a.
- if( IS_5704 != 0 ) {
-
- v = MAC5704_ADDR_OFFS;
- for( i = 0; i < BCM_NUM_MAC5704_ADDR; i++ ) {
- bcm_write_reg32( v, l_mac_st.m_hi_u32 );
- v += sizeof( uint32_t );
- bcm_write_reg32( v, l_mac_st.m_lo_u32 );
- v += sizeof( uint32_t );
- }
-
- }
- */
-
- /*
- * return MAC address as string
- */
- f_mac_pu08[0] = (uint8_t) ( ( l_mac_st.m_hi_u32 >> 8 ) & (uint32_t) 0xff );
- f_mac_pu08[1] = (uint8_t) ( ( l_mac_st.m_hi_u32 ) & (uint32_t) 0xff );
- f_mac_pu08[2] = (uint8_t) ( ( l_mac_st.m_lo_u32 >> 24 ) & (uint32_t) 0xff );
- f_mac_pu08[3] = (uint8_t) ( ( l_mac_st.m_lo_u32 >> 16 ) & (uint32_t) 0xff );
- f_mac_pu08[4] = (uint8_t) ( ( l_mac_st.m_lo_u32 >> 8 ) & (uint32_t) 0xff );
- f_mac_pu08[5] = (uint8_t) ( ( l_mac_st.m_lo_u32 ) & (uint32_t) 0xff );
-
-#ifdef BCM_DEBUG
- do {
- int32_t i;
- printf( "bcm57xx: retrieved MAC address " );
-
- for( i = 0; i < 6; i++ ) {
- printf( "%02X", f_mac_pu08[i] );
-
- if( i != 5 ) {
- printf( ":" );
- }
-
- }
-
- printf( "\n" );
- } while( 0 );
-#endif
-
- return 0;
-}
-
-
-/*
- ******************************************************************************
- * ASF Firmware
- ******************************************************************************
- */
-
-
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_ASF_REGS
-static void
-bcm_asf_check_register( void )
-{
- uint32_t i;
-
- i = bcm_read_reg32( ASF_CTRL_R );
- printf( "bcm57xx: ASF control : %x\n", i );
-
- i = bcm_read_reg32( ASF_WATCHDOG_TIMER_R );
- printf( "bcm57xx: ASF Watchdog Timer : %x\n", i );
-
- i = bcm_read_reg32( ASF_HEARTBEAT_TIMER_R );
- printf( "bcm57xx: ASF Heartbeat Timer : %x\n", i );
-
- i = bcm_read_reg32( ASF_POLL_TIMER_R );
- printf( "bcm57xx: ASF Poll Timer : %x\n", i );
-
- i = bcm_read_reg32( POLL_LEGACY_TIMER_R );
- printf( "bcm57xx: Poll Legacy Timer : %x\n", i );
-
- i = bcm_read_reg32( RETRANSMISSION_TIMER_R );
- printf( "bcm57xx: Retransmission Timer : %x\n", i );
-
- i = bcm_read_reg32( TIME_STAMP_COUNTER_R );
- printf( "bcm57xx: Time Stamp Counter : %x\n", i );
-
- i = bcm_read_reg32( RX_CPU_MODE_R );
- printf( "bcm57xx: RX RISC Mode : %x\n", i );
-
- i = bcm_read_reg32( RX_CPU_STATE_R );
- printf( "bcm57xx: RX RISC State : %x\n", i );
-
- i = bcm_read_reg32( RX_CPU_PC_R );
- printf( "bcm57xx: RX RISC Prg. Counter : %x\n", i );
-}
-#endif
-#endif
-
-static int
-bcm_fw_halt( void )
-{
- int i;
-
- bcm_write_mem32( BCM_FW_MBX_CMD, BCM_NICDRV_PAUSE_FW );
- bcm_setb_reg32( RX_CPU_EVENT_R, BIT32( 14 ) );
-
- /* Wait for RX cpu to ACK the event. */
- for (i = 0; i < 100; i++) {
- if(bcm_read_reg32( RX_CPU_EVENT_R ) & BIT32( 14 ))
- break;
- SLOF_msleep(1);
- }
- if( i>= 100)
- return -1;
- return 0;
-}
-
-
-#ifdef BCM_SW_AUTONEG
-static void
-bcm_sw_autoneg( void ) {
- uint32_t i, j, k;
- uint32_t SerDesCfg;
- uint32_t SgDigControl;
- uint32_t SgDigStatus;
- uint32_t ExpectedSgDigControl;
- int AutoNegJustInitiated = 0;
-
- // step 1: init TX 1000BX Autoneg. Register to zero
- bcm_write_reg32(TX_1000BX_AUTONEG_R, 0);
-
- // step 2&3: set TBI mode
- bcm_setb_reg32( ETH_MAC_MODE_R, BIT32( 2 ) | BIT32( 3 ) );
- SLOF_usleep(10);
-
- // step 4: enable link attention
- bcm_setb_reg32( ETH_MAC_EVT_EN_R, BIT32( 12 ) );
-
- // step 5: preserve voltage regulator bits
- SerDesCfg = bcm_read_reg32(SERDES_CTRL_R) & ( BIT32( 20 ) | BIT32( 21 )
- | BIT32( 22 ) | BIT32( 23 ) );
-
- // step 6: preserve voltage regulator bits
- SgDigControl = bcm_read_reg32(HW_AUTONEG_CTRL_R);
-
- // step 7: if device is NOT set-up for auto negotiation, then go to step 26
- // goto bcm_setup_phy_step26;
-
- // We want to use auto negotiation
-
- // step 8: we don't want to use flow control
- ExpectedSgDigControl = 0x81388400; // no flow control
-
- // step 9: compare SgDigControl with 0x81388400
- if(SgDigControl == ExpectedSgDigControl) {
- goto bcm_setup_phy_step17;
- }
-#ifdef BCM_DEBUG
- printf("bcm57xx: SgDigControl = %08X\n", SgDigControl);
-#endif
- // step 10
- bcm_write_reg32(SERDES_CTRL_R, SerDesCfg | 0xC011880);
-
- // step 11: restart auto negotiation
- bcm_write_reg32(HW_AUTONEG_CTRL_R, ExpectedSgDigControl | BIT32( 30 ) );
-
- // step 12: read back HW_AUTONEG_CTRL_R
- bcm_read_reg32(HW_AUTONEG_CTRL_R);
-
- // step 13
- SLOF_usleep( 5 );
-
- // step 14,15,16: same as step 11, but don't restart auto neg.
- bcm_write_reg32(HW_AUTONEG_CTRL_R, ExpectedSgDigControl);
- AutoNegJustInitiated = 1;
- goto bcm_setup_phy_step30;
-
- // step 17:
- bcm_setup_phy_step17:
- if( ( bcm_read_reg32(ETH_MAC_STAT_R) & ( BIT32( 1 ) | BIT32( 0 ) ) ) == 0 ) {
- goto bcm_setup_phy_step30;
- }
-
- // step 18: Get HW Autoneg. Status
- SgDigStatus = bcm_read_reg32(HW_AUTONEG_STAT_R);
-
- // step 19:
- if( ( SgDigStatus & BIT32(1) )
- && ( bcm_read_reg32(ETH_MAC_STAT_R) & BIT32(0) ) ) {
- // resolve the current flow control?
- AutoNegJustInitiated = 0;
- goto bcm_setup_phy_step30;
- }
-
- // step 20
- if( SgDigStatus & BIT32(1) ) {
- goto bcm_setup_phy_step30;
- }
- if( AutoNegJustInitiated != 0) {
- AutoNegJustInitiated = 0;
- goto bcm_setup_phy_step29;
- }
-
- // step 21, 22, 23, 24: fallback to 1000Mbps-FullDuplex forced mode
- if( ( bcm_read_reg32( MAC_FUNC_R ) & BIT32( 2 ) ) == 0 ) {
- // port 0
- bcm_write_reg32( SERDES_CTRL_R, 0xC010880 );
- }
- else { // port 1
- bcm_write_reg32( SERDES_CTRL_R, 0x4010880 );
- }
- // set to 1000Mbps-FullDuplex
- bcm_write_reg32(HW_AUTONEG_CTRL_R, 0x1388400);
- // read back
- bcm_read_reg32(HW_AUTONEG_CTRL_R);
- SLOF_usleep( 40 );
-
- // step 25: a little bit reduces...
- goto bcm_setup_phy_step30;
-
- // step 26: check if auto negotiation bit is NOT set
-// bcm_setup_phy_step26:
- if( ( SgDigControl & BIT32(31) )== 0 ) {
- printf("No autoneg.\n");
- goto bcm_setup_phy_step29;
- }
-
- // step 27:
- if( ( bcm_read_reg32( MAC_FUNC_R ) & BIT32( 2 ) ) == 0 ) {
- // port 0
- bcm_write_reg32( SERDES_CTRL_R, 0xC010880 );
- }
- else { // port 1
- bcm_write_reg32( SERDES_CTRL_R, 0x4010880 );
- }
-
- // step 28: disable auto neg. and force 1000FD mode
- bcm_write_reg32(HW_AUTONEG_CTRL_R, 0x1388400);
-
- // step 29-31: omitted for 5704S
- bcm_setup_phy_step29:
- bcm_setup_phy_step30:
-
- // step 32: clear link attentions
- i = bcm_read_reg32( ETH_MAC_STAT_R ) | BIT32( 3 ) | BIT32( 4 );
- k = 100;
- do {
- bcm_write_reg32( ETH_MAC_STAT_R, i );
- j = bcm_read_reg32( ETH_MAC_STAT_R );
- if( ( j & BIT32( 3 ) ) != 0 )
- i = i & ~(BIT32( 3 ));
- if( ( j & BIT32( 4 ) ) != 0 )
- i = i & ~(BIT32( 4 ));
- --k;
- } while( i & k);
-
- // step 33
- if( ( bcm_read_reg32( ETH_MAC_STAT_R ) & BIT32( 0 ) ) == 0 ) {
- goto bcm_setup_phy_step35;
- }
-
- // step 34
- i = bcm_read_reg32( ETH_MAC_MODE_R );
- i|= BIT32( 17 );
- bcm_write_reg32( ETH_MAC_MODE_R, i );
-
- SLOF_usleep( 1 );
-
- i = bcm_read_reg32( ETH_MAC_STAT_R );
- i&= ~BIT32( 17 );
- bcm_write_reg32( ETH_MAC_STAT_R, i );
-
- // step 35 & 36: done
- bcm_setup_phy_step35:
-#ifdef BCM_DEBUG
- printf("bcm57xx: SetupPhy\n");
-#endif
- return;
-}
-#endif
-
-static int
-bcm_handle_events( void ) {
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_ASF_REGS
- // ASF REGISTER CHECK
- // ------------------
- // check if watchdog timer expired
- if( bcm_read_reg32( ASF_WATCHDOG_TIMER_R ) == 0 ) {
- // Show ASF registers
- bcm_asf_check_register();
-
- // rearm watchdog timer
- bcm_write_reg32( ASF_WATCHDOG_TIMER_R, 5 );
- }
-#endif
-#endif
-
-#ifdef BCM_SW_AUTONEG
- // AUTO NEGOTIATION
- // ----------------
-
- // Check event for Auto Negotiation
- if( ( bcm_read_reg32( ETH_MAC_STAT_R ) &
- ( BIT32( 12 ) | BIT32( 3 ) | BIT32( 0 ) ) ) != 0 ) {
- // link timer procedure
- bcm_sw_autoneg();
- }
-#endif
-
- // ASF FW HEARTBEAT
- // ----------------
-
- // check if heartsbeat timer expired
- if( bcm_read_reg32( ASF_HEARTBEAT_TIMER_R ) <= 2) {
- int i;
-
- // Send heartbeat event
- bcm_write_mem32( BCM_FW_MBX_CMD, BCM_NICDRV_ALIVE );
- bcm_write_mem32( BCM_FW_MBX_LEN, 4 );
- bcm_write_mem32( BCM_FW_MBX_DATA, 5 );
- bcm_setb_reg32( RX_CPU_EVENT_R, BIT32( 14 ) );
-
- // Wait for RX cpu to ACK the event.
- for (i = 100; i > 0; i--) {
- if(bcm_read_reg32( RX_CPU_EVENT_R ) & BIT32( 14 ))
- break;
- SLOF_msleep(1);
- }
- if( i == 0) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: RX cpu did not acknowledge heartbeat event\n" );
-#endif
- return -1;
- }
-
- // rearm heartbeat timer
- bcm_write_reg32( ASF_HEARTBEAT_TIMER_R, 5 );
- }
- return 0;
-}
-
-/*
- * interface
- ******************************************************************************
- */
-
-/*
- * bcm_receive
- */
-static int
-bcm_receive( char *f_buffer_pc, int f_len_i )
-{
- uint32_t l_rxret_prod_u32 = bcm_read_reg32( RXRET_PROD_IND );
- uint32_t l_rxret_cons_u32 = bcm_read_reg32( RXRET_CONS_IND );
- uint32_t l_rxprod_prod_u32 = bcm_read_reg32( RXPROD_PROD_IND );
- int l_ret_i;
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_RCV_DATA
- int i, j;
-#endif
-#endif
-
- /*
- * NOTE: dummy read to ensure data has already been DMA'd is
- * done by the indice reads
- */
-
- bcm_handle_events();
-
- /*
- * if producer index == consumer index then nothing was received
- */
- if( l_rxret_prod_u32 == l_rxret_cons_u32 ) {
- return 0;
- }
-
- /*
- * discard erroneous packets
- */
- if( ( bcm_rxret_ring[l_rxret_cons_u32].m_typeflags_u32 & BIT32( 10 ) ) != 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: erroneous frame received\n" );
- printf( " : frame discarded\n" );
-#endif
- l_ret_i = 0;
- } else {
- /*
- * get packet length, throw away checksum (last 4 bytes)
- */
- l_ret_i = (int) ( bcm_rxret_ring[l_rxret_cons_u32].m_idxlen_u32 &
- (uint32_t) 0xffff ) - (int) 4;
-
- /*
- * discard oversized packets
- */
- if( l_ret_i > f_len_i ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: receive packet length error:\n" );
- printf( " : incoming 0x%X bytes, available buffer 0x%X bytes\n", l_ret_i, f_len_i );
- printf( " : frame discarded\n" );
-#endif
- l_ret_i = 0;
- }
-
- }
-
- /*
- * copy & update data & indices
- */
- if( l_ret_i != 0 ) {
- uint64_t l_cpyaddr_u64;
-
- l_cpyaddr_u64 =
- ( (uint64_t) bcm_rxret_ring[l_rxret_cons_u32].m_hostaddr_st.m_hi_u32 << 32 );
- l_cpyaddr_u64 +=
- ( (uint64_t) bcm_rxret_ring[l_rxret_cons_u32].m_hostaddr_st.m_lo_u32 );
-
-// FIXME:
- if(l_cpyaddr_u64 == 0) {
-#ifdef BCM_DEBUG
- printf("bcm57xx: NULL address\n");
-#endif
- return 0;
- }
-//
- memcpy( (void *) f_buffer_pc,
- (void *) l_cpyaddr_u64,
- (size_t) l_ret_i );
-
- }
-
- /*
- * replenish bd to producer ring
- */
- bcm_rxprod_ring[l_rxprod_prod_u32] =
- bcm_rxret_ring[l_rxret_cons_u32];
- bcm_rxprod_ring[l_rxprod_prod_u32].m_idxlen_u32 =
- ( l_rxprod_prod_u32 << 16 );
- bcm_rxprod_ring[l_rxprod_prod_u32].m_idxlen_u32 +=
- (uint32_t) BCM_BUF_SIZE;
-
- /*
- * update producer ring's producer index
- */
- l_rxprod_prod_u32 = ( l_rxprod_prod_u32 + 1 ) & ( BCM_RXPROD_RING_SIZE - 1 );
-
- /*
- * move to the next bd in return ring
- */
- l_rxret_cons_u32 = ( l_rxret_cons_u32 + 1 ) & ( bcm_rxret_ring_sz - 1 );
-
- /*
- * synchronize before new indices are send to NIC
- */
- mb();
-
- /*
- * write back new indices
- */
- bcm_write_reg32( RXRET_CONS_IND, l_rxret_cons_u32 );
- bcm_write_reg32( RXPROD_PROD_IND, l_rxprod_prod_u32 );
-
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_RCV
- if( l_ret_i != 0 ) {
- printf( "bcm57xx: received bytes: %d\n", l_ret_i );
- }
-#ifdef BCM_SHOW_RCV_DATA
- for( i = 0, j = 0; i < l_ret_i; i++ ) {
- printf( "%02X ", ( uint32_t ) f_buffer_pc[i] );
-
- if( ( ++j % 0x18 ) == 0 ) {
- printf( "\n" );
- }
- }
-
- if( ( i % 0x18 ) != 0 ) {
- printf( "\n" );
- }
-#endif
-#endif
-#endif
-
- /*
- * return packet length
- */
- return l_ret_i;
-}
-
-static int
-bcm_xmit( char *f_buffer_pc, int f_len_i )
-{
- uint32_t l_tx_cons_u32 = bcm_read_reg32( TX_CONS_IND );
- uint32_t l_tx_prod_u32 = bcm_read_reg32( TX_PROD_IND );
- uint64_t l_cpyaddr_u64;
-
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_XMIT_DATA
- int i, j;
-#endif
-#ifdef BCM_SHOW_IDX
- printf( "\n" );
- printf( "bcm57xx: TX_PROD_IND : 0x%03X\n", l_tx_prod_u32 );
- printf( "bcm57xx: TX_CONS_IND : 0x%03X\n", l_tx_cons_u32 );
- printf( "bcm57xx: RXPROD_PROD_IND: 0x%03X\n", bcm_read_reg32( RXPROD_PROD_IND ) );
- printf( "bcm57xx: RXPROD_CONS_IND: 0x%03X\n", bcm_read_reg32( RXPROD_CONS_IND ) );
- printf( "bcm57xx: RXRET_PROD_IND : 0x%03X\n", bcm_read_reg32( RXRET_PROD_IND ) );
- printf( "bcm57xx: RXRET_CONS_IND : 0x%03X\n", bcm_read_reg32( RXRET_CONS_IND ) );
- printf( "bcm57xx: available txb : 0x%03X\n", bcm_tx_bufavail_u32 );
-#endif
-#ifdef BCM_SHOW_STATS
- printf( "bcm57xx: bcm_status.m_st_word_u32: %08X\n", bcm_status.m_st_word_u32 );
- printf( "bcm57xx: bcm_status.m_st_tag_u32 : %08X\n", bcm_status.m_st_tag_u32 );
- printf( "bcm57xx: bcm_status.m_rxprod_cons_u16: %04X\n", ( uint32_t ) bcm_status.m_rxprod_cons_u16 );
- printf( "bcm57xx: bcm_status.m_unused_u16: %04X\n", ( uint32_t ) bcm_status.m_unused_u16 );
- printf( "bcm57xx: bcm_status.m_unused_u32: %08X\n", bcm_status.m_unused_u32 );
- printf( "bcm57xx: bcm_status.m_tx_cons_u16: %04X\n", ( uint32_t ) bcm_status.m_tx_cons_u16 );
- printf( "bcm57xx: bcm_status.m_rxret_prod_u16: %04X\n", ( uint32_t ) bcm_status.m_rxret_prod_u16 );
-#endif
-#endif
-
- bcm_handle_events();
-
- /*
- * make all consumed bd's available in the ring again
- * this way only a few buffers are needed instead of
- * having 512 buffers allocated
- */
- while( bcm_tx_start_u32 != l_tx_cons_u32 ) {
- bcm_tx_ring[bcm_tx_stop_u32] = bcm_tx_ring[bcm_tx_start_u32];
- bcm_tx_stop_u32 = ( bcm_tx_stop_u32 + 1 ) & ( BCM_TX_RING_SIZE - 1 );
- bcm_tx_start_u32 = ( bcm_tx_start_u32 + 1 ) & ( BCM_TX_RING_SIZE - 1 );
- bcm_tx_bufavail_u32++;
- }
-
- /*
- * check for tx buffer availability
- */
- if( bcm_tx_bufavail_u32 == 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: no more transmit buffers available\n" );
-#endif
- return 0;
- }
-
- /*
- * setup next available bd in tx ring
- */
- bcm_tx_ring[l_tx_prod_u32].m_lenflags_u32 = ( BIT32( 2 ) | BIT32( 7 ) /*| BIT32( 6 )*/ );
- bcm_tx_ring[l_tx_prod_u32].m_lenflags_u32 += ( (uint32_t) f_len_i << 16 );
-// bcm_tx_ring[l_tx_prod_u32].m_VLANtag_u32 = BCM_VLAN_TAG;
-
- l_cpyaddr_u64 = ( (uint64_t) bcm_tx_ring[l_tx_prod_u32].m_hostaddr_st.m_hi_u32 << 32 );
- l_cpyaddr_u64 += ( (uint64_t) bcm_tx_ring[l_tx_prod_u32].m_hostaddr_st.m_lo_u32 );
-
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_XMIT_STATS
- printf("bcm57xx: xmit: l_cpyaddr_u64: 0x%lx\n", l_cpyaddr_u64 );
- printf(" f_buffer_pc : 0x%lx\n", f_buffer_pc );
- printf(" f_len_i : %d\n", f_len_i );
-#endif
-#endif
- memcpy( (void *) l_cpyaddr_u64, (void *) f_buffer_pc, (size_t) f_len_i );
-
- /*
- * update tx producer index & available buffers
- */
- l_tx_prod_u32 = ( l_tx_prod_u32 + 1 ) & ( BCM_TX_RING_SIZE - 1 );
- bcm_tx_bufavail_u32--;
-
- /*
- * synchronize before new index is send to NIC
- */
- mb();
-
- bcm_write_reg32( TX_PROD_IND, l_tx_prod_u32 );
-
-#ifdef BCM_DEBUG
-#ifdef BCM_SHOW_XMIT
- printf( "bcm57xx: sent bytes: %d\n", f_len_i );
-#ifdef BCM_SHOW_XMIT_DATA
- for( i = 0, j = 0; i < f_len_i; i++ ) {
- printf( "%02X ", ( uint32_t ) f_buffer_pc[i] );
-
- if( ( ++j % 0x18 ) == 0 ) {
- printf( "\n" );
- }
-
- }
- if( ( i % 0x18 ) != 0 ) {
- printf( "\n" );
- }
-#endif
-#endif
-
-#ifdef BCM_SHOW_STATS
- // coalesce status block now
- bcm_setb_reg32( HOST_COAL_MODE_R, BIT32( 3 ) | BIT32( 1 ) );
-#endif
-
-#endif
- return f_len_i;
-}
-
-static int
-check_driver( uint16_t vendor_id, uint16_t device_id )
-{
- uint64_t i;
-
- /*
- * checks whether the driver is handling this device
- * by verifying vendor & device id
- * vendor id 0x14e4 == Broadcom
- */
- if( vendor_id != 0x14e4 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: netdevice not supported, illegal vendor id\n" );
-#endif
- return -1;
- }
-
- for( i = 0; bcm_dev[i].m_dev_u32 != 0; i++ ) {
- if( bcm_dev[i].m_dev_u32 == (uint32_t) device_id ) {
- // success
- break;
- }
- }
-
- if(bcm_dev[i].m_dev_u32 == 0) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: netdevice not supported, illegal device ID\n" );
-#endif
- return -1;
- }
-
- /*
- * initialize static variables
- */
- bcm_device_u64 = bcm_dev[i].m_devmsk_u64;
- bcm_rxret_ring_sz = 0;
- bcm_baseaddr_u64 = 0;
- bcm_memaddr_u64 = 0;
-
- bcm_tx_start_u32 = 0;
- bcm_tx_stop_u32 = 0;
- bcm_tx_bufavail_u32 = 0;
-
- return 0;
-}
-
-static void
-bcm_wol_activate(void)
-{
-#ifdef BCM_DEBUG
- uint16_t reg_pwr_cap;
-#endif
- uint16_t reg_pwr_crtl;
- uint32_t wol_mode;
-
- wol_mode = bcm_read_reg32( WOL_MODE_R );
- bcm_write_reg32( WOL_MODE_R, wol_mode | BIT32(0) );
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: WOL activating..." );
-#endif
-
-// bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_WOL );
-// SLOF_msleep( 100 );
-
-#ifdef BCM_DEBUG
- reg_pwr_cap = SLOF_pci_config_read16(0x4a);
- /*reg_pwr_cap = snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- 0x4a );*/
- printf( "bcm57xx: PM Capability Register: %04X\n", reg_pwr_cap );
-#endif
- /* get curretn power control register */
- reg_pwr_crtl = SLOF_pci_config_read16(0x4c);
- /*reg_pwr_crtl = snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- 0x4c );*/
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: PM Control/Status Register: %04X\n", reg_pwr_crtl );
-#endif
-
- /* switch to power state D0 */
- reg_pwr_crtl |= 0x8000;
- reg_pwr_crtl &= ~(0x0003);
- SLOF_pci_config_write16(0x4c, reg_pwr_crtl);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- 0x4c,
- reg_pwr_crtl );*/
- SLOF_msleep(10);
-
-/*
- bcm_write_mem32( BCM_NICDRV_WOL_MBX, BCM_WOL_MAGIC_NUMBER |
- NIC_WOLDRV_STATE_SHUTDOWN |
- NIC_WOLDRV_WOL |
- NIC_WOLDRV_SET_MAGIC_PKT );
-*/
-
- /* switch to power state D3hot */
-/*
- reg_pwr_crtl |= 0x0103;
- SLOF_pci_config_write16(0x4c, reg_pwr_crtl);
- snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- 0x4c,
- reg_pwr_crtl );
- SLOF_msleep(10);
-*/
-
-#ifdef BCM_DEBUG
- reg_pwr_crtl = SLOF_pci_config_read16(0x4c);
- /*reg_pwr_crtl = snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- 0x4c );*/
-
- printf( "bcm57xx: PM Control/Status Register: %04X\n", reg_pwr_crtl );
-#endif
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: WOL activated" );
-#endif
-}
-
-static int
-bcm_init( net_driver_t *driver )
-{
- static const uint32_t lc_Maxwait_u32 = (uint32_t) 1000;
- uint32_t l_baseaddrL_u32;
- uint32_t l_baseaddrH_u32;
- uint32_t i;
- uint8_t *mac_addr = driver->mac_addr;
-
- if(driver->running != 0) {
- return 0;
- }
-#ifdef BCM_DEBUG
- printf( "bcm57xx: detected device " );
- if( IS_5703 ) {
- printf( "5703S\n" );
- } else if( IS_5704 ) {
- printf( "5704" );
-
- if( IS_SERDES ) {
- printf( "S\n" );
- } else {
- printf( "C\n" );
- }
-
- } else if( IS_5714 ) {
- printf( "5714\n" );
- }
-#endif
- /*
- * setup register & memory base addresses of NIC
- */
- l_baseaddrL_u32 = (uint32_t) ~0xf &
- (uint32_t) SLOF_pci_config_read32(PCI_BAR1_R);
- /*l_baseaddrL_u32 = ( (uint32_t) ~0xf &
- (uint32_t) snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_BAR1_R ) );*/
-
- l_baseaddrH_u32 = (uint32_t) SLOF_pci_config_read32(PCI_BAR2_R);
- /*l_baseaddrH_u32 =
- (uint32_t) snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_BAR2_R );*/
- bcm_baseaddr_u64 = (uint64_t) l_baseaddrH_u32;
- bcm_baseaddr_u64 <<= 32;
- bcm_baseaddr_u64 += (uint64_t) l_baseaddrL_u32;
- bcm_baseaddr_u64 =
- (uint64_t) SLOF_translate_my_address((void *)bcm_baseaddr_u64);
- /*snk_kernel_interface->translate_addr(((void *)&(bcm_baseaddr_u64)));*/
- bcm_memaddr_u64 = bcm_baseaddr_u64 + BCM_MEMORY_OFFS;
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: device's register base high address = 0x%08X\n", l_baseaddrH_u32 );
- printf( "bcm57xx: device's register base low address = 0x%08X\n", l_baseaddrL_u32 );
- printf( "bcm57xx: device's register address = 0x%llx\n", bcm_baseaddr_u64 );
-#endif
-
- /*
- * 57xx hardware initialization
- * BCM57xx Programmer's Guide: Section 8, "Initialization"
- * steps 1 through 101
- */
-
- // step 1: enable bus master & memory space in command reg
- i = ( BIT32( 10 ) | BIT32( 2 ) | BIT32( 1 ) );
- SLOF_pci_config_write16(PCI_COM_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_COM_R,
- ( int ) i );*/
- // step 2: disable & mask interrupts & enable pci byte/word swapping & enable indirect addressing mode
- i = ( BIT32( 8 ) | BIT32( 7 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
-
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
-
- /*
- * from now on access may be made through the local
- * read/write functions
- */
-
- // step 3: Save ahche line size register
- // omitted, because register is not used for 5704
-
- // step 4: acquire the nvram lock
- if( bcm_nvram_lock() != 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: locking NVRAM failed\n" );
-#endif
- return -1;
- }
-
- // step 5: prepare the chip for writing TG3_MAGIC_NUMBER
- bcm_setb_reg32( MEMARB_MODE_R, BIT32( 1 ) );
- i = ( BIT32( 8 ) | BIT32( 7 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
- bcm_write_reg32( MODE_CTRL_R, BIT32( 23 ) | BIT32( 20 ) |
- BIT32( 17 ) | BIT32( 16 ) |
- BIT32( 14 ) | BIT32( 13 ) |
- BIT32( 5 ) | BIT32( 4 ) |
- BIT32( 2 ) | BIT32( 1 ) );
-
- // step 6: write TG3_MAGIC_NUMBER
- bcm_write_mem32( BCM_FW_MBX, BCM_MAGIC_NUMBER );
-
- // step 7: reset core clocks
-
- if( IS_5714 ) {
- bcm_setb_reg32( MISC_CFG_R, BIT32( 26 ) | BIT32( 0 ) );
- } else {
- bcm_setb_reg32( MISC_CFG_R, BIT32( 0 ) );
- }
- // step 8
- SLOF_msleep( 20 );
-
- // step 9: disable & mask interrupts & enable indirect addressing mode &
- // enable pci byte/word swapping initialize the misc host control register
- i = ( BIT32( 8 ) | BIT32( 7 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
-
- // step 10: set but master et cetera
- i = ( BIT32( 10 ) | BIT32( 2 ) | BIT32( 1 ) );
- SLOF_pci_config_write16(PCI_COM_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_COM_R,
- ( int ) i );*/
-
- // step 11: disable PCI-X relaxed ordering
- bcm_clrb_reg16( PCI_X_COM_R, BIT16( 1 ) );
-
- // step 12: enable the MAC memory arbiter
- bcm_setb_reg32( MEMARB_MODE_R, BIT32( 1 ) );
-
- // step 13: omitted, only for BCM5700
- // step 14: s. step 10
- i = ( BIT32( 8 ) | BIT32( 7 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
- // step 15: set byte swapping (incl. step 27/28/29/30)
- // included prohibition of tx/rx interrupts
- bcm_write_reg32( MODE_CTRL_R, BIT32( 23 ) | BIT32( 20 ) |
- BIT32( 17 ) | BIT32( 16 ) |
- BIT32( 14 ) | BIT32( 13 ) |
- BIT32( 5 ) | BIT32( 4 ) |
- BIT32( 2 ) | BIT32( 1 ) );
- // step 16: omitted
- i = 1000;
- while( ( --i ) &&
- ( bcm_read_mem32( BCM_FW_MBX ) != ~BCM_MAGIC_NUMBER ) ) {
-#ifdef BCM_DEBUG
- printf( "." );
-#endif
- SLOF_msleep( 1 );
- }
-
- // return on error
- if( bcm_read_mem32( BCM_FW_MBX ) != ~BCM_MAGIC_NUMBER ) {
- printf( "bootcode not loaded: %x\n", bcm_read_mem32( BCM_FW_MBX ) );
-#ifdef BCM_DEBUG
- printf( "failed\n" );
-#endif
- return -1;
- }
-
-
- // if ASF Firmware enabled
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_START );
- SLOF_msleep( 10 );
-
- // step 17: write ethernet mac mode register
- /*
- * WY 07.02.07
- * omitted for correct SOL function
- */
- /*
- if( IS_SERDES ) {
- bcm_write_reg32( ETH_MAC_MODE_R, (uint32_t) 0xc );
- } else {
- bcm_write_reg32( ETH_MAC_MODE_R, (uint32_t) 0x0 );
- }
- */
-
- // step 18/19: omitted
- // step 20: enable hw bugfix for 5704
- if( IS_5704 || IS_5703 ) {
- bcm_setb_reg32( MSG_DATA_R, BIT32( 26 ) |
- BIT32( 28 ) |
- BIT32( 29 ) );
- }
-
- // step 21: omitted
- // step 22: omitted
- // step 23: 5704 clear statistics block
- if( IS_5703 || IS_5704 ) {
- memset_ci( (void *) ( bcm_memaddr_u64 + BCM_STATISTIC_OFFS ),
- 0,
- BCM_STATISTIC_SIZE );
- }
-
- // step 24/25: omitted
- // step 26: set DMA Read/Write Control register
- // NOTE: recommended values from the spec are used here
- if( IS_5714 ) {
- bcm_write_reg32( DMA_RW_CTRL_R, DMA_RW_CTRL_VAL_5714 );
- } else {
- uint32_t l_PCIState_u32 = bcm_read_reg32( PCI_STATE_R );
- uint32_t l_DMAVal_u32 = DMA_RW_CTRL_VAL;
-
- if( ( l_PCIState_u32 & BIT32( 2 ) ) != 0 ) { // PCI
- l_DMAVal_u32 |= (uint32_t) 0x300000;
- } else { // PCI-X
- l_DMAVal_u32 |= (uint32_t) 0x900000;
-
- if( ( bcm_read_reg32( PCI_CLK_CTRL_R ) & (uint32_t) 0x1f )
- >= (uint32_t) 6 ) {
- l_DMAVal_u32 |= (uint32_t) 0x4000;
- }
-
- }
-
- bcm_write_reg32( DMA_RW_CTRL_R, l_DMAVal_u32 );
- }
-
- // step 27/28/29: s. step 14
-
- // step 30: Configure TCP/UDP pseudo header checksum offloading
- // already done in step 14: offloading disabled
-
- // step 31: setup timer prescaler
- i = bcm_read_reg32( MISC_CFG_R );
- i &= (uint32_t) ~0xfe; // clear bits 7-1 first
- i |= ( BCM_TMR_PRESCALE << 1 );
- bcm_write_reg32( MISC_CFG_R, i );
-
- // step 32: 5703/4 configure Mbuf pool address/length
- // step 33: 5703/4 configure MAC DMA resource pool
- // step 34: configure MAC memory pool watermarks
- // step 35: 5703/4 configure DMA resource watermarks
- // using recommended settings (hard coded)
- if( IS_5703 || IS_5704 ) {
-
- if( IS_5703 ) {
- bcm_write_reg32( MBUF_POOL_ADDR_R, (uint32_t) 0x8000 );
- bcm_write_reg32( MBUF_POOL_LEN_R, (uint32_t) 0x18000 );
- } else {
- bcm_write_reg32( MBUF_POOL_ADDR_R, (uint32_t) 0x10000 );
- bcm_write_reg32( MBUF_POOL_LEN_R, (uint32_t) 0x10000 );
- }
-
- bcm_write_reg32( DMA_DESC_POOL_ADDR_R, (uint32_t) 0x2000 );
- bcm_write_reg32( DMA_DESC_POOL_LEN_R, (uint32_t) 0x2000 );
-
- bcm_write_reg32( DMA_RMBUF_LOW_WMARK_R, (uint32_t) 0x50 );
- bcm_write_reg32( MAC_RXMBUF_LOW_WMARK_R, (uint32_t) 0x20 );
- bcm_write_reg32( MBUF_HIGH_WMARK_R, (uint32_t) 0x60 );
-
- bcm_write_reg32( DMA_DESC_LOW_WM_R, (uint32_t) 5 );
- bcm_write_reg32( DMA_DESC_HIGH_WM_R, (uint32_t) 10 );
- } else {
- bcm_write_reg32( DMA_RMBUF_LOW_WMARK_R, (uint32_t) 0x00 );
- bcm_write_reg32( MAC_RXMBUF_LOW_WMARK_R, (uint32_t) 0x10 );
- bcm_write_reg32( MBUF_HIGH_WMARK_R, (uint32_t) 0x60 );
- }
-
- // step 35: omitted
- // step 36: Configure flow control behaviour
- // using recommended settings (hard coded)
- bcm_write_reg32( LOW_WMARK_MAX_RXFRAM_R, (uint32_t) 0x02 );
-
- // step 37/38: enable buffer manager & wait for successful start
- bcm_setb_reg32( BUF_MAN_MODE_R, BIT32( 2 ) | BIT32( 1 ) );
-
- i = lc_Maxwait_u32;
- while( ( --i ) &&
- ( ( bcm_read_reg32( BUF_MAN_MODE_R ) & BIT32( 1 ) ) == 0 ) ) {
- SLOF_usleep( 10 );
- }
-
- // return on error
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: init step 38: enable buffer manager failed\n" );
-#endif
- return -1;
- }
-
- // step 39: enable internal hardware queues
- bcm_write_reg32( FTQ_RES_R, (uint32_t) ~0 );
- bcm_write_reg32( FTQ_RES_R, (uint32_t) 0 );
-
- // step 40/41/42: initialize rx producer ring
- bcm_init_rxprod_ring();
-
- // step 43: set rx producer ring replenish threshold
- // using recommended setting of maximum allocated BD's/8
- bcm_write_reg32( STD_RXPR_REP_THR_R, (uint32_t) BCM_MAX_RX_BUF / 8 );
-
- // step 44/45/46: initialize send rings
- bcm_init_tx_ring();
- bcm_init_rxret_ring();
-
- // steps 47-50 done in ring init functions
- // step 51: configure MAC unicast address
- bcm_nvram_init();
- if( bcm_mac_init( (uint8_t *) mac_addr ) < 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: init step 51: configure MAC unicast address failed\n" );
-#endif
- return -1;
- }
- memcpy(driver->mac_addr, mac_addr, 6);
-
- // step 52: configure backoff random seed for transmit
- // using recommended algorithm
- i = (uint32_t) mac_addr[0] + (uint32_t) mac_addr[1] +
- (uint32_t) mac_addr[2] + (uint32_t) mac_addr[3] +
- (uint32_t) mac_addr[4] + (uint32_t) mac_addr[5];
- i &= (uint32_t) 0x03ff;
- bcm_write_reg32( ETH_TX_RND_BO_R, i );
-
- // step 53: configure message transfer unit MTU size
- bcm_write_reg32( RX_MTU_SIZE_R, (uint32_t) BCM_MTU_MAX_LEN );
-
- // step 54: configure IPG for transmit
- // using recommended value (through #define)
- bcm_write_reg32( TX_MAC_LEN_R, TX_MAC_LEN_VAL );
-
- // step 55: configure receive rules
-
- // set RX rule default class
- bcm_write_reg32( RX_RULE_CFG_R, RX_RULE_CFG_VAL );
-
- // step 56: configure the number of receive lists
- bcm_write_reg32( RX_LST_PLACE_CFG_R, RX_LST_PLC_CFG_VAL );
- bcm_write_reg32( RX_LST_PLACE_STAT_EN_R, RX_LST_PLC_STAT_EN_VAL );
-
-/*
- // rule 1: accept frames for our MAC address
- bcm_write_reg32( RX_RULE_CTRL_R ( 0 ),
- BIT32( 31 ) | // enable rule
- BIT32( 30 ) | // and with next
- BIT32( 26 ) | // split value register
- BIT32( 8 ) ); // class 1
- bcm_write_reg32( RX_RULE_VAL_R ( 0 ),
- (uint32_t) 0xffff0000 |
- ( bcm_read_reg32( MAC_ADDR_OFFS_HI(0) ) &
- (uint32_t) 0xffff ) );
-
- bcm_write_reg32( RX_RULE_CTRL_R ( 1 ),
- BIT32( 31 ) | // enable rule
- BIT32( 8 ) | // class 1
- BIT32( 1 ) ); // offset 2
- bcm_write_reg32( RX_RULE_VAL_R ( 1 ),
- bcm_read_reg32( MAC_ADDR_OFFS_LO(0) ) );
-
- // rule 2: accept broadcast frames
- bcm_write_reg32( RX_RULE_CTRL_R ( 2 ),
- BIT32( 31 ) | // enable rule
- BIT32( 30 ) | // and with next
- BIT32( 26 ) | // split value register
- BIT32( 8 ) ); // class 1
- bcm_write_reg32( RX_RULE_VAL_R ( 2 ),
- (uint32_t) ~0 );
-
- bcm_write_reg32( RX_RULE_CTRL_R ( 3 ),
- BIT32( 31 ) | // enable rule
- BIT32( 8 ) | // class 1
- BIT32( 1 ) ); // offset 2
- bcm_write_reg32( RX_RULE_VAL_R ( 3 ),
- (uint32_t) ~0 );
-*/
- for( i=0; i<NUM_RX_RULE_ASF; ++i) {
- bcm_write_reg32( RX_RULE_CTRL_R ( i ), 0 );
- bcm_write_reg32( RX_RULE_VAL_R ( i ), 0 );
- }
-
- // step 57-60: enable rx/tx statistics
- // omitted, no need for statistics (so far)
-
- // step 61/62: disable host coalescing engine/wait 20ms
- bcm_write_reg32( HOST_COAL_MODE_R, (uint32_t) 0 );
-
- i = lc_Maxwait_u32 * 2;
- while( ( --i ) &&
- ( bcm_read_reg32( HOST_COAL_MODE_R ) != 0 ) ) {
- SLOF_usleep( 10 );
- }
-
- // return on error
- if( i == 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: init step 62: disable host coal. engine failed\n" );
-#endif
- return -1;
- }
-
- // step 63-66: initialize coalescing engine
- // NOTE: status block is unused in this driver,
- // therefore the coal. engine status block
- // automatic update is disabled (by writing
- // 0 to every counter
- bcm_write_reg32( RX_COAL_TICKS_R, 0 );
- bcm_write_reg32( TX_COAL_TICKS_R, 0 );
- bcm_write_reg32( RX_COAL_MAX_BD_R, 0 );
- bcm_write_reg32( TX_COAL_MAX_BD_R, 0 );
- bcm_write_reg32( RX_COAL_TICKS_INT_R, 0 );
- bcm_write_reg32( TX_COAL_TICKS_INT_R, 0 );
- bcm_write_reg32( RX_COAL_MAX_BD_INT_R, 0 );
- bcm_write_reg32( TX_COAL_MAX_BD_INT_R, 0 );
-
- // step 67: initialize host status block address
- // NOTE: status block is not needed in this driver,
- // still it needs to be set up
- i = (uint32_t) ( (uint64_t) &bcm_status >> 32 );
- bcm_write_reg32( STB_HOST_ADDR_HI_R, i );
- i = (uint32_t) ( (uint64_t) &bcm_status & (uint64_t) 0xffffffff );
- bcm_write_reg32( STB_HOST_ADDR_LO_R, i );
-
- // 5704/3 adaption
- if( IS_5703 || IS_5704 ) {
- // step 68: 5704, for now omitted
- // step 69: 5704 set the statistics coalescing tick counter
- bcm_write_reg32( STAT_TICK_CNT_R, 0 );
- // step 70: 5704 configure statistics block address in NIC memory
- // using recommended values (hard coded)
- bcm_write_reg32( STAT_NIC_ADDR_R, (uint32_t) 0x300 );
- // step 71: 5704 configure status block address in NIC memory
- // using recommended values (hard coded)
- bcm_write_reg32( STB_NIC_ADDR_R, (uint32_t) 0xb00 );
- }
-
- // step 72: enable host coalescing engine
- bcm_setb_reg32( HOST_COAL_MODE_R, BIT32( 12 ) | BIT32( 11 ) | BIT32( 1 ) );
-
- // step 73: enable rx bd completion functional block
- bcm_write_reg32( RX_BD_COMPL_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
-
- // step 74: enable rx list placement functional block
- bcm_write_reg32( RX_LST_PLACE_MODE_R, BIT32( 1 ) );
- // 5704/3 adaption
- if( IS_5703 || IS_5704 ) {
- // step 75: 5704/3 enable receive list selector func block
- bcm_write_reg32( RX_LST_SEL_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
- }
-
- // step 76: enable DMA engines
- bcm_setb_reg32( ETH_MAC_MODE_R, BIT32( 23 ) | BIT32( 22 ) | BIT32( 21 ) );
- /*
- * WY 26.10.07 This is wrong for 5714, better leave it alone
- if( IS_5714 ) {
- bcm_setb_reg32( ETH_MAC_MODE_R, BIT32( 20 ) );
- }
- */
-
- // step 77: omitted, statistics are not used
- // step 78: Configure the General Misc Local Control register
- // NOTE: as known so far nothing needs to be done here,
- // default values should work fine
- //bcm_setb_reg32( MISC_LOCAL_CTRL_R, 0 );
-
- // step 79: clear interrupts in INT_MBX0_R low word
- bcm_write_reg32( INT_MBX0_R, 0 );
- // 5704/3 adaption
- // step 80: 5704/3 enable DMA completion functional block
- if( IS_5703 || IS_5704 ) {
- bcm_write_reg32( DMA_COMPL_MODE_R, BIT32( 1 ) );
- }
-
- // step 81/82: configure write/read DMA mode registers
- // disable MSI
- bcm_write_reg32( RD_DMA_MODE_R, BIT32( 10 ) | BIT32( 9 ) | BIT32( 8 ) |
- BIT32( 7 ) | BIT32( 6 ) | BIT32( 5 ) |
- BIT32( 4 ) | BIT32( 3 ) | BIT32( 2 ) |
- BIT32( 1 ) );
- bcm_write_reg32( WR_DMA_MODE_R, BIT32( 9 ) | BIT32( 8 ) | BIT32( 7 ) |
- BIT32( 6 ) | BIT32( 5 ) | BIT32( 4 ) |
- BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) );
- bcm_clrb_reg32( MSI_MODE_R, BIT32( 1 ) );
- SLOF_usleep( 100 );
-
- // step 83-91: enable all these functional blocks...
- bcm_write_reg32( RX_DAT_COMPL_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
-
- if( IS_5703 || IS_5704 ) {
- bcm_write_reg32( MBUF_CLSTR_FREE_MODE_R, BIT32( 1 ) );
- }
-
- bcm_write_reg32( TX_DAT_COMPL_MODE_R, BIT32( 1 ) );
- bcm_write_reg32( TX_BD_COMPL_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
- bcm_write_reg32( RX_BD_INIT_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
- bcm_write_reg32( RX_DAT_BD_INIT_MODE_R, BIT32( 1 ) );
- bcm_write_reg32( TX_DAT_INIT_MODE_R, BIT32( 1 ) | BIT32( 3 ) );
- bcm_write_reg32( TX_BD_INIT_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
- bcm_write_reg32( TX_BD_RING_SEL_MODE_R, BIT32( 1 ) | BIT32( 2 ) );
-
- // step 92: omitted
- // step 93/94: Enable Tx/Rx MAC
- bcm_setb_reg32( TX_MAC_MODE_R, BIT32( 1 ) );
-// bcm_setb_reg32( RX_MAC_MODE_R, BIT32( 1 ) | BIT32( 2 ) ); // set BIT32( 8 ) for promiscious mode!
- bcm_setb_reg32( RX_MAC_MODE_R, BIT32( 1 ) ); // set BIT32( 8 ) for promiscious mode!
- // set BIT32( 10) for VLAN
-
- // step 95: disable auto polling:
- // bcm_phy_init takes care of this
- // step 96: omitted
- // step 97: omitted, may change though, but is not important
- // step 98: activate link & enable MAC functional block
- // NOTE autopolling is enabled so bit 0 needs not to be set
- //bcm_setb_reg32( MI_STATUS_R, BIT32( 0 ) );
-
- // step 99: setup PHY
- // return if link is down
- if( bcm_phy_init() < 0 ) {
-#ifdef BCM_DEBUG
- printf( "bcm57xx: init step 99: PHY initialization failed\n" );
-#endif
- return -1;
- }
-
- // step 100: setup multicast filters
- bcm_write_reg32( MAC_HASH0_R, (uint32_t) 0 );
- bcm_write_reg32( MAC_HASH1_R, (uint32_t) 0 );
- bcm_write_reg32( MAC_HASH2_R, (uint32_t) 0 );
- bcm_write_reg32( MAC_HASH3_R, (uint32_t) 0 );
-/*
- // accept all multicast frames
- bcm_write_reg32( MAC_HASH0_R, (uint32_t) 0xffffffff );
- bcm_write_reg32( MAC_HASH1_R, (uint32_t) 0xffffffff );
- bcm_write_reg32( MAC_HASH2_R, (uint32_t) 0xffffffff );
- bcm_write_reg32( MAC_HASH3_R, (uint32_t) 0xffffffff );
-*/
- // step 101: omitted, no interrupts used
-
- // make initial receive buffers available for NIC
- // this step has to be done here after RX DMA engine has started (step 94)
- bcm_write_reg32( RXPROD_PROD_IND, BCM_MAX_RX_BUF );
-
- // if ASF Firmware enabled
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_START_DONE );
- SLOF_msleep( 10 );
-
- // enable heartbeat timer
-
- bcm_write_reg32( ASF_HEARTBEAT_TIMER_R, 0x5 );
-
- driver->running = 1;
- // off we go..
- return 0;
-}
-
-static int
-bcm_reset( void )
-{
- uint32_t i;
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: resetting controller.." );
-#endif
-
- bcm_write_mem32( BCM_FW_MBX, BCM_MAGIC_NUMBER );
-
- if( IS_5714 ) {
- bcm_setb_reg32( MISC_CFG_R, BIT32( 26 ) | BIT32( 0 ) );
- } else {
- bcm_setb_reg32( MISC_CFG_R, BIT32( 0 ) );
- }
-
- SLOF_msleep( 20 );
-
- /*
- * after reset local read/write functions cannot be used annymore
- * until bus master & stuff is set up again
- */
-
- i = ( BIT32( 10 ) | BIT32( 2 ) | BIT32( 1 ) );
- SLOF_pci_config_write16(PCI_COM_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_COM_R,
- ( int ) i );*/
-
- // step 9 & 13: disable & mask interrupts & enable indirect addressing mode &
- // enable pci byte/word swapping initialize the misc host control register
- i = ( BIT32( 7 ) | BIT32( 5 ) | BIT32( 4 ) |
- BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
-
- // step 16: poll for bootcode completion by waiting for the one's
- // complement of the magic number previously written
- i = 1000;
- while( ( --i ) &&
- ( bcm_read_mem32( BCM_FW_MBX ) != ~BCM_MAGIC_NUMBER ) ) {
-#ifdef BCM_DEBUG
- printf( "." );
-#else
- SLOF_msleep( 1 );
-#endif
- }
-
- // return on error
- if( bcm_read_mem32( BCM_FW_MBX ) != ~BCM_MAGIC_NUMBER ) {
-#ifdef BCM_DEBUG
- printf( "failed\n" );
-#endif
- return -1;
- }
-
-#ifdef BCM_DEBUG
- printf( "done\n" );
-#endif
- return 0;
-}
-
-static int
-bcm_term( void )
-{
- uint32_t i;
- uint16_t v;
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: driver shutdown.." );
-#endif
-
- /*
- * halt ASF firmware
- */
- bcm_fw_halt();
-
- /*
- * unload ASF firmware
- */
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_UNLOAD );
-
- /*
- * disable RX producer rings
- */
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_JUM ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_JUM ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_JUM ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_JUM ), 0 );
-
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_STD ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_STD ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_STD ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_STD ), 0 );
-
- bcm_write_reg32( BCM_RCB_LENFLAG_u16( BCM_RXPROD_RCB_MIN ), RCB_FLAG_RING_DISABLED );
- bcm_write_reg32( BCM_RCB_HOSTADDR_HI_u16( BCM_RXPROD_RCB_MIN ), 0 );
- bcm_write_reg32( BCM_RCB_HOSTADDR_LOW_u16( BCM_RXPROD_RCB_MIN ), 0 );
- bcm_write_reg32( BCM_RCB_NICADDR_u16( BCM_RXPROD_RCB_MIN ), 0 );
-
- /*
- * disable RX return rings
- */
- v = BCM_RXRET_RCB_OFFS;
- for( i = 0; i < BCM_MAX_RXRET_RING; i++ ) {
- bcm_write_mem32( BCM_RCB_LENFLAG_u16( v ), RCB_FLAG_RING_DISABLED );
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( v ), 0 );
-
- v += BCM_RCB_SIZE_u16;
- }
-
- /*
- * disable TX rings
- */
- v = BCM_TX_RCB_OFFS;
- for( i = 0; i < BCM_MAX_TX_RING; i++ ) {
- bcm_write_mem32( BCM_RCB_LENFLAG_u16( v ), RCB_FLAG_RING_DISABLED );
- bcm_write_mem32( BCM_RCB_HOSTADDR_HI_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_HOSTADDR_LOW_u16( v ), 0 );
- bcm_write_mem32( BCM_RCB_NICADDR_u16( v ), 0 );
-
- v += BCM_RCB_SIZE_u16;
- }
-
- /*
- * remove receive rules
- */
- bcm_write_reg32( RX_RULE_CTRL_R ( 0 ), 0 );
- bcm_write_reg32( RX_RULE_VAL_R ( 0 ), 0 );
- bcm_write_reg32( RX_RULE_CTRL_R ( 1 ), 0 );
- bcm_write_reg32( RX_RULE_VAL_R ( 1 ), 0 );
-
- /*
- * shutdown sequence
- * BCM57xx Programmer's Guide: Section 8, "Shutdown"
- * the enable bit of every state machine of the 57xx
- * has to be reset.
- */
-
- /*
- * receive path shutdown sequence
- */
- bcm_clr_wait_bit32( RX_MAC_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RX_LST_PLACE_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RX_BD_INIT_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RX_DAT_BD_INIT_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RX_DAT_COMPL_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RX_BD_COMPL_MODE_R, BIT32( 1 ) );
-
- if( IS_5704 || IS_5703 ) {
- bcm_clr_wait_bit32( RX_LST_SEL_MODE_R, BIT32( 1 ) );
- }
-
- /*
- * transmit path & memory shutdown sequence
- */
- bcm_clr_wait_bit32( TX_BD_RING_SEL_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( TX_BD_INIT_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( TX_DAT_INIT_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( RD_DMA_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( TX_DAT_COMPL_MODE_R, BIT32( 1 ) );
-
- if( IS_5704 ) {
- bcm_clr_wait_bit32( DMA_COMPL_MODE_R, BIT32( 1 ) );
- }
-
- bcm_clr_wait_bit32( TX_BD_COMPL_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( ETH_MAC_MODE_R, BIT32( 21 ) );
- bcm_clr_wait_bit32( TX_MAC_MODE_R, BIT32( 1 ) );
-
- bcm_clr_wait_bit32( HOST_COAL_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( WR_DMA_MODE_R, BIT32( 1 ) );
-
- if( IS_5704 || IS_5703 ) {
- bcm_clr_wait_bit32( MBUF_CLSTR_FREE_MODE_R, BIT32( 1 ) );
- }
-
- bcm_write_reg32( FTQ_RES_R, (uint32_t) ~0 );
- bcm_write_reg32( FTQ_RES_R, (uint32_t) 0 );
-
- if( IS_5704 || IS_5703 ) {
- bcm_clr_wait_bit32( BUF_MAN_MODE_R, BIT32( 1 ) );
- bcm_clr_wait_bit32( MEMARB_MODE_R, BIT32( 1 ) );
- }
-
-#ifdef BCM_DEBUG
- printf( "done.\n" );
-#endif
- /*
- * controller reset
- */
- if( bcm_reset() != 0 ) {
- return -1;
- }
-
- /*
- * restart ASF firmware
- */
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_UNLOAD );
- SLOF_msleep( 10 );
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_UNLOAD_DONE );
- SLOF_msleep( 100 );
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_START );
- SLOF_msleep( 10 );
- bcm_write_mem32( BCM_NICDRV_STATE_MBX, NIC_FWDRV_STATE_START_DONE );
-
- /*
- * activate Wake-on-LAN
- */
- bcm_wol_activate();
-
- /*
- * PCI shutdown
- */
- bcm_clrb_reg32( PCI_MISC_HCTRL_R, BIT32( 3 ) | BIT32( 2 ) );
-
- /*
- * from now on local rw functions cannot be used anymore
- */
-
-// bcm_clrb_reg32( PCI_COM_R, BIT32( 10 ) | BIT32( 2 ) | BIT32( 1 ) );
-
- SLOF_pci_config_write32(PCI_COM_R, BIT32(8) | BIT32(6));
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_COM_R,
- BIT32(8) | BIT32(6) );*/
-
- // no more networking...
- return 0;
-}
-
-static int
-bcm_getmac(uint32_t addr, char mac[6])
-{
- uint32_t t1, t2;
- uint64_t t3;
-
- if (bcm_nvram_read(addr, &t1, 1) != 0)
- return -1;
- if (bcm_nvram_read(addr+4, &t2, 1) != 0)
- return -1;
- t3 = ((uint64_t)t1 << 32) + t2;
-
- mac[0] = (t3 >> 40) & 0xFF;
- mac[1] = (t3 >> 32) & 0xFF;
- mac[2] = (t3 >> 24) & 0xFF;
- mac[3] = (t3 >> 16) & 0xFF;
- mac[4] = (t3 >> 8) & 0xFF;
- mac[5] = (t3 >> 0) & 0xFF;
-
- return 0;
-}
-
-static char*
-print_itoa(char *text, uint32_t value)
-{
- if(value >= 10)
- text = print_itoa(text, value / 10);
- *text = '0' + (value % 10);
- ++text;
- return text;
-}
-
-static int
-bcm_get_version(char *text)
-{
- uint32_t t1;
-
- if (bcm_nvram_read(0x94, &t1, 1) != 0)
- return -1;
-
- text = print_itoa(text, (t1 >> 8) & 0xFF);
- text[0] = '.';
- text = print_itoa(&text[1], t1 & 0xFF);
- text[0] = '\n';
- return 0;
-}
-
-static uint32_t
-util_gen_crc( char *pcDatabuf, uint32_t ulDatalen, uint32_t ulCrc_in)
-{
- unsigned char data;
- uint32_t idx, bit, crc = ulCrc_in;
-
- for(idx = 0; idx < ulDatalen; idx++) {
- data = *pcDatabuf++;
- for(bit = 0; bit < 8; bit++, data >>= 1) {
- crc = (crc >> 1) ^ (((crc ^ data) & 1) ?
- CRC32_POLYNOMIAL : 0);
- }
- }
- return bswap_32(~crc);
-}
-
-static int
-bcm_setmac(char mac_addr1[6], char mac_addr2[6])
-{
- uint64_t mac1 = 0, mac2 = 0;
- uint32_t manu[MANUFACTURING_INFO_SIZE/4];
- int addr, i;
- uint32_t crc, val1, val2, val3, val4;
-
-#ifdef BCM_DEBUG
- printf("Flashing MAC 1: %02X:%02X:%02X:%02X:%02X:%02X\n",
- ((unsigned int) mac_addr1[0]) & 0xFF,
- ((unsigned int) mac_addr1[1]) & 0xFF,
- ((unsigned int) mac_addr1[2]) & 0xFF,
- ((unsigned int) mac_addr1[3]) & 0xFF,
- ((unsigned int) mac_addr1[4]) & 0xFF,
- ((unsigned int) mac_addr1[5]) & 0xFF);
-
- printf("Flashing MAC 2: %02X:%02X:%02X:%02X:%02X:%02X\n",
- ((unsigned int) mac_addr2[0]) & 0xFF,
- ((unsigned int) mac_addr2[1]) & 0xFF,
- ((unsigned int) mac_addr2[2]) & 0xFF,
- ((unsigned int) mac_addr2[3]) & 0xFF,
- ((unsigned int) mac_addr2[4]) & 0xFF,
- ((unsigned int) mac_addr2[5]) & 0xFF);
-#endif
-
- mac1 |= ((uint64_t) mac_addr1[0]) & 0xFF; mac1 = mac1 << 8;
- mac1 |= ((uint64_t) mac_addr1[1]) & 0xFF; mac1 = mac1 << 8;
- mac1 |= ((uint64_t) mac_addr1[2]) & 0xFF; mac1 = mac1 << 8;
- mac1 |= ((uint64_t) mac_addr1[3]) & 0xFF; mac1 = mac1 << 8;
- mac1 |= ((uint64_t) mac_addr1[4]) & 0xFF; mac1 = mac1 << 8;
- mac1 |= ((uint64_t) mac_addr1[5]) & 0xFF;
-
- mac2 |= ((uint64_t) mac_addr2[0]) & 0xFF; mac2 = mac2 << 8;
- mac2 |= ((uint64_t) mac_addr2[1]) & 0xFF; mac2 = mac2 << 8;
- mac2 |= ((uint64_t) mac_addr2[2]) & 0xFF; mac2 = mac2 << 8;
- mac2 |= ((uint64_t) mac_addr2[3]) & 0xFF; mac2 = mac2 << 8;
- mac2 |= ((uint64_t) mac_addr2[4]) & 0xFF; mac2 = mac2 << 8;
- mac2 |= ((uint64_t) mac_addr2[5]) & 0xFF;
-
- /* Extract the manufacturing data, starts at 0x74 */
- if(bcm_nvram_lock() == -1) {
- return -1;
- }
-
- addr = 0x74;
- for (i = 0; i < (MANUFACTURING_INFO_SIZE/4); i++) {
- if (bcm_nvram_read(addr, &manu[i], 0) != 0) {
- printf("\nREAD FAILED\n");
- bcm_nvram_unlock();
- return -1;
- }
- addr+=4;
- }
- bcm_nvram_unlock();
-
- /* Store the new MAC address in the manufacturing data */
- val1 = mac1 >> 32;
- val2 = mac1 & 0xFFFFFFFF;
- val3 = mac2 >> 32;
- val4 = mac2 & 0xFFFFFFFF;
- manu[(0x7C-0x74)/4] = val1;
- manu[(0x80-0x74)/4] = val2;
- manu[(0xCC-0x74)/4] = val3;
- manu[(0xD0-0x74)/4] = val4;
-
- /* Calculate the new manufacturing datas CRC */
- crc = util_gen_crc(((char *)manu),
- MANUFACTURING_INFO_SIZE - 4, 0xFFFFFFFF);
-
- /* Now write the new MAC addresses and CRC */
- if ((bcm_nvram_write(0x7C, val1, 1) != 0) ||
- (bcm_nvram_write(0x80, val2, 1) != 0) ||
- (bcm_nvram_write(0xCC, val3, 1) != 0) ||
- (bcm_nvram_write(0xD0, val4, 1) != 0) ||
- (bcm_nvram_write(0xFC, crc, 1) != 0) )
- {
- /* Disastor ! */
-#ifdef BCM_DEBUG
- printf("failed to write MAC address\n");
-#endif
- return -1;
- }
-
- /* Success !!!! */
- return 0;
-}
-
-static int
-bcm_ioctl( int request, void* data )
-{
- uint32_t l_baseaddrL_u32;
- uint32_t l_baseaddrH_u32;
- uint32_t i;
- int ret_val = 0;
- char mac_addr[6];
- ioctl_net_data_t *ioctl_data = (ioctl_net_data_t*) data;
-
- if(request != SIOCETHTOOL) {
- return -1;
- }
-
-#ifdef BCM_DEBUG
- printf( "bcm57xx: detected device " );
- if( IS_5703 ) {
- printf( "5703S" );
- } else if( IS_5704 ) {
- printf( "5704" );
- if( IS_SERDES ) {
- printf( "S\n" );
- } else {
- printf( "C\n" );
- }
- } else if( IS_5714 ) {
- printf( "5714\n" );
- }
-#endif
- /*
- * setup register & memory base addresses of NIC
- */
- l_baseaddrL_u32 = (uint32_t) ~0xf &
- SLOF_pci_config_read32(PCI_BAR1_R);
- /*l_baseaddrL_u32 = ( (uint32_t) ~0xf &
- (uint32_t) snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_BAR1_R ) );*/
-
- l_baseaddrH_u32 = SLOF_pci_config_read32(PCI_BAR2_R);
- /*l_baseaddrH_u32 =
- (uint32_t) snk_kernel_interface->pci_config_read( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_BAR2_R );*/
-
- bcm_baseaddr_u64 = (uint64_t) l_baseaddrH_u32;
- bcm_baseaddr_u64 <<= 32;
- bcm_baseaddr_u64 += (uint64_t) l_baseaddrL_u32;
- bcm_baseaddr_u64 =
- (uint64_t)SLOF_translate_my_address((void *)bcm_baseaddr_u64);
- /*snk_kernel_interface->translate_addr(((void *)&(bcm_baseaddr_u64)));*/
- bcm_memaddr_u64 = bcm_baseaddr_u64 + BCM_MEMORY_OFFS;
-
- /*
- * 57xx hardware initialization
- * BCM57xx Programmer's Guide: Section 8, "Initialization"
- * steps 1 through 101
- */
-
- // step 1: enable bus master & memory space in command reg
- i = ( BIT32( 10 ) | BIT32( 2 ) | BIT32( 1 ) );
- SLOF_pci_config_write16(PCI_COM_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 2,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_COM_R,
- ( int ) i );*/
-
- // step 2: disable & mask interrupts & enable pci byte/word swapping & enable indirect addressing mode
- i = ( BIT32( 7 ) | BIT32( 3 ) | BIT32( 2 ) | BIT32( 1 ) | BIT32( 0 ) );
- SLOF_pci_config_write32(PCI_MISC_HCTRL_R, i);
- /*snk_kernel_interface->pci_config_write( bcm_pcicfg_puid,
- 4,
- bcm_pcicfg_bus,
- bcm_pcicfg_devfn,
- PCI_MISC_HCTRL_R,
- ( int ) i );*/
-
- bcm_nvram_init();
-
- switch(ioctl_data->subcmd) {
- case ETHTOOL_GMAC:
- switch(ioctl_data->data.mac.idx) {
- case 0:
- ret_val = bcm_getmac(0x7C, ioctl_data->data.mac.address);
- break;
- case 1:
- ret_val = bcm_getmac(0xCC, ioctl_data->data.mac.address);
- break;
- default:
- ret_val = -1;
- break;
- }
- break;
- case ETHTOOL_SMAC:
- switch(ioctl_data->data.mac.idx) {
- case 0:
- ret_val = bcm_getmac(0xCC, mac_addr);
- if(ret_val == 0)
- ret_val = bcm_setmac(ioctl_data->data.mac.address, mac_addr);
- break;
- case 1:
- ret_val = bcm_getmac(0x7C, mac_addr);
- if(ret_val == 0)
- ret_val = bcm_setmac(mac_addr, ioctl_data->data.mac.address);
- break;
- default:
- ret_val = -1;
- break;
- }
- break;
- case ETHTOOL_VERSION: {
- char *text = ioctl_data->data.version.text;
- memcpy(text, " BCM57xx Boot code level: ", 27);
- ret_val = bcm_get_version(&text[27]);
- break;
- }
- default:
- ret_val = -1;
- break;
- }
-
- bcm_term();
- return ret_val;
-}
-
-net_driver_t *bcm57xx_open(void)
-{
- net_driver_t *driver;
- uint16_t vendor_id, device_id;
-
- vendor_id = SLOF_pci_config_read16(0);
- device_id = SLOF_pci_config_read16(2);
- if (check_driver(vendor_id, device_id))
- return NULL;
-
- driver = SLOF_alloc_mem(sizeof(*driver));
- if (!driver) {
- printf("Unable to allocate virtio-net driver\n");
- return NULL;
- }
- memset(driver, 0, sizeof(*driver));
-
- if (bcm_init(driver))
- goto FAIL;
-
- return driver;
-
-FAIL: SLOF_free_mem(driver, sizeof(*driver));
- return NULL;
-
- return 0;
-}
-
-void bcm57xx_close(net_driver_t *driver)
-{
- if (driver->running == 0)
- return;
-
- bcm_term();
- driver->running = 0;
- SLOF_free_mem(driver, sizeof(*driver));
-}
-
-int bcm57xx_read(char *buf, int len)
-{
- if (buf)
- return bcm_receive(buf, len);
- return -1;
-}
-
-int bcm57xx_write(char *buf, int len)
-{
- if (buf)
- return bcm_xmit(buf, len);
- return -1;
-}
diff --git a/qemu/roms/SLOF/lib/libbcm/bcm57xx.h b/qemu/roms/SLOF/lib/libbcm/bcm57xx.h
deleted file mode 100644
index efaba60c6..000000000
--- a/qemu/roms/SLOF/lib/libbcm/bcm57xx.h
+++ /dev/null
@@ -1,323 +0,0 @@
-/******************************************************************************
- * Copyright (c) 2004, 2008 IBM Corporation
- * All rights reserved.
- * This program and the accompanying materials
- * are made available under the terms of the BSD License
- * which accompanies this distribution, and is available at
- * http://www.opensource.org/licenses/bsd-license.php
- *
- * Contributors:
- * IBM Corporation - initial implementation
- *****************************************************************************/
-
-#include <cache.h>
-#include <netdriver.h>
-
-// Debug switches
-//#define BCM_DEBUG // main debug switch, w/o it the other ones don't work
-//#define BCM_SHOW_RCV
-//#define BCM_SHOW_RCV_DATA
-//#define BCM_SHOW_XMIT
-//#define BCM_SHOW_XMIT_DATA
-//#define BCM_SHOW_XMIT_STATS
-//#define BCM_SHOW_IDX
-//#define BCM_SHOW_STATS
-//#define BCM_SHOW_ASF_REGS
-
-// Switch to enable SW AUTO-NEG
-// don't try, it's still incomplete
-//#define BCM_SW_AUTONEG
-
-/*
- * used register offsets
- */
-// PCI command register
-#define PCI_COM_R ( (uint16_t) 0x0004 )
-// PCI Cache Line Size register
-#define PCI_CACHELS_R ( (uint16_t) 0x000c )
-// PCI bar1 register
-#define PCI_BAR1_R ( (uint16_t) 0x0010 )
-// PCI bar2 register
-#define PCI_BAR2_R ( (uint16_t) 0x0014 )
-// PCI bar1 register
-#define PCI_SUBID_R ( (uint16_t) 0x002e )
-// PCI-X Comand register
-#define PCI_X_COM_R ( (uint16_t) 0x0042 )
-// Message Data Register
-#define MSG_DATA_R ( (uint16_t) 0x0064 )
-// PCI misc host contrl register
-#define PCI_MISC_HCTRL_R ( (uint16_t) 0x0068 )
-// DMA Read/Write Control register
-#define DMA_RW_CTRL_R ( (uint16_t) 0x006c )
-// PCI State register
-#define PCI_STATE_R ( (uint16_t) 0x0070 )
-// PCI_Clock Control register
-#define PCI_CLK_CTRL_R ( (uint16_t) 0x0074 )
-// Register Base Address Register
-#define REG_BASE_ADDR_REG ( (uint16_t) 0x0078 )
-// Memory Window Base Address Register
-#define MEM_BASE_ADDR_REG ( (uint16_t) 0x007c )
-// Register Data Register
-#define REG_DATA_REG ( (uint16_t) 0x0080 )
-// Memory Window Data Register
-#define MEM_DATA_REG ( (uint16_t) 0x0084 )
-// MAC Function register
-#define MAC_FUNC_R ( (uint16_t) 0x00b8 )
-// Interrupt Mailbox 0 register
-#define INT_MBX0_R ( (uint16_t) 0x0204 )
-// Ethernet MAC Mode register
-#define ETH_MAC_MODE_R ( (uint16_t) 0x0400 )
-// Ethernet MAC Addresses registers
-#define MAC_ADDR_OFFS_HI( idx ) ( (uint16_t) ( (idx*2 + 0)*sizeof( uint32_t ) + 0x0410 ) )
-#define MAC_ADDR_OFFS_LO( idx ) ( (uint16_t) ( (idx*2 + 1)*sizeof( uint32_t ) + 0x0410 ) )
-// Ethernet MAC Status register
-#define ETH_MAC_STAT_R ( (uint16_t) 0x0404 )
-// Ethernet MAC Event Enable register
-#define ETH_MAC_EVT_EN_R ( (uint16_t) 0x0408 )
-// Ethernet Transmit Random Backoff register
-#define ETH_TX_RND_BO_R ( (uint16_t) 0x0438 )
-// Receive MTU Size register
-#define RX_MTU_SIZE_R ( (uint16_t) 0x043c )
-// Transmit 1000BASE-X Auto Negotiation register
-#define TX_1000BX_AUTONEG_R ( (uint16_t) 0x0444 )
-// Receive 1000BASE-X Auto Negotiation register
-#define RX_1000BX_AUTONEG_R ( (uint16_t) 0x0448 )
-// MI Communication register
-#define MI_COM_R ( (uint16_t) 0x044c )
-// MI Status Register
-#define MI_STATUS_R ( (uint16_t) 0x0450 )
-// MI Mode register
-#define MI_MODE_R ( (uint16_t) 0x0454 )
-// Transmit MAC Mode register
-#define TX_MAC_MODE_R ( (uint16_t) 0x045c )
-// Transmit MAC Length register
-#define TX_MAC_LEN_R ( (uint16_t) 0x0464 )
-// Receive MAC Mode register
-#define RX_MAC_MODE_R ( (uint16_t) 0x0468 )
-// MAC Hash 0 register* VPD Config:
-#define MAC_HASH0_R ( (uint16_t) 0x0470 )
-// MAC Hash 1 register
-#define MAC_HASH1_R ( (uint16_t) 0x0474 )
-// MAC Hash 2 register
-#define MAC_HASH2_R ( (uint16_t) 0x0478 )
-// MAC Hash 3 register
-#define MAC_HASH3_R ( (uint16_t) 0x047c )
-// Receive Rules Control register
-#define RX_RULE_CTRL_R( idx ) ( (uint16_t) ( idx*8 + 0x0480 ) )
-// Receive Rules Value register
-#define RX_RULE_VAL_R( idx ) ( (uint16_t) ( idx*8 + 0x0484 ) )
-// Receive Rules Configuration register
-#define RX_RULE_CFG_R ( (uint16_t) 0x0500 )
-// Low Watermark Max Receive Frames register
-#define LOW_WMARK_MAX_RXFRAM_R ( (uint16_t) 0x0504 )
-// SerDes Control Register
-#define SERDES_CTRL_R ( (uint16_t) 0x0590 )
-// Hardware Auto Negotiation Control Register
-#define HW_AUTONEG_CTRL_R ( (uint16_t) 0x05B0 )
-// Hardware Auto Negotiation Status Register
-#define HW_AUTONEG_STAT_R ( (uint16_t) 0x05B4 )
-// Send Data Initiator Mode register
-#define TX_DAT_INIT_MODE_R ( (uint16_t) 0x0c00 )
-// Send Data Completion Mode register
-#define TX_DAT_COMPL_MODE_R ( (uint16_t) 0x1000 )
-// Send BD Ring Selector Mode register
-#define TX_BD_RING_SEL_MODE_R ( (uint16_t) 0x1400 )
-// Send BD Initiator Mode register
-#define TX_BD_INIT_MODE_R ( (uint16_t) 0x1800 )
-// Send BD Completion Mode register
-#define TX_BD_COMPL_MODE_R ( (uint16_t) 0x1c00 )
-// Receive List Placement Mode register
-#define RX_LST_PLACE_MODE_R ( (uint16_t) 0x2000 )
-// Receive List Placement Configuration register
-#define RX_LST_PLACE_CFG_R ( (uint16_t) 0x2010 )
-// Receive List Placement Statistics Enable Mask register
-#define RX_LST_PLACE_STAT_EN_R ( (uint16_t) 0x2018 )
-// Receive Data & Receive BD Initiator Mode register
-#define RX_DAT_BD_INIT_MODE_R ( (uint16_t) 0x2400 )
-// Receive Data Completion Mode register
-#define RX_DAT_COMPL_MODE_R ( (uint16_t) 0x2800 )
-// Receive BD Initiator Mode register
-#define RX_BD_INIT_MODE_R ( (uint16_t) 0x2c00 )
-// Standard Receive Producer Ring Replenish Threshold register
-#define STD_RXPR_REP_THR_R ( (uint16_t) 0x2c18 )
-// Receive BD Completion Mode register
-#define RX_BD_COMPL_MODE_R ( (uint16_t) 0x3000 )
-// Receive List Selector Mode register
-#define RX_LST_SEL_MODE_R ( (uint16_t) 0x3400 )
-// MBUF Cluster Free Mode register
-#define MBUF_CLSTR_FREE_MODE_R ( (uint16_t) 0x3800 )
-// Host Coalescing Mode register
-#define HOST_COAL_MODE_R ( (uint16_t) 0x3c00 )
-// Receive Coalescing Ticks register
-#define RX_COAL_TICKS_R ( (uint16_t) 0x3c08 )
-// Send Coalescing Ticks register
-#define TX_COAL_TICKS_R ( (uint16_t) 0x3c0c )
-// Receive Max Coalesced BD Count register
-#define RX_COAL_MAX_BD_R ( (uint16_t) 0x3c10 )
-// Send Max Coalesced BD Count register
-#define TX_COAL_MAX_BD_R ( (uint16_t) 0x3c14 )
-// Receive Coalescing Ticks During Int register
-#define RX_COAL_TICKS_INT_R ( (uint16_t) 0x3c18 )
-// Send Coalescing Ticks During Int register
-#define TX_COAL_TICKS_INT_R ( (uint16_t) 0x3c1c )
-// Receive Max Coalesced BD Count During Int register
-#define RX_COAL_MAX_BD_INT_R ( (uint16_t) 0x3c18 )
-// Send Max Coalesced BD Count During Int register
-#define TX_COAL_MAX_BD_INT_R ( (uint16_t) 0x3c1c )
-// Statistics Ticks Counter register
-#define STAT_TICK_CNT_R ( (uint16_t) 0x3c28 )
-// Status Block Host Address Low register
-#define STB_HOST_ADDR_HI_R ( (uint16_t) 0x3c38 )
-// Status Block Host Address High register
-#define STB_HOST_ADDR_LO_R ( (uint16_t) 0x3c3c )
-// Statistics Base Address register
-#define STAT_NIC_ADDR_R ( (uint16_t) 0x3c40 )
-// Status Block Base Address register
-#define STB_NIC_ADDR_R ( (uint16_t) 0x3c44 )
-// Memory Arbiter Mode register
-#define MEMARB_MODE_R ( (uint16_t) 0x4000 )
-// Buffer Manager Mode register
-#define BUF_MAN_MODE_R ( (uint16_t) 0x4400 )
-// MBuf Pool Address register
-#define MBUF_POOL_ADDR_R ( (uint16_t) 0x4408 )
-// MBuf Pool Length register
-#define MBUF_POOL_LEN_R ( (uint16_t) 0x440c )
-// Read DMA Mbuf Low Watermark register
-#define DMA_RMBUF_LOW_WMARK_R ( (uint16_t) 0x4410 )
-// MAC Rx Mbuf Low Watermark register
-#define MAC_RXMBUF_LOW_WMARK_R ( (uint16_t) 0x4414 )
-// Mbuf High Watermark register
-#define MBUF_HIGH_WMARK_R ( (uint16_t) 0x4418 )
-// DMA Descriptor Pool Address register
-#define DMA_DESC_POOL_ADDR_R ( (uint16_t) 0x442c )
-// DMA Descriptor Pool Length register
-#define DMA_DESC_POOL_LEN_R ( (uint16_t) 0x4430 )
-// DMA Descriptor Low Watermark register
-#define DMA_DESC_LOW_WM_R ( (uint16_t) 0x4434 )
-// DMA Descriptor HIGH Watermark register
-#define DMA_DESC_HIGH_WM_R ( (uint16_t) 0x4438 )
-// Read DMA Mode register
-#define RD_DMA_MODE_R ( (uint16_t) 0x4800 )
-// Write DMA Mode register
-#define WR_DMA_MODE_R ( (uint16_t) 0x4c00 )
-// FTQ Reset register
-#define FTQ_RES_R ( (uint16_t) 0x5c00 )
-// MSI Mode register
-#define MSI_MODE_R ( (uint16_t) 0x6000 )
-// DMA completion Mode register
-#define DMA_COMPL_MODE_R ( (uint16_t) 0x6400 )
-// Mode Control register
-#define MODE_CTRL_R ( (uint16_t) 0x6800 )
-// Misc Configuration register
-#define MISC_CFG_R ( (uint16_t) 0x6804 )
-// Misc Local Control register
-#define MISC_LOCAL_CTRL_R ( (uint16_t) 0x6808 )
-// RX-Risc Mode Register
-#define RX_CPU_MODE_R ( (uint16_t) 0x5000 )
-// RX-Risc State Register
-#define RX_CPU_STATE_R ( (uint16_t) 0x5004 )
-// RX-Risc Program Counter
-#define RX_CPU_PC_R ( (uint16_t) 0x501c )
-// RX-Risc Event Register
-#define RX_CPU_EVENT_R ( (uint16_t) 0x6810 )
-// MDI Control register
-#define MDI_CTRL_R ( (uint16_t) 0x6844 )
-// WOL Mode register
-#define WOL_MODE_R ( (uint16_t) 0x6880 )
-// WOL Config register
-#define WOL_CFG_R ( (uint16_t) 0x6884 )
-// WOL Status register
-#define WOL_STATUS_R ( (uint16_t) 0x6888 )
-
-// ASF Control register
-#define ASF_CTRL_R ( (uint16_t) 0x6c00 )
-// ASF Watchdog Timer register
-#define ASF_WATCHDOG_TIMER_R ( (uint16_t) 0x6c0c )
-// ASF Heartbeat Timer register
-#define ASF_HEARTBEAT_TIMER_R ( (uint16_t) 0x6c10 )
-// Poll ASF Timer register
-#define ASF_POLL_TIMER_R ( (uint16_t) 0x6c14 )
-// Poll Legacy Timer register
-#define POLL_LEGACY_TIMER_R ( (uint16_t) 0x6c18 )
-// Retransmission Timer register
-#define RETRANSMISSION_TIMER_R ( (uint16_t) 0x6c1c )
-// Time Stamp Counter register
-#define TIME_STAMP_COUNTER_R ( (uint16_t) 0x6c20 )
-
-// NVM Command register
-#define NVM_COM_R ( (uint16_t) 0x7000 )
-// NVM Write register
-#define NVM_WRITE_R ( (uint16_t) 0x7008 )
-// NVM Address register
-#define NVM_ADDR_R ( (uint16_t) 0x700c )
-// NVM Read registertg3_phy_copper_begin
-#define NVM_READ_R ( (uint16_t) 0x7010 )
-// NVM Access register
-#define NVM_ACC_R ( (uint16_t) 0x7024 )
-// NVM Config 1 register
-#define NVM_CFG1_R ( (uint16_t) 0x7014 )
-// Software arbitration register
-#define SW_ARB_R ( (uint16_t) 0x7020 )
-
-/*
- * useful def's
- */
-#define rd08(a) ci_read_8((uint8_t *)(a))
-#define rd16(a) ci_read_16((uint16_t *)(a))
-#define rd32(a) ci_read_32((uint32_t *)(a))
-#define wr08(a,v) ci_write_8((uint8_t *)(a), (v))
-#define wr16(a,v) ci_write_16((uint16_t *)(a), (v))
-#define wr32(a,v) ci_write_32((uint32_t *)(a), (v))
-
-#define BIT08( bit ) ( (uint8_t) 0x1 << (bit) )
-#define BIT16( bit ) ( (uint16_t) 0x1 << (bit) )
-#define BIT32( bit ) ( (uint32_t) 0x1 << (bit) )
-
-/*
- * type definition
- */
-
-/*
- * Constants for different kinds of IOCTL requests
- */
-
-#define SIOCETHTOOL 0x1000
-
-/*
- * special structure and constants for IOCTL requests of type ETHTOOL
- */
-
-#define ETHTOOL_GMAC 0x03
-#define ETHTOOL_SMAC 0x04
-#define ETHTOOL_VERSION 0x05
-
-typedef struct {
- int idx;
- char address[6];
-} ioctl_ethtool_mac_t;
-
-typedef struct {
- unsigned int length;
- char *text;
-} ioctl_ethtool_version_t;
-
-
-/*
- * default structure and constants for IOCTL requests
- */
-
-#define IF_NAME_SIZE 0xFF
-
-typedef struct {
- char if_name[IF_NAME_SIZE];
- int subcmd;
- union {
- ioctl_ethtool_mac_t mac;
- ioctl_ethtool_version_t version;
- } data;
-} ioctl_net_data_t;
-
-extern net_driver_t *bcm57xx_open(void);
-extern void bcm57xx_close(net_driver_t *driver);
-extern int bcm57xx_read(char *buf, int len);
-extern int bcm57xx_write(char *buf, int len);