1133808Spjd/*
2133808Spjd * Copyright (c) 2004-2005 HighPoint Technologies, Inc.
3133808Spjd * All rights reserved.
4133808Spjd *
5133808Spjd * Redistribution and use in source and binary forms, with or without
6133808Spjd * modification, are permitted provided that the following conditions
7133808Spjd * are met:
8133808Spjd * 1. Redistributions of source code must retain the above copyright
9133808Spjd *    notice, this list of conditions and the following disclaimer.
10133808Spjd * 2. Redistributions in binary form must reproduce the above copyright
11133808Spjd *    notice, this list of conditions and the following disclaimer in the
12133808Spjd *    documentation and/or other materials provided with the distribution.
13133808Spjd *
14133808Spjd * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15133808Spjd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16133808Spjd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17133808Spjd * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18133808Spjd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19133808Spjd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20133808Spjd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21133808Spjd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22133808Spjd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23133808Spjd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24133808Spjd * SUCH DAMAGE.
25133808Spjd *
26133808Spjd * $FreeBSD$
27133808Spjd */
28133808Spjd#include <sys/param.h>
29133808Spjd#include <sys/systm.h>
30133808Spjd
31133808Spjd#include <sys/time.h>
32133808Spjd#include <sys/kernel.h>
33133808Spjd#include <sys/bus.h>
34133808Spjd#include <machine/resource.h>
35133808Spjd
36133808Spjd#if __FreeBSD_version >= 500043
37133808Spjd#include <machine/pci_cfgreg.h>
38133808Spjd#endif
39133808Spjd
40133808Spjd#if (__FreeBSD_version < 500043)
41133808Spjd#include <sys/bus_private.h>
42133808Spjd#endif
43133808Spjd
44133808Spjd#if (__FreeBSD_version < 500000)
45133808Spjd#include <machine/clock.h>
46133808Spjd#endif
47133808Spjd
48133808Spjd#ifndef __KERNEL__
49133808Spjd#define __KERNEL__
50133808Spjd#endif
51133808Spjd
52133808Spjd#include <dev/hptmv/global.h>
53133808Spjd#include <dev/hptmv/hptintf.h>
54133808Spjd#include <dev/hptmv/mvOs.h>
55133808Spjd#include <dev/hptmv/osbsd.h>
56133808Spjd
57133808Spjd
58133808Spjdvoid HPTLIBAPI
59133808SpjdMV_REG_WRITE_BYTE(MV_BUS_ADDR_T base, MV_U32 offset, MV_U8 val)
60133808Spjd{
61133808Spjd	writeb((void *)((ULONG_PTR)base + offset), val);
62133808Spjd}
63133808Spjd
64133808Spjdvoid HPTLIBAPI
65133808SpjdMV_REG_WRITE_WORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U16 val)
66133808Spjd{
67133808Spjd	writew((void *)((ULONG_PTR)base + offset), val);
68133808Spjd}
69133808Spjd
70133808Spjdvoid HPTLIBAPI
71133808SpjdMV_REG_WRITE_DWORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U32 val)
72133808Spjd{
73133808Spjd	writel((void *)((ULONG_PTR)base + offset), val);
74133808Spjd}
75133808Spjd
76133808SpjdMV_U8  HPTLIBAPI
77133808SpjdMV_REG_READ_BYTE(MV_BUS_ADDR_T base, MV_U32 offset)
78133808Spjd{
79133808Spjd	return readb((void *)((ULONG_PTR)base + offset));
80133808Spjd}
81133808Spjd
82133808SpjdMV_U16 HPTLIBAPI
83133808SpjdMV_REG_READ_WORD(MV_BUS_ADDR_T base, MV_U32 offset)
84133808Spjd{
85133808Spjd	return readw((void *)((ULONG_PTR)base + offset));
86133808Spjd}
87133808Spjd
88133808SpjdMV_U32 HPTLIBAPI
89133808SpjdMV_REG_READ_DWORD(MV_BUS_ADDR_T base, MV_U32 offset)
90133808Spjd{
91133808Spjd	return readl((void *)((ULONG_PTR)base + offset));
92133808Spjd}
93133808Spjd
94133808Spjdint HPTLIBAPI
95133808Spjdos_memcmp(const void *cs, const void *ct, unsigned len)
96133808Spjd{
97133808Spjd	return memcmp(cs, ct, len);
98133808Spjd}
99133808Spjd
100133808Spjdvoid HPTLIBAPI
101133808Spjdos_memcpy(void *to, const void *from, unsigned len)
102133808Spjd{
103133808Spjd	memcpy(to, from, len);
104133808Spjd}
105133808Spjd
106133808Spjdvoid HPTLIBAPI
107133808Spjdos_memset(void *s, char c, unsigned len)
108133808Spjd{
109133808Spjd	memset(s, c, len);
110133808Spjd}
111133808Spjd
112133808Spjdunsigned HPTLIBAPI
113133808Spjdos_strlen(const char *s)
114133808Spjd{
115133808Spjd	return strlen(s);
116133808Spjd}
117133808Spjd
118133808Spjdvoid HPTLIBAPI
119133808SpjdmvMicroSecondsDelay(MV_U32 msecs)
120133808Spjd{
121133808Spjd	DELAY(msecs);
122133808Spjd}
123133808Spjd
124133808SpjdULONG_PTR HPTLIBAPI
125133808SpjdfOsPhysicalAddress(void *addr)
126133808Spjd{
127133808Spjd	return (ULONG_PTR)(vtophys(addr));
128133808Spjd}
129133808Spjd