#include <linux/interrupt.h>
#include <linux/mailbox_controller.h>
#include <linux/of_device.h>
#include <linux/platform_device.h>
#include <dt-bindings/mailbox/tegra186-hsp.h>
#define HSP_INT_IE(x) (0x100 + ((x) * 4))
#define HSP_INT_EMPTY_SHIFT 0
#define HSP_INT_EMPTY_MASK 0xff
#define HSP_INT_FULL_SHIFT 8
#define HSP_INT_FULL_MASK 0xff
#define HSP_INT_DIMENSIONING 0x380
#define HSP_nINT_MASK 0xf
#define HSP_DB_TRIGGER 0x0
#define HSP_DB_ENABLE 0x4
#define HSP_DB_PENDING 0xc
#define HSP_SM_SHRD_MBOX 0x0
#define HSP_SM_SHRD_MBOX_FULL BIT(31)
#define HSP_SM_SHRD_MBOX_FULL_INT_IE 0x04
#define HSP_SM_SHRD_MBOX_EMPTY_INT_IE 0x08
struct tegra_hsp_channel;
struct tegra_hsp_channel {
struct tegra_hsp_doorbell {
struct tegra_hsp_channel channel;
struct tegra_hsp_mailbox {
struct tegra_hsp_channel channel;
struct tegra_hsp_db_map {
const struct tegra_hsp_db_map *map;