-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmax7219.h
More file actions
182 lines (163 loc) · 5.18 KB
/
max7219.h
File metadata and controls
182 lines (163 loc) · 5.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
/*
* Copyright (c) 2019 Ruslan V. Uss <unclerus@gmail.com>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. Neither the name of the copyright holder nor the names of itscontributors
* may be used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
* @file max7219.h
* @defgroup max7219 max7219
* @{
*
* ESP-IDF driver for MAX7219/MAX7221
* Serially Interfaced, 8-Digit LED Display Drivers
*
* Ported from esp-open-rtos
*
* Copyright (c) 2017 Ruslan V. Uss <unclerus@gmail.com>
*
* BSD Licensed as described in the file LICENSE
*/
#ifndef __MAX7219_H__
#define __MAX7219_H__
#include <stdint.h>
#include <stdbool.h>
#include <driver/spi_master.h>
#include <driver/gpio.h> // add by nopnop2002
#include <esp_err.h>
#ifdef __cplusplus
extern "C" {
#endif
#define MAX7219_MAX_CLOCK_SPEED_HZ (10000000) // 10 MHz
#define MAX7219_MAX_BRIGHTNESS 15
/**
* Display descriptor
*/
typedef struct
{
spi_device_interface_config_t spi_cfg;
spi_device_handle_t spi_dev;
uint8_t digits; //!< Accessible digits in 7seg. Up to cascade_size * 8
uint8_t cascade_size; //!< Number of cascaded MAX72xx devices
bool mirrored; //!< true for horizontally mirrored displays
bool bcd;
} max7219_t;
/**
* @brief Initialize device descriptor
*
* @param dev Device descriptor
* @param host SPI host
* @param clock_speed_hz SPI clock speed, Hz
* @param cs_pin CS GPIO number
* @return `ESP_OK` on success
*/
esp_err_t max7219_init_desc(max7219_t *dev, spi_host_device_t host, uint32_t clock_speed_hz, gpio_num_t cs_pin);
/**
* @brief Free device descriptor
*
* @param dev Device descriptor
* @return `ESP_OK` on success
*/
esp_err_t max7219_free_desc(max7219_t *dev);
/**
* @brief Initialize display
*
* Switch it to normal operation from shutdown mode,
* set scan limit to the max and clear
*
* @param dev Display descriptor
* @return `ESP_OK` on success
*/
esp_err_t max7219_init(max7219_t *dev);
/**
* @brief Set decode mode and clear display
*
* @param dev Display descriptor
* @param bcd true to set BCD decode mode, false to normal
* @return `ESP_OK` on success
*/
esp_err_t max7219_set_decode_mode(max7219_t *dev, bool bcd);
/**
* @brief Set display brightness
*
* @param dev Display descriptor
* @param value Brightness value, 0..MAX7219_MAX_BRIGHTNESS
* @return `ESP_OK` on success
*/
esp_err_t max7219_set_brightness(max7219_t *dev, uint8_t value);
/**
* @brief Set brightness of specific chip in cascade
*
* @param dev Display descriptor
* @param chip Chip index, 0..dev->cascade_size - 1
* @param value Brightness value, 0..MAX7219_MAX_BRIGHTNESS
* @return `ESP_OK` on success
*/
esp_err_t max7219_set_brightness_chip(max7219_t *dev, uint8_t chip, uint8_t value);
/**
* @brief Shutdown display or set it to normal mode
*
* @param dev Display descriptor
* @param shutdown Shutdown display if true
* @return `ESP_OK` on success
*/
esp_err_t max7219_set_shutdown_mode(max7219_t *dev, bool shutdown);
/**
* @brief Write data to display digit
*
* @param dev Display descriptor
* @param digit Digit index, 0..dev->digits - 1
* @param val Data
* @return `ESP_OK` on success
*/
esp_err_t max7219_set_digit(max7219_t *dev, uint8_t digit, uint8_t val);
/**
* @brief Clear display
*
* @param dev Display descriptor
* @return `ESP_OK` on success
*/
esp_err_t max7219_clear(max7219_t *dev);
/**
* @brief Draw text on 7-segment display
*
* @param dev Display descriptor
* @param pos Start digit
* @param s Text
* @return `ESP_OK` on success
*/
esp_err_t max7219_draw_text_7seg(max7219_t *dev, uint8_t pos, const char *s);
/**
* @brief Draw 64-bit image on 8x8 matrix
*
* @param dev Display descriptor
* @param pos Start digit
* @param image 64-bit buffer with image data
* @return `ESP_OK` on success
*/
esp_err_t max7219_draw_image_8x8(max7219_t *dev, uint8_t pos, const void *image);
#ifdef __cplusplus
}
#endif
/**@}*/
#endif /* __MAX7219_H__ */