// SPDX-License-Identifier: GPL-2.0 /* * Copyright (c) 2020 MediaTek Inc. */ #ifndef _MC3XXX_H_ #define _MC3XXX_H_ #include #define GSE_TAG "[Gsensor] " #define GSE_FUN(f) pr_debug(GSE_TAG "%s\n", __func__) #define GSE_LOG(fmt, args...) pr_debug(GSE_TAG fmt, ##args) /*********************************************** *** REGISTER MAP ***********************************************/ #define MC3XXX_REG_XOUT 0x00 #define MC3XXX_REG_YOUT 0x01 #define MC3XXX_REG_ZOUT 0x02 #define MC3XXX_REG_TILT_STATUS 0x03 #define MC3XXX_REG_SAMPLE_RATE_STATUS 0x04 #define MC3XXX_REG_SLEEP_COUNT 0x05 #define MC3XXX_REG_INTERRUPT_ENABLE 0x06 #define MC3XXX_REG_MODE_FEATURE 0x07 #define MC3XXX_REG_SAMPLE_RATE 0x08 #define MC3XXX_REG_TAP_DETECTION_ENABLE 0x09 #define MC3XXX_REG_TAP_DWELL_REJECT 0x0A #define MC3XXX_REG_DROP_CONTROL 0x0B #define MC3XXX_REG_SHAKE_DEBOUNCE 0x0C #define MC3XXX_REG_XOUT_EX_L 0x0D #define MC3XXX_REG_XOUT_EX_H 0x0E #define MC3XXX_REG_YOUT_EX_L 0x0F #define MC3XXX_REG_YOUT_EX_H 0x10 #define MC3XXX_REG_ZOUT_EX_L 0x11 #define MC3XXX_REG_ZOUT_EX_H 0x12 #define MC3XXX_REG_RANGE_CONTROL 0x20 #define MC3XXX_REG_SHAKE_THRESHOLD 0x2B #define MC3XXX_REG_UD_Z_TH 0x2C #define MC3XXX_REG_UD_X_TH 0x2D #define MC3XXX_REG_RL_Z_TH 0x2E #define MC3XXX_REG_RL_Y_TH 0x2F #define MC3XXX_REG_FB_Z_TH 0x30 #define MC3XXX_REG_DROP_THRESHOLD 0x31 #define MC3XXX_REG_TAP_THRESHOLD 0x32 #define MC3XXX_REG_PRODUCT_CODE 0x3B /*********************************************** *** RETURN CODE ***********************************************/ #define MC3XXX_RETCODE_SUCCESS (0) #define MC3XXX_RETCODE_ERROR_I2C (-1) #define MC3XXX_RETCODE_ERROR_NULL_POINTER (-2) #define MC3XXX_RETCODE_ERROR_STATUS (-3) #define MC3XXX_RETCODE_ERROR_SETUP (-4) #define MC3XXX_RETCODE_ERROR_GET_DATA (-5) #define MC3XXX_RETCODE_ERROR_IDENTIFICATION (-6) /*********************************************** *** CONFIGURATION ***********************************************/ #define MC3XXX_BUF_SIZE 256 /*********************************************** *** PRODUCT ID ***********************************************/ #define MC3XXX_PCODE_3210 0x90 #define MC3XXX_PCODE_3230 0x19 #define MC3XXX_PCODE_3250 0x88 #define MC3XXX_PCODE_3410 0xA8 #define MC3XXX_PCODE_3410N 0xB8 #define MC3XXX_PCODE_3430 0x29 #define MC3XXX_PCODE_3430N 0x39 #define MC3XXX_PCODE_3510 0x40 #define MC3XXX_PCODE_3530 0x30 #define MC3XXX_PCODE_3216 0x10 #define MC3XXX_PCODE_3236 0x60 #define MC3XXX_PCODE_RESERVE_1 0x20 #define MC3XXX_PCODE_RESERVE_2 0x11 #define MC3XXX_PCODE_RESERVE_3 0x21 #define MC3XXX_PCODE_RESERVE_4 0x61 #define MC3XXX_PCODE_RESERVE_5 0xA0 #define MC3XXX_PCODE_RESERVE_6 0xE0 #define MC3XXX_PCODE_RESERVE_7 0x91 #define MC3XXX_PCODE_RESERVE_8 0xA1 #define MC3XXX_PCODE_RESERVE_9 0xE1 #define MC3XXX_PCODE_RESERVE_10 0x99 #define MC3410_ACCEL_ODR_400HZ 0x0A #define MC3410_ACCEL_ODR_200HZ 0x0B #define MC3410_ACCEL_ODR_100HZ 0x0C #ifdef CONFIG_CUSTOM_KERNEL_ACCELEROMETER_MODULE extern bool success_Flag; #endif #endif /* END OF _MC3XXX_H_ */