annotate Scan/STLcd/lcd_scan.c @ 353:c6613db89cbe

Adding capability to set default image on LCD
author Jacob Alexander <haata@kiibohd.com>
date Sat, 01 Aug 2015 23:13:19 -0700
parents 99b567a3b1f2
children 40bbbc667399
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
1 /* Copyright (C) 2015 by Jacob Alexander
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
2 *
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
3 * This file is free software: you can redistribute it and/or modify
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
4 * it under the terms of the GNU General Public License as published by
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
5 * the Free Software Foundation, either version 3 of the License, or
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
6 * (at your option) any later version.
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
7 *
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
8 * This file is distributed in the hope that it will be useful,
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
11 * GNU General Public License for more details.
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
12 *
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
13 * You should have received a copy of the GNU General Public License
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
14 * along with this file. If not, see <http://www.gnu.org/licenses/>.
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
15 */
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
16
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
17 // ----- Includes -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
18
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
19 // Compiler Includes
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
20 #include <Lib/ScanLib.h>
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
21
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
22 // Project Includes
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
23 #include <cli.h>
351
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
24 #include <kll.h>
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
25 #include <led.h>
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
26 #include <print.h>
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
27
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
28 // Local Includes
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
29 #include "lcd_scan.h"
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
30
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
31
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
32
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
33 // ----- Defines -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
34
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
35 #define LCD_TOTAL_VISIBLE_PAGES 4
332
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
36 #define LCD_PAGE_LEN 128
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
37
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
38
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
39
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
40 // ----- Macros -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
41
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
42 // Number of entries in the SPI0 TxFIFO
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
43 #define SPI0_TxFIFO_CNT ( ( SPI0_SR & SPI_SR_TXCTR ) >> 12 )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
44
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
45
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
46
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
47 // ----- Structs -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
48
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
49 // ----- Function Declarations -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
50
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
51 // CLI Functions
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
52 void cliFunc_lcdCmd ( char* args );
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
53 void cliFunc_lcdColor( char* args );
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
54 void cliFunc_lcdInit ( char* args );
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
55 void cliFunc_lcdTest ( char* args );
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
56
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
57
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
58
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
59 // ----- Variables -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
60
353
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
61 // Default Image - Displays on startup
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
62 const uint8_t STLcdDefaultImage[] = { STLcdDefaultImage_define };
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
63
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
64 // Full Toggle State
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
65 uint8_t cliFullToggleState = 0;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
66
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
67 // Normal/Reverse Toggle State
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
68 uint8_t cliNormalReverseToggleState = 0;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
69
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
70 // Scan Module command dictionary
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
71 CLIDict_Entry( lcdCmd, "Send byte via SPI, second argument enables a0. Defaults to control." );
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
72 CLIDict_Entry( lcdColor, "Set backlight color. 3 16-bit numbers: R G B. i.e. 0xFFF 0x1444 0x32" );
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
73 CLIDict_Entry( lcdInit, "Re-initialize the LCD display." );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
74 CLIDict_Entry( lcdTest, "Test out the LCD display." );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
75
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
76 CLIDict_Def( lcdCLIDict, "ST LCD Module Commands" ) = {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
77 CLIDict_Item( lcdCmd ),
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
78 CLIDict_Item( lcdColor ),
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
79 CLIDict_Item( lcdInit ),
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
80 CLIDict_Item( lcdTest ),
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
81 { 0, 0, 0 } // Null entry for dictionary end
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
82 };
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
83
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
84
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
85
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
86 // ----- Interrupt Functions -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
87
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
88
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
89
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
90 // ----- Functions -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
91
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
92 inline void SPI_setup()
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
93 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
94 // Enable SPI internal clock
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
95 SIM_SCGC6 |= SIM_SCGC6_SPI0;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
96
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
97 // Setup MOSI (SOUT) and SCLK (SCK)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
98 PORTC_PCR6 = PORT_PCR_DSE | PORT_PCR_MUX(2);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
99 PORTC_PCR5 = PORT_PCR_DSE | PORT_PCR_MUX(2);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
100
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
101 // Setup SS (PCS)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
102 PORTC_PCR4 = PORT_PCR_DSE | PORT_PCR_MUX(2);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
103
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
104 // Master Mode, CS0
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
105 SPI0_MCR = SPI_MCR_MSTR | SPI_MCR_PCSIS(1);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
106
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
107 // DSPI Clock and Transfer Attributes
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
108 // Frame Size: 8 bits
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
109 // MSB First
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
110 // CLK Low by default
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
111 SPI0_CTAR0 = SPI_CTAR_FMSZ(7)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
112 | SPI_CTAR_ASC(7)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
113 | SPI_CTAR_DT(7)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
114 | SPI_CTAR_CSSCK(7)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
115 | SPI_CTAR_PBR(0) | SPI_CTAR_BR(7);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
116 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
117
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
118 // Write buffer to SPI FIFO
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
119 void SPI_write( uint8_t *buffer, uint8_t len )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
120 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
121
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
122 for ( uint8_t byte = 0; byte < len; byte++ )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
123 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
124 // Wait for SPI TxFIFO to have 4 or fewer entries
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
125 while ( !( SPI0_SR & SPI_SR_TFFF ) )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
126 delayMicroseconds(10);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
127
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
128 // Write byte to TxFIFO
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
129 // CS0, CTAR0
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
130 SPI0_PUSHR = ( buffer[ byte ] & 0xff ) | SPI_PUSHR_PCS(1);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
131
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
132 // Indicate transfer has completed
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
133 while ( !( SPI0_SR & SPI_SR_TCF ) );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
134 SPI0_SR |= SPI_SR_TCF;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
135 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
136 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
137
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
138 // Write to a control register
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
139 void LCD_writeControlReg( uint8_t byte )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
140 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
141 // Wait for TxFIFO to be empt
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
142 while ( SPI0_TxFIFO_CNT != 0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
143
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
144 // Set A0 low to enter control register mode
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
145 GPIOC_PCOR |= (1<<7);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
146
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
147 // Write byte to SPI FIFO
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
148 SPI_write( &byte, 1 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
149
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
150 // Wait for TxFIFO to be empty
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
151 while ( SPI0_TxFIFO_CNT != 0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
152
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
153 // Make sure data has transferred
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
154 delayMicroseconds(10); // XXX Adjust if SPI speed changes
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
155
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
156 // Set A0 high to go back to display register mode
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
157 GPIOC_PSOR |= (1<<7);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
158 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
159
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
160 // Write to display register
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
161 // Pages 0-7 normal display
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
162 // Page 8 icon buffer
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
163 void LCD_writeDisplayReg( uint8_t page, uint8_t *buffer, uint8_t len )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
164 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
165 // Set the register page
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
166 LCD_writeControlReg( 0xB0 | ( 0x0F & page ) );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
167
332
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
168 // Set display start line
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
169 LCD_writeControlReg( 0x40 );
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
170
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
171 // Reset Column Address
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
172 LCD_writeControlReg( 0x10 );
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
173 LCD_writeControlReg( 0x00 );
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
174
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
175 // Write buffer to SPI
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
176 SPI_write( buffer, len );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
177 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
178
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
179 inline void LCD_clearPage( uint8_t page )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
180 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
181 // Set the register page
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
182 LCD_writeControlReg( 0xB0 | ( 0x0F & page ) );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
183
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
184 // Set display start line
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
185 LCD_writeControlReg( 0x40 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
186
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
187 // Reset Column Address
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
188 LCD_writeControlReg( 0x10 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
189 LCD_writeControlReg( 0x00 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
190
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
191 for ( uint8_t page_reg = 0; page_reg < LCD_PAGE_LEN; page_reg++ )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
192 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
193 uint8_t byte = 0;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
194
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
195 // Write buffer to SPI
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
196 SPI_write( &byte, 1 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
197 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
198
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
199 // Wait for TxFIFO to be empty
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
200 while ( SPI0_TxFIFO_CNT != 0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
201 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
202
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
203 // Clear Display
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
204 void LCD_clear()
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
205 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
206 // Setup each page
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
207 for ( uint8_t page = 0; page < LCD_TOTAL_VISIBLE_PAGES; page++ )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
208 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
209 LCD_clearPage( page );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
210 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
211
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
212 // Reset Page, Start Line, and Column Address
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
213 // Page
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
214 LCD_writeControlReg( 0xB0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
215
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
216 // Start Line
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
217 LCD_writeControlReg( 0x40 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
218
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
219 // Reset Column Address
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
220 LCD_writeControlReg( 0x10 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
221 LCD_writeControlReg( 0x00 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
222 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
223
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
224 // Intialize display
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
225 void LCD_initialize()
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
226 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
227 // ADC Select (Normal)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
228 LCD_writeControlReg( 0xA0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
229
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
230 // LCD Off
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
231 LCD_writeControlReg( 0xAE );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
232
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
233 // COM Scan Output Direction
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
234 LCD_writeControlReg( 0xC0 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
235
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
236 // LCD Bias (1/6 bias)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
237 LCD_writeControlReg( 0xA2 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
238
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
239 // Power Supply Operating Mode (Internal Only)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
240 LCD_writeControlReg( 0x2F );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
241
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
242 // Internal Rb/Ra Ratio
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
243 LCD_writeControlReg( 0x26 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
244
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
245 // Reset
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
246 LCD_writeControlReg( 0xE2 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
247
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
248 // Electric volume mode set, and value
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
249 LCD_writeControlReg( 0x81 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
250 LCD_writeControlReg( 0x00 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
251
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
252 // LCD On
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
253 LCD_writeControlReg( 0xAF );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
254
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
255 // Clear Display RAM
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
256 LCD_clear();
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
257 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
258
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
259 // Setup
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
260 inline void LCD_setup()
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
261 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
262 // Register Scan CLI dictionary
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
263 CLI_registerDictionary( lcdCLIDict, lcdCLIDictName );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
264
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
265 // Initialize SPI
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
266 SPI_setup();
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
267
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
268 // Setup Register Control Signal (A0)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
269 // Start in display register mode (1)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
270 GPIOC_PDDR |= (1<<7);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
271 PORTC_PCR7 = PORT_PCR_SRE | PORT_PCR_DSE | PORT_PCR_MUX(1);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
272 GPIOC_PSOR |= (1<<7);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
273
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
274 // Setup LCD Reset pin (RST)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
275 // 0 - Reset, 1 - Normal Operation
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
276 // Start in normal mode (1)
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
277 GPIOC_PDDR |= (1<<8);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
278 PORTC_PCR8 = PORT_PCR_SRE | PORT_PCR_DSE | PORT_PCR_MUX(1);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
279 GPIOC_PSOR |= (1<<8);
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
280
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
281 // Run LCD intialization sequence
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
282 LCD_initialize();
347
136e47478441 UARTConnect enumeration working!
Jacob Alexander <haata@kiibohd.com>
parents: 332
diff changeset
283
353
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
284 // Write default image to LCD
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
285 for ( uint8_t page = 0; page < LCD_TOTAL_VISIBLE_PAGES; page++ )
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
286 LCD_writeDisplayReg( page, (uint8_t*)&STLcdDefaultImage[page * LCD_PAGE_LEN], LCD_PAGE_LEN );
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
287
347
136e47478441 UARTConnect enumeration working!
Jacob Alexander <haata@kiibohd.com>
parents: 332
diff changeset
288 // Setup Backlight
136e47478441 UARTConnect enumeration working!
Jacob Alexander <haata@kiibohd.com>
parents: 332
diff changeset
289 // TODO Expose default settings
351
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
290 SIM_SCGC6 |= SIM_SCGC6_FTM0;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
291 FTM0_CNT = 0; // Reset counter
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
292
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
293 // PWM Period
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
294 // 16-bit maximum
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
295 FTM0_MOD = 0xFFFF;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
296
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
297 // Set FTM to PWM output - Edge Aligned, Low-true pulses
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
298 FTM0_C0SC = 0x24; // MSnB:MSnA = 10, ELSnB:ELSnA = 01
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
299 FTM0_C1SC = 0x24;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
300 FTM0_C2SC = 0x24;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
301
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
302 // Base FTM clock selection (72 MHz system clock)
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
303 // @ 0xFFFF period, 72 MHz / 0xFFFF * 2 = Actual period
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
304 // Higher pre-scalar will use the most power (also look the best)
351
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
305 // Pre-scalar calculations
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
306 // 0 - 72 MHz -> 549 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
307 // 1 - 36 MHz -> 275 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
308 // 2 - 18 MHz -> 137 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
309 // 3 - 9 MHz -> 69 Hz (Slightly visible flicker)
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
310 // 4 - 4 500 kHz -> 34 Hz (Visible flickering)
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
311 // 5 - 2 250 kHz -> 17 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
312 // 6 - 1 125 kHz -> 9 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
313 // 7 - 562 500 Hz -> 4 Hz
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
314 // Using a higher pre-scalar without flicker is possible but FTM0_MOD will need to be reduced
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
315 // Which will reduce the brightness range
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
316
351
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
317 // System clock, /w prescalar setting
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
318 FTM0_SC = FTM_SC_CLKS(1) | FTM_SC_PS( STLcdBacklightPrescalar_define );
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
319
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
320 // Red
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
321 FTM0_C0V = STLcdBacklightRed_define;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
322 PORTC_PCR1 = PORT_PCR_SRE | PORT_PCR_DSE | PORT_PCR_MUX(4);
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
323
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
324 // Green
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
325 FTM0_C1V = STLcdBacklightGreen_define;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
326 PORTC_PCR2 = PORT_PCR_SRE | PORT_PCR_DSE | PORT_PCR_MUX(4);
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
327
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
328 // Blue
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
329 FTM0_C2V = STLcdBacklightBlue_define;
38395a57cf52 Adding 16-bit brightness control to LCD backlight
Jacob Alexander <haata@kiibohd.com>
parents: 347
diff changeset
330 PORTC_PCR3 = PORT_PCR_SRE | PORT_PCR_DSE | PORT_PCR_MUX(4);
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
331 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
332
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
333
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
334 // LCD State processing loop
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
335 inline uint8_t LCD_scan()
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
336 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
337 // NOP - Screen Refresh
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
338 //LCD_writeControlReg( 0xE3 );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
339 return 0;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
340 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
341
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
342
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
343
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
344 // ----- CLI Command Functions -----
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
345
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
346 void cliFunc_lcdInit( char* args )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
347 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
348 LCD_initialize();
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
349 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
350
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
351 void cliFunc_lcdTest( char* args )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
352 {
353
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
353 // Write default image
332
2e0074f75855 Adding example logo to the lcdtest and bmp conversion script.
Jacob Alexander <haata@kiibohd.com>
parents: 331
diff changeset
354 for ( uint8_t page = 0; page < LCD_TOTAL_VISIBLE_PAGES; page++ )
353
c6613db89cbe Adding capability to set default image on LCD
Jacob Alexander <haata@kiibohd.com>
parents: 352
diff changeset
355 LCD_writeDisplayReg( page, (uint8_t *)&STLcdDefaultImage[page * LCD_PAGE_LEN], LCD_PAGE_LEN );
331
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
356 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
357
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
358 void cliFunc_lcdCmd( char* args )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
359 {
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
360 char* curArgs;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
361 char* arg1Ptr;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
362 char* arg2Ptr = args;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
363
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
364 print( NL ); // No \r\n by default after the command is entered
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
365
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
366 curArgs = arg2Ptr; // Use the previous 2nd arg pointer to separate the next arg from the list
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
367 CLI_argumentIsolation( curArgs, &arg1Ptr, &arg2Ptr );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
368
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
369 // No args
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
370 if ( *arg1Ptr == '\0' )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
371 return;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
372
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
373 // SPI Command
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
374 uint8_t cmd = (uint8_t)numToInt( arg1Ptr );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
375
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
376 curArgs = arg2Ptr; // Use the previous 2nd arg pointer to separate the next arg from the list
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
377 CLI_argumentIsolation( curArgs, &arg1Ptr, &arg2Ptr );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
378
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
379 // Single Arg
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
380 if ( *arg1Ptr == '\0' )
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
381 goto cmd;
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
382
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
383 // TODO Deal with a0
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
384 cmd:
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
385 info_msg("Sending - ");
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
386 printHex( cmd );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
387 print( NL );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
388 LCD_writeControlReg( cmd );
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
389 }
9e31d92caf12 Initial STLcd code.
Jacob Alexander <haata@kiibohd.com>
parents:
diff changeset
390
352
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
391 void cliFunc_lcdColor( char* args )
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
392 {
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
393 char* curArgs;
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
394 char* arg1Ptr;
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
395 char* arg2Ptr = args;
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
396
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
397 // Colors
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
398 uint16_t rgb[3]; // Red, Green, Blue
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
399
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
400 // Parse integers from 3 arguments
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
401 for ( uint8_t color = 0; color < 3; color++ )
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
402 {
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
403 curArgs = arg2Ptr;
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
404 CLI_argumentIsolation( curArgs, &arg1Ptr, &arg2Ptr );
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
405
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
406 // Give up if not enough args given
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
407 if ( *arg1Ptr == '\0' )
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
408 return;
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
409
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
410 // Convert argument to integer
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
411 rgb[ color ] = numToInt( arg1Ptr );
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
412 }
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
413
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
414 // Set PWM channels
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
415 FTM0_C0V = rgb[0];
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
416 FTM0_C1V = rgb[1];
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
417 FTM0_C2V = rgb[2];
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
418 }
99b567a3b1f2 Adding cli API call to set LCD backlight brightness (16 bit per channel)
Jacob Alexander <haata@kiibohd.com>
parents: 351
diff changeset
419