Added SPI burst mode to spi 8 bit.
Dependents: Bicycl_Computer_NUCLEO-F411RE Bicycl_Computer_NUCLEO-L476RG
Fork of UniGraphic by
Added SPI burst mode to this graphics driver. If whoever wants this rolled in to repository let me know. I replaced _spi.write(); with fastWrite(); and clearRX();
SPI8.cpp
// need to re-create SPI firmware to access SPI handle static SPI_HandleTypeDef SpiHandle; void SPI8::fastWrite(int data) { SpiHandle.Instance = SPI1; // Check if data is transmitted while ((SpiHandle.Instance->SR & SPI_SR_TXE) == 0); SpiHandle.Instance->DR = data; } void SPI8::clearRX( void ) { SpiHandle.Instance = SPI1; //Check if the RX buffer is busy //While busy, keep checking while (SpiHandle.Instance->SR & SPI_SR_BSY){ // Check RX buffer readable while ((SpiHandle.Instance->SR & SPI_SR_RXNE) == 0); int dummy = SpiHandle.Instance->DR; } }
Inits/TFT_MIPI.h
- Committer:
- trevieze
- Date:
- 2017-08-04
- Revision:
- 36:0ced7cf0ec8c
- Parent:
- 18:ffa58f1a680a
File content as of revision 36:0ced7cf0ec8c:
#ifndef MBED_TFT_MIPI_H #define MBED_TFT_MIPI_H #include "mbed.h" #include "TFT.h" /** Class for (quite)standard MIPI-DBI TypeB (parallel) and TypeC (spi) TFT display controller * for Ilitek ILI9481, Renesas R61581, Raydium RM68042 * to be copypasted and adapted for other controllers */ class TFT_MIPI : public TFT { public: /** Create a PAR display interface * @param displayproto PAR_8 or PAR_16 * @param port GPIO port name to use * @param CS pin connected to CS of display * @param reset pin connected to RESET of display * @param DC pin connected to data/command of display * @param WR pin connected to SDI of display * @param RD pin connected to RS of display * @param name The name used by the parent class to access the interface * @param LCDSIZE_X x size in pixel - optional * @param LCDSIZE_Y y size in pixel - optional */ TFT_MIPI(proto_t displayproto, PortName port, PinName CS, PinName reset, PinName DC, PinName WR, PinName RD, const char* name , unsigned int LCDSIZE_X = 320, unsigned int LCDSIZE_Y = 480); /** Create an SPI display interface * @param displayproto SPI_8 or SPI_16 * @param Hz SPI speed in Hz * @param mosi SPI pin * @param miso SPI pin * @param sclk SPI pin * @param CS pin connected to CS of display * @param reset pin connected to RESET of display * @param DC pin connected to data/command of display * @param name The name used by the parent class to access the interface * @param LCDSIZE_X x size in pixel - optional * @param LCDSIZE_Y y size in pixel - optional */ TFT_MIPI(proto_t displayproto, int Hz, PinName mosi, PinName miso, PinName sclk, PinName CS, PinName reset, PinName DC, const char* name , unsigned int LCDSIZE_X = 320, unsigned int LCDSIZE_Y = 480); protected: /** Init command sequence */ void init(); }; #endif