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