2021-03-27 15:16:57 +08:00

160 lines
6.4 KiB
C

/*************************************************************************//**
* @file dmd_ssd2119.h
* @brief Dot matrix display driver for LCD controller SSD2119
* @author Energy Micro AS
******************************************************************************
* @section License
* <b>(C) Copyright 2012 Energy Micro AS, http://www.energymicro.com</b>
******************************************************************************
*
* Permission is granted to anyone to use this software for any purpose,
* including commercial applications, and to alter it and redistribute it
* freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you must not
* claim that you wrote the original software.
* 2. Altered source versions must be plainly marked as such, and must not be
* misrepresented as being the original software.
* 3. This notice may not be removed or altered from any source distribution.
* 4. The source and compiled code may only be used on Energy Micro "EFM32"
* microcontrollers and "EFR4" radios.
*
* DISCLAIMER OF WARRANTY/LIMITATION OF REMEDIES: Energy Micro AS has no
* obligation to support this Software. Energy Micro AS is providing the
* Software "AS IS", with no express or implied warranties of any kind,
* including, but not limited to, any implied warranties of merchantability
* or fitness for any particular purpose or warranties against infringement
* of any proprietary rights of a third party.
*
* Energy Micro AS will not be liable for any consequential, incidental, or
* special damages, or any other relief, or for any claim by any third party,
* arising from your use of this Software.
*
*****************************************************************************/
#ifndef __DMD_SSD2119_H
#define __DMD_SSD2119_H
#include <stdint.h>
#include "graphics/em_types.h"
/* TODO: remove this and replace with include types and ecodes */
#define ECODE_DMD_BASE 0x00000000
/* Error codes */
/** Successful call */
#define DMD_OK 0x00000000
/** Driver not initialized correctly */
#define DMD_ERROR_DRIVER_NOT_INITIALIZED (ECODE_DMD_BASE | 0x0001)
/** Driver is already initialized */
#define DMD_ERROR_DRIVER_ALREADY_INITIALIZED (ECODE_DMD_BASE | 0x0002)
/** Length of data is larger than size of clip */
#define DMD_ERROR_TOO_MUCH_DATA (ECODE_DMD_BASE | 0x0003)
/** Pixel is outside current clipping area */
#define DMD_ERROR_PIXEL_OUT_OF_BOUNDS (ECODE_DMD_BASE | 0x0004)
/** Clipping area is empty */
#define DMD_ERROR_EMPTY_CLIPPING_AREA (ECODE_DMD_BASE | 0x0005)
/** Wrong device code */
#define DMD_ERROR_WRONG_DEVICE_CODE (ECODE_DMD_BASE | 0x0006)
/** Memory error */
#define DMD_ERROR_MEMORY_ERROR (ECODE_DMD_BASE | 0x0007)
/** Error code expected, but didn't happen */
#define DMD_ERROR_NO_ERROR_CODE (ECODE_DMD_BASE | 0x0008)
/** Test run failed */
#define DMD_ERROR_TEST_FAILED (ECODE_DMD_BASE | 0x0009)
/** Frame update frequency of display */
#define DMD_FRAME_FREQUENCY 80
/** Horizontal size of the display */
#define DMD_HORIZONTAL_SIZE 320
/** Vertical size of the display */
#define DMD_VERTICAL_SIZE 240
/* Tests */
/** Device code test */
#define DMD_TEST_DEVICE_CODE 0x00000001
/** Memory test */
#define DMD_TEST_MEMORY 0x00000002
/** Parameter checks test */
#define DMD_TEST_PARAMETER_CHECKS 0x00000004
/** Color test */
#define DMD_TEST_COLORS 0x00000008
/** Clipping test */
#define DMD_TEST_CLIPPING 0x00000010
#define DMD_MEMORY_TEST_WIDTH 4
#define DMD_MEMORY_TEST_HEIGHT 3
/** @struct __DMD_DisplayGeometry
* @brief Dimensions of the display
*/
typedef struct __DMD_DisplayGeometry
{
/** Horizontal size of the display, in pixels */
uint16_t xSize;
/** Vertical size of the display, in pixels */
uint16_t ySize;
/** X coordinate of the top left corner of the clipping area */
uint16_t xClipStart;
/** Y coordinate of the top left corner of the clipping area */
uint16_t yClipStart;
/** Width of the clipping area */
uint16_t clipWidth;
/** Height of the clipping area */
uint16_t clipHeight;
} DMD_DisplayGeometry; /**< Typedef for display dimensions */
/** @struct __DMD_MemoryError
* @brief Information about a memory error
*/
typedef struct __DMD_MemoryError
{
/** X coordinate of the address where the error happened */
uint16_t x;
/** Y coordinate of the address where the error happened */
uint16_t y;
/** The color that was written to the memory address */
uint8_t writtenColor[3];
/** The color that was read from the memory address */
uint8_t readColor[3];
} DMD_MemoryError; /**< Typedef for memory error information */
/* Module prototypes */
EMSTATUS DMD_init(uint32_t cmdRegAddr, uint32_t dataRegAddr);
EMSTATUS DMD_getDisplayGeometry(DMD_DisplayGeometry **geometry);
EMSTATUS DMD_setClippingArea(uint16_t xStart, uint16_t yStart,
uint16_t width, uint16_t height);
EMSTATUS DMD_writeData(uint16_t x, uint16_t y,
const uint8_t data[], uint32_t numPixels);
EMSTATUS DMD_writeDataRLE(uint16_t x, uint16_t y, uint16_t xlen, uint16_t ylen,
const uint8_t *data);
EMSTATUS DMD_writeDataRLEFade(uint16_t x, uint16_t y, uint16_t xlen, uint16_t ylen,
const uint8_t *data,
int red, int green, int blue, int weight);
EMSTATUS DMD_readData(uint16_t x, uint16_t y,
uint8_t data[], uint32_t numPixels);
EMSTATUS DMD_writeColor(uint16_t x, uint16_t y, uint8_t red,
uint8_t green, uint8_t blue, uint32_t numPixels);
EMSTATUS DMD_writePixel(uint16_t x, uint16_t y, uint16_t color,
uint32_t numPixels);
EMSTATUS DMD_readPixel(uint16_t x, uint16_t y, uint16_t *color);
EMSTATUS DMD_sleep(void);
EMSTATUS DMD_wakeUp(void);
/* Test functions */
EMSTATUS DMD_testParameterChecks(void);
EMSTATUS DMD_testMemory(uint16_t x, uint16_t y,
uint32_t useClipWrite, uint32_t useClipRead,
DMD_MemoryError *memoryError);
EMSTATUS DMD_testMemory2(uint16_t x, uint16_t y,
uint32_t useClipWrite);
EMSTATUS DMD_testDeviceCode(void);
EMSTATUS DMD_testColors(uint32_t delay);
EMSTATUS DMD_testClipping(void);
EMSTATUS DMD_runTests(uint32_t tests, uint32_t *result);
EMSTATUS DMD_flipDisplay(int horizontal, int vertical);
#endif