Merge tag 'regmap-fix-v5.11-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git...
[linux/fpc-iii.git] / drivers / thunderbolt / dma_port.h
blob7deadd97ce311a6fa92c6a87e3521c6a4095a0b3
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3 * Thunderbolt DMA configuration based mailbox support
5 * Copyright (C) 2017, Intel Corporation
6 * Authors: Michael Jamet <michael.jamet@intel.com>
7 * Mika Westerberg <mika.westerberg@linux.intel.com>
8 */
10 #ifndef DMA_PORT_H_
11 #define DMA_PORT_H_
13 #include "tb.h"
15 struct tb_switch;
16 struct tb_dma_port;
18 #define DMA_PORT_CSS_ADDRESS 0x3fffff
19 #define DMA_PORT_CSS_MAX_SIZE SZ_128
21 struct tb_dma_port *dma_port_alloc(struct tb_switch *sw);
22 void dma_port_free(struct tb_dma_port *dma);
23 int dma_port_flash_read(struct tb_dma_port *dma, unsigned int address,
24 void *buf, size_t size);
25 int dma_port_flash_update_auth(struct tb_dma_port *dma);
26 int dma_port_flash_update_auth_status(struct tb_dma_port *dma, u32 *status);
27 int dma_port_flash_write(struct tb_dma_port *dma, unsigned int address,
28 const void *buf, size_t size);
29 int dma_port_power_cycle(struct tb_dma_port *dma);
31 #endif