This repository has been archived on 2024-01-25. You can view files and clone it, but cannot push or open issues or pull requests.
Solar-Panel/lcd/ssd1963_cmd.h

457 lines
12 KiB
C
Raw Permalink Normal View History

2023-02-24 13:34:16 +00:00
/****************************************************************************
**
** Copyright (C) 2020 MikroElektronika d.o.o.
** Contact: https://www.mikroe.com/contact
**
** This file is part of the mikroSDK package
**
** Commercial License Usage
**
** Licensees holding valid commercial NECTO compilers AI licenses may use this
** file in accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The mikroElektronika Company.
** For licensing terms and conditions see
** https://www.mikroe.com/legal/software-license-agreement.
** For further information use the contact form at
** https://www.mikroe.com/contact.
**
**
** GNU Lesser General Public License Usage
**
** Alternatively, this file may be used for
** non-commercial projects under the terms of the GNU Lesser
** General Public License version 3 as published by the Free Software
** Foundation: https://www.gnu.org/licenses/lgpl-3.0.html.
**
** The above copyright notice and this permission notice shall be
** included in all copies or substantial portions of the Software.
**
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
** OF MERCHANTABILITY, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
** TO THE WARRANTIES FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
** DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
** OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
** OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
**
****************************************************************************/
/*!
* @file ssd1963_cmd.h
* @brief SSD1963 Display Controller Commands.
*/
/*!
* @addtogroup middlewaregroup Middleware
* @{
*/
/*!
* @addtogroup ssd1963 SSD1963 Display Controller Driver
* @{
*/
/*!
* @addtogroup ssd1963_commands SSD1963 Display Controller Commands
* @brief SSD1963 Display Controller Command List
* @{
*/
#ifndef SSD1963_CMD_H
#define SSD1963_CMD_H
/**
* @brief No operation.
*/
#define SSD1963_CMD_NOP 0X00
/**
* @brief Software Reset.
*/
#define SSD1963_CMD_SOFT_RESET 0x01
/**
* @brief Get the current power mode.
*/
#define SSD1963_CMD_GET_POWER_MODE 0x0A
/**
* @brief Get the frame buffer to the display panel read order.
*/
#define SSD1963_CMD_GET_ADDRESS_MODE 0x0B
// #define SSD1963_CMD_RESERVED 0X0C
/**
* @brief The SSD1963 returns the Display Image Mode.
*/
#define SSD1963_CMD_GET_DISPLAY_MODE 0x0D
/**
* @brief Get the Tear Effect status.
*/
#define SSD1963_CMD_GET_TEAR_EFFECT_status 0x0E
//#define SSD1963_CMD_RESERVED 0X0F
/**
* @brief Turn off the panel. This command will pull high the GPIO0. If GPIO0 is configured as normal GPIO or LCD miscellaneous signal with command set_gpio_conf, this command will be ignored.
*/
#define SSD1963_CMD_ENTER_SLEEP_MODE 0x10
/**
* @brief Turn on the panel. This command will pull low the GPIO0. If GPIO0 is configured as normal GPIO or LCD miscellaneous signal with command set_gpio_conf, this command will be ignored.
*/
#define SSD1963_CMD_EXIT_SLEEP_MODE 0x11
/**
* @brief Part of the display area is used for image display.
*/
#define SSD1963_CMD_ENTER_PARTIAL_MODE 0x12
/**
* @brief The whole display area is used for image display.
*/
#define SSD1963_CMD_ENTER_NORMAL_MODE 0x13
/**
* @brief Displayed image colors are not inverted.
*/
#define SSD1963_CMD_EXIT_INVERT_MODE 0x20
/**
* @brief Displayed image colors are inverted.
*/
#define SSD1963_CMD_ENTER_INVERT_MODE 0x21
/**
* @brief Selects the gamma curve used by the display panel.
*/
#define SSD1963_CMD_SET_GAMMA_CURVE 0x26
/**
* @brief Blanks the display panel.
*/
#define SSD1963_CMD_SET_DISPLAY_OFF 0x28
/**
* @brief Show the image on the display panel.
*/
#define SSD1963_CMD_SET_DISPLAY_ON 0x29
/**
* @brief Set the column address.
*/
#define SSD1963_CMD_SET_COLUMN_ADDRESS 0x2A
/**
* @brief Set the page address.
*/
#define SSD1963_CMD_SET_PAGE_ADDRESS 0x2B
/**
* @brief Transfer image information from the host processor interface to the SSD1963 starting at the location provided by set_column_address and set_page_address.
*/
#define SSD1963_CMD_WRITE_MEMORY_START 0x2C
/**
* @brief Transfer image data from the SSD1963 to the host processor interface starting at the location provided by set_column_address and set_page_address.
*/
#define SSD1963_CMD_READ_MEMORY_START 0x2E
/**
* @brief Defines the partial display area on the display panel.
*/
#define SSD1963_CMD_SET_PARTIAL_AREA 0x30
/**
* @brief Defines the vertical scrolling and fixed area on display area.
*/
#define SSD1963_CMD_SET_SCROLL_AREA 0x33
/**
* @brief Synchronization information is not sent from the SSD1963 to the host processor.
*/
#define SSD1963_CMD_SET_TEAR_OFF 0x34
/**
* @brief Synchronization information is sent from the SSD1963 to the host processor at the start of VFP.
*/
#define SSD1963_CMD_SET_TEAR_ON 0x35
/**
* @brief Set the read order from frame buffer to the display panel.
*/
#define SSD1963_CMD_SET_ADDRESS_MODE 0x36
/**
* @brief Defines the vertical scrolling starting point.
*/
#define SSD1963_CMD_SET_SCROLL_START 0x37
/**
* @brief Full color depth is used for the display panel.
*/
#define SSD1963_CMD_EXIT_IDLE_MODE 0x38
/**
* @brief Reduce color depth is used on the display panel.
*/
#define SSD1963_CMD_ENTER_IDLE_MODE 0x39
// #define SSD1963_CMD_RESERVED 0X3A
/**
* @brief Transfer image information from the host processor interface to the SSD1963 from the last written location.
*/
#define SSD1963_CMD_WRITE_MEMORY_CONTINUE 0x3C
/**
* @brief Read image data from the SSD1963 continuing after the last read_memory_continue or read_memory_start.
*/
#define SSD1963_CMD_READ_MEMORY_CONTINUE 0x3E
/**
* @brief Synchronization information is sent from the SSD1963 to the host processor when the display panel refresh reaches the provided scan line.
*/
#define SSD1963_CMD_SET_TEAR_SCANLINE 0x44
/**
* @brief Get the current scan line.
*/
#define SSD1963_CMD_GET_SCANLINE 0x45
/**
* @brief Read the DDB from the provided location.
*/
#define SSD1963_CMD_READ_DDB 0xA1
// #define SSD1963_CMD_RESERVED 0xA8
/**
* @brief Set the LCD panel mode and resolution.
*/
#define SSD1963_CMD_SET_LCD_MODE 0xB0
/**
* @brief Get the current LCD panel mode, pad strength and resolution.
*/
#define SSD1963_CMD_GET_LCD_MODE 0xB1
/**
* @brief Set front porch
*/
#define SSD1963_CMD_SET_HORI_PERIOD 0xB4
/**
* @brief Get current front porch settings.
*/
#define SSD1963_CMD_GET_HORI_PERIOD 0xB5
/**
* @brief Set the vertical blanking interval between last scan line and next LFRAME pulse.
*/
#define SSD1963_CMD_SET_VERT_PERIOD 0xB6
/**
* @brief Get the vertical blanking interval between last scan line and next LFRAME pulse.
*/
#define SSD1963_CMD_GET_VERT_PERIOD 0xB7
/**
* @brief Set the GPIO configuration. If the GPIO is not used for LCD, set the direction. Otherwise, they are toggled with LCD signals.
*/
#define SSD1963_CMD_SET_GPIO_CONF 0xB8
/**
* @brief Get the current GPIO configuration.
*/
#define SSD1963_CMD_GET_GPIO_CONF 0xB9
/**
* @brief Set GPIO value for GPIO configured as output.
*/
#define SSD1963_CMD_SET_GPIO_VALUE 0xBA
/**
* @brief Read current GPIO status. If the individual GPIO was configured as input, the value is the status of the corresponding pin. Otherwise, it is the programmed value.
*/
#define SSD1963_CMD_GET_GPIO_STATUS 0xBB
/**
* @brief Set the image post processor.
*/
#define SSD1963_CMD_SET_POST_PROC 0xBC
/**
* @brief Get the image post processor.
*/
#define SSD1963_CMD_GET_POST_PROC 0xBD
/**
* @brief Set the image post processor.
*/
#define SSD1963_CMD_SET_PWM_CONF 0xBE
/**
* @brief Get the image post processor.
*/
#define SSD1963_CMD_GET_PWM_CONF 0xBF
/**
* @brief Set the rise, fall, period and toggling properties of LCD signal generator 0.
*/
#define SSD1963_CMD_SET_LCD_GEN0 0xC0
/**
* @brief Get the current settings of LCD signal generator 0.
*/
#define SSD1963_CMD_GET_LCD_GEN0 0xC1
/**
* @brief Set the rise, fall, period and toggling properties of LCD signal generator 1.
*/
#define SSD1963_CMD_SET_LCD_GEN1 0xC2
/**
* @brief Get the current settings of LCD signal generator 1.
*/
#define SSD1963_CMD_GET_LCD_GEN1 0xC3
/**
* @brief Set the rise, fall, period and toggling properties of LCD signal generator 2.
*/
#define SSD1963_CMD_SET_LCD_GEN2 0xC4
/**
* @brief Get the current settings of LCD signal generator 2.
*/
#define SSD1963_CMD_GET_LCD_GEN2 0xC5
/**
* @brief Set the rise, fall, period and toggling properties of LCD signal generator 3.
*/
#define SSD1963_CMD_SET_LCD_GEN3 0xC6
/**
* @brief Get the current settings of LCD signal generator 3.
*/
#define SSD1963_CMD_GET_LCD_GEN3 0xC7
/**
* @brief Set the GPIO0 with respect to the LCD signal generators using ROP operation. No effect if the GPIO0 is configured as general GPIO.
*/
#define SSD1963_CMD_SET_GPIO0_ROP 0xC8
/**
* @brief Get the GPIO0 properties with respect to the LCD signal generators.
*/
#define SSD1963_CMD_GET_GPIO0_ROP 0xC9
/**
* @brief Set the GPIO1 with respect to the LCD signal generators using ROP operation. No effect if the GPIO1 is configured as general GPIO.
*/
#define SSD1963_CMD_SET_GPIO1_ROP 0xCA
/**
* @brief Get the GPIO1 properties with respect to the LCD signal generators.
*/
#define SSD1963_CMD_GET_GPIO1_ROP 0xCB
/**
* @brief Set the GPIO2 with respect to the LCD signal generators using ROP operation. No effect if the GPIO2 is configured as general GPIO.
*/
#define SSD1963_CMD_SET_GPIO2_ROP 0xCC
/**
* @brief Get the GPIO2 properties with respect to the LCD signal generators.
*/
#define SSD1963_CMD_GET_GPIO2_ROP 0xCD
/**
* @brief Set the GPIO3 with respect to the LCD signal generators using ROP operation. No effect if the GPIO3 is configured as general GPIO.
*/
#define SSD1963_CMD_SET_GPIO3_ROP 0xCE
/**
* @brief Get the GPIO3 properties with respect to the LCD signal generators.
*/
#define SSD1963_CMD_GET_GPIO3_ROP 0xCF
/**
* @brief Set the dynamic back light configuration.
*/
#define SSD1963_CMD_SET_DBC_CONF 0xD0
/**
* @brief Get the current dynamic back light configuration.
*/
#define SSD1963_CMD_GET_DBC_CONF 0xD
/**
* @brief Set the threshold for each level of power saving.
*/
#define SSD1963_CMD_SET_DBC_TH 0xD4
/**
* @brief Get the threshold for each level of power saving.
*/
#define SSD1963_CMD_GET_DBC_TH 0xD5
/**
* @brief Start the PLL. Before the start, the system was operated with the crystal oscillator or clock input.
*/
#define SSD1963_CMD_SET_PLL 0xE0
/**
* @brief Set the PLL.
*/
#define SSD1963_CMD_SET_PLL_MN 0xE2
/**
* @brief Get the PLL settings.
*/
#define SSD1963_CMD_GET_PLL_MN 0xE3
/**
* @brief Get the current PLL status.
*/
#define SSD1963_CMD_GET_PLL_STATUS 0xE4
/**
* @brief Set deep sleep mode.
*/
#define SSD1963_CMD_SET_DEEP_SLEEP 0xE5
/**
* @brief Set the LSHIFT (pixel clock) frequency.
*/
#define SSD1963_CMD_SET_LSHIFT_FREQ 0xE6
/**
* @brief Get current LSHIFT (pixel clock) frequency setting.
*/
#define SSD1963_CMD_GET_LSHIFT_FREQ 0xE7
// #define SSD1963_CMD_RESERVED 0xE8
// #define SSD1963_CMD_RESERVED 0xE9
/**
* @brief Set the pixel data format of the parallel host processor interface.
*/
#define SSD1963_CMD_SET_PIXEL_DATA_INTERFACE 0xF0
/**
* @brief Get the current pixel data format settings.
*/
#define SSD1963_CMD_GET_PIXEL_DATA_INTERFACE 0xF1
// #define SSD1963_CMD_RESERVED 0xFF
/*! @} */ // ssd1963
/*! @} */ // ssd1963
/*! @} */ // mwgroup
#endif // SSD1963_CMD_H
// ------------------------------------------------------------------------- END