diff options
author | Joey Castillo <jose.castillo@gmail.com> | 2021-08-02 13:48:35 -0400 |
---|---|---|
committer | Joey Castillo <jose.castillo@gmail.com> | 2021-08-02 14:36:04 -0400 |
commit | 34945d78e933fc62bedcc975e88be02a0b7fcc2e (patch) | |
tree | 317edc18fe08d76a1f5d8c3aabf88cf58ba73897 /watch-library/hpl/slcd | |
parent | 2d1e2e8c76623543817f4c62b26fc300c1fd0d2c (diff) | |
download | Sensor-Watch-34945d78e933fc62bedcc975e88be02a0b7fcc2e.tar.gz Sensor-Watch-34945d78e933fc62bedcc975e88be02a0b7fcc2e.tar.bz2 Sensor-Watch-34945d78e933fc62bedcc975e88be02a0b7fcc2e.zip |
major project reorg, move library one level up
Diffstat (limited to 'watch-library/hpl/slcd')
-rw-r--r-- | watch-library/hpl/slcd/hpl_slcd.c | 336 | ||||
-rw-r--r-- | watch-library/hpl/slcd/hpl_slcd_cm.h | 59 | ||||
-rw-r--r-- | watch-library/hpl/slcd/hpl_slcd_cm_14_seg_mapping.h | 104 | ||||
-rw-r--r-- | watch-library/hpl/slcd/hpl_slcd_cm_7_seg_mapping.h | 68 |
4 files changed, 567 insertions, 0 deletions
diff --git a/watch-library/hpl/slcd/hpl_slcd.c b/watch-library/hpl/slcd/hpl_slcd.c new file mode 100644 index 00000000..f8f42bdd --- /dev/null +++ b/watch-library/hpl/slcd/hpl_slcd.c @@ -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; +} diff --git a/watch-library/hpl/slcd/hpl_slcd_cm.h b/watch-library/hpl/slcd/hpl_slcd_cm.h new file mode 100644 index 00000000..66dbde93 --- /dev/null +++ b/watch-library/hpl/slcd/hpl_slcd_cm.h @@ -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 */ diff --git a/watch-library/hpl/slcd/hpl_slcd_cm_14_seg_mapping.h b/watch-library/hpl/slcd/hpl_slcd_cm_14_seg_mapping.h new file mode 100644 index 00000000..65777d6d --- /dev/null +++ b/watch-library/hpl/slcd/hpl_slcd_cm_14_seg_mapping.h @@ -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}, \ + } diff --git a/watch-library/hpl/slcd/hpl_slcd_cm_7_seg_mapping.h b/watch-library/hpl/slcd/hpl_slcd_cm_7_seg_mapping.h new file mode 100644 index 00000000..eae344c8 --- /dev/null +++ b/watch-library/hpl/slcd/hpl_slcd_cm_7_seg_mapping.h @@ -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 \ + } \ + } |