/* SPDX-License-Identifier: GPL-2.0-only */

#ifndef __DRIVERS_I2C_SX9324_CHIP_H__
#define __DRIVERS_I2C_SX9324_CHIP_H__

#include <acpi/acpi_device.h>
#include <device/i2c_simple.h>

#define REGISTER(NAME) uint8_t NAME

struct drivers_i2c_sx9324_config {
	/* Device Description */
	const char *desc;

	/* ACPI _UID */
	unsigned int uid;

	/* Bus speed in Hz, default is I2C_SPEED_FAST */
	enum i2c_speed speed;

	/* Use GPIO-based interrupt instead of IO-APIC */
	struct acpi_gpio irq_gpio;

	/* IO-APIC interrupt */
	struct acpi_irq irq;

	/*
	semtech,ph0-pin:
	  description: |
	    Array of 3 entries. Index represent the id of the CS pin.
	    Value indicates how each CS pin is used during phase 0.
	    Each of the 3 pins have the following value -
	    0 : unused (high impedance)
	    1 : measured input
	    2 : dynamic shield
	    3 : grounded.
	    For instance, CS0 measured, CS1 shield and CS2 ground is [1, 2, 3]
	  items:
	    enum: [ 0, 1, 2, 3 ]
	  minItems: 3
	  maxItems: 3
	*/
	uint64_t ph0_pin[3];

	/*
	semtech,ph1-pin:
	  Same as ph0-pin for phase 1.
	*/
	uint64_t ph1_pin[3];

	/*
	semtech,ph2-pin:
	  Same as ph0-pin for phase 2.
	*/
	uint64_t ph2_pin[3];

	/*
	semtech,ph3-pin:
	  Same as ph0-pin for phase 3.
	*/
	uint64_t ph3_pin[3];

	/*
	semtech,ph01-resolution:
	  enum: [8, 16, 32, 64, 128, 256, 512, 1024]
	  description:
	    Capacitance measurement resolution. For phase 0 and 1.
	    Higher the number, higher the resolution.
	  default: 128
	*/
	uint64_t ph01_resolution;

	/*
	semtech,ph23-resolution:
	  Same as ph01-resolution for phase 2 and 3.
	*/
	uint64_t ph23_resolution;

	/*
	semtech,startup-sensor:
	  enum: [0, 1, 2, 3]
	  default: 0
	  description: |
	    Phase used for start-up proximity detection.
	    It is used when we enable a phase to remove static offset and measure
	    only capacitance changes introduced by the user.
	*/
	uint64_t startup_sensor;

	/*
	semtech,ph01-proxraw-strength:
	  minimum: 0
	  maximum: 7
	  default: 1
	  description:
	    PROXRAW filter strength for phase 0 and 1. A value of 0 represents off,
	    and other values represent 1-1/2^N.
	*/
	uint64_t ph01_proxraw_strength;

	/*
	semtech,ph23-proxraw-strength:
	  Same as proxraw-strength01, for phase 2 and 3.
	*/
	uint64_t ph23_proxraw_strength;

	/*
	semtech,avg-pos-strength:
	  enum: [0, 16, 64, 128, 256, 512, 1024, 4294967295]
	  default: 16
	  description: |
	    Average positive filter strength. A value of 0 represents off and
	    UINT_MAX (4294967295) represents infinite. Other values
	    represent 1-1/N.
	*/
	uint64_t avg_pos_strength;

	/*
	semtech,cs-idle-sleep:
	  description:
	    State of CS pins during sleep mode and idle time.
	  enum:
	    - hi-z
	    - gnd
	    - vdd
	*/
	const char *cs_idle_sleep;

	/*
	semtech,int-comp-resistor:
	  description:
	    Internal resistor setting for compensation.
	  enum:
	    - lowest
	    - low
	    - high
	    - highest
	*/
	const char *int_comp_resistor;

	/*
	semtech,input-precharge-resistor-ohms:
	  default: 4000
	  multipleOf: 2000
	  minimum: 0
	  maximum: 30000
	  description:
	    Pre-charge input resistance in Ohm.
	*/
	uint64_t input_precharge_resistor_ohms;

	/*
	semtech,input-analog-gain:
	  minimum: 0
	  maximum: 3
	  description: |
	    Defines the input antenna analog gain
	    0: x1.247
	    1: x1 (default)
	    2: x0.768
	    3: x0.552
	*/
	uint64_t input_analog_gain;

#if CONFIG(DRIVERS_I2C_SX9324_SUPPORT_LEGACY_LINUX_DRIVER)
#include "registers.h"
#endif
};

#undef REGISTER

#endif /* __DRIVERS_I2C_SX9324_CHIP_H__ */