13dec9fcdSqs148142 /* 23dec9fcdSqs148142 * CDDL HEADER START 33dec9fcdSqs148142 * 43dec9fcdSqs148142 * The contents of this file are subject to the terms of the 53dec9fcdSqs148142 * Common Development and Distribution License (the "License"). 63dec9fcdSqs148142 * You may not use this file except in compliance with the License. 73dec9fcdSqs148142 * 83dec9fcdSqs148142 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 93dec9fcdSqs148142 * or http://www.opensolaris.org/os/licensing. 103dec9fcdSqs148142 * See the License for the specific language governing permissions 113dec9fcdSqs148142 * and limitations under the License. 123dec9fcdSqs148142 * 133dec9fcdSqs148142 * When distributing Covered Code, include this CDDL HEADER in each 143dec9fcdSqs148142 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 153dec9fcdSqs148142 * If applicable, add the following below this CDDL HEADER, with the 163dec9fcdSqs148142 * fields enclosed by brackets "[]" replaced with your own identifying 173dec9fcdSqs148142 * information: Portions Copyright [yyyy] [name of copyright owner] 183dec9fcdSqs148142 * 193dec9fcdSqs148142 * CDDL HEADER END 203dec9fcdSqs148142 */ 213dec9fcdSqs148142 /* 223dec9fcdSqs148142 * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 233dec9fcdSqs148142 * Use is subject to license terms. 243dec9fcdSqs148142 */ 253dec9fcdSqs148142 263dec9fcdSqs148142 #ifndef _SYS_HXGE_HXGE_DEFS_H 273dec9fcdSqs148142 #define _SYS_HXGE_HXGE_DEFS_H 283dec9fcdSqs148142 293dec9fcdSqs148142 #ifdef __cplusplus 303dec9fcdSqs148142 extern "C" { 313dec9fcdSqs148142 #endif 323dec9fcdSqs148142 333dec9fcdSqs148142 #if !defined(_BIG_ENDIAN) && !defined(_LITTLE_ENDIAN) && \ 343dec9fcdSqs148142 !defined(__BIG_ENDIAN) && !defined(__LITTLE_ENDIAN) 353dec9fcdSqs148142 #error Host endianness not defined 363dec9fcdSqs148142 #endif 373dec9fcdSqs148142 383dec9fcdSqs148142 #if !defined(_BIT_FIELDS_HTOL) && !defined(_BIT_FIELDS_LTOH) && \ 393dec9fcdSqs148142 !defined(__BIT_FIELDS_HTOL) && !defined(__BIT_FIELDS_LTOH) 403dec9fcdSqs148142 #error Bit ordering not defined 413dec9fcdSqs148142 #endif 423dec9fcdSqs148142 433dec9fcdSqs148142 /* RDC/TDC CSR size */ 443dec9fcdSqs148142 #define DMA_CSR_SIZE 2048 453dec9fcdSqs148142 463dec9fcdSqs148142 /* 473dec9fcdSqs148142 * Define the Default RBR, RCR 483dec9fcdSqs148142 */ 493dec9fcdSqs148142 #define RBR_DEFAULT_MAX_BLKS 4096 /* each entry (16 blockaddr/64B) */ 503dec9fcdSqs148142 #define RBR_NBLK_PER_LINE 16 /* 16 block addresses per 64 B line */ 513dec9fcdSqs148142 #define RBR_DEFAULT_MAX_LEN 65472 /* 2^16 - 64 */ 523dec9fcdSqs148142 #define RBR_DEFAULT_MIN_LEN 64 /* multiple of 64 */ 533dec9fcdSqs148142 543dec9fcdSqs148142 #define SW_OFFSET_NO_OFFSET 0 553dec9fcdSqs148142 #define SW_OFFSET_64 1 /* 64 bytes */ 563dec9fcdSqs148142 #define SW_OFFSET_128 2 /* 128 bytes */ 573dec9fcdSqs148142 #define SW_OFFSET_INVALID 3 583dec9fcdSqs148142 593dec9fcdSqs148142 /* 603dec9fcdSqs148142 * RBR block descriptor is 32 bits (bits [43:12] 613dec9fcdSqs148142 */ 623dec9fcdSqs148142 #define RBR_BKADDR_SHIFT 12 633dec9fcdSqs148142 #define RCR_DEFAULT_MAX_BLKS 4096 /* each entry (8 blockaddr/64B) */ 643dec9fcdSqs148142 #define RCR_NBLK_PER_LINE 8 /* 8 block addresses per 64 B line */ 653dec9fcdSqs148142 #define RCR_DEFAULT_MAX_LEN (RCR_DEFAULT_MAX_BLKS) 663dec9fcdSqs148142 #define RCR_DEFAULT_MIN_LEN 32 673dec9fcdSqs148142 683dec9fcdSqs148142 /* DMA Channels. */ 693dec9fcdSqs148142 #define HXGE_MAX_DMCS (HXGE_MAX_RDCS + HXGE_MAX_TDCS) 703dec9fcdSqs148142 #define HXGE_MAX_RDCS 4 713dec9fcdSqs148142 #define HXGE_MAX_TDCS 4 723dec9fcdSqs148142 733dec9fcdSqs148142 #define VLAN_ETHERTYPE (0x8100) 743dec9fcdSqs148142 753dec9fcdSqs148142 /* 256 total, each blade gets 42 */ 763dec9fcdSqs148142 #define TCAM_HXGE_TCAM_MAX_ENTRY 42 773dec9fcdSqs148142 783dec9fcdSqs148142 /* 793dec9fcdSqs148142 * Locate the DMA channel start offset (PIO_VADDR) 803dec9fcdSqs148142 * (DMA virtual address space of the PIO block) 813dec9fcdSqs148142 */ 823dec9fcdSqs148142 /* TX_RNG_CFIG is not used since we are not using VADDR. */ 833dec9fcdSqs148142 #define TX_RNG_CFIG 0x1000000 843dec9fcdSqs148142 #define TDMC_PIOVADDR_OFFSET(channel) (2 * DMA_CSR_SIZE * channel) 853dec9fcdSqs148142 #define RDMC_PIOVADDR_OFFSET(channel) (TDMC_OFFSET(channel) + DMA_CSR_SIZE) 863dec9fcdSqs148142 873dec9fcdSqs148142 /* 883dec9fcdSqs148142 * PIO access using the DMC block directly (DMC) 893dec9fcdSqs148142 */ 903dec9fcdSqs148142 #define DMC_OFFSET(channel) (DMA_CSR_SIZE * channel) 913dec9fcdSqs148142 #define TDMC_OFFSET(channel) (TX_RNG_CFIG + DMA_CSR_SIZE * channel) 923dec9fcdSqs148142 933dec9fcdSqs148142 #ifdef SOLARIS 943dec9fcdSqs148142 #ifndef i386 953dec9fcdSqs148142 #define _BIT_FIELDS_BIG_ENDIAN _BIT_FIELDS_HTOL 963dec9fcdSqs148142 #else 973dec9fcdSqs148142 #define _BIT_FIELDS_LITTLE_ENDIAN _BIT_FIELDS_LTOH 983dec9fcdSqs148142 #endif 993dec9fcdSqs148142 #else 1003dec9fcdSqs148142 #define _BIT_FIELDS_LITTLE_ENDIAN _LITTLE_ENDIAN_BITFIELD 1013dec9fcdSqs148142 #endif 1023dec9fcdSqs148142 1033dec9fcdSqs148142 /* 1043dec9fcdSqs148142 * The following macros expect unsigned input values. 1053dec9fcdSqs148142 */ 1063dec9fcdSqs148142 #define TXDMA_CHANNEL_VALID(cn) (cn < HXGE_MAX_TDCS) 1073dec9fcdSqs148142 1083dec9fcdSqs148142 /* 1093dec9fcdSqs148142 * Logical device definitions. 1103dec9fcdSqs148142 */ 1113dec9fcdSqs148142 #define HXGE_INT_MAX_LD 32 1123dec9fcdSqs148142 #define HXGE_INT_MAX_LDG 32 1133dec9fcdSqs148142 1143dec9fcdSqs148142 #define HXGE_RDMA_LD_START 0 /* 0 - 3 with 4 - 7 reserved */ 1153dec9fcdSqs148142 #define HXGE_TDMA_LD_START 8 /* 8 - 11 with 12 - 15 reserved */ 1163dec9fcdSqs148142 #define HXGE_VMAC_LD 16 1173dec9fcdSqs148142 #define HXGE_PFC_LD 17 1183dec9fcdSqs148142 #define HXGE_NMAC_LD 18 1193dec9fcdSqs148142 #define HXGE_MBOX_LD_START 20 /* 20 - 23 for SW Mbox */ 1203dec9fcdSqs148142 #define HXGE_SYS_ERROR_LD 31 1213dec9fcdSqs148142 1223dec9fcdSqs148142 #define LDG_VALID(n) (n < HXGE_INT_MAX_LDG) 1233dec9fcdSqs148142 #define LD_VALID(n) (n < HXGE_INT_MAX_LD) 1243dec9fcdSqs148142 #define LD_RXDMA_LD_VALID(n) (n < HXGE_MAX_RDCS) 1253dec9fcdSqs148142 #define LD_TXDMA_LD_VALID(n) (n >= HXGE_MAX_RDCS && \ 1263dec9fcdSqs148142 ((n - HXGE_MAX_RDCS) < HXGE_MAX_TDCS))) 1273dec9fcdSqs148142 1283dec9fcdSqs148142 #define LD_TIMER_MAX 0x3f 1293dec9fcdSqs148142 #define LD_INTTIMER_VALID(n) (n <= LD_TIMER_MAX) 1303dec9fcdSqs148142 1313dec9fcdSqs148142 /* System Interrupt Data */ 1323dec9fcdSqs148142 #define SID_VECTOR_MAX 0x1f 1333dec9fcdSqs148142 #define SID_VECTOR_VALID(n) (n <= SID_VECTOR_MAX) 1343dec9fcdSqs148142 1353dec9fcdSqs148142 #define LD_IM_MASK 0x00000003ULL 1363dec9fcdSqs148142 #define LDGTITMRES_RES_MASK 0x000FFFFFULL 1373dec9fcdSqs148142 138*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States #define MIN_FRAME_SIZE 106 /* 68 byte min MTU + 38 byte header */ 139*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States #define MAX_FRAME_SIZE 9216 1403dec9fcdSqs148142 #define STD_FRAME_SIZE 1522 /* 1518 + 4 = 5EE + 4 */ 141*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States #define HXGE_DEFAULT_MTU 1500 142*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States /* 143*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States * sizeof (struct ether_header) + ETHERFCSL + 4 + TX_PKT_HEADER_SIZE 144*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States * 12 + 6 + 4 + 16 145*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States */ 146*a512c5d1SQiyan Sun - Sun Microsystems - San Diego United States #define MTU_TO_FRAME_SIZE 38 1473dec9fcdSqs148142 1483dec9fcdSqs148142 #ifdef __cplusplus 1493dec9fcdSqs148142 } 1503dec9fcdSqs148142 #endif 1513dec9fcdSqs148142 1523dec9fcdSqs148142 #endif /* _SYS_HXGE_HXGE_DEFS_H */ 153