// *** Hardwarespecific functions *** void UTFT::_hw_special_init() { } void UTFT::LCD_Writ_Bus(char VH,char VL, byte mode) { switch (mode) { case 1: if (display_serial_mode==SERIAL_4PIN) { if (VH==1) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); } else { if (VH==1) sbi(P_RS, B_RS); else cbi(P_RS, B_RS); } if (VL & 0x80) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x40) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x20) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x10) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x08) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x04) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x02) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); if (VL & 0x01) sbi(P_SDA, B_SDA); else cbi(P_SDA, B_SDA); pulse_low(P_SCL, B_SCL); break; case 8: cport(PORTC, 0xBF); cport(PORTD, 0x60); cport(PORTE, 0xBF); PORTC += ((VH & 0x20)<<1); PORTD += ((VH & 0x40)<<1) + (VH & 0x10) + ((VH & 0x08)>>3) + ((VH & 0x04)>>1) + ((VH & 0x03)<<2); PORTE += ((VH & 0x80)>>1); pulse_low(P_WR, B_WR); cport(PORTC, 0xBF); cport(PORTD, 0x60); cport(PORTE, 0xBF); PORTC += ((VL & 0x20)<<1); PORTD += ((VL & 0x40)<<1) + (VL & 0x10) + ((VL & 0x08)>>3) + ((VL & 0x04)>>1) + ((VL & 0x03)<<2); PORTE += ((VL & 0x80)>>1); pulse_low(P_WR, B_WR); break; case 16: cport(PORTB, 0x0F); cport(PORTC, 0x3F); cport(PORTD, 0x20); cport(PORTE, 0xBF); cport(PORTF, 0x3F); PORTB |= ((VL & 0x0F)<<4); PORTC |= ((VL & 0x20)<<2) + ((VH & 0x20)<<1); PORTD |= ((VH & 0x40)<<1) + (VH & 0x10) + ((VH & 0x08)>>3) + ((VH & 0x04)>>1) + ((VH & 0x03)<<2) + ((VL & 0x10)<<2); PORTE |= ((VH & 0x80)>>1); PORTF |= ((VL & 0x80)>>1) + ((VL & 0x40)<<1); pulse_low(P_WR, B_WR); break; case LATCHED_16: cport(PORTC, 0xBF); cport(PORTD, 0x60); cport(PORTE, 0xBF); PORTC += ((VH & 0x20)<<1); PORTD += ((VH & 0x40)<<1) + (VH & 0x10) + ((VH & 0x08)>>3) + ((VH & 0x04)>>1) + ((VH & 0x03)<<2); PORTE += ((VH & 0x80)>>1); cbi(P_ALE, B_ALE); pulse_high(P_ALE, B_ALE); cbi(P_CS, B_CS); cport(PORTC, 0xBF); cport(PORTD, 0x60); cport(PORTE, 0xBF); PORTC += ((VL & 0x20)<<1); PORTD += ((VL & 0x40)<<1) + (VL & 0x10) + ((VL & 0x08)>>3) + ((VL & 0x04)>>1) + ((VL & 0x03)<<2); PORTE += ((VL & 0x80)>>1); pulse_low(P_WR, B_WR); sbi(P_CS, B_CS); break; } } void UTFT::_set_direction_registers(byte mode) { switch (mode) { case 8: case LATCHED_16: DDRC |= 0x40; DDRD |= 0x9F; DDRE |= 0x40; break; case 16: DDRB |= 0xF0; DDRC |= 0xC0; DDRD |= 0xDF; DDRE |= 0x40; DDRF |= 0xC0; break; } } void UTFT::_fast_fill_16(int ch, int cl, long pix) { long blocks; cport(PORTB, 0x0F); cport(PORTC, 0x3F); cport(PORTD, 0x20); cport(PORTE, 0xBF); cport(PORTF, 0x3F); PORTB |= ((cl & 0x0F)<<4); PORTC |= ((cl & 0x20)<<2) + ((ch & 0x20)<<1); PORTD |= ((ch & 0x40)<<1) + (ch & 0x10) + ((ch & 0x08)>>3) + ((ch & 0x04)>>1) + ((ch & 0x03)<<2) + ((cl & 0x10)<<2); PORTE |= ((ch & 0x80)>>1); PORTF |= ((cl & 0x80)>>1) + ((cl & 0x40)<<1); blocks = pix/16; for (int i=0; i>3) + ((ch & 0x04)>>1) + ((ch & 0x03)<<2); PORTE |= ((ch & 0x80)>>1); blocks = pix/16; for (int i=0; i