Commit cdac0cd4 authored by Thomas Zimmermann's avatar Thomas Zimmermann

drm/ast: Add I/O helpers without ast device

Implement I/O access in helpers that do not use an ast device
instance, but the raw pointer to the I/O memory. We'll later need
these helpers to detect the device type before allocating the ast
device instance.

v3:
	* fix typo in commit message (Sui)
Signed-off-by: default avatarThomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: default avatarJocelyn Falempe <jfalempe@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20231116100240.22975-5-tzimmermann@suse.de
parent b45efcfc
...@@ -273,55 +273,94 @@ static inline bool __ast_gen_is_eq(struct ast_device *ast, unsigned long gen) ...@@ -273,55 +273,94 @@ static inline bool __ast_gen_is_eq(struct ast_device *ast, unsigned long gen)
#define IS_AST_GEN6(__ast) __ast_gen_is_eq(__ast, 6) #define IS_AST_GEN6(__ast) __ast_gen_is_eq(__ast, 6)
#define IS_AST_GEN7(__ast) __ast_gen_is_eq(__ast, 7) #define IS_AST_GEN7(__ast) __ast_gen_is_eq(__ast, 7)
static inline u8 __ast_read8(const void __iomem *addr, u32 reg)
{
return ioread8(addr + reg);
}
static inline u32 __ast_read32(const void __iomem *addr, u32 reg)
{
return ioread32(addr + reg);
}
static inline void __ast_write8(void __iomem *addr, u32 reg, u8 val)
{
iowrite8(val, addr + reg);
}
static inline void __ast_write32(void __iomem *addr, u32 reg, u32 val)
{
iowrite32(val, addr + reg);
}
static inline u8 __ast_read8_i(void __iomem *addr, u32 reg, u8 index)
{
__ast_write8(addr, reg, index);
return __ast_read8(addr, reg + 1);
}
static inline u8 __ast_read8_i_masked(void __iomem *addr, u32 reg, u8 index, u8 read_mask)
{
u8 val = __ast_read8_i(addr, reg, index);
return val & read_mask;
}
static inline void __ast_write8_i(void __iomem *addr, u32 reg, u8 index, u8 val)
{
__ast_write8(addr, reg, index);
__ast_write8(addr, reg + 1, val);
}
static inline void __ast_write8_i_masked(void __iomem *addr, u32 reg, u8 index, u8 read_mask,
u8 val)
{
u8 tmp = __ast_read8_i_masked(addr, reg, index, read_mask);
tmp |= val;
__ast_write8_i(addr, reg, index, tmp);
}
static inline u32 ast_read32(struct ast_device *ast, u32 reg) static inline u32 ast_read32(struct ast_device *ast, u32 reg)
{ {
return ioread32(ast->regs + reg); return __ast_read32(ast->regs, reg);
} }
static inline void ast_write32(struct ast_device *ast, u32 reg, u32 val) static inline void ast_write32(struct ast_device *ast, u32 reg, u32 val)
{ {
iowrite32(val, ast->regs + reg); __ast_write32(ast->regs, reg, val);
} }
static inline u8 ast_io_read8(struct ast_device *ast, u32 reg) static inline u8 ast_io_read8(struct ast_device *ast, u32 reg)
{ {
return ioread8(ast->ioregs + reg); return __ast_read8(ast->ioregs, reg);
} }
static inline void ast_io_write8(struct ast_device *ast, u32 reg, u8 val) static inline void ast_io_write8(struct ast_device *ast, u32 reg, u8 val)
{ {
iowrite8(val, ast->ioregs + reg); __ast_write8(ast->ioregs, reg, val);
} }
static inline u8 ast_get_index_reg(struct ast_device *ast, u32 base, u8 index) static inline u8 ast_get_index_reg(struct ast_device *ast, u32 base, u8 index)
{ {
ast_io_write8(ast, base, index); return __ast_read8_i(ast->ioregs, base, index);
++base;
return ast_io_read8(ast, base);
} }
static inline u8 ast_get_index_reg_mask(struct ast_device *ast, u32 base, u8 index, static inline u8 ast_get_index_reg_mask(struct ast_device *ast, u32 base, u8 index,
u8 preserve_mask) u8 preserve_mask)
{ {
u8 val = ast_get_index_reg(ast, base, index); return __ast_read8_i_masked(ast->ioregs, base, index, preserve_mask);
return val & preserve_mask;
} }
static inline void ast_set_index_reg(struct ast_device *ast, u32 base, u8 index, u8 val) static inline void ast_set_index_reg(struct ast_device *ast, u32 base, u8 index, u8 val)
{ {
ast_io_write8(ast, base, index); __ast_write8_i(ast->ioregs, base, index, val);
++base;
ast_io_write8(ast, base, val);
} }
static inline void ast_set_index_reg_mask(struct ast_device *ast, u32 base, u8 index, static inline void ast_set_index_reg_mask(struct ast_device *ast, u32 base, u8 index,
u8 preserve_mask, u8 val) u8 preserve_mask, u8 val)
{ {
u8 tmp = ast_get_index_reg_mask(ast, base, index, preserve_mask); __ast_write8_i_masked(ast->ioregs, base, index, preserve_mask, val);
tmp |= val;
ast_set_index_reg(ast, base, index, tmp);
} }
#define AST_VIDMEM_SIZE_8M 0x00800000 #define AST_VIDMEM_SIZE_8M 0x00800000
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment