2014-01-06 12:58:19 -08:00
/**
* Marvell NFC driver
*
* Copyright ( C ) 2014 , Marvell International Ltd .
*
* This software file ( the " File " ) is distributed by Marvell International
* Ltd . under the terms of the GNU General Public License Version 2 , June 1991
* ( the " License " ) . You may use , redistribute and / or modify this File in
* accordance with the terms and conditions of the License , a copy of which
* is available on the worldwide web at
* http : //www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
*
* THE FILE IS DISTRIBUTED AS - IS , WITHOUT WARRANTY OF ANY KIND , AND THE
* IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE
* ARE EXPRESSLY DISCLAIMED . The License provides additional details about
* this warranty disclaimer .
* */
2015-06-11 14:00:19 +02:00
# ifndef _NFCMRVL_H_
# define _NFCMRVL_H_
# include <linux/platform_data/nfcmrvl.h>
2014-01-06 12:58:19 -08:00
/* Define private flags: */
# define NFCMRVL_NCI_RUNNING 1
2014-01-06 12:58:20 -08:00
# define NFCMRVL_EXT_COEX_ID 0xE0
# define NFCMRVL_NOT_ALLOWED_ID 0xE1
# define NFCMRVL_ACTIVE_ID 0xE2
# define NFCMRVL_EXT_COEX_ENABLE 1
# define NFCMRVL_GPIO_PIN_NFC_NOT_ALLOWED 0xA
# define NFCMRVL_GPIO_PIN_NFC_ACTIVE 0xB
2014-01-06 12:58:19 -08:00
# define NFCMRVL_NCI_MAX_EVENT_SIZE 260
2015-06-12 15:35:54 +02:00
/*
* * NCI FW Parmaters
*/
# define NFCMRVL_PB_BAIL_OUT 0x11
2015-06-11 11:25:43 +02:00
/*
* * HCI defines
*/
# define NFCMRVL_HCI_EVENT_HEADER_SIZE 0x04
# define NFCMRVL_HCI_EVENT_CODE 0x04
# define NFCMRVL_HCI_NFC_EVENT_CODE 0xFF
# define NFCMRVL_HCI_COMMAND_CODE 0x01
# define NFCMRVL_HCI_OGF 0x81
# define NFCMRVL_HCI_OCF 0xFE
2015-06-11 14:00:20 +02:00
enum nfcmrvl_phy {
NFCMRVL_PHY_USB = 0 ,
NFCMRVL_PHY_UART = 1 ,
} ;
2015-06-11 11:25:43 +02:00
2014-01-06 12:58:19 -08:00
struct nfcmrvl_private {
2015-06-11 11:25:43 +02:00
2015-06-11 14:00:19 +02:00
unsigned long flags ;
/* Platform configuration */
struct nfcmrvl_platform_data config ;
2014-01-06 12:58:19 -08:00
struct nci_dev * ndev ;
2015-06-11 11:25:46 +02:00
2015-06-11 14:00:19 +02:00
/*
* * PHY related information
*/
2015-06-11 11:25:46 +02:00
2015-06-11 14:00:19 +02:00
/* PHY driver context */
2014-01-06 12:58:19 -08:00
void * drv_data ;
2015-06-11 14:00:19 +02:00
/* PHY device */
2014-01-06 12:58:19 -08:00
struct device * dev ;
2015-06-11 14:00:20 +02:00
/* PHY type */
enum nfcmrvl_phy phy ;
2015-06-11 14:00:19 +02:00
/* Low level driver ops */
2014-01-06 12:58:19 -08:00
struct nfcmrvl_if_ops * if_ops ;
} ;
struct nfcmrvl_if_ops {
int ( * nci_open ) ( struct nfcmrvl_private * priv ) ;
int ( * nci_close ) ( struct nfcmrvl_private * priv ) ;
int ( * nci_send ) ( struct nfcmrvl_private * priv , struct sk_buff * skb ) ;
} ;
void nfcmrvl_nci_unregister_dev ( struct nfcmrvl_private * priv ) ;
2015-06-11 11:25:44 +02:00
int nfcmrvl_nci_recv_frame ( struct nfcmrvl_private * priv , struct sk_buff * skb ) ;
2014-01-06 12:58:19 -08:00
struct nfcmrvl_private * nfcmrvl_nci_register_dev ( void * drv_data ,
2015-06-11 14:00:19 +02:00
struct nfcmrvl_if_ops * ops ,
struct device * dev ,
struct nfcmrvl_platform_data * pdata ) ;
2015-06-11 11:25:46 +02:00
void nfcmrvl_chip_reset ( struct nfcmrvl_private * priv ) ;
2015-06-11 14:00:19 +02:00
int nfcmrvl_parse_dt ( struct device_node * node ,
struct nfcmrvl_platform_data * pdata ) ;
# endif