1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause 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 50 void HPTLIBAPI 51 MV_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 56 void HPTLIBAPI 57 MV_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 62 void HPTLIBAPI 63 MV_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 68 MV_U8 HPTLIBAPI 69 MV_REG_READ_BYTE(MV_BUS_ADDR_T base, MV_U32 offset) 70 { 71 return readb((void *)((ULONG_PTR)base + offset)); 72 } 73 74 MV_U16 HPTLIBAPI 75 MV_REG_READ_WORD(MV_BUS_ADDR_T base, MV_U32 offset) 76 { 77 return readw((void *)((ULONG_PTR)base + offset)); 78 } 79 80 MV_U32 HPTLIBAPI 81 MV_REG_READ_DWORD(MV_BUS_ADDR_T base, MV_U32 offset) 82 { 83 return readl((void *)((ULONG_PTR)base + offset)); 84 } 85 86 int HPTLIBAPI 87 os_memcmp(const void *cs, const void *ct, unsigned len) 88 { 89 return memcmp(cs, ct, len); 90 } 91 92 void HPTLIBAPI 93 os_memcpy(void *to, const void *from, unsigned len) 94 { 95 memcpy(to, from, len); 96 } 97 98 void HPTLIBAPI 99 os_memset(void *s, char c, unsigned len) 100 { 101 memset(s, c, len); 102 } 103 104 unsigned HPTLIBAPI 105 os_strlen(const char *s) 106 { 107 return strlen(s); 108 } 109 110 void HPTLIBAPI 111 mvMicroSecondsDelay(MV_U32 msecs) 112 { 113 DELAY(msecs); 114 } 115 116 ULONG_PTR HPTLIBAPI 117 fOsPhysicalAddress(void *addr) 118 { 119 return (ULONG_PTR)(vtophys(addr)); 120 } 121