1*86d7f5d3SJohn Marino /*
2*86d7f5d3SJohn Marino * Copyright (c) 2004-2005 HighPoint Technologies, Inc.
3*86d7f5d3SJohn Marino * All rights reserved.
4*86d7f5d3SJohn Marino *
5*86d7f5d3SJohn Marino * Redistribution and use in source and binary forms, with or without
6*86d7f5d3SJohn Marino * modification, are permitted provided that the following conditions
7*86d7f5d3SJohn Marino * are met:
8*86d7f5d3SJohn Marino * 1. Redistributions of source code must retain the above copyright
9*86d7f5d3SJohn Marino * notice, this list of conditions and the following disclaimer.
10*86d7f5d3SJohn Marino * 2. Redistributions in binary form must reproduce the above copyright
11*86d7f5d3SJohn Marino * notice, this list of conditions and the following disclaimer in the
12*86d7f5d3SJohn Marino * documentation and/or other materials provided with the distribution.
13*86d7f5d3SJohn Marino *
14*86d7f5d3SJohn Marino * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*86d7f5d3SJohn Marino * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*86d7f5d3SJohn Marino * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*86d7f5d3SJohn Marino * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*86d7f5d3SJohn Marino * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*86d7f5d3SJohn Marino * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*86d7f5d3SJohn Marino * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*86d7f5d3SJohn Marino * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*86d7f5d3SJohn Marino * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*86d7f5d3SJohn Marino * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*86d7f5d3SJohn Marino * SUCH DAMAGE.
25*86d7f5d3SJohn Marino *
26*86d7f5d3SJohn Marino * $FreeBSD: src/sys/dev/hptmv/mv.c,v 1.3 2005/09/07 23:33:26 scottl Exp $
27*86d7f5d3SJohn Marino */
28*86d7f5d3SJohn Marino #include <sys/param.h>
29*86d7f5d3SJohn Marino #include <sys/systm.h>
30*86d7f5d3SJohn Marino
31*86d7f5d3SJohn Marino #include <sys/time.h>
32*86d7f5d3SJohn Marino #include <sys/kernel.h>
33*86d7f5d3SJohn Marino #include <sys/bus.h>
34*86d7f5d3SJohn Marino
35*86d7f5d3SJohn Marino #ifndef __KERNEL__
36*86d7f5d3SJohn Marino #define __KERNEL__
37*86d7f5d3SJohn Marino #endif
38*86d7f5d3SJohn Marino
39*86d7f5d3SJohn Marino #include <dev/raid/hptmv/global.h>
40*86d7f5d3SJohn Marino #include <dev/raid/hptmv/hptintf.h>
41*86d7f5d3SJohn Marino #include <dev/raid/hptmv/mvOs.h>
42*86d7f5d3SJohn Marino #include <dev/raid/hptmv/osbsd.h>
43*86d7f5d3SJohn Marino
44*86d7f5d3SJohn Marino
45*86d7f5d3SJohn Marino void HPTLIBAPI
MV_REG_WRITE_BYTE(MV_BUS_ADDR_T base,MV_U32 offset,MV_U8 val)46*86d7f5d3SJohn Marino MV_REG_WRITE_BYTE(MV_BUS_ADDR_T base, MV_U32 offset, MV_U8 val)
47*86d7f5d3SJohn Marino {
48*86d7f5d3SJohn Marino writeb((void *)((ULONG_PTR)base + offset), val);
49*86d7f5d3SJohn Marino }
50*86d7f5d3SJohn Marino
51*86d7f5d3SJohn Marino void HPTLIBAPI
MV_REG_WRITE_WORD(MV_BUS_ADDR_T base,MV_U32 offset,MV_U16 val)52*86d7f5d3SJohn Marino MV_REG_WRITE_WORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U16 val)
53*86d7f5d3SJohn Marino {
54*86d7f5d3SJohn Marino writew((void *)((ULONG_PTR)base + offset), val);
55*86d7f5d3SJohn Marino }
56*86d7f5d3SJohn Marino
57*86d7f5d3SJohn Marino void HPTLIBAPI
MV_REG_WRITE_DWORD(MV_BUS_ADDR_T base,MV_U32 offset,MV_U32 val)58*86d7f5d3SJohn Marino MV_REG_WRITE_DWORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U32 val)
59*86d7f5d3SJohn Marino {
60*86d7f5d3SJohn Marino writel((void *)((ULONG_PTR)base + offset), val);
61*86d7f5d3SJohn Marino }
62*86d7f5d3SJohn Marino
63*86d7f5d3SJohn Marino MV_U8 HPTLIBAPI
MV_REG_READ_BYTE(MV_BUS_ADDR_T base,MV_U32 offset)64*86d7f5d3SJohn Marino MV_REG_READ_BYTE(MV_BUS_ADDR_T base, MV_U32 offset)
65*86d7f5d3SJohn Marino {
66*86d7f5d3SJohn Marino return readb((void *)((ULONG_PTR)base + offset));
67*86d7f5d3SJohn Marino }
68*86d7f5d3SJohn Marino
69*86d7f5d3SJohn Marino MV_U16 HPTLIBAPI
MV_REG_READ_WORD(MV_BUS_ADDR_T base,MV_U32 offset)70*86d7f5d3SJohn Marino MV_REG_READ_WORD(MV_BUS_ADDR_T base, MV_U32 offset)
71*86d7f5d3SJohn Marino {
72*86d7f5d3SJohn Marino return readw((void *)((ULONG_PTR)base + offset));
73*86d7f5d3SJohn Marino }
74*86d7f5d3SJohn Marino
75*86d7f5d3SJohn Marino MV_U32 HPTLIBAPI
MV_REG_READ_DWORD(MV_BUS_ADDR_T base,MV_U32 offset)76*86d7f5d3SJohn Marino MV_REG_READ_DWORD(MV_BUS_ADDR_T base, MV_U32 offset)
77*86d7f5d3SJohn Marino {
78*86d7f5d3SJohn Marino return readl((void *)((ULONG_PTR)base + offset));
79*86d7f5d3SJohn Marino }
80*86d7f5d3SJohn Marino
81*86d7f5d3SJohn Marino int HPTLIBAPI
os_memcmp(const void * cs,const void * ct,unsigned len)82*86d7f5d3SJohn Marino os_memcmp(const void *cs, const void *ct, unsigned len)
83*86d7f5d3SJohn Marino {
84*86d7f5d3SJohn Marino return memcmp(cs, ct, len);
85*86d7f5d3SJohn Marino }
86*86d7f5d3SJohn Marino
87*86d7f5d3SJohn Marino void HPTLIBAPI
os_memcpy(void * to,const void * from,unsigned len)88*86d7f5d3SJohn Marino os_memcpy(void *to, const void *from, unsigned len)
89*86d7f5d3SJohn Marino {
90*86d7f5d3SJohn Marino memcpy(to, from, len);
91*86d7f5d3SJohn Marino }
92*86d7f5d3SJohn Marino
93*86d7f5d3SJohn Marino void HPTLIBAPI
os_memset(void * s,char c,unsigned len)94*86d7f5d3SJohn Marino os_memset(void *s, char c, unsigned len)
95*86d7f5d3SJohn Marino {
96*86d7f5d3SJohn Marino memset(s, c, len);
97*86d7f5d3SJohn Marino }
98*86d7f5d3SJohn Marino
99*86d7f5d3SJohn Marino unsigned HPTLIBAPI
os_strlen(const char * s)100*86d7f5d3SJohn Marino os_strlen(const char *s)
101*86d7f5d3SJohn Marino {
102*86d7f5d3SJohn Marino return strlen(s);
103*86d7f5d3SJohn Marino }
104*86d7f5d3SJohn Marino
105*86d7f5d3SJohn Marino void HPTLIBAPI
mvMicroSecondsDelay(MV_U32 msecs)106*86d7f5d3SJohn Marino mvMicroSecondsDelay(MV_U32 msecs)
107*86d7f5d3SJohn Marino {
108*86d7f5d3SJohn Marino DELAY(msecs);
109*86d7f5d3SJohn Marino }
110*86d7f5d3SJohn Marino
111*86d7f5d3SJohn Marino ULONG_PTR HPTLIBAPI
fOsPhysicalAddress(void * addr)112*86d7f5d3SJohn Marino fOsPhysicalAddress(void *addr)
113*86d7f5d3SJohn Marino {
114*86d7f5d3SJohn Marino return (ULONG_PTR)(vtophys(addr));
115*86d7f5d3SJohn Marino }
116