2017-11-03 11:28:30 +01:00
// SPDX-License-Identifier: GPL-2.0
2015-01-21 00:55:57 +02:00
/*
* Driver for the NXP ISP1760 chip
*
* Copyright 2014 Laurent Pinchart
* Copyright 2007 Sebastian Siewior
*
* Contacts :
* Sebastian Siewior < bigeasy @ linutronix . de >
* Laurent Pinchart < laurent . pinchart @ ideasonboard . com >
*/
# ifndef _ISP1760_CORE_H_
# define _ISP1760_CORE_H_
# include <linux/ioport.h>
# include "isp1760-hcd.h"
2015-01-21 00:56:01 +02:00
# include "isp1760-udc.h"
2015-01-21 00:55:57 +02:00
2015-01-21 00:55:59 +02:00
struct device ;
struct gpio_desc ;
/*
* Device flags that can vary from board to board . All of these
* indicate the most " atypical " case , so that a devflags of 0 is
* a sane default configuration .
*/
# define ISP1760_FLAG_BUS_WIDTH_16 0x00000002 /* 16-bit data bus width */
# define ISP1760_FLAG_OTG_EN 0x00000004 /* Port 1 supports OTG */
# define ISP1760_FLAG_ANALOG_OC 0x00000008 /* Analog overcurrent */
# define ISP1760_FLAG_DACK_POL_HIGH 0x00000010 /* DACK active high */
# define ISP1760_FLAG_DREQ_POL_HIGH 0x00000020 /* DREQ active high */
# define ISP1760_FLAG_ISP1761 0x00000040 /* Chip is ISP1761 */
# define ISP1760_FLAG_INTR_POL_HIGH 0x00000080 /* Interrupt polarity active high */
# define ISP1760_FLAG_INTR_EDGE_TRIG 0x00000100 /* Interrupt edge triggered */
2015-01-21 00:55:57 +02:00
struct isp1760_device {
2015-01-21 00:55:59 +02:00
struct device * dev ;
2015-01-21 00:55:57 +02:00
void __iomem * regs ;
2015-01-21 00:55:59 +02:00
unsigned int devflags ;
struct gpio_desc * rst_gpio ;
2015-01-21 00:55:57 +02:00
struct isp1760_hcd hcd ;
2015-01-21 00:56:01 +02:00
struct isp1760_udc udc ;
2015-01-21 00:55:57 +02:00
} ;
int isp1760_register ( struct resource * mem , int irq , unsigned long irqflags ,
struct device * dev , unsigned int devflags ) ;
void isp1760_unregister ( struct device * dev ) ;
2015-01-21 00:56:01 +02:00
void isp1760_set_pullup ( struct isp1760_device * isp , bool enable ) ;
2015-01-21 00:55:59 +02:00
static inline u32 isp1760_read32 ( void __iomem * base , u32 reg )
{
return readl ( base + reg ) ;
}
static inline void isp1760_write32 ( void __iomem * base , u32 reg , u32 val )
{
writel ( val , base + reg ) ;
}
2015-01-21 00:55:57 +02:00
# endif