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