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#include <sys/param.h> 31#include <sys/systm.h> 32 33#include <sys/time.h> 34#include <sys/kernel.h> 35#include <sys/bus.h> 36#include <machine/resource.h> 37 38#include <machine/pci_cfgreg.h> 39 40#ifndef __KERNEL__ 41#define __KERNEL__ 42#endif 43 44#include <dev/hptmv/global.h> 45#include <dev/hptmv/hptintf.h> 46#include <dev/hptmv/mvOs.h> 47#include <dev/hptmv/osbsd.h> 48 49 50void HPTLIBAPI 51MV_REG_WRITE_BYTE(MV_BUS_ADDR_T base, MV_U32 offset, MV_U8 val) 52{ 53 writeb((void *)((ULONG_PTR)base + offset), val); 54} 55 56void HPTLIBAPI 57MV_REG_WRITE_WORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U16 val) 58{ 59 writew((void *)((ULONG_PTR)base + offset), val); 60} 61 62void HPTLIBAPI 63MV_REG_WRITE_DWORD(MV_BUS_ADDR_T base, MV_U32 offset, MV_U32 val) 64{ 65 writel((void *)((ULONG_PTR)base + offset), val); 66} 67 68MV_U8 HPTLIBAPI 69MV_REG_READ_BYTE(MV_BUS_ADDR_T base, MV_U32 offset) 70{ 71 return readb((void *)((ULONG_PTR)base + offset)); 72} 73 74MV_U16 HPTLIBAPI 75MV_REG_READ_WORD(MV_BUS_ADDR_T base, MV_U32 offset) 76{ 77 return readw((void *)((ULONG_PTR)base + offset)); 78} 79 80MV_U32 HPTLIBAPI 81MV_REG_READ_DWORD(MV_BUS_ADDR_T base, MV_U32 offset) 82{ 83 return readl((void *)((ULONG_PTR)base + offset)); 84} 85 86int HPTLIBAPI 87os_memcmp(const void *cs, const void *ct, unsigned len) 88{ 89 return memcmp(cs, ct, len); 90} 91 92void HPTLIBAPI 93os_memcpy(void *to, const void *from, unsigned len) 94{ 95 memcpy(to, from, len); 96} 97 98void HPTLIBAPI 99os_memset(void *s, char c, unsigned len) 100{ 101 memset(s, c, len); 102} 103 104unsigned HPTLIBAPI 105os_strlen(const char *s) 106{ 107 return strlen(s); 108} 109 110void HPTLIBAPI 111mvMicroSecondsDelay(MV_U32 msecs) 112{ 113 DELAY(msecs); 114} 115 116ULONG_PTR HPTLIBAPI 117fOsPhysicalAddress(void *addr) 118{ 119 return (ULONG_PTR)(vtophys(addr)); 120} 121