A library with drivers for different peripherals on the LPC4088 QuickStart Board or related add-on boards.
Dependents: LPC4088test LPC4088test_ledonly LPC4088test_deleteall LPC4088_RAMtest ... more
Diff: EaLcdBoard.h
- Revision:
- 0:0fdadbc3d852
- Child:
- 4:b32cf4ef45c5
diff -r 000000000000 -r 0fdadbc3d852 EaLcdBoard.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/EaLcdBoard.h Thu Sep 26 06:37:02 2013 +0000 @@ -0,0 +1,161 @@ + +#ifndef EALCDBOARD_H +#define EALCDBOARD_H + +#include "LcdController.h" + +/** An interface to Embedded Artists LCD Boards + * + */ +class EaLcdBoard { +public: + + enum Result { + Ok = 0, + InvalidCommandString, + InvalidArgument, + InvalidStorage, + BufferTooSmall, + VersionNotSupported, + LcdAccessError + }; + + enum Constants { + NameBufferSize = 30 + }; + + /** Create an interface to an Embedded Artists LCD Board + * + * @param sda I2C data line pin + * @param scl I2C clock line pin + */ + EaLcdBoard(PinName sda, PinName scl); + + /** Open the interface and start initialization. + * + * @param cfg initialize with a given LCD configuration. If this argument is + * NULL the LCD configuration will be retrieved from persistent + * storage on the LCD Board. + * @param initSeq the initialization string. If this argument is NULL the + * initialization string will be retrieved from persistent + * storage on the LCD Board. + * + * @returns the result of the operation + */ + Result open(LcdController::Config* cfg, char* initSeq); + + /** Close the interface + * + * @returns the result of the operation + */ + Result close(); + + /** Set and activate the address of the frame buffer to use. + * + * It is the content of the frame buffer that is shown on the + * display. All the drawing on the frame buffer can be done + * 'offline' and whenever it should be shown this function + * can be called with the address of the offline frame buffer. + * + * @param address Memory address of the frame buffer + * + * @returns the result of the operation + */ + Result setFrameBuffer(uint32_t address); + + /** Get the LCD configuration stored in persistent storage on the LCD Board + * + * @param cfg pointer to a configuration object. Parameters are copied to + * this object. + * + * @returns the result of the operation + */ + Result getLcdConfig(LcdController::Config* cfg); + + /** Get the display name stored in persistent storage on the LCD Board + * + * @param buf buffer to which the name will be copied + * @param len size of the buffer in bytes + * + * @returns the result of the operation + */ + Result getDisplayName(char* buf, int len); + + /** Get the display manufacturer stored in persistent storage on the + * LCD Board + * + * @param buf buffer to which the name will be copied + * @param len size of the buffer in bytes + * + * @returns the result of the operation + */ + Result getDisplayMfg(char* buf, int len); + + /** Get the initialization sequence stored in persistent storage on the + * LCD Board + * + * @param buf buffer to which the string will be copied + * @param len size of the buffer in bytes + * + * @returns the result of the operation + */ + Result getInitSeq(char* buf, int len); + + /** Get the power down sequence stored in persistent storage on the + * LCD Board + * + * @param buf buffer to which the string will be copied + * @param len size of the buffer in bytes + * + * @returns the result of the operation + */ + Result getPowerDownSeq(char* buf, int len); + + +private: + + typedef struct { + uint32_t magic; // magic number + uint8_t lcd_name[NameBufferSize]; // LCD name + uint8_t lcd_mfg[NameBufferSize]; // manufacturer name + uint16_t lcdParamOff; // offset to LCD parameters + uint16_t initOff; // offset to init sequence string + uint16_t pdOff; // offset to power down sequence string + uint16_t tsOff; // offset to touch parameters + uint16_t end; // end offset + } store_t; + + Result getStore(store_t* store); + + int eepromRead(uint8_t* buf, uint16_t offset, uint16_t len); + int eepromWrite(uint8_t* buf, uint16_t offset, uint16_t len); + + Result parseInitString(char* str, LcdController::Config* cfg); + Result checkVersion(char* v, uint32_t len); + Result execDelay(char* del, uint32_t len); + Result execSeqCtrl(char* cmd, uint32_t len); + + void setLsStates(uint16_t states, uint8_t* ls, uint8_t mode); + void setLeds(void); + void pca9532_setLeds (uint16_t ledOnMask, uint16_t ledOffMask); + void pca9532_setBlink0Period(uint8_t period); + void pca9532_setBlink0Duty(uint8_t duty); + void pca9532_setBlink0Leds(uint16_t ledMask); + + void set3V3Signal(bool enabled); + void set5VSignal(bool enabled); + void setDisplayEnableSignal(bool enabled); + void setBacklightContrast(uint32_t value); + + I2C _i2c; + LcdController::Config _cfg; + LcdController lcdCtrl; + uint16_t _blink0Shadow; + uint16_t _blink1Shadow; + uint16_t _ledStateShadow; + bool _lcdPwrOn; +}; + +#endif + +