mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
d69d804845
In the match() callback, the struct device_driver * should not be changed, so change the function callback to be a const *. This is one step of many towards making the driver core safe to have struct device_driver in read-only memory. Because the match() callback is in all busses, all busses are modified to handle this properly. This does entail switching some container_of() calls to container_of_const() to properly handle the constant *. For some busses, like PCI and USB and HV, the const * is cast away in the match callback as those busses do want to modify those structures at this point in time (they have a local lock in the driver structure.) That will have to be changed in the future if they wish to have their struct device * in read-only-memory. Cc: Rafael J. Wysocki <rafael@kernel.org> Reviewed-by: Alex Elder <elder@kernel.org> Acked-by: Sumit Garg <sumit.garg@linaro.org> Link: https://lore.kernel.org/r/2024070136-wrongdoer-busily-01e8@gregkh Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
142 lines
4.2 KiB
C
142 lines
4.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (c) 2011-2016 Synaptics Incorporated
|
|
* Copyright (c) 2011 Unixphere
|
|
*/
|
|
|
|
#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(const struct device_driver *);
|
|
int rmi_register_physical_driver(void);
|
|
void rmi_unregister_physical_driver(void);
|
|
void rmi_free_function_list(struct rmi_device *rmi_dev);
|
|
struct rmi_function *rmi_find_function(struct rmi_device *rmi_dev, u8 number);
|
|
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);
|
|
void rmi_enable_irq(struct rmi_device *rmi_dev, bool clear_wake);
|
|
void rmi_disable_irq(struct rmi_device *rmi_dev, bool enable_wake);
|
|
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);
|
|
|
|
const char *rmi_f01_get_product_ID(struct rmi_function *fn);
|
|
|
|
#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
|
|
|
|
#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 */
|
|
|
|
extern struct rmi_function_handler rmi_f01_handler;
|
|
extern struct rmi_function_handler rmi_f03_handler;
|
|
extern struct rmi_function_handler rmi_f11_handler;
|
|
extern struct rmi_function_handler rmi_f12_handler;
|
|
extern struct rmi_function_handler rmi_f30_handler;
|
|
extern struct rmi_function_handler rmi_f34_handler;
|
|
extern struct rmi_function_handler rmi_f3a_handler;
|
|
extern struct rmi_function_handler rmi_f54_handler;
|
|
extern struct rmi_function_handler rmi_f55_handler;
|
|
#endif
|