130 lines
2.6 KiB
C
130 lines
2.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2023 Cai Huoqing
|
|
* Synopsys DesignWare HDMA v0 reg
|
|
*
|
|
* Author: Cai Huoqing <cai.huoqing@linux.dev>
|
|
*/
|
|
|
|
#ifndef _DW_HDMA_V0_REGS_H
|
|
#define _DW_HDMA_V0_REGS_H
|
|
|
|
#include <linux/dmaengine.h>
|
|
|
|
#define HDMA_V0_MAX_NR_CH 8
|
|
#define HDMA_V0_LOCAL_ABORT_INT_EN BIT(6)
|
|
#define HDMA_V0_REMOTE_ABORT_INT_EN BIT(5)
|
|
#define HDMA_V0_LOCAL_STOP_INT_EN BIT(4)
|
|
#define HDMA_V0_REMOTEL_STOP_INT_EN BIT(3)
|
|
#define HDMA_V0_ABORT_INT_MASK BIT(2)
|
|
#define HDMA_V0_STOP_INT_MASK BIT(0)
|
|
#define HDMA_V0_LINKLIST_EN BIT(0)
|
|
#define HDMA_V0_CONSUMER_CYCLE_STAT BIT(1)
|
|
#define HDMA_V0_CONSUMER_CYCLE_BIT BIT(0)
|
|
#define HDMA_V0_DOORBELL_START BIT(0)
|
|
#define HDMA_V0_CH_STATUS_MASK GENMASK(1, 0)
|
|
|
|
struct dw_hdma_v0_ch_regs {
|
|
u32 ch_en; /* 0x0000 */
|
|
u32 doorbell; /* 0x0004 */
|
|
u32 prefetch; /* 0x0008 */
|
|
u32 handshake; /* 0x000c */
|
|
union {
|
|
u64 reg; /* 0x0010..0x0014 */
|
|
struct {
|
|
u32 lsb; /* 0x0010 */
|
|
u32 msb; /* 0x0014 */
|
|
};
|
|
} llp;
|
|
u32 cycle_sync; /* 0x0018 */
|
|
u32 transfer_size; /* 0x001c */
|
|
union {
|
|
u64 reg; /* 0x0020..0x0024 */
|
|
struct {
|
|
u32 lsb; /* 0x0020 */
|
|
u32 msb; /* 0x0024 */
|
|
};
|
|
} sar;
|
|
union {
|
|
u64 reg; /* 0x0028..0x002c */
|
|
struct {
|
|
u32 lsb; /* 0x0028 */
|
|
u32 msb; /* 0x002c */
|
|
};
|
|
} dar;
|
|
u32 watermark_en; /* 0x0030 */
|
|
u32 control1; /* 0x0034 */
|
|
u32 func_num; /* 0x0038 */
|
|
u32 qos; /* 0x003c */
|
|
u32 padding_1[16]; /* 0x0040..0x007c */
|
|
u32 ch_stat; /* 0x0080 */
|
|
u32 int_stat; /* 0x0084 */
|
|
u32 int_setup; /* 0x0088 */
|
|
u32 int_clear; /* 0x008c */
|
|
union {
|
|
u64 reg; /* 0x0090..0x0094 */
|
|
struct {
|
|
u32 lsb; /* 0x0090 */
|
|
u32 msb; /* 0x0094 */
|
|
};
|
|
} msi_stop;
|
|
union {
|
|
u64 reg; /* 0x0098..0x009c */
|
|
struct {
|
|
u32 lsb; /* 0x0098 */
|
|
u32 msb; /* 0x009c */
|
|
};
|
|
} msi_watermark;
|
|
union {
|
|
u64 reg; /* 0x00a0..0x00a4 */
|
|
struct {
|
|
u32 lsb; /* 0x00a0 */
|
|
u32 msb; /* 0x00a4 */
|
|
};
|
|
} msi_abort;
|
|
u32 msi_msgdata; /* 0x00a8 */
|
|
u32 padding_2[21]; /* 0x00ac..0x00fc */
|
|
} __packed;
|
|
|
|
struct dw_hdma_v0_ch {
|
|
struct dw_hdma_v0_ch_regs wr; /* 0x0000 */
|
|
struct dw_hdma_v0_ch_regs rd; /* 0x0100 */
|
|
} __packed;
|
|
|
|
struct dw_hdma_v0_regs {
|
|
struct dw_hdma_v0_ch ch[HDMA_V0_MAX_NR_CH]; /* 0x0000..0x0fa8 */
|
|
} __packed;
|
|
|
|
struct dw_hdma_v0_lli {
|
|
u32 control;
|
|
u32 transfer_size;
|
|
union {
|
|
u64 reg;
|
|
struct {
|
|
u32 lsb;
|
|
u32 msb;
|
|
};
|
|
} sar;
|
|
union {
|
|
u64 reg;
|
|
struct {
|
|
u32 lsb;
|
|
u32 msb;
|
|
};
|
|
} dar;
|
|
} __packed;
|
|
|
|
struct dw_hdma_v0_llp {
|
|
u32 control;
|
|
u32 reserved;
|
|
union {
|
|
u64 reg;
|
|
struct {
|
|
u32 lsb;
|
|
u32 msb;
|
|
};
|
|
} llp;
|
|
} __packed;
|
|
|
|
#endif /* _DW_HDMA_V0_REGS_H */
|