1*78ee8d1cSJulian Grajkowski /* SPDX-License-Identifier: BSD-3-Clause */ 2*78ee8d1cSJulian Grajkowski /* Copyright(c) 2007-2022 Intel Corporation */ 3*78ee8d1cSJulian Grajkowski /* $FreeBSD$ */ 4*78ee8d1cSJulian Grajkowski #ifndef QAT_FREEBSD_H_ 5*78ee8d1cSJulian Grajkowski #define QAT_FREEBSD_H_ 6*78ee8d1cSJulian Grajkowski 7*78ee8d1cSJulian Grajkowski #include <sys/param.h> 8*78ee8d1cSJulian Grajkowski #include <sys/module.h> 9*78ee8d1cSJulian Grajkowski #include <sys/bus.h> 10*78ee8d1cSJulian Grajkowski #include <sys/param.h> 11*78ee8d1cSJulian Grajkowski #include <sys/malloc.h> 12*78ee8d1cSJulian Grajkowski #include <sys/firmware.h> 13*78ee8d1cSJulian Grajkowski #include <sys/rman.h> 14*78ee8d1cSJulian Grajkowski #include <sys/types.h> 15*78ee8d1cSJulian Grajkowski #include <sys/ctype.h> 16*78ee8d1cSJulian Grajkowski #include <sys/ioccom.h> 17*78ee8d1cSJulian Grajkowski #include <sys/param.h> 18*78ee8d1cSJulian Grajkowski #include <sys/lock.h> 19*78ee8d1cSJulian Grajkowski #include <linux/device.h> 20*78ee8d1cSJulian Grajkowski #include <linux/dma-mapping.h> 21*78ee8d1cSJulian Grajkowski #include <linux/completion.h> 22*78ee8d1cSJulian Grajkowski #include <linux/list.h> 23*78ee8d1cSJulian Grajkowski #include <machine/bus.h> 24*78ee8d1cSJulian Grajkowski #include <machine/bus_dma.h> 25*78ee8d1cSJulian Grajkowski #include <sys/firmware.h> 26*78ee8d1cSJulian Grajkowski #include <asm/uaccess.h> 27*78ee8d1cSJulian Grajkowski #include <linux/math64.h> 28*78ee8d1cSJulian Grajkowski #include <linux/spinlock.h> 29*78ee8d1cSJulian Grajkowski 30*78ee8d1cSJulian Grajkowski #define PCI_VENDOR_ID_INTEL 0x8086 31*78ee8d1cSJulian Grajkowski 32*78ee8d1cSJulian Grajkowski #if !defined(__bool_true_false_are_defined) 33*78ee8d1cSJulian Grajkowski #define __bool_true_false_are_defined 1 34*78ee8d1cSJulian Grajkowski #define false 0 35*78ee8d1cSJulian Grajkowski #define true 1 36*78ee8d1cSJulian Grajkowski #if __STDC_VERSION__ < 199901L && __GNUC__ < 3 && !defined(__INTEL_COMPILER) 37*78ee8d1cSJulian Grajkowski typedef int _Bool; 38*78ee8d1cSJulian Grajkowski #endif 39*78ee8d1cSJulian Grajkowski typedef _Bool bool; 40*78ee8d1cSJulian Grajkowski #endif /* !__bool_true_false_are_defined && !__cplusplus */ 41*78ee8d1cSJulian Grajkowski 42*78ee8d1cSJulian Grajkowski #if __STDC_VERSION__ < 199901L && __GNUC__ < 3 && !defined(__INTEL_COMPILER) 43*78ee8d1cSJulian Grajkowski typedef int _Bool; 44*78ee8d1cSJulian Grajkowski #endif 45*78ee8d1cSJulian Grajkowski 46*78ee8d1cSJulian Grajkowski #define pause_ms(wmesg, ms) pause_sbt(wmesg, (ms)*SBT_1MS, 0, C_HARDCLOCK) 47*78ee8d1cSJulian Grajkowski 48*78ee8d1cSJulian Grajkowski /* Function sets the MaxPayload size of a PCI device. */ 49*78ee8d1cSJulian Grajkowski int pci_set_max_payload(device_t dev, int payload_size); 50*78ee8d1cSJulian Grajkowski 51*78ee8d1cSJulian Grajkowski device_t pci_find_pf(device_t vf); 52*78ee8d1cSJulian Grajkowski 53*78ee8d1cSJulian Grajkowski MALLOC_DECLARE(M_QAT); 54*78ee8d1cSJulian Grajkowski 55*78ee8d1cSJulian Grajkowski struct msix_entry { 56*78ee8d1cSJulian Grajkowski struct resource *irq; 57*78ee8d1cSJulian Grajkowski void *cookie; 58*78ee8d1cSJulian Grajkowski }; 59*78ee8d1cSJulian Grajkowski 60*78ee8d1cSJulian Grajkowski struct pci_device_id { 61*78ee8d1cSJulian Grajkowski uint16_t vendor; 62*78ee8d1cSJulian Grajkowski uint16_t device; 63*78ee8d1cSJulian Grajkowski }; 64*78ee8d1cSJulian Grajkowski 65*78ee8d1cSJulian Grajkowski struct bus_dmamem { 66*78ee8d1cSJulian Grajkowski bus_dma_tag_t dma_tag; 67*78ee8d1cSJulian Grajkowski bus_dmamap_t dma_map; 68*78ee8d1cSJulian Grajkowski void *dma_vaddr; 69*78ee8d1cSJulian Grajkowski bus_addr_t dma_baddr; 70*78ee8d1cSJulian Grajkowski }; 71*78ee8d1cSJulian Grajkowski 72*78ee8d1cSJulian Grajkowski /* 73*78ee8d1cSJulian Grajkowski * Allocate a mapping. On success, zero is returned and the 'dma_vaddr' 74*78ee8d1cSJulian Grajkowski * and 'dma_baddr' fields are populated with the virtual and bus addresses, 75*78ee8d1cSJulian Grajkowski * respectively, of the mapping. 76*78ee8d1cSJulian Grajkowski */ 77*78ee8d1cSJulian Grajkowski int bus_dma_mem_create(struct bus_dmamem *mem, 78*78ee8d1cSJulian Grajkowski bus_dma_tag_t parent, 79*78ee8d1cSJulian Grajkowski bus_size_t alignment, 80*78ee8d1cSJulian Grajkowski bus_addr_t lowaddr, 81*78ee8d1cSJulian Grajkowski bus_size_t len, 82*78ee8d1cSJulian Grajkowski int flags); 83*78ee8d1cSJulian Grajkowski 84*78ee8d1cSJulian Grajkowski /* 85*78ee8d1cSJulian Grajkowski * Release a mapping created by bus_dma_mem_create(). 86*78ee8d1cSJulian Grajkowski */ 87*78ee8d1cSJulian Grajkowski void bus_dma_mem_free(struct bus_dmamem *mem); 88*78ee8d1cSJulian Grajkowski 89*78ee8d1cSJulian Grajkowski #define list_for_each_prev_safe(p, n, h) \ 90*78ee8d1cSJulian Grajkowski for (p = (h)->prev, n = (p)->prev; p != (h); p = n, n = (p)->prev) 91*78ee8d1cSJulian Grajkowski 92*78ee8d1cSJulian Grajkowski static inline int 93*78ee8d1cSJulian Grajkowski compat_strtoul(const char *cp, unsigned int base, unsigned long *res) 94*78ee8d1cSJulian Grajkowski { 95*78ee8d1cSJulian Grajkowski char *end; 96*78ee8d1cSJulian Grajkowski 97*78ee8d1cSJulian Grajkowski *res = strtoul(cp, &end, base); 98*78ee8d1cSJulian Grajkowski 99*78ee8d1cSJulian Grajkowski /* skip newline character, if any */ 100*78ee8d1cSJulian Grajkowski if (*end == '\n') 101*78ee8d1cSJulian Grajkowski end++; 102*78ee8d1cSJulian Grajkowski if (*cp == 0 || *end != 0) 103*78ee8d1cSJulian Grajkowski return (-EINVAL); 104*78ee8d1cSJulian Grajkowski return (0); 105*78ee8d1cSJulian Grajkowski } 106*78ee8d1cSJulian Grajkowski 107*78ee8d1cSJulian Grajkowski static inline int 108*78ee8d1cSJulian Grajkowski compat_strtouint(const char *cp, unsigned int base, unsigned int *res) 109*78ee8d1cSJulian Grajkowski { 110*78ee8d1cSJulian Grajkowski char *end; 111*78ee8d1cSJulian Grajkowski unsigned long temp; 112*78ee8d1cSJulian Grajkowski 113*78ee8d1cSJulian Grajkowski *res = temp = strtoul(cp, &end, base); 114*78ee8d1cSJulian Grajkowski 115*78ee8d1cSJulian Grajkowski /* skip newline character, if any */ 116*78ee8d1cSJulian Grajkowski if (*end == '\n') 117*78ee8d1cSJulian Grajkowski end++; 118*78ee8d1cSJulian Grajkowski if (*cp == 0 || *end != 0) 119*78ee8d1cSJulian Grajkowski return (-EINVAL); 120*78ee8d1cSJulian Grajkowski if (temp != (unsigned int)temp) 121*78ee8d1cSJulian Grajkowski return (-ERANGE); 122*78ee8d1cSJulian Grajkowski return (0); 123*78ee8d1cSJulian Grajkowski } 124*78ee8d1cSJulian Grajkowski 125*78ee8d1cSJulian Grajkowski static inline int 126*78ee8d1cSJulian Grajkowski compat_strtou8(const char *cp, unsigned int base, unsigned char *res) 127*78ee8d1cSJulian Grajkowski { 128*78ee8d1cSJulian Grajkowski char *end; 129*78ee8d1cSJulian Grajkowski unsigned long temp; 130*78ee8d1cSJulian Grajkowski 131*78ee8d1cSJulian Grajkowski *res = temp = strtoul(cp, &end, base); 132*78ee8d1cSJulian Grajkowski 133*78ee8d1cSJulian Grajkowski /* skip newline character, if any */ 134*78ee8d1cSJulian Grajkowski if (*end == '\n') 135*78ee8d1cSJulian Grajkowski end++; 136*78ee8d1cSJulian Grajkowski if (*cp == 0 || *end != 0) 137*78ee8d1cSJulian Grajkowski return -EINVAL; 138*78ee8d1cSJulian Grajkowski if (temp != (unsigned char)temp) 139*78ee8d1cSJulian Grajkowski return -ERANGE; 140*78ee8d1cSJulian Grajkowski return 0; 141*78ee8d1cSJulian Grajkowski } 142*78ee8d1cSJulian Grajkowski 143*78ee8d1cSJulian Grajkowski #if __FreeBSD_version >= 1300500 144*78ee8d1cSJulian Grajkowski #undef dev_to_node 145*78ee8d1cSJulian Grajkowski static inline int 146*78ee8d1cSJulian Grajkowski dev_to_node(device_t dev) 147*78ee8d1cSJulian Grajkowski { 148*78ee8d1cSJulian Grajkowski int numa_domain; 149*78ee8d1cSJulian Grajkowski 150*78ee8d1cSJulian Grajkowski if (!dev || bus_get_domain(dev, &numa_domain) != 0) 151*78ee8d1cSJulian Grajkowski return (-1); 152*78ee8d1cSJulian Grajkowski else 153*78ee8d1cSJulian Grajkowski return (numa_domain); 154*78ee8d1cSJulian Grajkowski } 155*78ee8d1cSJulian Grajkowski #endif 156*78ee8d1cSJulian Grajkowski #endif 157