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
43#ifdef PREINIT_SUPPORTED
44#include "preinit.h"
45#endif
46
47#ifdef MikroCCoreVersion
48 #if MikroCCoreVersion >= 1
49 #include "delays.h"
50 #endif
51#endif
52
53#include "drv_digital_out.h"
54#include "drv_digital_in.h"
55#include "drv_spi_master.h"
56
57
58// -------------------------------------------------------------- PUBLIC MACROS
59
70#define MATRIXG_MAP_MIKROBUS( cfg, mikrobus ) \
71 cfg.miso = MIKROBUS( mikrobus, MIKROBUS_MISO ); \
72 cfg.mosi = MIKROBUS( mikrobus, MIKROBUS_MOSI ); \
73 cfg.sck = MIKROBUS( mikrobus, MIKROBUS_SCK ); \
74 cfg.cs = MIKROBUS( mikrobus, MIKROBUS_CS ); \
75 cfg.csn = MIKROBUS( mikrobus, MIKROBUS_AN );
82#define MATRIXG_RETVAL uint8_t
83
84#define MATRIXG_OK 0x00
85#define MATRIXG_INIT_ERROR 0xFF
92#define MATRIXG_DECODE_MODE_REG 0x09
93#define MATRIXG_INTENSITY_REG 0x0A
94#define MATRIXG_SCAN_LIMIT_REG 0x0B
95#define MATRIXG_SHUTDOWN_REG 0x0C
96#define MATRIXG_DISPLAY_TEST_REG 0x0F
103#define MATRIXG_NO_DECODE 0x00
104#define MATRIXG_DECODE_DIGIT_0 0x01
105#define MATRIXG_DECODE_DIGIT_3_0 0x0F
106#define MATRIXG_DECODE_DIGIT_7 0xFF
113#define MATRIXG_INTEN_LVL_0 0x00
114#define MATRIXG_INTEN_LVL_1 0x03
115#define MATRIXG_INTEN_LVL_2 0x06
116#define MATRIXG_INTEN_LVL_3 0x09
117#define MATRIXG_INTEN_LVL_4 0x0C
118#define MATRIXG_INTEN_LVL_5 0x0F
125#define MATRIXG_DISPLAY_DIGIT_0 0x00
126#define MATRIXG_DISPLAY_DIGIT_0_1 0x01
127#define MATRIXG_DISPLAY_DIGIT_0_2 0x02
128#define MATRIXG_DISPLAY_DIGIT_0_3 0x03
129#define MATRIXG_DISPLAY_DIGIT_0_4 0x04
130#define MATRIXG_DISPLAY_DIGIT_0_5 0x05
131#define MATRIXG_DISPLAY_DIGIT_0_6 0x06
132#define MATRIXG_DISPLAY_DIGIT_0_7 0x07
139#define MATRIXG_SHUTDOWN_MODE 0x00
140#define MATRIXG_NORMAL_OPERATION 0x01
141
146#define MATRIXG_DISPLAY_NORMAL_OPERATION 0x00
147#define MATRIXG_DISPLAY_TEST_MODE 0X01
150 // End group macro
151
152// --------------------------------------------------------------- PUBLIC TYPES
153
162typedef struct
163{
164 // Output pins
165
166 digital_out_t csn;
167 digital_out_t cs;
168
169 // Modules
170
171 spi_master_t spi;
172 pin_name_t chip_select;
173
174} matrixg_t;
175
179typedef struct
180{
181 // Communication gpio pins
182
183 pin_name_t miso;
184 pin_name_t mosi;
185 pin_name_t sck;
186 pin_name_t cs;
187
188 // Additional gpio pins
189
190 pin_name_t csn;
191
192 // static variable
193
194 uint32_t spi_speed;
195 spi_master_mode_t spi_mode;
196 spi_master_chip_select_polarity_t cs_polarity;
197
198
200
201 // End types group
202
203// ----------------------------------------------- PUBLIC FUNCTION DECLARATIONS
204
205
210#ifdef __cplusplus
211extern "C"{
212#endif
213
223
232
241
251void matrixg_display_characters ( matrixg_t *ctx, uint8_t left_char, uint8_t right_char );
252
262void matrixg_write_reg ( matrixg_t *ctx, uint8_t address, uint8_t input_data );
263
272
281
282#ifdef __cplusplus
283}
284#endif
285#endif // _MATRIXG_H_
286
287 // End public_function group
289
290// ------------------------------------------------------------------------- END
#define MATRIXG_RETVAL
Definition matrixg.h:82
void matrixg_default_cfg(matrixg_t *ctx)
Click Default Configuration function.
void matrixg_write_reg(matrixg_t *ctx, uint8_t address, uint8_t input_data)
Register write function.
void matrixg_display_characters(matrixg_t *ctx, uint8_t left_char, uint8_t right_char)
Display characters function.
MATRIXG_RETVAL matrixg_init(matrixg_t *ctx, matrixg_cfg_t *cfg)
Initialization function.
void matrixg_set_csn_low(matrixg_t *ctx)
Set CSN pin to low function.
void matrixg_cfg_setup(matrixg_cfg_t *cfg)
Config Object Initialization function.
void matrixg_set_csn_high(matrixg_t *ctx)
Set CSN pin to high function.
Click configuration structure definition.
Definition matrixg.h:180
pin_name_t csn
Definition matrixg.h:190
spi_master_chip_select_polarity_t cs_polarity
Definition matrixg.h:196
pin_name_t sck
Definition matrixg.h:185
spi_master_mode_t spi_mode
Definition matrixg.h:195
pin_name_t mosi
Definition matrixg.h:184
uint32_t spi_speed
Definition matrixg.h:194
pin_name_t miso
Definition matrixg.h:183
pin_name_t cs
Definition matrixg.h:186
Click ctx object definition.
Definition matrixg.h:163
digital_out_t cs
Definition matrixg.h:167
spi_master_t spi
Definition matrixg.h:171
digital_out_t csn
Definition matrixg.h:166
pin_name_t chip_select
Definition matrixg.h:172