matrixg  2.0.0.0
matrixg.h
Go to the documentation of this file.
1 /****************************************************************************
2 ** Copyright (C) 2020 MikroElektronika d.o.o.
3 ** Contact: https://www.mikroe.com/contact
4 **
5 ** Permission is hereby granted, free of charge, to any person obtaining a copy
6 ** of this software and associated documentation files (the "Software"), to deal
7 ** in the Software without restriction, including without limitation the rights
8 ** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 ** copies of the Software, and to permit persons to whom the Software is
10 ** furnished to do so, subject to the following conditions:
11 ** The above copyright notice and this permission notice shall be
12 ** included in all copies or substantial portions of the Software.
13 **
14 ** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15 ** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
16 ** OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
17 ** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18 ** DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
19 ** OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20 ** USE OR OTHER DEALINGS IN THE SOFTWARE.
21 ****************************************************************************/
22 
34 // ----------------------------------------------------------------------------
35 
36 #ifndef MATRIXG_H
37 #define MATRIXG_H
38 
39 #include "drv_digital_out.h"
40 #include "drv_digital_in.h"
41 #include "drv_spi_master.h"
42 
43 
44 // -------------------------------------------------------------- PUBLIC MACROS
45 
56 #define MATRIXG_MAP_MIKROBUS( cfg, mikrobus ) \
57  cfg.miso = MIKROBUS( mikrobus, MIKROBUS_MISO ); \
58  cfg.mosi = MIKROBUS( mikrobus, MIKROBUS_MOSI ); \
59  cfg.sck = MIKROBUS( mikrobus, MIKROBUS_SCK ); \
60  cfg.cs = MIKROBUS( mikrobus, MIKROBUS_CS ); \
61  cfg.csn = MIKROBUS( mikrobus, MIKROBUS_AN );
62 
68 #define MATRIXG_RETVAL uint8_t
69 
70 #define MATRIXG_OK 0x00
71 #define MATRIXG_INIT_ERROR 0xFF
72 
78 #define MATRIXG_DECODE_MODE_REG 0x09
79 #define MATRIXG_INTENSITY_REG 0x0A
80 #define MATRIXG_SCAN_LIMIT_REG 0x0B
81 #define MATRIXG_SHUTDOWN_REG 0x0C
82 #define MATRIXG_DISPLAY_TEST_REG 0x0F
83 
89 #define MATRIXG_NO_DECODE 0x00
90 #define MATRIXG_DECODE_DIGIT_0 0x01
91 #define MATRIXG_DECODE_DIGIT_3_0 0x0F
92 #define MATRIXG_DECODE_DIGIT_7 0xFF
93 
99 #define MATRIXG_INTEN_LVL_0 0x00
100 #define MATRIXG_INTEN_LVL_1 0x03
101 #define MATRIXG_INTEN_LVL_2 0x06
102 #define MATRIXG_INTEN_LVL_3 0x09
103 #define MATRIXG_INTEN_LVL_4 0x0C
104 #define MATRIXG_INTEN_LVL_5 0x0F
105 
111 #define MATRIXG_DISPLAY_DIGIT_0 0x00
112 #define MATRIXG_DISPLAY_DIGIT_0_1 0x01
113 #define MATRIXG_DISPLAY_DIGIT_0_2 0x02
114 #define MATRIXG_DISPLAY_DIGIT_0_3 0x03
115 #define MATRIXG_DISPLAY_DIGIT_0_4 0x04
116 #define MATRIXG_DISPLAY_DIGIT_0_5 0x05
117 #define MATRIXG_DISPLAY_DIGIT_0_6 0x06
118 #define MATRIXG_DISPLAY_DIGIT_0_7 0x07
119 
125 #define MATRIXG_SHUTDOWN_MODE 0x00
126 #define MATRIXG_NORMAL_OPERATION 0x01
127 
132 #define MATRIXG_DISPLAY_NORMAL_OPERATION 0x00
133 #define MATRIXG_DISPLAY_TEST_MODE 0X01
134  // End group macro
137 
138 // --------------------------------------------------------------- PUBLIC TYPES
139 
148 typedef struct
149 {
150  // Output pins
151 
152  digital_out_t csn;
153  digital_out_t cs;
154 
155  // Modules
156 
157  spi_master_t spi;
158  pin_name_t chip_select;
159 
160 } matrixg_t;
161 
165 typedef struct
166 {
167  // Communication gpio pins
168 
169  pin_name_t miso;
170  pin_name_t mosi;
171  pin_name_t sck;
172  pin_name_t cs;
173 
174  // Additional gpio pins
175 
176  pin_name_t csn;
177 
178  // static variable
179 
180  uint32_t spi_speed;
181  spi_master_mode_t spi_mode;
182  spi_master_chip_select_polarity_t cs_polarity;
183 
184 
185 } matrixg_cfg_t;
186  // End types group
188 
189 // ----------------------------------------------- PUBLIC FUNCTION DECLARATIONS
190 
191 
196 #ifdef __cplusplus
197 extern "C"{
198 #endif
199 
209 
218 
227 
237 void matrixg_display_characters ( matrixg_t *ctx, uint8_t left_char, uint8_t right_char );
238 
248 void matrixg_write_reg ( matrixg_t *ctx, uint8_t address, uint8_t input_data );
249 
258 
267 
268 #ifdef __cplusplus
269 }
270 #endif
271 #endif // _MATRIXG_H_
272  // End public_function group
275 
276 // ------------------------------------------------------------------------- END
matrixg_cfg_setup
void matrixg_cfg_setup(matrixg_cfg_t *cfg)
Config Object Initialization function.
matrixg_cfg_t::mosi
pin_name_t mosi
Definition: matrixg.h:170
matrixg_write_reg
void matrixg_write_reg(matrixg_t *ctx, uint8_t address, uint8_t input_data)
Register write function.
matrixg_cfg_t
Click configuration structure definition.
Definition: matrixg.h:166
MATRIXG_RETVAL
#define MATRIXG_RETVAL
Definition: matrixg.h:68
matrixg_t
Click ctx object definition.
Definition: matrixg.h:149
matrixg_init
MATRIXG_RETVAL matrixg_init(matrixg_t *ctx, matrixg_cfg_t *cfg)
Initialization function.
matrixg_cfg_t::spi_speed
uint32_t spi_speed
Definition: matrixg.h:180
matrixg_t::chip_select
pin_name_t chip_select
Definition: matrixg.h:158
matrixg_default_cfg
void matrixg_default_cfg(matrixg_t *ctx)
Click Default Configuration function.
matrixg_display_characters
void matrixg_display_characters(matrixg_t *ctx, uint8_t left_char, uint8_t right_char)
Display characters function.
matrixg_cfg_t::spi_mode
spi_master_mode_t spi_mode
Definition: matrixg.h:181
matrixg_cfg_t::cs
pin_name_t cs
Definition: matrixg.h:172
matrixg_t::csn
digital_out_t csn
Definition: matrixg.h:152
matrixg_t::cs
digital_out_t cs
Definition: matrixg.h:153
matrixg_cfg_t::cs_polarity
spi_master_chip_select_polarity_t cs_polarity
Definition: matrixg.h:182
matrixg_t::spi
spi_master_t spi
Definition: matrixg.h:157
matrixg_set_csn_low
void matrixg_set_csn_low(matrixg_t *ctx)
Set CSN pin to low function.
matrixg_cfg_t::miso
pin_name_t miso
Definition: matrixg.h:169
matrixg_set_csn_high
void matrixg_set_csn_high(matrixg_t *ctx)
Set CSN pin to high function.
matrixg_cfg_t::csn
pin_name_t csn
Definition: matrixg.h:176
matrixg_cfg_t::sck
pin_name_t sck
Definition: matrixg.h:171