bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * CDDL HEADER START
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan *
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * The contents of this file are subject to the terms of the
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Common Development and Distribution License (the "License").
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * You may not use this file except in compliance with the License.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan *
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * or http://www.opensolaris.org/os/licensing.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * See the License for the specific language governing permissions
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * and limitations under the License.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan *
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * When distributing Covered Code, include this CDDL HEADER in each
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * If applicable, add the following below this CDDL HEADER, with the
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * fields enclosed by brackets "[]" replaced with your own identifying
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * information: Portions Copyright [yyyy] [name of copyright owner]
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan *
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * CDDL HEADER END
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan * Copyright 2010 QLogic Corporation. All rights reserved.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifndef _QLGE_H
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define _QLGE_H
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef __cplusplus
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern "C" {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/ddi.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/sunddi.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/sunmdi.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/modctl.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/pci.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/dlpi.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/sdt.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/mac_provider.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/mac.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/mac_flow.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/mac_ether.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/vlan.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/netlb.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/kmem.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/file.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/proc.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/callb.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/disp.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/strsun.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/ethernet.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/miiregs.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/kstat.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <sys/byteorder.h>
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#include <sys/ddifm.h>
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#include <sys/fm/protocol.h>
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#include <sys/fm/util.h>
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#include <sys/fm/io/ddi.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <qlge_hw.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <qlge_dbg.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#include <qlge_open.h>
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define ADAPTER_NAME "qlge"
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Local Macro Definitions.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef TRUE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#undef TRUE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TRUE 1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef FALSE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#undef FALSE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define FALSE 0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* #define QLGE_TRACK_BUFFER_USAGE */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * byte order, sparc is big endian, x86 is little endian,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * but PCI is little endian only
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef sparc
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le64(x) BSWAP_64(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le32(x) BSWAP_32(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le16(x) BSWAP_16(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le64_to_cpu(x) cpu_to_le64(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le32_to_cpu(x) cpu_to_le32(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le16_to_cpu(x) cpu_to_le16(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#else
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le64(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le32(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define cpu_to_le16(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le64_to_cpu(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le32_to_cpu(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define le16_to_cpu(x) (x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Macros to help code, maintain, etc.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LSB(x) (uint8_t)(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MSB(x) (uint8_t)((uint16_t)(x) >> 8)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MSW(x) (uint16_t)((uint32_t)(x) >> 16)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LSW(x) (uint16_t)(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MS32(x) (uint32_t)((uint32_t)(x) >> 32)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LS32(x) (uint32_t)(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MSW_LSB(x) (uint8_t)(LSB(MSW(x)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MSW_MSB(x) (uint8_t)(MSB(MSW(x)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LSD(x) (uint32_t)(x)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MSD(x) (uint32_t)((uint64_t)(x) >> 32)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SHORT_TO_LONG(a, b) (uint32_t)((uint16_t)b << 16 | (uint16_t)a)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CHAR_TO_SHORT(a, b) (uint16_t)((uint8_t)b << 8 | (uint8_t)a)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SWAP_ENDIAN_16(x) ((LSB(x) << 8) | MSB(x))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SWAP_ENDIAN_32(x) ((SWAP_ENDIAN_16(LSW(x)) << 16) | \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan SWAP_ENDIAN_16(MSW(x)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SWAP_ENDIAN_64(x) ((SWAP_ENDIAN_32(LS32(x)) << 32) | \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan SWAP_ENDIAN_32(MS32(x)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_MIN(x, y) ((x < y) ? x : y)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CARRIER_ON(qlge) mac_link_update((qlge)->mh, LINK_STATE_UP)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CARRIER_OFF(qlge) mac_link_update((qlge)->mh, LINK_STATE_DOWN)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * qlge local function return status codes
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_ERROR 1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_SUCCESS 0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Solaris version compatibility definitions.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_GET_LBOLT(timer) timer = ddi_get_lbolt()
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_XFER_COUNTER (uint64_t)0xffffffff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DRIVER_NAME(dip) ddi_driver_name(ddi_get_parent(dip))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MINOR_NODE_FLAG 8
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Host adapter default definitions.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* Timeout timer counts in seconds (must greater than 1 second). */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define USEC_PER_TICK drv_hztousec(1)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TICKS_PER_SEC drv_usectohz(1000000)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_ONE_SEC_DELAY 1000000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_ONE_MSEC_DELAY 1000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_TIMEOUT 3*TICKS_PER_SEC
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * DMA attributes definitions.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_LOW_ADDRESS (uint64_t)0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_HIGH_64BIT_ADDRESS (uint64_t)0xffffffffffffffffull
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_HIGH_32BIT_ADDRESS (uint64_t)0xffffffff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_ADDRESS_ALIGNMENT (uint64_t)8
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_ALIGN_8_BYTE_BOUNDARY (uint64_t)BIT_3
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_RING_ADDRESS_ALIGNMENT (uint64_t)64
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_ALIGN_64_BYTE_BOUNDARY (uint64_t)BIT_6
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_BURSTSIZES 0xfff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_MIN_XFER_SIZE 1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_MAX_XFER_SIZE (uint64_t)0xffffffff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_SEGMENT_BOUNDARY (uint64_t)0xffffffff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_GRANULARITY 1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_DMA_XFER_FLAGS 0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_MAX_COOKIES 16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * ISP PCI Configuration.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_INTR_INTERVAL 128 /* default interrupt interval 128us */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_INTR_PKTS 8 /* default packet count threshold 8us */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* GLD */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_STREAM_OPS(dev_ops, attach, detach) \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan DDI_DEFINE_STREAM_OPS(dev_ops, nulldev, nulldev, attach, detach, \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan nodev, NULL, D_MP, NULL, ql_quiesce)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_GET_DEV(dip) ((qlge_t *)(ddi_get_driver_private(dip)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define RESUME_TX(tx_ring) mac_tx_update(tx_ring->qlge->mh);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define RX_UPSTREAM(rx_ring, mp) mac_rx(rx_ring->qlge->mh, \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan rx_ring->qlge->handle, mp);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* GLD DMA */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern ddi_device_acc_attr_t ql_dev_acc_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern ddi_device_acc_attr_t ql_desc_acc_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern ddi_device_acc_attr_t ql_buf_acc_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct dma_info {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan void *vaddr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_dma_handle_t dma_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_acc_handle_t acc_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t dma_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan size_t mem_len; /* allocated size */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan offset_t offset; /* relative to handle */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Sync a DMA area described by a dma_info
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define DMA_SYNC(area, flag) ((void) ddi_dma_sync((area).dma_handle, \
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan (area).offset, (area).mem_len, (flag)))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Find the (kernel virtual) address of block of memory
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * described by a dma_info
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define DMA_VPTR(area) ((area).vaddr)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Zero a block of memory described by a dma_info
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define DMA_ZERO(area) bzero(DMA_VPTR(area), (area).mem_len)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_SG_ELEMENTS 16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_MAX_TX_DMA_HANDLES MAX_SG_ELEMENTS
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TOTAL_SG_ELEMENTS (MAX_SG_ELEMENTS + TX_DESC_PER_IOCB)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * ISP PCI Configuration.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* Initialize steps */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_SOFTSTATE_ALLOC BIT_0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_REGS_SETUP BIT_1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_DOORBELL_REGS_SETUP BIT_2
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_MAC_ALLOC BIT_3
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_PCI_CONFIG_SETUP BIT_4
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_SETUP_RINGS BIT_5
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_MEMORY_ALLOC BIT_6
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_INTR_ALLOC BIT_7
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_ADD_INTERRUPT BIT_8
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_LOCKS_CREATED BIT_9
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_ADD_SOFT_INTERRUPT BIT_10
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_MUTEX BIT_11
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define ADAPTER_INIT BIT_12
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_MAC_REGISTERED BIT_13
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define INIT_KSTATS BIT_14
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#define INIT_FM BIT_15
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#define INIT_ADAPTER_UP BIT_16
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#define INIT_ALLOC_RX_BUF BIT_17
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#define INIT_INTR_ENABLED BIT_18
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LS_64BITS(x) (uint32_t)(0xffffffff & ((uint64_t)x))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MS_64BITS(x) (uint32_t)(0xffffffff & (((uint64_t)x)>>16>>16))
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathantypedef uint64_t dma_addr_t;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_quiesce(dev_info_t *dip);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan * LSO can support up to 65535 bytes of data, but can not be sent in one IOCB
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * which only has 8 TX OALs, additional OALs must be applied separately.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#define QL_LSO_MAX 65535 /* Maximum supported LSO data Length */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum tx_mode_t {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan USE_DMA,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan USE_COPY
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QL_MAX_COPY_LENGTH 256
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_FRAGMENTS_IN_IOCB 7
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifndef VLAN_ID_MASK
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define VLAN_ID_MASK 0x0fffu
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifndef VLAN_TAGSZ
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define VLAN_TAGSZ 4
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifndef ETHERTYPE_VLAN
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define ETHERTYPE_VLAN 0x8100
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifndef MBLKL
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MBLKL(mp) ((uintptr_t)(mp)->b_wptr - (uintptr_t)(mp)->b_rptr)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Checksum Offload
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TCP_CKSUM_OFFSET 16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define UDP_CKSUM_OFFSET 6
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define IPPROTO_IPv6OVERv4 41
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Driver must be in one of these states
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum mac_state {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_INIT, /* in the initialization stage */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_ATTACHED, /* driver attached */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_STARTED, /* interrupt enabled, driver is ready */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_BRINGDOWN, /* in the bring down process */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_STOPPED, /* stoped, no more interrupts */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_DETACH, /* to be detached */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_MAC_SUSPENDED
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Soft Request Flag
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define NEED_HW_RESET BIT_0 /* need hardware reset */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define NEED_MPI_RESET BIT_1 /* need MPI RISC reset */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * (Internal) return values from ioctl subroutines
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum ioc_reply {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_INVAL = -1, /* bad, NAK with EINVAL */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_DONE, /* OK, reply sent */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_ACK, /* OK, just send ACK */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_REPLY, /* OK, just send reply */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_RESTART_ACK, /* OK, restart & ACK */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan IOC_RESTART_REPLY /* OK, restart & reply */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Link Speed,in Mbps
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SPEED_10 10
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SPEED_100 100
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SPEED_1000 1000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SPEED_10G 10000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Multicast List
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathantypedef struct {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct ether_addr addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan unsigned char reserved[2];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan} ql_multicast_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_MULTICAST_LIST_SIZE 128
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathantypedef struct {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct ether_addr addr; /* in canonical form */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t set; /* B_TRUE => valid */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan} qlge_mac_addr_t;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_UNICAST_LIST_SIZE 128
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Device kstate structure.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_KSTAT_CHIP = 0,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_KSTAT_LINK,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_KSTAT_REG,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QL_KSTAT_COUNT
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Register Bit Set/Reset
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan BIT_SET = 0,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan BIT_RESET
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Flash Image Search State
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum { STOP_SEARCH, /* Image address bad, no more search */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan CONTINUE_SEARCH, /* Image address ok, continue search */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan LAST_IMAGE_FOUND /* Found last image and FLTDS address */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Loop Back Modes
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum { QLGE_LOOP_NONE,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QLGE_LOOP_INTERNAL_PARALLEL,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QLGE_LOOP_INTERNAL_SERIAL,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan QLGE_LOOP_EXTERNAL_PHY
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* for soft state routine */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathantypedef struct {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan offset_t index;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan char *name;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan} ql_ksindex_t;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct bq_desc {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info bd_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc *next;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct rx_ring *rx_ring;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan mblk_t *mp;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan frtn_t rx_recycle; /* recycle function - called after mp */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* is to be freed by OS */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t index;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t free_buf; /* Set to indicate the buffer is */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* being freed, new one should not */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* be allocated */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t upl_inuse; /* buffer in use by upper layers */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define VM_PAGE_SIZE 4096
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define QLGE_POLL_ALL -1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define SMALL_BUFFER_SIZE 512
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LARGE_BUFFER_SIZE 4096
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_TX_WAIT_COUNT 1000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_RX_WAIT_COUNT 25 /* 25 second */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MIN_BUFFERS_ARM_COUNT 16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MIN_BUFFERS_FREE_COUNT 32 /* If free buffer count go over this */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* value, arm the chip */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* if less than 16 free lrg buf nodes in the free list, then */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* rx has to use copy method to send packets upstream */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define RX_COPY_MODE_THRESHOLD (MIN_BUFFERS_ARM_COUNT/4)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/* if there are more than TX_STOP_THRESHOLD free tx buffers, try to send it */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_STOP_THRESHOLD 16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_RESUME_THRESHOLD 8
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct tx_ring_desc {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct ob_mac_iocb_req *queue_entry; /* tx descriptor of this */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info dma_mem_area; /* tx buffer */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_dma_handle_t tx_dma_handle[QL_MAX_TX_DMA_HANDLES];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int tx_dma_handle_used;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan enum tx_mode_t tx_type; /* map mode or copy mode */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan mblk_t *mp; /* requested sending packet */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t index;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan caddr_t copy_buffer;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t copy_buffer_dma_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info oal_dma; /* oal is premapped */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t oal_dma_addr; /* oal dma address premapped */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t tx_bytes;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan void *oal;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct tx_ring {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct qlge *qlge;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info wqicb_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t cq_id; /* completion (rx) queue for */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* tx completions */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint8_t wq_id;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t wq_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t wq_len;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t tx_lock;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info wq_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t tx_free_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t tx_mode;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t queue_stopped; /* Tx no resource */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *prod_idx_db_reg;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t prod_idx;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *valid_db_reg; /* PCI doorbell mem area + 4 */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct tx_ring_desc *wq_desc;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* shadow copy of consumer idx */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *cnsmr_idx_sh_reg;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* dma-shadow copy consumer */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t cnsmr_idx_sh_reg_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t defer; /* tx no resource */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t obytes;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t opackets;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t errxmt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t brdcstxmt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t multixmt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t tx_fail_dma_bind;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t tx_no_dma_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t tx_no_dma_cookie;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan enum mac_state mac_flags;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct bq_element {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanuint32_t addr_lo;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanuint32_t addr_hi;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Type of inbound queue.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan DEFAULT_Q = 2, /* Handles slow queue and chip/MPI events. */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan TX_Q = 3, /* Handles outbound completions. */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan RX_Q = 4, /* Handles inbound completions. */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct rx_ring {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info cqicb_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* GLD required flags */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t ring_gen_num;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* statistics */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t rx_packets;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t rx_bytes;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t frame_too_long;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t frame_too_short;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t fcs_err;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_packets_dropped_no_buffer;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_pkt_dropped_mac_unenabled;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t rx_indicate;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* miscellaneous */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int type; /* DEFAULT_Q, TX_Q, RX_Q */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t rx_lock;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t irq;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct qlge *qlge;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t cpu; /* Which CPU this should run on. */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan enum mac_state mac_flags;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* completion queue */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info cq_dma; /* virtual addr and phy addr */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t cq_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t cq_len;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t cq_id;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan off_t prod_idx_sh_reg_offset;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t *prod_idx_sh_reg; /* Shadowed prod reg */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t prod_idx_sh_reg_dma; /* Physical address */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *cnsmr_idx_db_reg; /* PCI db mem area 0 */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t cnsmr_idx; /* current sw idx */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct net_rsp_iocb *curr_entry; /* next entry on queue */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *valid_db_reg; /* PCI doorbell mem area + 4 */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* large buffer queue */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_len; /* entry count */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_size; /* size in bytes */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_buf_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info lbq_dma; /* lbq dma info */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t *lbq_base_indirect;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t lbq_base_indirect_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t lbq_lock;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc **lbuf_in_use;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t lbuf_in_use_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc **lbuf_free;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t lbuf_free_count; /* free lbuf desc cnt */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *lbq_prod_idx_db_reg; /* PCI db mem area+0x18 */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_prod_idx; /* current sw prod idx */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_curr_idx; /* next entry we expect */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_free_tail; /* free tail */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_free_head; /* free head */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_use_tail; /* inuse tail */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbq_use_head; /* inuse head */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc *lbq_desc;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* small buffer queue */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_len; /* entry count */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_size; /* size in bytes of queue */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_buf_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info sbq_dma; /* sbq dma info */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t *sbq_base_indirect;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t sbq_base_indirect_dma;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t sbq_lock;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc **sbuf_in_use;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t sbuf_in_use_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc **sbuf_free;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t sbuf_free_count; /* free buffer desc cnt */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t *sbq_prod_idx_db_reg; /* PCI db mem area+0x1c */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_prod_idx; /* current sw prod idx */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_curr_idx; /* next entry we expect */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_free_tail; /* free tail */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_free_head; /* free head */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_use_tail; /* inuse tail */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbq_use_head; /* inuse head */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct bq_desc *sbq_desc;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* for test purpose */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_failed_sbq_allocs;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_failed_lbq_allocs;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sbuf_copy_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lbuf_copy_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#ifdef QLGE_PERFORMANCE
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan uint32_t hist[8];
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct intr_ctx {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct qlge *qlge;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t intr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t hooked;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t intr_en_mask;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t intr_dis_mask;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t intr_read_mask;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * It's incremented for
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * each irq handler that is scheduled.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * When each handler finishes it
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * decrements irq_cnt and enables
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * interrupts if it's zero.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t irq_cnt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint_t (*handler)(caddr_t, caddr_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanstruct tx_buf_desc {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint64_t addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t len;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_DESC_LEN_MASK 0x000fffff
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_DESC_C 0x40000000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define TX_DESC_E 0x80000000
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan};
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathantypedef struct qlge {
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Solaris adapter configuration data
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan dev_info_t *dip;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int instance;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_acc_handle_t dev_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan caddr_t iobase;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_acc_handle_t dev_doorbell_reg_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan caddr_t doorbell_reg_iobase;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan pci_cfg_t pci_cfg;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_acc_handle_t pci_handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t page_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t sequence;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct intr_ctx intr_ctx[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info ricb_dma;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan /* fault management capabilities */
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan int fm_capabilities;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan boolean_t fm_enable;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan enum mac_state mac_flags;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t cfg_flags;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_JUMBLE_PACKET BIT_1
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_RX_COPY_MODE BIT_2
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_SUPPORT_MULTICAST BIT_3
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_HW_UNABLE_PSEUDO_HDR_CKSUM BIT_4
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_CKSUM_HEADER_IPv4 BIT_5
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_CKSUM_PARTIAL BIT_6
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_CKSUM_FULL_IPv4 BIT_7
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_CKSUM_FULL_IPv6 BIT_8
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_LSO BIT_9
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_SUPPORT_SCATTER_GATHER BIT_10
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_ENABLE_SPLIT_HEADER BIT_11
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_ENABLE_EXTENDED_LOGGING BIT_15
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t chksum_cap;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan volatile uint32_t flags;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_CHIP_8100 BIT_16
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define CFG_IST(qlge, cfgflags) (qlge->cfg_flags & cfgflags)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* For Shadow Registers, used by adapter to write to host memory */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info host_copy_shadow_dma_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Extra 2x8 bytes memory saving large/small buf queue base address
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * for each CQICB and read by chip, new request since 8100
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info buf_q_ptr_base_addr_dma_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Debugging
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t ql_dbgprnt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * GLD
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan mac_handle_t mh;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan mac_resource_handle_t handle;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_stats_t stats;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kstat_t *ql_kstats[QL_KSTAT_COUNT];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * mutex
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t gen_mutex; /* general adapter mutex */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t hw_mutex; /* common hw(nvram)access */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Generic timer
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan timeout_id_t ql_timer_timeout_id;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan clock_t ql_timer_ticks;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Interrupt
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int intr_type;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* for legacy interrupt */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_iblock_cookie_t iblock_cookie;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* for MSI and Fixed interrupts */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_intr_handle_t *htable; /* For array of interrupts */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int intr_cnt; /* # of intrs actually allocated */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint_t intr_pri; /* Interrupt priority */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int intr_cap; /* Interrupt capabilities */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan size_t intr_size; /* size of the allocated */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* interrupt handlers */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* Power management context. */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint8_t power_level;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define LOW_POWER_LEVEL (BIT_1 | BIT_0)
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#define MAX_POWER_LEVEL 0
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * General NIC
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t xgmac_sem_mask;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t xgmac_sem_bits;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t func_number;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t fn0_net; /* network function 0 port */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t fn1_net; /* network function 1 port */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t mtu;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan uint32_t max_frame_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t port_link_state;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t speed;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t link_type;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t duplex;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t pause; /* flow-control mode */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t loop_back_mode;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t lso_enable;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan uint32_t dcbx_enable; /* dcbx mode */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * PCI status
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t vendor_id;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t device_id;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Multicast list
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t multicast_list_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_multicast_addr multicast_list[MAX_MULTICAST_LIST_SIZE];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t multicast_promisc;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * MAC address information
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct ether_addr dev_addr; /* ethernet address read from nvram */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan qlge_mac_addr_t unicst_addr[MAX_UNICAST_LIST_SIZE];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t unicst_total; /* total unicst addresses */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t unicst_avail;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Soft Interrupt handlers
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* soft interrupt handle for MPI interrupt */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_softint_handle_t mpi_event_intr_hdl;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* soft interrupt handle for asic reset */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_softint_handle_t asic_reset_intr_hdl;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* soft interrupt handle for mpi reset */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ddi_softint_handle_t mpi_reset_intr_hdl;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * IOCTL
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* new ioctl admin flags to work around the 1024 max data copy in&out */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan caddr_t ioctl_buf_ptr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t ioctl_buf_lenth;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t expected_trans_times;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t ioctl_total_length;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t ioctl_transferred_bytes;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_mpi_coredump_t ql_mpi_coredump;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Mailbox lock and flags
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t fw_init_complete;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kmutex_t mbx_mutex;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t mbx_wait_completion;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan kcondvar_t cv_mbx_intr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan mbx_data_t received_mbx_cmds;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint_t max_read_mbx;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan firmware_version_info_t fw_version_info;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan phy_firmware_version_info_t phy_version_info;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan port_cfg_info_t port_cfg_info;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct dma_info ioctl_buf_dma_attr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Flash
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_fltds_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_flt_fdt_index;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_fdt_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_fdt_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_flt_nic_config_table_index;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_nic_config_table_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_nic_config_table_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t flash_vpd_addr;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_flash_info_t flash_info;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_fltds_t fltds;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_flt_t flt;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t flash_len; /* size of Flash memory */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan ql_nic_config_t nic_config;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan flash_desc_t fdesc;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * TX / RX
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan clock_t last_tx_time;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan boolean_t rx_copy;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t rx_coalesce_usecs;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t rx_max_coalesced_frames;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t tx_coalesce_usecs;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint16_t tx_max_coalesced_frames;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t payload_copy_thresh;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t xg_sem_mask;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t ip_hdr_offset;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t selected_tx_ring;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct rx_ring rx_ring[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct tx_ring tx_ring[MAX_TX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_polls[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_interrupts[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int tx_ring_size;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan int rx_ring_size;
a6766df40e85f57b203ec7f2143dd1a99e6fe03dSukumar Swaminathan uint32_t rx_copy_threshold;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_ring_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rss_ring_count;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t tx_ring_first_cq_id;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t tx_ring_count;
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan uint32_t isr_stride;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef QLGE_TRACK_BUFFER_USAGE
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan /* Count no of times the buffers fell below 32 */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_sb_low_count[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t rx_lb_low_count[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan uint32_t cq_low_count[MAX_RX_RINGS];
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan} qlge_t;
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Reconfiguring the network devices requires the net_config privilege
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * in Solaris 10+.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int secpolicy_net_config(const cred_t *, boolean_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Global Function Prototypes in qlge_dbg.c source file.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_fw_dump(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint8_t ql_get8(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint16_t ql_get16(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint32_t ql_get32(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_put8(qlge_t *, uint32_t, uint8_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_put16(qlge_t *, uint32_t, uint16_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_put32(qlge_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint32_t ql_read_reg(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_write_reg(qlge_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_all_contrl_regs(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_wait_reg_bit(qlge_t *, uint32_t, uint32_t, int, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_pci_config(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_host_pci_regs(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_req_pkt(qlge_t *, struct ob_mac_iocb_req *, void *, int);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_cqicb(qlge_t *, struct cqicb_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_wqicb(qlge_t *, struct wqicb_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_gld3_init(qlge_t *, mac_register_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum ioc_reply ql_chip_ioctl(qlge_t *, queue_t *, mblk_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanenum ioc_reply ql_loop_ioctl(qlge_t *, queue_t *, mblk_t *, struct iocblk *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_8xxx_binary_core_dump(qlge_t *, ql_mpi_coredump_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Global Data in qlge.c source file.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void qlge_delay(clock_t usecs);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_sem_spinlock(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_sem_unlock(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_sem_lock(qlge_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_init_misc_registers(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_init_mem_resources(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_do_start(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_do_stop(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_add_to_multicast_list(qlge_t *, uint8_t *ep);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_remove_from_multicast_list(qlge_t *, uint8_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_set_promiscuous(qlge_t *, int);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_get_hw_stats(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_send_common(struct tx_ring *, mblk_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_wake_asic_reset_soft_intr(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_write_doorbell_reg(qlge_t *, uint32_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint32_t ql_read_doorbell_reg(qlge_t *, uint32_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_set_mac_addr_reg(qlge_t *, uint8_t *, uint32_t, uint16_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_read_xgmac_reg(qlge_t *, uint32_t, uint32_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_enable_completion_interrupt(qlge_t *, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern mblk_t *ql_ring_rx_poll(void *, int);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_disable_completion_interrupt(qlge_t *qlge, uint32_t intr);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern mblk_t *ql_ring_tx(void *arg, mblk_t *mp);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern uint8_t ql_tx_hashing(qlge_t *qlge, caddr_t bp);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_atomic_set_32(volatile uint32_t *target, uint32_t newval);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern uint32_t ql_atomic_read_32(volatile uint32_t *target);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_restart_timer(qlge_t *qlge);
cddcb3dae85e03889ec217ef3da5a8898f4f66c7Sukumar Swaminathanextern int ql_route_initialize(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Global Function Prototypes in qlge_flash.c source file.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_sem_flash_lock(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_sem_flash_unlock(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int qlge_load_flash(qlge_t *, uint8_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int qlge_dump_fcode(qlge_t *, uint8_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_flash_vpd(qlge_t *qlge, uint8_t *buf);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_get_flash_params(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan/*
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan * Global Function Prototypes in qlge_mpi.c source file.
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan */
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_do_mpi_intr(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_reset_mpi_risc(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_get_fw_state(qlge_t *, uint32_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int qlge_get_link_status(qlge_t *, struct qlnic_link_status_info *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_mbx_test(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_mbx_test2(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_get_port_cfg(qlge_t *qlge);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_set_mpi_port_config(qlge_t *qlge, port_cfg_info_t new_cfg);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_set_loop_back_mode(qlge_t *qlge);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_set_pause_mode(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_get_LED_config(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_dump_sfp(qlge_t *, void *bp, int mode);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_set_IDC_Req(qlge_t *, uint8_t dest_functions, uint8_t timeout);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_write_flash_test(qlge_t *qlge, uint32_t testAddr);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_write_flash_test2(qlge_t *qlge, uint32_t testAddr);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_get_firmware_version(qlge_t *,
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan struct qlnic_mpi_version_info *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_read_processor_data(qlge_t *, uint32_t, uint32_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_write_processor_data(qlge_t *, uint32_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_read_risc_ram(qlge_t *, uint32_t, uint64_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern int ql_trigger_system_error_event(qlge_t *qlge);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_core_dump(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_crash_record(qlge_t *);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_dump_buf(char *, uint8_t *, uint8_t, uint32_t);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathanextern void ql_printf(const char *, ...);
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan/*
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan * Global Function Prototypes in qlge_gld.c source file.
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan */
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_unicst_set(qlge_t *qlge, const uint8_t *macaddr, int slot);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan/*
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan * Global Function Prototypes in qlge_fm.c source file.
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan */
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern void ql_fm_ereport(qlge_t *qlge, char *detail);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_fm_check_acc_handle(ddi_acc_handle_t handle);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathanextern int ql_fm_check_dma_handle(ddi_dma_handle_t handle);
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan
accf27a5824ae84dfac7b089c4325917231a7d15Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#ifdef __cplusplus
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan}
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan
bafec74292ca6805e5acb387856f4e60a5314b37Sukumar Swaminathan#endif /* _QLGE_H */