2017-11-01 15:07:57 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2014-04-28 20:47:36 +01:00
|
|
|
#ifndef __LINUX_GOLDFISH_H
|
|
|
|
|
#define __LINUX_GOLDFISH_H
|
|
|
|
|
|
2018-07-23 15:47:27 -07:00
|
|
|
#include <linux/kernel.h>
|
2018-07-23 15:47:26 -07:00
|
|
|
#include <linux/types.h>
|
|
|
|
|
#include <linux/io.h>
|
|
|
|
|
|
2014-04-28 20:47:36 +01:00
|
|
|
/* Helpers for Goldfish virtual platform */
|
|
|
|
|
|
2022-04-06 22:15:20 +02:00
|
|
|
#ifndef gf_ioread32
|
|
|
|
|
#define gf_ioread32 ioread32
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef gf_iowrite32
|
|
|
|
|
#define gf_iowrite32 iowrite32
|
|
|
|
|
#endif
|
|
|
|
|
|
2015-05-19 11:44:46 +02:00
|
|
|
static inline void gf_write_ptr(const void *ptr, void __iomem *portl,
|
|
|
|
|
void __iomem *porth)
|
2014-04-28 20:47:36 +01:00
|
|
|
{
|
2018-07-23 15:47:27 -07:00
|
|
|
const unsigned long addr = (unsigned long)ptr;
|
|
|
|
|
|
2022-04-06 22:15:20 +02:00
|
|
|
gf_iowrite32(lower_32_bits(addr), portl);
|
2014-05-19 14:34:09 +01:00
|
|
|
#ifdef CONFIG_64BIT
|
2022-04-06 22:15:20 +02:00
|
|
|
gf_iowrite32(upper_32_bits(addr), porth);
|
2014-04-28 20:47:36 +01:00
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2015-05-19 11:44:46 +02:00
|
|
|
static inline void gf_write_dma_addr(const dma_addr_t addr,
|
|
|
|
|
void __iomem *portl,
|
|
|
|
|
void __iomem *porth)
|
|
|
|
|
{
|
2022-04-06 22:15:20 +02:00
|
|
|
gf_iowrite32(lower_32_bits(addr), portl);
|
2015-05-19 11:44:46 +02:00
|
|
|
#ifdef CONFIG_ARCH_DMA_ADDR_T_64BIT
|
2022-04-06 22:15:20 +02:00
|
|
|
gf_iowrite32(upper_32_bits(addr), porth);
|
2015-05-19 11:44:46 +02:00
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2014-04-28 20:47:36 +01:00
|
|
|
#endif /* __LINUX_GOLDFISH_H */
|