1*5939d8a1SRuslan Bukin /*- 2*5939d8a1SRuslan Bukin * SPDX-License-Identifier: BSD-2-Clause 3*5939d8a1SRuslan Bukin * 4*5939d8a1SRuslan Bukin * Copyright (c) 2019 Ruslan Bukin <br@bsdpad.com> 5*5939d8a1SRuslan Bukin * 6*5939d8a1SRuslan Bukin * This software was developed by SRI International and the University of 7*5939d8a1SRuslan Bukin * Cambridge Computer Laboratory (Department of Computer Science and 8*5939d8a1SRuslan Bukin * Technology) under DARPA contract HR0011-18-C-0016 ("ECATS"), as part of the 9*5939d8a1SRuslan Bukin * DARPA SSITH research programme. 10*5939d8a1SRuslan Bukin * 11*5939d8a1SRuslan Bukin * Redistribution and use in source and binary forms, with or without 12*5939d8a1SRuslan Bukin * modification, are permitted provided that the following conditions 13*5939d8a1SRuslan Bukin * are met: 14*5939d8a1SRuslan Bukin * 1. Redistributions of source code must retain the above copyright 15*5939d8a1SRuslan Bukin * notice, this list of conditions and the following disclaimer. 16*5939d8a1SRuslan Bukin * 2. Redistributions in binary form must reproduce the above copyright 17*5939d8a1SRuslan Bukin * notice, this list of conditions and the following disclaimer in the 18*5939d8a1SRuslan Bukin * documentation and/or other materials provided with the distribution. 19*5939d8a1SRuslan Bukin * 20*5939d8a1SRuslan Bukin * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 21*5939d8a1SRuslan Bukin * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22*5939d8a1SRuslan Bukin * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23*5939d8a1SRuslan Bukin * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 24*5939d8a1SRuslan Bukin * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25*5939d8a1SRuslan Bukin * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26*5939d8a1SRuslan Bukin * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27*5939d8a1SRuslan Bukin * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28*5939d8a1SRuslan Bukin * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29*5939d8a1SRuslan Bukin * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30*5939d8a1SRuslan Bukin * SUCH DAMAGE. 31*5939d8a1SRuslan Bukin * 32*5939d8a1SRuslan Bukin * $FreeBSD$ 33*5939d8a1SRuslan Bukin */ 34*5939d8a1SRuslan Bukin 35*5939d8a1SRuslan Bukin #ifndef _DEV_XILINX_AXIDMA_H_ 36*5939d8a1SRuslan Bukin #define _DEV_XILINX_AXIDMA_H_ 37*5939d8a1SRuslan Bukin 38*5939d8a1SRuslan Bukin #define AXI_DMACR(n) (0x00 + 0x30 * (n)) /* DMA Control register */ 39*5939d8a1SRuslan Bukin #define DMACR_RS (1 << 0) /* Run / Stop. */ 40*5939d8a1SRuslan Bukin #define DMACR_RESET (1 << 2) /* Soft reset the AXI DMA core. */ 41*5939d8a1SRuslan Bukin #define DMACR_IOC_IRQEN (1 << 12) /* Interrupt on Complete (IOC) Interrupt Enable. */ 42*5939d8a1SRuslan Bukin #define DMACR_DLY_IRQEN (1 << 13) /* Interrupt on Delay Timer Interrupt Enable. */ 43*5939d8a1SRuslan Bukin #define DMACR_ERR_IRQEN (1 << 14) /* Interrupt on Error Interrupt Enable. */ 44*5939d8a1SRuslan Bukin #define AXI_DMASR(n) (0x04 + 0x30 * (n)) /* DMA Status register */ 45*5939d8a1SRuslan Bukin #define DMASR_HALTED (1 << 0) 46*5939d8a1SRuslan Bukin #define DMASR_IDLE (1 << 1) 47*5939d8a1SRuslan Bukin #define DMASR_SGINCLD (1 << 3) /* Scatter Gather Enabled */ 48*5939d8a1SRuslan Bukin #define DMASR_DMAINTERR (1 << 4) /* DMA Internal Error. */ 49*5939d8a1SRuslan Bukin #define DMASR_DMASLVERR (1 << 5) /* DMA Slave Error. */ 50*5939d8a1SRuslan Bukin #define DMASR_DMADECOREERR (1 << 6) /* Decode Error. */ 51*5939d8a1SRuslan Bukin #define DMASR_SGINTERR (1 << 8) /* Scatter Gather Internal Error. */ 52*5939d8a1SRuslan Bukin #define DMASR_SGSLVERR (1 << 9) /* Scatter Gather Slave Error. */ 53*5939d8a1SRuslan Bukin #define DMASR_SGDECERR (1 << 10) /* Scatter Gather Decode Error. */ 54*5939d8a1SRuslan Bukin #define DMASR_IOC_IRQ (1 << 12) /* Interrupt on Complete. */ 55*5939d8a1SRuslan Bukin #define DMASR_DLY_IRQ (1 << 13) /* Interrupt on Delay. */ 56*5939d8a1SRuslan Bukin #define DMASR_ERR_IRQ (1 << 14) /* Interrupt on Error. */ 57*5939d8a1SRuslan Bukin #define AXI_CURDESC(n) (0x08 + 0x30 * (n)) /* Current Descriptor Pointer. Lower 32 bits of the address. */ 58*5939d8a1SRuslan Bukin #define AXI_CURDESC_MSB(n) (0x0C + 0x30 * (n)) /* Current Descriptor Pointer. Upper 32 bits of address. */ 59*5939d8a1SRuslan Bukin #define AXI_TAILDESC(n) (0x10 + 0x30 * (n)) /* Tail Descriptor Pointer. Lower 32 bits. */ 60*5939d8a1SRuslan Bukin #define AXI_TAILDESC_MSB(n) (0x14 + 0x30 * (n)) /* Tail Descriptor Pointer. Upper 32 bits of address. */ 61*5939d8a1SRuslan Bukin #define AXI_SG_CTL 0x2C /* Scatter/Gather User and Cache */ 62*5939d8a1SRuslan Bukin 63*5939d8a1SRuslan Bukin #define READ4(_sc, _reg) \ 64*5939d8a1SRuslan Bukin bus_space_read_4(_sc->bst, _sc->bsh, _reg) 65*5939d8a1SRuslan Bukin #define WRITE4(_sc, _reg, _val) \ 66*5939d8a1SRuslan Bukin bus_space_write_4(_sc->bst, _sc->bsh, _reg, _val) 67*5939d8a1SRuslan Bukin #define READ8(_sc, _reg) \ 68*5939d8a1SRuslan Bukin bus_space_read_8(_sc->bst, _sc->bsh, _reg) 69*5939d8a1SRuslan Bukin #define WRITE8(_sc, _reg, _val) \ 70*5939d8a1SRuslan Bukin bus_space_write_8(_sc->bst, _sc->bsh, _reg, _val) 71*5939d8a1SRuslan Bukin 72*5939d8a1SRuslan Bukin struct axidma_desc { 73*5939d8a1SRuslan Bukin uint32_t next; 74*5939d8a1SRuslan Bukin uint32_t reserved1; 75*5939d8a1SRuslan Bukin uint32_t phys; 76*5939d8a1SRuslan Bukin uint32_t reserved2; 77*5939d8a1SRuslan Bukin uint32_t reserved3; 78*5939d8a1SRuslan Bukin uint32_t reserved4; 79*5939d8a1SRuslan Bukin uint32_t control; 80*5939d8a1SRuslan Bukin #define BD_CONTROL_TXSOF (1 << 27) /* Start of Frame. */ 81*5939d8a1SRuslan Bukin #define BD_CONTROL_TXEOF (1 << 26) /* End of Frame. */ 82*5939d8a1SRuslan Bukin #define BD_CONTROL_LEN_S 0 /* Buffer Length. */ 83*5939d8a1SRuslan Bukin #define BD_CONTROL_LEN_M (0x3ffffff << BD_CONTROL_LEN_S) 84*5939d8a1SRuslan Bukin uint32_t status; 85*5939d8a1SRuslan Bukin #define BD_STATUS_CMPLT (1 << 31) 86*5939d8a1SRuslan Bukin #define BD_STATUS_TRANSFERRED_S 0 87*5939d8a1SRuslan Bukin #define BD_STATUS_TRANSFERRED_M (0x7fffff << BD_STATUS_TRANSFERRED_S) 88*5939d8a1SRuslan Bukin uint32_t app0; 89*5939d8a1SRuslan Bukin uint32_t app1; 90*5939d8a1SRuslan Bukin uint32_t app2; 91*5939d8a1SRuslan Bukin uint32_t app3; 92*5939d8a1SRuslan Bukin uint32_t app4; 93*5939d8a1SRuslan Bukin uint32_t reserved[3]; 94*5939d8a1SRuslan Bukin }; 95*5939d8a1SRuslan Bukin 96*5939d8a1SRuslan Bukin #endif /* !_DEV_XILINX_AXIDMA_H_ */ 97