1/* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 * 21 * Copyright (c) 2002-2006 Neterion, Inc. 22 */ 23 24#ifndef XGE_DEFS_H 25#define XGE_DEFS_H 26 27#define XGE_PCI_VENDOR_ID 0x17D5 28#define XGE_PCI_DEVICE_ID_XENA_1 0x5731 29#define XGE_PCI_DEVICE_ID_XENA_2 0x5831 30#define XGE_PCI_DEVICE_ID_HERC_1 0x5732 31#define XGE_PCI_DEVICE_ID_HERC_2 0x5832 32#define XGE_PCI_DEVICE_ID_TITAN_1 0x5733 33#define XGE_PCI_DEVICE_ID_TITAN_2 0x5833 34 35#define XGE_DRIVER_NAME "Xge driver" 36#define XGE_DRIVER_VENDOR "Neterion, Inc" 37#define XGE_CHIP_FAMILY "Xframe" 38#define XGE_SUPPORTED_MEDIA_0 "Fiber" 39 40#include "version.h" 41 42#if defined(__cplusplus) 43#define __EXTERN_BEGIN_DECLS extern "C" { 44#define __EXTERN_END_DECLS } 45#else 46#define __EXTERN_BEGIN_DECLS 47#define __EXTERN_END_DECLS 48#endif 49 50__EXTERN_BEGIN_DECLS 51 52/*---------------------------- DMA attributes ------------------------------*/ 53/* Used in xge_os_dma_malloc() and xge_os_dma_map() */ 54/*---------------------------- DMA attributes ------------------------------*/ 55 56/* XGE_OS_DMA_REQUIRES_SYNC - should be defined or 57 NOT defined in the Makefile */ 58#define XGE_OS_DMA_CACHELINE_ALIGNED 0x1 59/* Either STREAMING or CONSISTENT should be used. 60 The combination of both or none is invalid */ 61#define XGE_OS_DMA_STREAMING 0x2 62#define XGE_OS_DMA_CONSISTENT 0x4 63#define XGE_OS_SPRINTF_STRLEN 64 64 65/*---------------------------- common stuffs -------------------------------*/ 66 67#define XGE_OS_LLXFMT "%llx" 68#define XGE_OS_NEWLINE "\n" 69#ifdef XGE_OS_MEMORY_CHECK 70typedef struct { 71 void *ptr; 72 int size; 73 char *file; 74 int line; 75} xge_os_malloc_t; 76 77#define XGE_OS_MALLOC_CNT_MAX 64*1024 78extern xge_os_malloc_t g_malloc_arr[XGE_OS_MALLOC_CNT_MAX]; 79extern int g_malloc_cnt; 80 81#define XGE_OS_MEMORY_CHECK_MALLOC(_vaddr, _size, _file, _line) { \ 82 if (_vaddr) { \ 83 int index_mem_chk; \ 84 for (index_mem_chk=0; index_mem_chk < g_malloc_cnt; index_mem_chk++) { \ 85 if (g_malloc_arr[index_mem_chk].ptr == NULL) { \ 86 break; \ 87 } \ 88 } \ 89 if (index_mem_chk == g_malloc_cnt) { \ 90 g_malloc_cnt++; \ 91 if (g_malloc_cnt >= XGE_OS_MALLOC_CNT_MAX) { \ 92 xge_os_bug("g_malloc_cnt exceed %d", \ 93 XGE_OS_MALLOC_CNT_MAX); \ 94 } \ 95 } \ 96 g_malloc_arr[index_mem_chk].ptr = _vaddr; \ 97 g_malloc_arr[index_mem_chk].size = _size; \ 98 g_malloc_arr[index_mem_chk].file = _file; \ 99 g_malloc_arr[index_mem_chk].line = _line; \ 100 for (index_mem_chk=0; index_mem_chk<_size; index_mem_chk++) { \ 101 *((char *)_vaddr+index_mem_chk) = 0x5a; \ 102 } \ 103 } \ 104} 105 106#define XGE_OS_MEMORY_CHECK_FREE(_vaddr, _check_size) { \ 107 int index_mem_chk; \ 108 for (index_mem_chk=0; index<XGE_OS_MALLOC_CNT_MAX; index++) { \ 109 if (g_malloc_arr[index_mem_chk].ptr == _vaddr) { \ 110 g_malloc_arr[index_mem_chk].ptr = NULL; \ 111 if(_check_size && g_malloc_arr[index].size!=_check_size) { \ 112 xge_os_printf("OSPAL: freeing with wrong " \ 113 "size %d! allocated at %s:%d:"XGE_OS_LLXFMT":%d", \ 114 (int)_check_size, \ 115 g_malloc_arr[index_mem_chk].file, \ 116 g_malloc_arr[index_mem_chk].line, \ 117 (unsigned long long)(ulong_t) \ 118 g_malloc_arr[index_mem_chk].ptr, \ 119 g_malloc_arr[index_mem_chk].size); \ 120 } \ 121 break; \ 122 } \ 123 } \ 124 if (index_mem_chk == XGE_OS_MALLOC_CNT_MAX) { \ 125 xge_os_printf("OSPAL: ptr "XGE_OS_LLXFMT" not found!", \ 126 (unsigned long long)(ulong_t)_vaddr); \ 127 } \ 128} 129#else 130#define XGE_OS_MEMORY_CHECK_MALLOC(ptr, size, file, line) 131#define XGE_OS_MEMORY_CHECK_FREE(vaddr, check_size) 132#endif 133 134__EXTERN_END_DECLS 135 136#endif /* XGE_DEFS_H */ 137