2016-03-10 15:35:49 -08:00
/*
* Copyright ( c ) 2011 - 2016 Synaptics Incorporated
* Copyright ( c ) 2011 Unixphere
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License version 2 as published by
* the Free Software Foundation .
*/
# ifndef _RMI_DRIVER_H
# define _RMI_DRIVER_H
# include <linux/ctype.h>
# include <linux/hrtimer.h>
# include <linux/ktime.h>
# include <linux/input.h>
# include "rmi_bus.h"
# define SYNAPTICS_INPUT_DEVICE_NAME "Synaptics RMI4 Touch Sensor"
# define SYNAPTICS_VENDOR_ID 0x06cb
# define GROUP(_attrs) { \
. attrs = _attrs , \
}
# define PDT_PROPERTIES_LOCATION 0x00EF
# define BSR_LOCATION 0x00FE
# define RMI_PDT_PROPS_HAS_BSR 0x02
# define NAME_BUFFER_SIZE 256
# define RMI_PDT_ENTRY_SIZE 6
# define RMI_PDT_FUNCTION_VERSION_MASK 0x60
# define RMI_PDT_INT_SOURCE_COUNT_MASK 0x07
# define PDT_START_SCAN_LOCATION 0x00e9
# define PDT_END_SCAN_LOCATION 0x0005
# define RMI4_END_OF_PDT(id) ((id) == 0x00 || (id) == 0xff)
struct pdt_entry {
u16 page_start ;
u8 query_base_addr ;
u8 command_base_addr ;
u8 control_base_addr ;
u8 data_base_addr ;
u8 interrupt_source_count ;
u8 function_version ;
u8 function_number ;
} ;
# define RMI_REG_DESC_PRESENSE_BITS (32 * BITS_PER_BYTE)
# define RMI_REG_DESC_SUBPACKET_BITS (37 * BITS_PER_BYTE)
/* describes a single packet register */
struct rmi_register_desc_item {
u16 reg ;
unsigned long reg_size ;
u8 num_subpackets ;
unsigned long subpacket_map [ BITS_TO_LONGS (
RMI_REG_DESC_SUBPACKET_BITS ) ] ;
} ;
/*
* describes the packet registers for a particular type
* ( ie query , control , data )
*/
struct rmi_register_descriptor {
unsigned long struct_size ;
unsigned long presense_map [ BITS_TO_LONGS ( RMI_REG_DESC_PRESENSE_BITS ) ] ;
u8 num_registers ;
struct rmi_register_desc_item * registers ;
} ;
int rmi_read_register_desc ( struct rmi_device * d , u16 addr ,
struct rmi_register_descriptor * rdesc ) ;
const struct rmi_register_desc_item * rmi_get_register_desc_item (
struct rmi_register_descriptor * rdesc , u16 reg ) ;
/*
* Calculate the total size of all of the registers described in the
* descriptor .
*/
size_t rmi_register_desc_calc_size ( struct rmi_register_descriptor * rdesc ) ;
int rmi_register_desc_calc_reg_offset (
struct rmi_register_descriptor * rdesc , u16 reg ) ;
bool rmi_register_desc_has_subpacket ( const struct rmi_register_desc_item * item ,
u8 subpacket ) ;
bool rmi_is_physical_driver ( struct device_driver * ) ;
int rmi_register_physical_driver ( void ) ;
void rmi_unregister_physical_driver ( void ) ;
2016-11-22 17:44:12 -08:00
void rmi_free_function_list ( struct rmi_device * rmi_dev ) ;
2017-02-06 09:57:01 -08:00
struct rmi_function * rmi_find_function ( struct rmi_device * rmi_dev , u8 number ) ;
2016-11-22 17:44:12 -08:00
int rmi_enable_sensor ( struct rmi_device * rmi_dev ) ;
int rmi_scan_pdt ( struct rmi_device * rmi_dev , void * ctx ,
int ( * callback ) ( struct rmi_device * rmi_dev , void * ctx ,
const struct pdt_entry * entry ) ) ;
int rmi_probe_interrupts ( struct rmi_driver_data * data ) ;
2016-11-29 17:42:13 -08:00
void rmi_enable_irq ( struct rmi_device * rmi_dev , bool clear_wake ) ;
void rmi_disable_irq ( struct rmi_device * rmi_dev , bool enable_wake ) ;
2016-11-22 17:44:12 -08:00
int rmi_init_functions ( struct rmi_driver_data * data ) ;
int rmi_initial_reset ( struct rmi_device * rmi_dev , void * ctx ,
const struct pdt_entry * pdt ) ;
2016-03-10 15:35:49 -08:00
2017-01-31 15:44:49 -08:00
const char * rmi_f01_get_product_ID ( struct rmi_function * fn ) ;
2016-03-10 15:35:49 -08:00
2017-02-08 00:26:45 -08:00
# ifdef CONFIG_RMI4_F03
int rmi_f03_overwrite_button ( struct rmi_function * fn , unsigned int button ,
int value ) ;
void rmi_f03_commit_buttons ( struct rmi_function * fn ) ;
# else
static inline int rmi_f03_overwrite_button ( struct rmi_function * fn ,
unsigned int button , int value )
{
return 0 ;
}
static inline void rmi_f03_commit_buttons ( struct rmi_function * fn ) { }
# endif
2016-11-22 17:44:12 -08:00
# ifdef CONFIG_RMI4_F34
int rmi_f34_create_sysfs ( struct rmi_device * rmi_dev ) ;
void rmi_f34_remove_sysfs ( struct rmi_device * rmi_dev ) ;
# else
static inline int rmi_f34_create_sysfs ( struct rmi_device * rmi_dev )
{
return 0 ;
}
static inline void rmi_f34_remove_sysfs ( struct rmi_device * rmi_dev )
{
}
# endif /* CONFIG_RMI_F34 */
2016-03-10 15:35:49 -08:00
extern struct rmi_function_handler rmi_f01_handler ;
2016-12-02 16:59:07 -08:00
extern struct rmi_function_handler rmi_f03_handler ;
2016-03-10 15:47:28 -08:00
extern struct rmi_function_handler rmi_f11_handler ;
2016-03-10 15:55:29 -08:00
extern struct rmi_function_handler rmi_f12_handler ;
2016-03-10 15:56:58 -08:00
extern struct rmi_function_handler rmi_f30_handler ;
2016-11-22 17:44:12 -08:00
extern struct rmi_function_handler rmi_f34_handler ;
2016-07-18 18:10:37 -03:00
extern struct rmi_function_handler rmi_f54_handler ;
2016-11-22 17:53:26 -08:00
extern struct rmi_function_handler rmi_f55_handler ;
2016-03-10 15:35:49 -08:00
# endif