1*a0701b62SRui Miguel Silva /* SPDX-License-Identifier: GPL-2.0 */ 2*a0701b62SRui Miguel Silva /* 3*a0701b62SRui Miguel Silva * Driver for NXP FXAS21002C Gyroscope - Header 4*a0701b62SRui Miguel Silva * 5*a0701b62SRui Miguel Silva * Copyright (C) 2019 Linaro Ltd. 6*a0701b62SRui Miguel Silva */ 7*a0701b62SRui Miguel Silva 8*a0701b62SRui Miguel Silva #ifndef FXAS21002C_H_ 9*a0701b62SRui Miguel Silva #define FXAS21002C_H_ 10*a0701b62SRui Miguel Silva 11*a0701b62SRui Miguel Silva #include <linux/regmap.h> 12*a0701b62SRui Miguel Silva 13*a0701b62SRui Miguel Silva #define FXAS21002C_REG_STATUS 0x00 14*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_X_MSB 0x01 15*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_X_LSB 0x02 16*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_Y_MSB 0x03 17*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_Y_LSB 0x04 18*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_Z_MSB 0x05 19*a0701b62SRui Miguel Silva #define FXAS21002C_REG_OUT_Z_LSB 0x06 20*a0701b62SRui Miguel Silva #define FXAS21002C_REG_DR_STATUS 0x07 21*a0701b62SRui Miguel Silva #define FXAS21002C_REG_F_STATUS 0x08 22*a0701b62SRui Miguel Silva #define FXAS21002C_REG_F_SETUP 0x09 23*a0701b62SRui Miguel Silva #define FXAS21002C_REG_F_EVENT 0x0A 24*a0701b62SRui Miguel Silva #define FXAS21002C_REG_INT_SRC_FLAG 0x0B 25*a0701b62SRui Miguel Silva #define FXAS21002C_REG_WHO_AM_I 0x0C 26*a0701b62SRui Miguel Silva #define FXAS21002C_REG_CTRL0 0x0D 27*a0701b62SRui Miguel Silva #define FXAS21002C_REG_RT_CFG 0x0E 28*a0701b62SRui Miguel Silva #define FXAS21002C_REG_RT_SRC 0x0F 29*a0701b62SRui Miguel Silva #define FXAS21002C_REG_RT_THS 0x10 30*a0701b62SRui Miguel Silva #define FXAS21002C_REG_RT_COUNT 0x11 31*a0701b62SRui Miguel Silva #define FXAS21002C_REG_TEMP 0x12 32*a0701b62SRui Miguel Silva #define FXAS21002C_REG_CTRL1 0x13 33*a0701b62SRui Miguel Silva #define FXAS21002C_REG_CTRL2 0x14 34*a0701b62SRui Miguel Silva #define FXAS21002C_REG_CTRL3 0x15 35*a0701b62SRui Miguel Silva 36*a0701b62SRui Miguel Silva enum fxas21002c_fields { 37*a0701b62SRui Miguel Silva F_DR_STATUS, 38*a0701b62SRui Miguel Silva F_OUT_X_MSB, 39*a0701b62SRui Miguel Silva F_OUT_X_LSB, 40*a0701b62SRui Miguel Silva F_OUT_Y_MSB, 41*a0701b62SRui Miguel Silva F_OUT_Y_LSB, 42*a0701b62SRui Miguel Silva F_OUT_Z_MSB, 43*a0701b62SRui Miguel Silva F_OUT_Z_LSB, 44*a0701b62SRui Miguel Silva /* DR_STATUS */ 45*a0701b62SRui Miguel Silva F_ZYX_OW, F_Z_OW, F_Y_OW, F_X_OW, F_ZYX_DR, F_Z_DR, F_Y_DR, F_X_DR, 46*a0701b62SRui Miguel Silva /* F_STATUS */ 47*a0701b62SRui Miguel Silva F_OVF, F_WMKF, F_CNT, 48*a0701b62SRui Miguel Silva /* F_SETUP */ 49*a0701b62SRui Miguel Silva F_MODE, F_WMRK, 50*a0701b62SRui Miguel Silva /* F_EVENT */ 51*a0701b62SRui Miguel Silva F_EVENT, FE_TIME, 52*a0701b62SRui Miguel Silva /* INT_SOURCE_FLAG */ 53*a0701b62SRui Miguel Silva F_BOOTEND, F_SRC_FIFO, F_SRC_RT, F_SRC_DRDY, 54*a0701b62SRui Miguel Silva /* WHO_AM_I */ 55*a0701b62SRui Miguel Silva F_WHO_AM_I, 56*a0701b62SRui Miguel Silva /* CTRL_REG0 */ 57*a0701b62SRui Miguel Silva F_BW, F_SPIW, F_SEL, F_HPF_EN, F_FS, 58*a0701b62SRui Miguel Silva /* RT_CFG */ 59*a0701b62SRui Miguel Silva F_ELE, F_ZTEFE, F_YTEFE, F_XTEFE, 60*a0701b62SRui Miguel Silva /* RT_SRC */ 61*a0701b62SRui Miguel Silva F_EA, F_ZRT, F_ZRT_POL, F_YRT, F_YRT_POL, F_XRT, F_XRT_POL, 62*a0701b62SRui Miguel Silva /* RT_THS */ 63*a0701b62SRui Miguel Silva F_DBCNTM, F_THS, 64*a0701b62SRui Miguel Silva /* RT_COUNT */ 65*a0701b62SRui Miguel Silva F_RT_COUNT, 66*a0701b62SRui Miguel Silva /* TEMP */ 67*a0701b62SRui Miguel Silva F_TEMP, 68*a0701b62SRui Miguel Silva /* CTRL_REG1 */ 69*a0701b62SRui Miguel Silva F_RST, F_ST, F_DR, F_ACTIVE, F_READY, 70*a0701b62SRui Miguel Silva /* CTRL_REG2 */ 71*a0701b62SRui Miguel Silva F_INT_CFG_FIFO, F_INT_EN_FIFO, F_INT_CFG_RT, F_INT_EN_RT, 72*a0701b62SRui Miguel Silva F_INT_CFG_DRDY, F_INT_EN_DRDY, F_IPOL, F_PP_OD, 73*a0701b62SRui Miguel Silva /* CTRL_REG3 */ 74*a0701b62SRui Miguel Silva F_WRAPTOONE, F_EXTCTRLEN, F_FS_DOUBLE, 75*a0701b62SRui Miguel Silva /* MAX FIELDS */ 76*a0701b62SRui Miguel Silva F_MAX_FIELDS, 77*a0701b62SRui Miguel Silva }; 78*a0701b62SRui Miguel Silva 79*a0701b62SRui Miguel Silva static const struct reg_field fxas21002c_reg_fields[] = { 80*a0701b62SRui Miguel Silva [F_DR_STATUS] = REG_FIELD(FXAS21002C_REG_STATUS, 0, 7), 81*a0701b62SRui Miguel Silva [F_OUT_X_MSB] = REG_FIELD(FXAS21002C_REG_OUT_X_MSB, 0, 7), 82*a0701b62SRui Miguel Silva [F_OUT_X_LSB] = REG_FIELD(FXAS21002C_REG_OUT_X_LSB, 0, 7), 83*a0701b62SRui Miguel Silva [F_OUT_Y_MSB] = REG_FIELD(FXAS21002C_REG_OUT_Y_MSB, 0, 7), 84*a0701b62SRui Miguel Silva [F_OUT_Y_LSB] = REG_FIELD(FXAS21002C_REG_OUT_Y_LSB, 0, 7), 85*a0701b62SRui Miguel Silva [F_OUT_Z_MSB] = REG_FIELD(FXAS21002C_REG_OUT_Z_MSB, 0, 7), 86*a0701b62SRui Miguel Silva [F_OUT_Z_LSB] = REG_FIELD(FXAS21002C_REG_OUT_Z_LSB, 0, 7), 87*a0701b62SRui Miguel Silva [F_ZYX_OW] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 7, 7), 88*a0701b62SRui Miguel Silva [F_Z_OW] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 6, 6), 89*a0701b62SRui Miguel Silva [F_Y_OW] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 5, 5), 90*a0701b62SRui Miguel Silva [F_X_OW] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 4, 4), 91*a0701b62SRui Miguel Silva [F_ZYX_DR] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 3, 3), 92*a0701b62SRui Miguel Silva [F_Z_DR] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 2, 2), 93*a0701b62SRui Miguel Silva [F_Y_DR] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 1, 1), 94*a0701b62SRui Miguel Silva [F_X_DR] = REG_FIELD(FXAS21002C_REG_DR_STATUS, 0, 0), 95*a0701b62SRui Miguel Silva [F_OVF] = REG_FIELD(FXAS21002C_REG_F_STATUS, 7, 7), 96*a0701b62SRui Miguel Silva [F_WMKF] = REG_FIELD(FXAS21002C_REG_F_STATUS, 6, 6), 97*a0701b62SRui Miguel Silva [F_CNT] = REG_FIELD(FXAS21002C_REG_F_STATUS, 0, 5), 98*a0701b62SRui Miguel Silva [F_MODE] = REG_FIELD(FXAS21002C_REG_F_SETUP, 6, 7), 99*a0701b62SRui Miguel Silva [F_WMRK] = REG_FIELD(FXAS21002C_REG_F_SETUP, 0, 5), 100*a0701b62SRui Miguel Silva [F_EVENT] = REG_FIELD(FXAS21002C_REG_F_EVENT, 5, 5), 101*a0701b62SRui Miguel Silva [FE_TIME] = REG_FIELD(FXAS21002C_REG_F_EVENT, 0, 4), 102*a0701b62SRui Miguel Silva [F_BOOTEND] = REG_FIELD(FXAS21002C_REG_INT_SRC_FLAG, 3, 3), 103*a0701b62SRui Miguel Silva [F_SRC_FIFO] = REG_FIELD(FXAS21002C_REG_INT_SRC_FLAG, 2, 2), 104*a0701b62SRui Miguel Silva [F_SRC_RT] = REG_FIELD(FXAS21002C_REG_INT_SRC_FLAG, 1, 1), 105*a0701b62SRui Miguel Silva [F_SRC_DRDY] = REG_FIELD(FXAS21002C_REG_INT_SRC_FLAG, 0, 0), 106*a0701b62SRui Miguel Silva [F_WHO_AM_I] = REG_FIELD(FXAS21002C_REG_WHO_AM_I, 0, 7), 107*a0701b62SRui Miguel Silva [F_BW] = REG_FIELD(FXAS21002C_REG_CTRL0, 6, 7), 108*a0701b62SRui Miguel Silva [F_SPIW] = REG_FIELD(FXAS21002C_REG_CTRL0, 5, 5), 109*a0701b62SRui Miguel Silva [F_SEL] = REG_FIELD(FXAS21002C_REG_CTRL0, 3, 4), 110*a0701b62SRui Miguel Silva [F_HPF_EN] = REG_FIELD(FXAS21002C_REG_CTRL0, 2, 2), 111*a0701b62SRui Miguel Silva [F_FS] = REG_FIELD(FXAS21002C_REG_CTRL0, 0, 1), 112*a0701b62SRui Miguel Silva [F_ELE] = REG_FIELD(FXAS21002C_REG_RT_CFG, 3, 3), 113*a0701b62SRui Miguel Silva [F_ZTEFE] = REG_FIELD(FXAS21002C_REG_RT_CFG, 2, 2), 114*a0701b62SRui Miguel Silva [F_YTEFE] = REG_FIELD(FXAS21002C_REG_RT_CFG, 1, 1), 115*a0701b62SRui Miguel Silva [F_XTEFE] = REG_FIELD(FXAS21002C_REG_RT_CFG, 0, 0), 116*a0701b62SRui Miguel Silva [F_EA] = REG_FIELD(FXAS21002C_REG_RT_SRC, 6, 6), 117*a0701b62SRui Miguel Silva [F_ZRT] = REG_FIELD(FXAS21002C_REG_RT_SRC, 5, 5), 118*a0701b62SRui Miguel Silva [F_ZRT_POL] = REG_FIELD(FXAS21002C_REG_RT_SRC, 4, 4), 119*a0701b62SRui Miguel Silva [F_YRT] = REG_FIELD(FXAS21002C_REG_RT_SRC, 3, 3), 120*a0701b62SRui Miguel Silva [F_YRT_POL] = REG_FIELD(FXAS21002C_REG_RT_SRC, 2, 2), 121*a0701b62SRui Miguel Silva [F_XRT] = REG_FIELD(FXAS21002C_REG_RT_SRC, 1, 1), 122*a0701b62SRui Miguel Silva [F_XRT_POL] = REG_FIELD(FXAS21002C_REG_RT_SRC, 0, 0), 123*a0701b62SRui Miguel Silva [F_DBCNTM] = REG_FIELD(FXAS21002C_REG_RT_THS, 7, 7), 124*a0701b62SRui Miguel Silva [F_THS] = REG_FIELD(FXAS21002C_REG_RT_SRC, 0, 6), 125*a0701b62SRui Miguel Silva [F_RT_COUNT] = REG_FIELD(FXAS21002C_REG_RT_COUNT, 0, 7), 126*a0701b62SRui Miguel Silva [F_TEMP] = REG_FIELD(FXAS21002C_REG_TEMP, 0, 7), 127*a0701b62SRui Miguel Silva [F_RST] = REG_FIELD(FXAS21002C_REG_CTRL1, 6, 6), 128*a0701b62SRui Miguel Silva [F_ST] = REG_FIELD(FXAS21002C_REG_CTRL1, 5, 5), 129*a0701b62SRui Miguel Silva [F_DR] = REG_FIELD(FXAS21002C_REG_CTRL1, 2, 4), 130*a0701b62SRui Miguel Silva [F_ACTIVE] = REG_FIELD(FXAS21002C_REG_CTRL1, 1, 1), 131*a0701b62SRui Miguel Silva [F_READY] = REG_FIELD(FXAS21002C_REG_CTRL1, 0, 0), 132*a0701b62SRui Miguel Silva [F_INT_CFG_FIFO] = REG_FIELD(FXAS21002C_REG_CTRL2, 7, 7), 133*a0701b62SRui Miguel Silva [F_INT_EN_FIFO] = REG_FIELD(FXAS21002C_REG_CTRL2, 6, 6), 134*a0701b62SRui Miguel Silva [F_INT_CFG_RT] = REG_FIELD(FXAS21002C_REG_CTRL2, 5, 5), 135*a0701b62SRui Miguel Silva [F_INT_EN_RT] = REG_FIELD(FXAS21002C_REG_CTRL2, 4, 4), 136*a0701b62SRui Miguel Silva [F_INT_CFG_DRDY] = REG_FIELD(FXAS21002C_REG_CTRL2, 3, 3), 137*a0701b62SRui Miguel Silva [F_INT_EN_DRDY] = REG_FIELD(FXAS21002C_REG_CTRL2, 2, 2), 138*a0701b62SRui Miguel Silva [F_IPOL] = REG_FIELD(FXAS21002C_REG_CTRL2, 1, 1), 139*a0701b62SRui Miguel Silva [F_PP_OD] = REG_FIELD(FXAS21002C_REG_CTRL2, 0, 0), 140*a0701b62SRui Miguel Silva [F_WRAPTOONE] = REG_FIELD(FXAS21002C_REG_CTRL3, 3, 3), 141*a0701b62SRui Miguel Silva [F_EXTCTRLEN] = REG_FIELD(FXAS21002C_REG_CTRL3, 2, 2), 142*a0701b62SRui Miguel Silva [F_FS_DOUBLE] = REG_FIELD(FXAS21002C_REG_CTRL3, 0, 0), 143*a0701b62SRui Miguel Silva }; 144*a0701b62SRui Miguel Silva 145*a0701b62SRui Miguel Silva extern const struct dev_pm_ops fxas21002c_pm_ops; 146*a0701b62SRui Miguel Silva 147*a0701b62SRui Miguel Silva int fxas21002c_core_probe(struct device *dev, struct regmap *regmap, int irq, 148*a0701b62SRui Miguel Silva const char *name); 149*a0701b62SRui Miguel Silva void fxas21002c_core_remove(struct device *dev); 150*a0701b62SRui Miguel Silva #endif 151