1 /*
2  * Author: Yevgeniy Kiveisha <yevgeniy.kiveisha@intel.com>
3  * Copyright (c) 2014 Intel Corporation.
4  *
5  * Credits to Seeed Studeo.
6  * Based on Seeed Studeo code example,
7  * http://www.seeedstudio.com/wiki/index.php?title=Twig_-_I2C_Color_Sensor_v0.9b.
8  *
9  * Permission is hereby granted, free of charge, to any person obtaining
10  * a copy of this software and associated documentation files (the
11  * "Software"), to deal in the Software without restriction, including
12  * without limitation the rights to use, copy, modify, merge, publish,
13  * distribute, sublicense, and/or sell copies of the Software, and to
14  * permit persons to whom the Software is furnished to do so, subject to
15  * the following conditions:
16  *
17  * The above copyright notice and this permission notice shall be
18  * included in all copies or substantial portions of the Software.
19  *
20  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24  * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25  * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26  * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27  */
28 #pragma once
29 
30 #include <string>
31 #include <mraa/i2c.hpp>
32 
33 #define ADDR                        0x39 // device address
34 
35 #define REG_CTL                     0x80
36 #define REG_TIMING                  0x81
37 #define REG_INT                     0x82
38 #define REG_INT_SOURCE              0x83
39 #define REG_ID                      0x84
40 #define REG_GAIN                    0x87
41 #define REG_LOW_THRESH_LOW_BYTE     0x88
42 #define REG_LOW_THRESH_HIGH_BYTE    0x89
43 #define REG_HIGH_THRESH_LOW_BYTE    0x8A
44 #define REG_HIGH_THRESH_HIGH_BYTE   0x8B
45 #define REG_BLOCK_READ              0xCF
46 #define REG_GREEN_LOW               0xD0
47 #define REG_GREEN_HIGH              0xD1
48 #define REG_RED_LOW                 0xD2
49 #define REG_RED_HIGH                0xD3
50 #define REG_BLUE_LOW                0xD4
51 #define REG_BLUE_HIGH               0xD5
52 #define REG_CLEAR_LOW               0xD6
53 #define REG_CLEAR_HIGH              0xD7
54 #define CTL_DAT_INIITIATE           0x03
55 #define CLR_INT                     0xE0
56 
57 /* Timing Register */
58 #define SYNC_EDGE                   0x40
59 #define INTEG_MODE_FREE             0x00
60 #define INTEG_MODE_MANUAL           0x10
61 #define INTEG_MODE_SYN_SINGLE       0x20
62 #define INTEG_MODE_SYN_MULTI        0x30
63 
64 #define INTEG_PARAM_PULSE_COUNT1    0x00
65 #define INTEG_PARAM_PULSE_COUNT2    0x01
66 #define INTEG_PARAM_PULSE_COUNT4    0x02
67 #define INTEG_PARAM_PULSE_COUNT8    0x03
68 
69 /* Interrupt Control Register */
70 #define INTR_STOP                   40
71 #define INTR_DISABLE                0x00
72 #define INTR_LEVEL                  0x10
73 #define INTR_PERSIST_EVERY          0x00
74 #define INTR_PERSIST_SINGLE         0x01
75 
76 /* Interrupt Souce Register */
77 #define INT_SOURCE_GREEN            0x00
78 #define INT_SOURCE_RED              0x01
79 #define INT_SOURCE_BLUE             0x10
80 #define INT_SOURCE_CLEAR            0x03
81 
82 /* Gain Register */
83 #define GAIN_1                      0x00
84 #define GAIN_4                      0x10
85 #define GAIN_16                     0x20
86 #define GANI_64                     0x30
87 #define PRESCALER_1                 0x00
88 #define PRESCALER_2                 0x01
89 #define PRESCALER_4                 0x02
90 #define PRESCALER_8                 0x03
91 #define PRESCALER_16                0x04
92 #define PRESCALER_32                0x05
93 #define PRESCALER_64                0x06
94 
95 #define HIGH                        1
96 #define LOW                         0
97 
98 namespace upm {
99 
100 typedef struct {
101     uint16_t r;
102     uint16_t g;
103     uint16_t b;
104     uint16_t clr;
105 } tcs3414sc_rgb_t;
106 
107 /**
108  * @brief TCS3414CS Color Sensor library
109  * @defgroup tcs3414cs libupm-tcs3414cs
110  * @ingroup seeed i2c color
111  */
112 /**
113  * @library tcs3414cs
114  * @sensor tcs3414cs
115  * @comname TCS3414CS Color Sensor
116  * @altname Grove Color Sensor
117  * @type color
118  * @man seeed
119  * @web http://www.seeedstudio.com/wiki/Grove_-_I2C_Color_Sensor
120  * @con i2c
121  *
122  * @brief API for the TCS3414CS Color Sensor
123  *
124  * This module defines the TCS3414CS interface for the color sensor
125  *
126  * @image html tcs3414cs.jpg
127  * @snippet tcs3414cs.cxx Interesting
128  */
129 class TCS3414CS {
130     public:
131         /**
132          * Instantiates a TCS3414CS object
133          *
134          * @param bus Number of the used bus
135          */
136         TCS3414CS ();
137 
138         /**
139          * Gets the RGB value from the sensor.
140          *
141          * @param rgb Color values
142          */
143         void readRGB (tcs3414sc_rgb_t * rgb);
144 
145         /**
146          * Clears interrupts.
147          */
148         void clearInterrupt ();
149 
150         /**
151          * Returns the name of the component
152          */
name()153         std::string name()
154         {
155             return m_name;
156         }
157     private:
158         std::string m_name;
159         mraa::I2c m_i2Ctx;
160 
161         uint16_t i2cReadReg_N (int reg, unsigned int len, uint8_t * buffer);
162         mraa::Result i2cWriteReg_N (uint8_t reg, unsigned int len, uint8_t * buffer);
163         mraa::Result i2cWriteReg (uint8_t reg, uint8_t data);
164 };
165 
166 }
167