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