123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322 |
- /*
- * paj7620.h
- * A library for Grove-Guesture 1.0
- *
- * Copyright (c) 2015 seeed technology inc.
- * Website : www.seeed.cc
- * Author : Xiangnan
- *
- * The MIT License (MIT)
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- * THE SOFTWARE.
- */
- #define BIT(x) 1 << x
- // REGISTER DESCRIPTION
- #define PAJ7620_VAL(val, maskbit) ( val << maskbit )
- #define PAJ7620_ADDR_BASE 0x00
- // REGISTER BANK SELECT
- #define PAJ7620_REGITER_BANK_SEL (PAJ7620_ADDR_BASE + 0xEF) //W
- // DEVICE ID
- #define PAJ7620_ID 0x73
- // REGISTER BANK 0
- #define PAJ7620_ADDR_SUSPEND_CMD (PAJ7620_ADDR_BASE + 0x3) //W
- #define PAJ7620_ADDR_GES_PS_DET_MASK_0 (PAJ7620_ADDR_BASE + 0x41) //RW
- #define PAJ7620_ADDR_GES_PS_DET_MASK_1 (PAJ7620_ADDR_BASE + 0x42) //RW
- #define PAJ7620_ADDR_GES_PS_DET_FLAG_0 (PAJ7620_ADDR_BASE + 0x43) //R
- #define PAJ7620_ADDR_GES_PS_DET_FLAG_1 (PAJ7620_ADDR_BASE + 0x44) //R
- #define PAJ7620_ADDR_STATE_INDICATOR (PAJ7620_ADDR_BASE + 0x45) //R
- #define PAJ7620_ADDR_PS_HIGH_THRESHOLD (PAJ7620_ADDR_BASE + 0x69) //RW
- #define PAJ7620_ADDR_PS_LOW_THRESHOLD (PAJ7620_ADDR_BASE + 0x6A) //RW
- #define PAJ7620_ADDR_PS_APPROACH_STATE (PAJ7620_ADDR_BASE + 0x6B) //R
- #define PAJ7620_ADDR_PS_RAW_DATA (PAJ7620_ADDR_BASE + 0x6C) //R
- // REGISTER BANK 1
- #define PAJ7620_ADDR_PS_GAIN (PAJ7620_ADDR_BASE + 0x44) //RW
- #define PAJ7620_ADDR_IDLE_S1_STEP_0 (PAJ7620_ADDR_BASE + 0x67) //RW
- #define PAJ7620_ADDR_IDLE_S1_STEP_1 (PAJ7620_ADDR_BASE + 0x68) //RW
- #define PAJ7620_ADDR_IDLE_S2_STEP_0 (PAJ7620_ADDR_BASE + 0x69) //RW
- #define PAJ7620_ADDR_IDLE_S2_STEP_1 (PAJ7620_ADDR_BASE + 0x6A) //RW
- #define PAJ7620_ADDR_OP_TO_S1_STEP_0 (PAJ7620_ADDR_BASE + 0x6B) //RW
- #define PAJ7620_ADDR_OP_TO_S1_STEP_1 (PAJ7620_ADDR_BASE + 0x6C) //RW
- #define PAJ7620_ADDR_OP_TO_S2_STEP_0 (PAJ7620_ADDR_BASE + 0x6D) //RW
- #define PAJ7620_ADDR_OP_TO_S2_STEP_1 (PAJ7620_ADDR_BASE + 0x6E) //RW
- #define PAJ7620_ADDR_OPERATION_ENABLE (PAJ7620_ADDR_BASE + 0x72) //RW
- // PAJ7620_REGITER_BANK_SEL
- #define PAJ7620_BANK0 PAJ7620_VAL(0,0)
- #define PAJ7620_BANK1 PAJ7620_VAL(1,0)
- // PAJ7620_ADDR_SUSPEND_CMD
- #define PAJ7620_I2C_WAKEUP PAJ7620_VAL(1,0)
- #define PAJ7620_I2C_SUSPEND PAJ7620_VAL(0,0)
- // PAJ7620_ADDR_OPERATION_ENABLE
- #define PAJ7620_ENABLE PAJ7620_VAL(1,0)
- #define PAJ7620_DISABLE PAJ7620_VAL(0,0)
- typedef enum {
- BANK0 = 0,
- BANK1,
- } bank_e;
- enum {
- // REGISTER 0
- GES_RIGHT_FLAG = BIT(0),
- GES_LEFT_FLAG = BIT(1),
- GES_UP_FLAG = BIT(2),
- GES_DOWN_FLAG = BIT(3),
- GES_FORWARD_FLAG = BIT(4),
- GES_BACKWARD_FLAG = BIT(5),
- GES_CLOCKWISE_FLAG = BIT(6),
- GES_COUNT_CLOCKWISE_FLAG = BIT(7),
- //REGISTER 1
- GES_WAVE_FLAG = BIT(0),
- };
- // PAJ7620U2_20140305.asc
- unsigned char init_register_array[][2] = { // Initial Gesture
- {0xEF,0x00},
- {0x32,0x29},
- {0x33,0x01},
- {0x34,0x00},
- {0x35,0x01},
- {0x36,0x00},
- {0x37,0x07},
- {0x38,0x17},
- {0x39,0x06},
- {0x3A,0x12},
- {0x3F,0x00},
- {0x40,0x02},
- {0x41,0xFF},
- {0x42,0x01},
- {0x46,0x2D},
- {0x47,0x0F},
- {0x48,0x3C},
- {0x49,0x00},
- {0x4A,0x1E},
- {0x4B,0x00},
- {0x4C,0x20},
- {0x4D,0x00},
- {0x4E,0x1A},
- {0x4F,0x14},
- {0x50,0x00},
- {0x51,0x10},
- {0x52,0x00},
- {0x5C,0x02},
- {0x5D,0x00},
- {0x5E,0x10},
- {0x5F,0x3F},
- {0x60,0x27},
- {0x61,0x28},
- {0x62,0x00},
- {0x63,0x03},
- {0x64,0xF7},
- {0x65,0x03},
- {0x66,0xD9},
- {0x67,0x03},
- {0x68,0x01},
- {0x69,0xC8},
- {0x6A,0x40},
- {0x6D,0x04},
- {0x6E,0x00},
- {0x6F,0x00},
- {0x70,0x80},
- {0x71,0x00},
- {0x72,0x00},
- {0x73,0x00},
- {0x74,0xF0},
- {0x75,0x00},
- {0x80,0x42},
- {0x81,0x44},
- {0x82,0x04},
- {0x83,0x20},
- {0x84,0x20},
- {0x85,0x00},
- {0x86,0x10},
- {0x87,0x00},
- {0x88,0x05},
- {0x89,0x18},
- {0x8A,0x10},
- {0x8B,0x01},
- {0x8C,0x37},
- {0x8D,0x00},
- {0x8E,0xF0},
- {0x8F,0x81},
- {0x90,0x06},
- {0x91,0x06},
- {0x92,0x1E},
- {0x93,0x0D},
- {0x94,0x0A},
- {0x95,0x0A},
- {0x96,0x0C},
- {0x97,0x05},
- {0x98,0x0A},
- {0x99,0x41},
- {0x9A,0x14},
- {0x9B,0x0A},
- {0x9C,0x3F},
- {0x9D,0x33},
- {0x9E,0xAE},
- {0x9F,0xF9},
- {0xA0,0x48},
- {0xA1,0x13},
- {0xA2,0x10},
- {0xA3,0x08},
- {0xA4,0x30},
- {0xA5,0x19},
- {0xA6,0x10},
- {0xA7,0x08},
- {0xA8,0x24},
- {0xA9,0x04},
- {0xAA,0x1E},
- {0xAB,0x1E},
- {0xCC,0x19},
- {0xCD,0x0B},
- {0xCE,0x13},
- {0xCF,0x64},
- {0xD0,0x21},
- {0xD1,0x0F},
- {0xD2,0x88},
- {0xE0,0x01},
- {0xE1,0x04},
- {0xE2,0x41},
- {0xE3,0xD6},
- {0xE4,0x00},
- {0xE5,0x0C},
- {0xE6,0x0A},
- {0xE7,0x00},
- {0xE8,0x00},
- {0xE9,0x00},
- {0xEE,0x07},
- {0xEF,0x01},
- {0x00,0x1E},
- {0x01,0x1E},
- {0x02,0x0F},
- {0x03,0x10},
- {0x04,0x02},
- {0x05,0x00},
- {0x06,0xB0},
- {0x07,0x04},
- {0x08,0x0D},
- {0x09,0x0E},
- {0x0A,0x9C},
- {0x0B,0x04},
- {0x0C,0x05},
- {0x0D,0x0F},
- {0x0E,0x02},
- {0x0F,0x12},
- {0x10,0x02},
- {0x11,0x02},
- {0x12,0x00},
- {0x13,0x01},
- {0x14,0x05},
- {0x15,0x07},
- {0x16,0x05},
- {0x17,0x07},
- {0x18,0x01},
- {0x19,0x04},
- {0x1A,0x05},
- {0x1B,0x0C},
- {0x1C,0x2A},
- {0x1D,0x01},
- {0x1E,0x00},
- {0x21,0x00},
- {0x22,0x00},
- {0x23,0x00},
- {0x25,0x01},
- {0x26,0x00},
- {0x27,0x39},
- {0x28,0x7F},
- {0x29,0x08},
- {0x30,0x03},
- {0x31,0x00},
- {0x32,0x1A},
- {0x33,0x1A},
- {0x34,0x07},
- {0x35,0x07},
- {0x36,0x01},
- {0x37,0xFF},
- {0x38,0x36},
- {0x39,0x07},
- {0x3A,0x00},
- {0x3E,0xFF},
- {0x3F,0x00},
- {0x40,0x77},
- {0x41,0x40},
- {0x42,0x00},
- {0x43,0x30},
- {0x44,0xA0},
- {0x45,0x5C},
- {0x46,0x00},
- {0x47,0x00},
- {0x48,0x58},
- {0x4A,0x1E},
- {0x4B,0x1E},
- {0x4C,0x00},
- {0x4D,0x00},
- {0x4E,0xA0},
- {0x4F,0x80},
- {0x50,0x00},
- {0x51,0x00},
- {0x52,0x00},
- {0x53,0x00},
- {0x54,0x00},
- {0x57,0x80},
- {0x59,0x10},
- {0x5A,0x08},
- {0x5B,0x94},
- {0x5C,0xE8},
- {0x5D,0x08},
- {0x5E,0x3D},
- {0x5F,0x99},
- {0x60,0x45},
- {0x61,0x40},
- {0x63,0x2D},
- {0x64,0x02},
- {0x65,0x96},
- {0x66,0x00},
- {0x67,0x97},
- {0x68,0x01},
- {0x69,0xCD},
- {0x6A,0x01},
- {0x6B,0xB0},
- {0x6C,0x04},
- {0x6D,0x2C},
- {0x6E,0x01},
- {0x6F,0x32},
- {0x71,0x00},
- {0x72,0x01},
- {0x73,0x35},
- {0x74,0x00},
- {0x75,0x33},
- {0x76,0x31},
- {0x77,0x01},
- {0x7C,0x84},
- {0x7D,0x03},
- {0x7E,0x01},
- };
- #define INIT_REG_ARRAY_SIZE (sizeof(init_register_array)/sizeof(init_register_array[0]))
|