kernel_samsung_a34x-permissive/drivers/misc/mediatek/usb20/musb_io.h
2024-04-28 15:51:13 +02:00

174 lines
4.1 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2017 MediaTek Inc.
*/
#ifndef __MUSB_LINUX_PLATFORM_ARCH_H__
#define __MUSB_LINUX_PLATFORM_ARCH_H__
#include <linux/io.h>
#include <linux/spinlock.h>
#include <usb20.h>
#include <musb_debug.h>
extern bool mtk_usb_power;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
extern void mt_usb_clock_prepare(void);
extern void mt_usb_clock_unprepare(void);
#endif
extern spinlock_t usb_io_lock;
static inline u16 musb_readw(const void __iomem *addr, unsigned int offset)
{
u16 rc = 0;
if (likely(mtk_usb_power)) {
rc = readw(addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
rc = readw(addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
return rc;
}
static inline u32
musb_readl(const void __iomem *addr, unsigned int offset)
{
u32 rc = 0;
if (likely(mtk_usb_power)) {
rc = readl(addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
rc = readl(addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
return rc;
}
static inline void
musb_writew(void __iomem *addr, unsigned int offset, u16 data)
{
if (likely(mtk_usb_power)) {
writew(data, addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
writew(data, addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
}
static inline void
musb_writel(void __iomem *addr, unsigned int offset, u32 data)
{
if (likely(mtk_usb_power)) {
writel(data, addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
writel(data, addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
}
static inline u8 musb_readb(const void __iomem *addr, unsigned int offset)
{
u8 rc = 0;
if (likely(mtk_usb_power)) {
rc = readb(addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
rc = readb(addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
return rc;
}
static inline void musb_writeb
(void __iomem *addr, unsigned int offset, u8 data)
{
if (likely(mtk_usb_power)) {
writeb(data, addr + offset);
} else {
unsigned long flags = 0;
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_prepare();
#endif
spin_lock_irqsave(&usb_io_lock, flags);
usb_enable_clock(true);
DBG(1, "[MUSB]:access %s function when usb clock is off 0x%X\n",
__func__, offset);
writeb(data, addr + offset);
usb_enable_clock(false);
spin_unlock_irqrestore(&usb_io_lock, flags);
#ifdef CONFIG_MTK_MUSB_PORT0_LOWPOWER_MODE
mt_usb_clock_unprepare();
#endif
}
}
#endif