1/*-
2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3 *
4 * Copyright (c) 2004-2005 HighPoint Technologies, Inc.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 *    notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 *    notice, this list of conditions and the following disclaimer in the
14 *    documentation and/or other materials provided with the distribution.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 *
28 * $FreeBSD$
29 */
30#ifndef _GLOBAL_H_
31#define _GLOBAL_H_
32
33#include <dev/hptmv/mvOs.h>
34#include <dev/hptmv/mvSata.h>
35#include <dev/hptmv/mvStorageDev.h>
36
37#define COMPANY      "HighPoint Technologies, Inc."
38#define COPYRIGHT    "(c) 2000-2007. HighPoint Technologies, Inc."
39#define DRIVER_NAME		"RocketRAID 18xx SATA Controller driver"
40#define CONTROLLER_NAME	"RocketRAID 18xx SATA Controller"
41#define PROC_DIR_NAME hptmv
42
43#define HPT_INTERFACE_VERSION 0x01010000
44#define SUPPORT_48BIT_LBA
45#define SUPPORT_ARRAY
46#define SUPPORT_RAID5 1
47#define _RAID5N_
48#define MAX_QUEUE_COMM 32
49#define MAX_SG_DESCRIPTORS 17
50#define MAX_VBUS 2    /*one vbus per adapter in mv linux driver,
51                        MAX_VBUS is defined for share code and can not be 1*/
52
53#define SET_VBUS_FOR_EACH_CONTROLLER
54#define MAX_MEMBERS 8
55#define MAX_ARRAY_NAME 16
56#define MAX_VDEVICE_PER_VBUS 8
57#define MAX_ARRAY_DEVICE MAX_ARRAY_PER_VBUS
58#define MAX_CHIP_IN_VBUS 1
59
60#define SUPPORT_IOCTL
61#define SUPPORT_FAIL_LED
62
63typedef void * PChipInstance;
64typedef void * PChannel;
65typedef struct _VDevice *PVDevice;
66typedef struct _VBus *PVBus;
67typedef struct _ArrayDescript *PArrayDescript;
68typedef struct _ArrayDescriptV2 *PArrayDescriptV2;
69typedef struct _Command *PCommand;
70
71typedef struct _Device {
72	UCHAR df_on_line;
73	UCHAR df_atapi;
74	UCHAR df_removable_drive;
75	UCHAR busyCount;
76
77	UCHAR df_tcq_set: 1;
78    UCHAR df_tcq: 1;          /* enable TCQ */
79	UCHAR df_ncq_set: 1;
80    UCHAR df_ncq: 1;          /* enable NCQ */
81	UCHAR df_write_cache_set: 1;
82    UCHAR df_write_cache: 1;  /* enable write cache */
83	UCHAR df_read_ahead_set: 1;
84    UCHAR df_read_ahead: 1;   /* enable read ahead */
85
86	UCHAR retryCount;
87	UCHAR resetCount;
88	UCHAR pad1;
89
90	UCHAR df_user_mode_set;
91    UCHAR bDeModeSetting;    /* Current Data Transfer mode: 0-4 PIO 0-4 */
92    UCHAR bDeUsable_Mode;       /* actual maximum data transfer mode */
93	UCHAR bDeUserSelectMode;
94
95	PVBus pVBus;
96	ULONG dDeRealCapacity;
97	ULONG dDeHiddenLba;
98	ULONG HeadPosition;
99	ULONG QueueLength;
100	MV_SATA_CHANNEL *mv;
101}
102Device, *PDevice;
103
104typedef struct _SCAT_GATH
105{
106    ULONG_PTR     dSgAddress;
107    USHORT        wSgSize;
108    USHORT        wSgFlag;
109} SCAT_GATH, FAR *FPSCAT_GATH;
110
111#define OS_VDEV_EXT
112typedef struct _VDevice_Ext
113{
114	UCHAR gui_locked; /* the device is locked by GUI */
115	UCHAR reserve[3];
116} VDevice_Ext, *PVDevice_Ext;
117
118
119#define SG_FLAG_SKIP        0x4000
120#define SG_FLAG_EOT         0x8000
121
122#define _VBUS_ARG0 PVBus _vbus_p
123#define _VBUS_ARG PVBus _vbus_p,
124#define _VBUS_P _vbus_p,
125#define _VBUS_P0 _vbus_p
126#define _VBUS_INST(x) PVBus _vbus_p = x;
127#define _vbus_(x) (_vbus_p->x)
128
129/*************************************************************************
130 * arithmetic functions
131 *************************************************************************/
132#define LongRShift(x, y) 	(x >> y)
133#define LongLShift(x, y)   	(x << y)
134#define LongDiv(x, y)      	(x / (UINT)(y))
135#define LongRem(x, y)		(x % (UINT)(y))
136#define LongMul(x, y)      	(x * y)
137
138/*************************************************************************
139 * C library
140 *************************************************************************/
141int HPTLIBAPI os_memcmp(const void *cs, const void *ct, unsigned len);
142void HPTLIBAPI os_memcpy(void *to, const void *from, unsigned len);
143void HPTLIBAPI os_memset(void *s, char c, unsigned len);
144unsigned HPTLIBAPI os_strlen(const char *s);
145
146#ifdef NO_LIBC
147#define memcmp os_memcmp
148#define memcpy os_memcpy
149#define memset os_memset
150#define strlen os_strlen
151#endif
152#define ZeroMemory(a, b)  	memset((char *)a, 0, b)
153#define MemoryCopy(a,b,c) 	memcpy((char *)(a), (char *)(b), (UINT)(c))
154#define farMemoryCopy(a,b,c) memcpy((char *)(a), (char *)(b), (UINT)c)
155#define StrLen            	strlen
156
157/*
158 * we don't want whole hptintf.h in shared code...
159 * some constants must match that in hptintf.h!
160 */
161enum _driver_events_t
162{
163	ET_DEVICE=0,
164    ET_DEVICE_REMOVED,
165    ET_DEVICE_PLUGGED,
166    ET_DEVICE_ERROR,
167    ET_REBUILD_STARTED,
168    ET_REBUILD_ABORTED,
169    ET_REBUILD_FINISHED,
170    ET_SPARE_TOOK_OVER,
171    ET_REBUILD_FAILED,
172	ET_VERIFY_STARTED,
173	ET_VERIFY_ABORTED,
174	ET_VERIFY_FAILED,
175	ET_VERIFY_FINISHED,
176	ET_INITIALIZE_STARTED,
177	ET_INITIALIZE_ABORTED,
178	ET_INITIALIZE_FAILED,
179	ET_INITIALIZE_FINISHED,
180	ET_VERIFY_DATA_ERROR,
181};
182
183#define StallExec(x) mvMicroSecondsDelay(x)
184extern void HPTLIBAPI ioctl_ReportEvent(UCHAR event, PVOID param);
185#define fNotifyGUI(WhatHappen, pVDevice) ioctl_ReportEvent(WhatHappen, pVDevice)
186#define DECLARE_BUFFER(type, ptr) UCHAR ptr##__buf[512]; type ptr=(type)ptr##__buf
187
188int HPTLIBAPI fDeReadWrite(PDevice pDev, ULONG Lba, UCHAR Cmd, void *tmpBuffer);
189void HPTLIBAPI fDeSelectMode(PDevice pDev, UCHAR NewMode);
190int HPTLIBAPI fDeSetTCQ(PDevice pDev, int enable, int depth);
191int HPTLIBAPI fDeSetNCQ(PDevice pDev, int enable, int depth);
192int HPTLIBAPI fDeSetWriteCache(PDevice pDev, int enable);
193int HPTLIBAPI fDeSetReadAhead(PDevice pDev, int enable);
194
195#include <dev/hptmv/atapi.h>
196#include <dev/hptmv/command.h>
197#include <dev/hptmv/array.h>
198#include <dev/hptmv/raid5n.h>
199#include <dev/hptmv/vdevice.h>
200
201#if defined(__FreeBSD__) && defined(HPTLIBAPI)
202#undef HPTLIBAPI
203#define HPTLIBAPI
204#endif
205
206#ifdef SUPPORT_ARRAY
207#define ArrayTables(i) ((PVDevice)&_vbus_(_ArrayTables)[i*ARRAY_VDEV_SIZE])
208#endif
209
210#endif
211