WIP simple C-based library for hacking on the watch

This commit is contained in:
Joey Castillo
2021-04-25 22:43:47 -04:00
parent 9dda14e554
commit efd1e8a123
273 changed files with 142085 additions and 0 deletions

View File

@@ -0,0 +1,336 @@
/**
* \file
*
* \brief SLCD Segment Liquid Crystal Display Controller(Sync) functionality
* Implementation.
*
* Copyright (c) 2015-2018 Microchip Technology Inc. and its subsidiaries.
*
* \asf_license_start
*
* \page License
*
* Subject to your compliance with these terms, you may use Microchip
* software and any derivatives exclusively with Microchip products.
* It is your responsibility to comply with third party license terms applicable
* to your use of third party software (including open source software) that
* may accompany Microchip software.
*
* THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES,
* WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE,
* INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY,
* AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROCHIP BE
* LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL
* LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE
* SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE
* POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT
* ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY
* RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY,
* THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE.
*
* \asf_license_stop
*
*/
#include <utils_assert.h>
#include <hpl_slcd_sync.h>
#include <hpl_slcd_config.h>
#include <hpl_slcd_cm_7_seg_mapping.h>
#include <hpl_slcd_cm_14_seg_mapping.h>
static int32_t _slcd_sync_set_segment(struct _slcd_sync_device *dev, const uint32_t com, const uint32_t seg,
const bool on);
/**
* \brief SLCD configuration type
*/
struct slcd_configuration {
hri_slcd_ctrla_reg_t ctrla; /*!< Control A Register */
hri_slcd_ctrlb_reg_t ctrlb; /*!< Control B Register */
hri_slcd_ctrlc_reg_t ctrlc; /*!< Control C Register */
hri_slcd_ctrld_reg_t ctrld; /*!< Control D Register */
};
/**
* \brief Array of AC configurations
*/
static struct slcd_configuration _slcd
= {SLCD_CTRLA_DUTY(CONF_SLCD_COM_NUM) | CONF_SLCD_WMOD << SLCD_CTRLA_WMOD_Pos
| CONF_SLCD_RUNSTDBY << SLCD_CTRLA_RUNSTDBY_Pos | SLCD_CTRLA_PRESC(CONF_SLCD_PRESC)
| SLCD_CTRLA_CKDIV(CONF_SLCD_CKDIV) | SLCD_CTRLA_BIAS(CONF_SLCD_BIAS)
| CONF_SLCD_XVLCD << SLCD_CTRLA_XVLCD_Pos | SLCD_CTRLA_PRF(CONF_SLCD_PRF) | SLCD_CTRLA_RRF(CONF_SLCD_RRF),
CONF_SLCD_BBEN << SLCD_CTRLB_BBEN_Pos | SLCD_CTRLB_BBD(CONF_SLCD_BBD - 1),
SLCD_CTRLC_CTST(CONF_SLCD_CONTRAST_ADJUST),
SLCD_CTRLD_DISPEN};
static const struct slcd_char_setting cm_setting[] = SLCD_CHAR_SETTING_TABLE;
static const struct slcd_char_mapping cm7_lut[] = SLCD_SEG7_LUT;
static const struct slcd_char_mapping cm14_lut[] = SLCD_SEG14_LUT;
/**
* \brief Initialize SLCD Device Descriptor
*/
int32_t _slcd_sync_init(struct _slcd_sync_device *dev, void *const hw)
{
if (!hri_slcd_is_syncing(hw, SLCD_SYNCBUSY_SWRST)) {
if (hri_slcd_get_CTRLA_ENABLE_bit(hw)) {
hri_slcd_clear_CTRLA_ENABLE_bit(hw);
hri_slcd_wait_for_sync(hw, SLCD_SYNCBUSY_ENABLE);
}
hri_slcd_write_CTRLA_reg(hw, SLCD_CTRLA_SWRST);
}
hri_slcd_wait_for_sync(hw, SLCD_SYNCBUSY_SWRST);
dev->hw = hw;
hri_slcd_write_CTRLA_reg(hw, _slcd.ctrla);
hri_slcd_write_CTRLB_reg(hw, _slcd.ctrlb);
hri_slcd_write_CTRLC_reg(hw, _slcd.ctrlc);
hri_slcd_write_CTRLD_reg(hw, _slcd.ctrld);
hri_slcd_write_LPENL_reg(hw, CONF_SLCD_LPENL);
hri_slcd_write_LPENH_reg(hw, CONF_SLCD_LPENH);
hri_slcd_write_SDATAL0_reg(hw, 0);
hri_slcd_write_SDATAH0_reg(hw, 0);
hri_slcd_write_SDATAL1_reg(hw, 0);
hri_slcd_write_SDATAH1_reg(hw, 0);
hri_slcd_write_SDATAL2_reg(hw, 0);
hri_slcd_write_SDATAH2_reg(hw, 0);
hri_slcd_write_SDATAL3_reg(hw, 0);
hri_slcd_write_SDATAH3_reg(hw, 0);
hri_slcd_write_SDATAL4_reg(hw, 0);
hri_slcd_write_SDATAH4_reg(hw, 0);
hri_slcd_write_SDATAL5_reg(hw, 0);
hri_slcd_write_SDATAH5_reg(hw, 0);
hri_slcd_write_SDATAL6_reg(hw, 0);
hri_slcd_write_SDATAH6_reg(hw, 0);
hri_slcd_write_SDATAL7_reg(hw, 0);
hri_slcd_write_SDATAH7_reg(hw, 0);
hri_slcd_set_BCFG_MODE_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief DeInitialize SLCD Device Descriptor
*/
int32_t _slcd_sync_deinit(struct _slcd_sync_device *dev)
{
hri_slcd_clear_CTRLA_ENABLE_bit(dev->hw);
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_ENABLE);
hri_slcd_set_CTRLA_SWRST_bit(dev->hw);
dev->hw = NULL;
return ERR_NONE;
}
/**
* \brief Enable SLCD driver
*
* \param[in] dev SLCD device descriptor to be enabled
*/
int32_t _slcd_sync_enable(struct _slcd_sync_device *dev)
{
hri_slcd_set_CTRLA_ENABLE_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief Disable SLCD driver
*/
int32_t _slcd_sync_disable(struct _slcd_sync_device *dev)
{
hri_slcd_clear_CTRLA_ENABLE_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief Turn on a Segment
*/
int32_t _slcd_sync_seg_on(struct _slcd_sync_device *dev, uint32_t seg)
{
return _slcd_sync_set_segment(dev, SLCD_COMNUM(seg), SLCD_SEGNUM(seg), true);
}
/**
* \brief Turn off a Segment
*/
int32_t _slcd_sync_seg_off(struct _slcd_sync_device *dev, uint32_t seg)
{
return _slcd_sync_set_segment(dev, SLCD_COMNUM(seg), SLCD_SEGNUM(seg), false);
}
/**
* \brief Blink a Segment
*/
int32_t _slcd_sync_seg_blink(struct _slcd_sync_device *dev, uint32_t seg, const uint32_t period)
{
if ((SLCD_COMNUM(seg) >= CONF_SLCD_COM_NUM) || (SLCD_SEGNUM(seg) >= CONF_SLCD_SEG_NUM)) {
return ERR_INVALID_ARG;
}
/* COM[0..7], Seg[0,1] support blink */
if (SLCD_SEGNUM(seg) >= 2) {
return ERR_INVALID_ARG;
}
/* Verify period */
if (period > SLCD_FC_MAX_MS || period < SLCD_FC_MIN_MS) {
return ERR_INVALID_ARG;
}
/* Set Period, use Frame Counter 0 for blink */
hri_slcd_clear_CTRLD_FC0EN_bit(dev->hw);
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_CTRLD);
if (period <= SLCD_FC_BYPASS_MAX_MS) {
hri_slcd_set_FC0_reg(dev->hw, SLCD_FC0_PB | ((period / (1000 / SLCD_FRAME_FREQUENCY)) - 1));
} else {
hri_slcd_set_FC0_reg(dev->hw, (((period / (1000 / SLCD_FRAME_FREQUENCY)) / 8 - 1)));
}
hri_slcd_set_CTRLD_FC0EN_bit(dev->hw);
/* Set Blink Segments */
_slcd_sync_set_segment(dev, SLCD_COMNUM(seg), SLCD_SEGNUM(seg), true);
hri_slcd_clear_CTRLD_BLINK_bit(dev->hw);
hri_slcd_clear_CTRLA_ENABLE_bit(dev->hw);
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_ENABLE);
/* Update BCFG */
if (SLCD_SEGNUM(seg) == 0) {
hri_slcd_set_BCFG_BSS0_bf(dev->hw, 1 << SLCD_COMNUM(seg));
} else {
hri_slcd_set_BCFG_BSS1_bf(dev->hw, 1 << SLCD_COMNUM(seg));
}
hri_slcd_set_CTRLA_ENABLE_bit(dev->hw);
hri_slcd_set_CTRLD_BLINK_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief Displays a character
*/
int32_t _slcd_sync_write_char(struct _slcd_sync_device *dev, const uint8_t character, uint32_t index)
{
uint32_t i;
uint32_t data = ~0;
if (cm_setting[index].size == 7) {
for (i = 0; i<sizeof(cm7_lut)>> 2; i++) {
if (cm7_lut[i].character == character) {
data = cm7_lut[i].mapping;
break;
}
}
} else if (cm_setting[index].size == 14) {
for (i = 0; i<sizeof(cm14_lut)>> 2; i++) {
if (cm14_lut[i].character == character) {
data = cm14_lut[i].mapping;
break;
}
}
}
if (data == 0xFFFFFFFF) {
return ERR_INVALID_ARG;
}
hri_slcd_write_CMCFG_NSEG_bf(dev->hw, cm_setting[index].nseg);
hri_slcd_write_CMINDEX_CINDEX_bf(dev->hw, cm_setting[index].com_index);
hri_slcd_write_CMINDEX_SINDEX_bf(dev->hw, cm_setting[index].seg_index);
if (cm_setting[index].size == 7) {
hri_slcd_write_CMDMASK_reg(dev->hw, SEG7_MASK);
} else if (cm_setting[index].size == 14) {
hri_slcd_write_CMDMASK_reg(dev->hw, SEG14_MASK);
}
while (hri_slcd_get_STATUS_CMWRBUSY_bit(dev->hw))
;
hri_slcd_write_CMDATA_reg(dev->hw, data);
return ERR_NONE;
}
/**
* \brief Start animation play by a segment array
*/
int32_t _slcd_sync_start_animation(struct _slcd_sync_device *dev, const uint32_t segs[], uint32_t len,
const uint32_t period)
{
uint32_t i;
uint32_t csrlen = 0;
if (len > 16) {
return ERR_INVALID_ARG;
}
/* COM[0..7], Seg[2,3] support animation */
for (i = 0; i < len; i++) {
if ((SLCD_SEGNUM(segs[i]) != 2 && SLCD_SEGNUM(segs[i]) != 3)) {
return ERR_INVALID_ARG;
}
}
/* Verify period */
if (period > SLCD_FC_MAX_MS || period < SLCD_FC_MIN_MS) {
return ERR_INVALID_ARG;
}
/* Set Period */
_slcd_sync_set_animation_period(dev, period);
/* Set animation segments */
hri_slcd_clear_CTRLA_ENABLE_bit(dev->hw);
hri_slcd_clear_CTRLD_CSREN_bit(dev->hw);
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_ENABLE | SLCD_SYNCBUSY_CTRLD);
hri_slcd_set_CSRCFG_FCS_bf(dev->hw, 1);
hri_slcd_write_CSRCFG_DATA_bf(dev->hw, 0);
for (i = 0; i < len; i++) {
hri_slcd_set_CSRCFG_DATA_bf(dev->hw, (1 << ((SLCD_COMNUM(segs[i]) * 2) + (SLCD_SEGNUM(segs[i]) - 2))));
if (((SLCD_COMNUM(segs[i]) * 2) + (SLCD_SEGNUM(segs[i]) - 2)) > csrlen) {
csrlen = (SLCD_COMNUM(segs[i]) * 2) + (SLCD_SEGNUM(segs[i]) - 2);
}
}
hri_slcd_set_CSRCFG_SIZE_bf(dev->hw, csrlen + 1);
hri_slcd_set_BCFG_MODE_bit(dev->hw);
hri_slcd_set_CTRLD_CSREN_bit(dev->hw);
hri_slcd_set_CTRLA_ENABLE_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief Stop animation play by a segment array
*/
int32_t _slcd_sync_stop_animation(struct _slcd_sync_device *dev, const uint32_t segs[], uint32_t len)
{
/* Not used because of the current version is not supported, Reserved */
(void)segs;
(void)len;
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_CTRLD);
hri_slcd_clear_CTRLD_CSREN_bit(dev->hw);
return ERR_NONE;
}
/**
* \brief Set animation Frequency
*/
int32_t _slcd_sync_set_animation_period(struct _slcd_sync_device *dev, const uint32_t period)
{
hri_slcd_clear_CTRLD_FC1EN_bit(dev->hw);
hri_slcd_wait_for_sync(dev->hw, SLCD_SYNCBUSY_CTRLD);
/* Use Frame Counter 1 for blink */
if (period <= SLCD_FC_BYPASS_MAX_MS) {
hri_slcd_set_FC1_reg(dev->hw, SLCD_FC1_PB | ((period / (1000 / SLCD_FRAME_FREQUENCY)) - 1));
} else {
hri_slcd_set_FC1_reg(dev->hw, (((period / (1000 / SLCD_FRAME_FREQUENCY)) / 8 - 1)));
}
hri_slcd_set_CTRLD_FC1EN_bit(dev->hw);
return ERR_NONE;
}
static int32_t _slcd_sync_set_segment(struct _slcd_sync_device *dev, const uint32_t com, const uint32_t seg,
const bool on)
{
if ((SLCD_COMNUM(seg) >= CONF_SLCD_COM_NUM) || (SLCD_SEGNUM(seg) >= CONF_SLCD_SEG_NUM)) {
return ERR_INVALID_ARG;
}
/* Use register instead hri interface to optimization code */
if (on) {
((uint32_t *)&(((Slcd *)dev->hw)->SDATAL0))[(com * 2) + (seg >> 5)]
|= (seg < 32) ? (1 << seg) : (1 << (seg >> 5));
} else {
((uint32_t *)&(((Slcd *)dev->hw)->SDATAL0))[(com * 2) + (seg >> 5)]
&= ~((seg < 32) ? (1 << seg) : (1 << (seg >> 5)));
}
return ERR_NONE;
}

View File

@@ -0,0 +1,59 @@
/**
* \file
*
* \brief SLCD Character Mapping declaration.
*
* Copyright (c) 2015-2018 Microchip Technology Inc. and its subsidiaries.
*
* \asf_license_start
*
* \page License
*
* Subject to your compliance with these terms, you may use Microchip
* software and any derivatives exclusively with Microchip products.
* It is your responsibility to comply with third party license terms applicable
* to your use of third party software (including open source software) that
* may accompany Microchip software.
*
* THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES,
* WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE,
* INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY,
* AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROCHIP BE
* LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL
* LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE
* SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE
* POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT
* ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY
* RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY,
* THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE.
*
* \asf_license_stop
*
*/
#ifndef HPL_SLCD_CM_H_INCLUDED
#define HPL_SLCD_CM_H_INCLUDED
#include <stdint.h>
/* Character Mapping Struct */
struct slcd_char_mapping {
uint32_t character : 8; /*!< ASCII character */
uint32_t mapping : 24; /*!< Mapping value */
};
/* SLCD Character settting Struct */
struct slcd_char_setting {
uint8_t com_index; /*!< Common terminal index, start from 0 */
uint8_t seg_index; /*!< Segment terminal index, start from 0 */
uint8_t nseg; /*!< Number of Segment, this field is used to
indentify which segments line will be
used. For example, if char mapping from
COM1/SEG2 and nseg=2,size=7, then
COM1/SEG2, COM1/SEG3, COM2/SEG2,
COM2/SEG3, COM3/SEG2, COM3/SEG3,
COM4/SEG2 will be used for mapping
*/
uint8_t size; /*!< char size, typical is 7/14/16 */
};
#endif /* HPL_SLCD_CM_H_INCLUDED */

View File

@@ -0,0 +1,104 @@
#include <hpl_slcd_config.h>
/**
* character segments position index
*
* For a 14-segments character, each segment has an unique position index.
* The segment layout and position index value is shown as below.
* The symbol '-', '|', '/', '\' represent the SLCD character segment, and the
* number represent each segment's position index, which equals to macro
* SEG14_0 to SEG14_7.
* The character lookup mapping table use those position index
* (SEG14_0..SEG14_14) to compose some visible arabic numerals, letters or some
* specific ASCII.
* For example char '1' can be represented by use position index 1,2.
* (SEG7_1 | SEG7_2).
* More predefined character lookup can be found at below "14-segment character
* lookup mapping table"
*
* -0
* |5 \6 |7 /8 |1
* -9 -10
* |4 /11 |12 \13 |2
* -3
*/
/**
* Character segment position remapping setting
*
* An SLCD screen typically use several hardware segments to display a
* character(for example from COM3/SEG0 to COM4/SEG7).
* The lowest COM and SEG index is 0 (COM3/SEG0 index is 0).
* The "hardware character segments index" maybe different with the "character
* segments position index". The remapping setting allow application to adjust
* those sequence.
*
*/
#define SEG14_0 (0x1 << CONF_SLCD_CM_14SEGS_0_SETTING)
#define SEG14_1 (0x1 << CONF_SLCD_CM_14SEGS_1_SETTING)
#define SEG14_2 (0x1 << CONF_SLCD_CM_14SEGS_2_SETTING)
#define SEG14_3 (0x1 << CONF_SLCD_CM_14SEGS_3_SETTING)
#define SEG14_4 (0x1 << CONF_SLCD_CM_14SEGS_4_SETTING)
#define SEG14_5 (0x1 << CONF_SLCD_CM_14SEGS_5_SETTING)
#define SEG14_6 (0x1 << CONF_SLCD_CM_14SEGS_6_SETTING)
#define SEG14_7 (0x1 << CONF_SLCD_CM_14SEGS_7_SETTING)
#define SEG14_8 (0x1 << CONF_SLCD_CM_14SEGS_8_SETTING)
#define SEG14_9 (0x1 << CONF_SLCD_CM_14SEGS_9_SETTING)
#define SEG14_10 (0x1 << CONF_SLCD_CM_14SEGS_10_SETTING)
#define SEG14_11 (0x1 << CONF_SLCD_CM_14SEGS_11_SETTING)
#define SEG14_12 (0x1 << CONF_SLCD_CM_14SEGS_12_SETTING)
#define SEG14_13 (0x1 << CONF_SLCD_CM_14SEGS_13_SETTING)
/**
* 17-segments character mask value
*/
#define SEG14_MASK \
(0xFFFFFF \
& ~(SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_6 | SEG14_7 | SEG14_8 | SEG14_9 | SEG14_10 \
| SEG14_11 | SEG14_12 | SEG14_13))
/**
* 14-segment character lookup mapping table
* struct slcd_char_mapping;
*/
#define SLCD_SEG14_LUT \
{ \
{'0', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_8 | SEG14_11}, \
{'1', SEG14_1 | SEG14_2}, {'2', SEG14_0 | SEG14_1 | SEG14_3 | SEG14_4 | SEG14_9 | SEG14_10}, \
{'3', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_9 | SEG14_10}, \
{'4', SEG14_1 | SEG14_2 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'5', SEG14_0 | SEG14_2 | SEG14_3 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'6', SEG14_0 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'7', SEG14_0 | SEG14_1 | SEG14_2}, \
{'8', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'9', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'a', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'b', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_7 | SEG14_10 | SEG14_12}, \
{'c', SEG14_0 | SEG14_3 | SEG14_4 | SEG14_5}, \
{'d', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_7 | SEG14_12}, \
{'e', SEG14_0 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'f', SEG14_0 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'g', SEG14_0 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_10}, \
{'h', SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'i', SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'j', SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4}, {'k', SEG14_4 | SEG14_5 | SEG14_8 | SEG14_9 | SEG14_13}, \
{'l', SEG14_3 | SEG14_4 | SEG14_5}, {'m', SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_6 | SEG14_8}, \
{'n', SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_6 | SEG14_13}, \
{'o', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5}, \
{'p', SEG14_0 | SEG14_1 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'q', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5 | SEG14_13}, \
{'r', SEG14_0 | SEG14_1 | SEG14_4 | SEG14_5 | SEG14_9 | SEG14_10 | SEG14_13}, \
{'s', SEG14_0 | SEG14_3 | SEG14_5 | SEG14_9 | SEG14_13}, {'t', SEG14_0 | SEG14_7 | SEG14_12}, \
{'u', SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_5}, {'v', SEG14_4 | SEG14_5 | SEG14_8 | SEG14_11}, \
{'w', SEG14_1 | SEG14_2 | SEG14_4 | SEG14_5 | SEG14_11 | SEG14_13}, \
{'x', SEG14_6 | SEG14_8 | SEG14_11 | SEG14_13}, \
{'y', SEG14_1 | SEG14_2 | SEG14_3 | SEG14_5 | SEG14_9 | SEG14_10}, \
{'z', SEG14_0 | SEG14_3 | SEG14_8 | SEG14_11}, {'-', SEG14_9 | SEG14_10}, \
{'+', SEG14_7 | SEG14_9 | SEG14_10 | SEG14_12}, {'/', SEG14_8 | SEG14_11}, \
{'=', SEG14_3 | SEG14_9 | SEG14_10}, \
{'#', SEG14_1 | SEG14_2 | SEG14_3 | SEG14_7 | SEG14_9 | SEG14_10 | SEG14_12}, \
{'*', SEG14_6 | SEG14_8 | SEG14_11 | SEG14_13}, {'\'', SEG14_13}, {')', SEG14_6 | SEG14_11}, \
{'(', SEG14_8 | SEG14_13}, {'@', SEG14_0 | SEG14_1 | SEG14_2 | SEG14_3 | SEG14_4 | SEG14_9 | SEG14_13}, \
{'$', SEG14_0 | SEG14_2 | SEG14_3 | SEG14_5 | SEG14_7 | SEG14_9 | SEG14_10 | SEG14_12}, \
{'%', SEG14_2 | SEG14_5 | SEG14_8 | SEG14_11}, {'\\', SEG14_6 | SEG14_13}, {'_', SEG14_3}, {0, 0}, \
}

View File

@@ -0,0 +1,68 @@
#include <hpl_slcd_config.h>
/**
* character segments position index
*
* For a 7 segments character, each segment has an unique position index.
* The segment layout and position index value is shown as below.
* The symbol '-', '|' represent the SLCD character segment, and the
* number represent each segment's position index, which equals to macro
* SEG7_0 to SEG7_7.
* The character lookup mapping table use those position index (SEG7_0..SEG7_7)
* to compose some visible arabic numerals, letters or some specific ASCII.
* For example char '0' can be represented by use position index 0,1,2,3,4,5.
* (SEG7_0 | SEG7_1 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5).
* More predefined character lookup can be found at below "7-segments character
* lookup mapping table"
* -0
* |5 |1
* -6
* |4 |2
* -3
*/
/**
* Character segment position remapping setting
*
* An SLCD screen typically use several hardware segments to display a
* character(for example from COM3/SEG0 to COM3/SEG7).
* The lowest COM and SEG index is 0 (COM3/SEG0 index is 0).
* The "hardware character segments index" maybe different with the "character
* segments position index". The remapping setting allow application to adjust
* those sequence.
*
*/
#define SEG7_0 (0x1 << CONF_SLCD_CM_7SEGS_0_SETTING)
#define SEG7_1 (0x1 << CONF_SLCD_CM_7SEGS_1_SETTING)
#define SEG7_2 (0x1 << CONF_SLCD_CM_7SEGS_2_SETTING)
#define SEG7_3 (0x1 << CONF_SLCD_CM_7SEGS_3_SETTING)
#define SEG7_4 (0x1 << CONF_SLCD_CM_7SEGS_4_SETTING)
#define SEG7_5 (0x1 << CONF_SLCD_CM_7SEGS_5_SETTING)
#define SEG7_6 (0x1 << CONF_SLCD_CM_7SEGS_6_SETTING)
/**
* 7-segments character mask value
*/
#define SEG7_MASK (0xFFFFFF & ~(SEG7_0 | SEG7_1 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5 | SEG7_6))
/**
* 7-segments character lookup mapping table.
*
* Array value of slcd_char_mapping struct, application can add or remove
* item from it.
*/
#define SLCD_SEG7_LUT \
{ \
{0, 0}, {'0', SEG7_0 | SEG7_1 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5}, {'1', SEG7_1 | SEG7_2}, \
{'2', SEG7_0 | SEG7_1 | SEG7_3 | SEG7_4 | SEG7_6}, {'3', SEG7_0 | SEG7_1 | SEG7_2 | SEG7_3 | SEG7_6}, \
{'4', SEG7_1 | SEG7_2 | SEG7_5 | SEG7_6}, {'5', SEG7_0 | SEG7_2 | SEG7_3 | SEG7_5 | SEG7_6}, \
{'6', SEG7_0 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5 | SEG7_6}, {'7', SEG7_0 | SEG7_1 | SEG7_2}, \
{'8', SEG7_0 | SEG7_1 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5 | SEG7_6}, \
{'9', SEG7_0 | SEG7_1 | SEG7_2 | SEG7_5 | SEG7_6}, \
{'a', SEG7_0 | SEG7_1 | SEG7_2 | SEG7_4 | SEG7_5 | SEG7_6}, \
{'b', SEG7_2 | SEG7_3 | SEG7_4 | SEG7_5 | SEG7_6}, {'c', SEG7_0 | SEG7_3 | SEG7_4 | SEG7_5}, \
{'d', SEG7_1 | SEG7_2 | SEG7_3 | SEG7_4 | SEG7_6}, {'e', SEG7_0 | SEG7_3 | SEG7_4 | SEG7_5 | SEG7_6}, \
{ \
'f', SEG7_0 | SEG7_4 | SEG7_5 | SEG7_6 \
} \
}