|  | 
 | /******************************************************************************/ | 
 | /*                                                                            */ | 
 | /* Broadcom BCM5700 Linux Network Driver, Copyright (c) 2000 Broadcom         */ | 
 | /* Corporation.                                                               */ | 
 | /* All rights reserved.                                                       */ | 
 | /*                                                                            */ | 
 | /* This program is free software; you can redistribute it and/or modify       */ | 
 | /* it under the terms of the GNU General Public License as published by       */ | 
 | /* the Free Software Foundation, located in the file LICENSE.                 */ | 
 | /*                                                                            */ | 
 | /******************************************************************************/ | 
 |  | 
 | #ifndef MM_H | 
 | #define MM_H | 
 |  | 
 | #define __raw_readl readl | 
 | #define __raw_writel writel | 
 |  | 
 | #define BIG_ENDIAN_HOST 1 | 
 | #define readl(addr) (*(volatile unsigned int*)(addr)) | 
 | #define writel(b,addr) ((*(volatile unsigned int *) (addr)) = (b)) | 
 |  | 
 | /* Define memory barrier function here if needed */ | 
 | #define wmb() | 
 | #define membar() | 
 | #include <common.h> | 
 | #include <asm/types.h> | 
 | #include "bcm570x_lm.h" | 
 | #include "bcm570x_queue.h" | 
 | #include "tigon3.h" | 
 | #include <pci.h> | 
 |  | 
 | #define FALSE 0 | 
 | #define TRUE  1 | 
 | #define ERROR -1 | 
 |  | 
 | #if DBG | 
 | #define STATIC | 
 | #else | 
 | #define STATIC static | 
 | #endif | 
 |  | 
 | extern int MM_Packet_Desc_Size; | 
 |  | 
 | #define MM_PACKET_DESC_SIZE MM_Packet_Desc_Size | 
 |  | 
 | DECLARE_QUEUE_TYPE (UM_RX_PACKET_Q, MAX_RX_PACKET_DESC_COUNT + 1); | 
 |  | 
 | #define MAX_MEM 16 | 
 |  | 
 | /* Synch */ | 
 | typedef int mutex_t; | 
 | typedef int spinlock_t; | 
 |  | 
 | /* Embedded device control */ | 
 | typedef struct _UM_DEVICE_BLOCK { | 
 | 	LM_DEVICE_BLOCK lm_dev; | 
 | 	pci_dev_t pdev; | 
 | 	char *name; | 
 | 	void *mem_list[MAX_MEM]; | 
 | 	dma_addr_t dma_list[MAX_MEM]; | 
 | 	int mem_size_list[MAX_MEM]; | 
 | 	int mem_list_num; | 
 | 	int mtu; | 
 | 	int index; | 
 | 	int opened; | 
 | 	int delayed_link_ind;	/* Delay link status during initial load */ | 
 | 	int adapter_just_inited;	/* the first few seconds after init. */ | 
 | 	int spurious_int;	/* new -- unsupported */ | 
 | 	int timer_interval; | 
 | 	int adaptive_expiry; | 
 | 	int crc_counter_expiry;	/* new -- unsupported */ | 
 | 	int poll_tib_expiry;	/* new -- unsupported */ | 
 | 	int tx_full; | 
 | 	int tx_queued; | 
 | 	int line_speed;		/* in Mbps, 0 if link is down */ | 
 | 	UM_RX_PACKET_Q rx_out_of_buf_q; | 
 | 	int rx_out_of_buf; | 
 | 	int rx_low_buf_thresh;	/* changed to rx_buf_repl_thresh */ | 
 | 	int rx_buf_repl_panic_thresh; | 
 | 	int rx_buf_align;	/* new -- unsupported */ | 
 | 	int do_global_lock; | 
 | 	mutex_t global_lock; | 
 | 	mutex_t undi_lock; | 
 | 	long undi_flags; | 
 | 	volatile int interrupt; | 
 | 	int tasklet_pending; | 
 | 	int tasklet_busy;	/* new -- unsupported */ | 
 | 	int rx_pkt; | 
 | 	int tx_pkt; | 
 | #ifdef NICE_SUPPORT		/* unsupported, this is a linux ioctl */ | 
 | 	void (*nice_rx) (void *, void *); | 
 | 	void *nice_ctx; | 
 | #endif				/* NICE_SUPPORT */ | 
 | 	int rx_adaptive_coalesce; | 
 | 	unsigned int rx_last_cnt; | 
 | 	unsigned int tx_last_cnt; | 
 | 	unsigned int rx_curr_coalesce_frames; | 
 | 	unsigned int rx_curr_coalesce_ticks; | 
 | 	unsigned int tx_curr_coalesce_frames;	/* new -- unsupported */ | 
 | #if TIGON3_DEBUG		/* new -- unsupported */ | 
 | 	uint tx_zc_count; | 
 | 	uint tx_chksum_count; | 
 | 	uint tx_himem_count; | 
 | 	uint rx_good_chksum_count; | 
 | #endif | 
 | 	unsigned int rx_bad_chksum_count;	/* new -- unsupported */ | 
 | 	unsigned int rx_misc_errors;	/* new -- unsupported */ | 
 | } UM_DEVICE_BLOCK, *PUM_DEVICE_BLOCK; | 
 |  | 
 | /* Physical/PCI DMA address */ | 
 | typedef union { | 
 | 	dma_addr_t dma_map; | 
 | } dma_map_t; | 
 |  | 
 | /* Packet */ | 
 | typedef struct | 
 |     _UM_PACKET { | 
 | 	LM_PACKET lm_packet; | 
 | 	void *skbuff;		/* Address of packet buffer */ | 
 | } UM_PACKET, *PUM_PACKET; | 
 |  | 
 | #define MM_ACQUIRE_UNDI_LOCK(_pDevice) | 
 | #define MM_RELEASE_UNDI_LOCK(_pDevice) | 
 | #define MM_ACQUIRE_INT_LOCK(_pDevice) | 
 | #define MM_RELEASE_INT_LOCK(_pDevice) | 
 | #define MM_UINT_PTR(_ptr)   ((unsigned long) (_ptr)) | 
 |  | 
 | /* Macro for setting 64bit address struct */ | 
 | #define set_64bit_addr(paddr, low, high) \ | 
 | 	(paddr)->Low = low;             \ | 
 | 	(paddr)->High = high; | 
 |  | 
 | /* Assume that PCI controller's view of host memory is same as host */ | 
 |  | 
 | #define MEM_TO_PCI_PHYS(addr) (addr) | 
 |  | 
 | extern void MM_SetAddr (LM_PHYSICAL_ADDRESS * paddr, dma_addr_t addr); | 
 | extern void MM_SetT3Addr (T3_64BIT_HOST_ADDR * paddr, dma_addr_t addr); | 
 | extern void MM_MapTxDma (PLM_DEVICE_BLOCK pDevice, | 
 | 			 struct _LM_PACKET *pPacket, T3_64BIT_HOST_ADDR * paddr, | 
 | 			 LM_UINT32 * len, int frag); | 
 | extern void MM_MapRxDma (PLM_DEVICE_BLOCK pDevice, | 
 | 			 struct _LM_PACKET *pPacket, | 
 | 			 T3_64BIT_HOST_ADDR * paddr); | 
 |  | 
 | /* BSP needs to provide sysUsecDelay and sysSerialPrintString */ | 
 | extern void sysSerialPrintString (char *s); | 
 | #define MM_Wait(usec) udelay(usec) | 
 |  | 
 | /* Define memory barrier function here if needed */ | 
 | #define wmb() | 
 |  | 
 | #if 0 | 
 | #define cpu_to_le32(val) LONGSWAP(val) | 
 | #endif | 
 | #endif				/* MM_H */ |