36 lines
803 B
C
36 lines
803 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (C) 2021-2022 Digiteq Automotive
|
|
* author: Martin Tuma <martin.tuma@digiteqautomotive.com>
|
|
*/
|
|
|
|
#ifndef __MGB4_REGS_H__
|
|
#define __MGB4_REGS_H__
|
|
|
|
#include <linux/io.h>
|
|
|
|
struct mgb4_regs {
|
|
resource_size_t mapbase;
|
|
resource_size_t mapsize;
|
|
void __iomem *membase;
|
|
};
|
|
|
|
#define mgb4_write_reg(regs, offset, val) \
|
|
iowrite32(val, (regs)->membase + (offset))
|
|
#define mgb4_read_reg(regs, offset) \
|
|
ioread32((regs)->membase + (offset))
|
|
|
|
static inline void mgb4_mask_reg(struct mgb4_regs *regs, u32 reg, u32 mask,
|
|
u32 val)
|
|
{
|
|
u32 ret = mgb4_read_reg(regs, reg);
|
|
|
|
val |= ret & ~mask;
|
|
mgb4_write_reg(regs, reg, val);
|
|
}
|
|
|
|
int mgb4_regs_map(struct resource *res, struct mgb4_regs *regs);
|
|
void mgb4_regs_free(struct mgb4_regs *regs);
|
|
|
|
#endif
|