mirror of
				https://github.com/digistump/DigistumpArduino.git
				synced 2025-11-03 13:04:48 -08:00 
			
		
		
		
	switch to setup for Arduino Boards Manager
This commit is contained in:
		
							
								
								
									
										7
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_ARM.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_ARM.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,7 @@
 | 
			
		||||
void UTFT::_convert_float(char *buf, double num, int width, byte prec)
 | 
			
		||||
{
 | 
			
		||||
	char format[10];
 | 
			
		||||
	
 | 
			
		||||
	sprintf(format, "%%%i.%if", width, prec);
 | 
			
		||||
	sprintf(buf, format, num);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										26
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_ARM_defines.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_ARM_defines.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,26 @@
 | 
			
		||||
// CTE TFT LCD/SD Shield for Arduino Due
 | 
			
		||||
// -------------------------------------
 | 
			
		||||
// Uncomment the following line if you are using this shield
 | 
			
		||||
//#define CTE_DUE_SHIELD 1
 | 
			
		||||
//
 | 
			
		||||
// For this shield: RS=25, WR=26, CS=27, RST=28
 | 
			
		||||
//********************************************************************
 | 
			
		||||
 | 
			
		||||
// *** Hardwarespecific defines ***
 | 
			
		||||
#define cbi(reg, bitmask) *reg &= ~bitmask
 | 
			
		||||
#define sbi(reg, bitmask) *reg |= bitmask
 | 
			
		||||
#define pulse_high(reg, bitmask) sbi(reg, bitmask); cbi(reg, bitmask);
 | 
			
		||||
#define pulse_low(reg, bitmask) cbi(reg, bitmask); sbi(reg, bitmask);
 | 
			
		||||
 | 
			
		||||
#define cport(port, data) port &= data
 | 
			
		||||
#define sport(port, data) port |= data
 | 
			
		||||
 | 
			
		||||
#define swap(type, i, j) {type t = i; i = j; j = t;}
 | 
			
		||||
 | 
			
		||||
#define fontbyte(x) cfont.font[x]  
 | 
			
		||||
 | 
			
		||||
#define pgm_read_word(data) *data
 | 
			
		||||
#define pgm_read_byte(data) *data
 | 
			
		||||
#define regtype volatile uint32_t
 | 
			
		||||
#define regsize uint32_t
 | 
			
		||||
#define bitmapdatatype unsigned short*
 | 
			
		||||
							
								
								
									
										338
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_SAM3X8E.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										338
									
								
								digistump-sam/libraries/UTFT/hardware/arm/HW_SAM3X8E.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,338 @@
 | 
			
		||||
// *** Hardwarespecific functions ***
 | 
			
		||||
void UTFT::_hw_special_init()
 | 
			
		||||
{
 | 
			
		||||
	//REG_PIOA_OWER = 0xFFFFFFFF;
 | 
			
		||||
	//REG_PIOB_OWER = 0xFFFFFFFF;
 | 
			
		||||
	//REG_PIOC_OWER = 0xFFFFFFFF;  
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
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:
 | 
			
		||||
#ifdef CTE_DUE_SHIELD
 | 
			
		||||
		REG_PIOC_CODR=0xFF000;
 | 
			
		||||
		REG_PIOC_SODR=(VH<<12) & 0xFF000;
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		REG_PIOC_CODR=0xFF000;
 | 
			
		||||
		REG_PIOC_SODR=(VL<<12) & 0xFF000;
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
#else
 | 
			
		||||
		//Clear port registers
 | 
			
		||||
		REG_PIOA_CODR=0xc000; //PA14,PA15
 | 
			
		||||
		REG_PIOB_CODR=0x4000000; //PB26
 | 
			
		||||
		REG_PIOD_CODR=0x64f; //PD0-3,PD6,PD9-10
 | 
			
		||||
 | 
			
		||||
		//DB08 on PIN22 -> PIO_PB26
 | 
			
		||||
		REG_PIOB_SODR=(VH<<26) & 0x4000000;
 | 
			
		||||
		//DB09 on PIN23 -> PIO_PA14
 | 
			
		||||
		REG_PIOA_SODR=(VH<<13) & 0x4000;
 | 
			
		||||
		//DB10 on PIN24 -> PIO_PA15
 | 
			
		||||
		REG_PIOA_SODR=(VH<<13) & 0x8000;
 | 
			
		||||
		//DB11 on PIN25 -> PIO_PD0
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x01;
 | 
			
		||||
		//DB12 on PIN26 -> PIO_PD1
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x02;
 | 
			
		||||
		//DB13 on PIN27 -> PIO_PD2
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x04;
 | 
			
		||||
		//DB14 on PIN28 -> PIO_PD3
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x08;
 | 
			
		||||
		//DB15 on PIN29 -> PIO_PD6
 | 
			
		||||
		REG_PIOD_SODR=(VH>>1) & 0x40;
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
 | 
			
		||||
		REG_PIOA_CODR=0xc000; //PA14,PA15
 | 
			
		||||
		REG_PIOB_CODR=0x4000000; //PB26
 | 
			
		||||
		REG_PIOD_CODR=0x64f; //PD0-3,PD6,PD9-10
 | 
			
		||||
		//DB08 on PIN22 -> PIO_PB26
 | 
			
		||||
		REG_PIOB_SODR=(VL<<26) & 0x4000000;
 | 
			
		||||
		//DB09 on PIN23 -> PIO_PA14
 | 
			
		||||
		REG_PIOA_SODR=(VL<<13) & 0x4000;
 | 
			
		||||
		//DB10 on PIN24 -> PIO_PA15
 | 
			
		||||
		REG_PIOA_SODR=(VL<<13) & 0x8000;
 | 
			
		||||
		//DB11 on PIN25 -> PIO_PD0
 | 
			
		||||
		REG_PIOD_SODR=(VL>>3) & 0x01;
 | 
			
		||||
		//DB12 on PIN26 -> PIO_PD1
 | 
			
		||||
		REG_PIOD_SODR=(VL>>3) & 0x02;
 | 
			
		||||
		//DB13 on PIN27 -> PIO_PD2
 | 
			
		||||
		REG_PIOD_SODR=(VL>>3) & 0x04;
 | 
			
		||||
		//DB14 on PIN28 -> PIO_PD3
 | 
			
		||||
		REG_PIOD_SODR=(VL>>3) & 0x08;
 | 
			
		||||
		//DB15 on PIN29 -> PIO_PD6
 | 
			
		||||
		REG_PIOD_SODR=(VL>>1) & 0x40;
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
#endif
 | 
			
		||||
		break;
 | 
			
		||||
	case 16:
 | 
			
		||||
#ifdef CTE_DUE_SHIELD
 | 
			
		||||
        REG_PIOC_CODR=0xFF1FE;
 | 
			
		||||
		REG_PIOC_SODR=(VL<<1) & 0x1FE;
 | 
			
		||||
		REG_PIOC_SODR=(VH<<12) & 0xFF000;
 | 
			
		||||
#else
 | 
			
		||||
		//Clear port registers
 | 
			
		||||
		REG_PIOA_CODR=0xc080; //PA7,PA14,PA15
 | 
			
		||||
		REG_PIOB_CODR=0x4000000; //PB26
 | 
			
		||||
		REG_PIOC_CODR=0x3e; //PC1 - PC5
 | 
			
		||||
		REG_PIOD_CODR=0x64f; //PD0-3,PD6,PD9-10
 | 
			
		||||
                
 | 
			
		||||
		//DB00 on PIN37 -> PIO_PC5
 | 
			
		||||
		REG_PIOC_SODR=(VL<<5) & 0x20;
 | 
			
		||||
		//DB01 on PIN36 -> PIO_PC4
 | 
			
		||||
		REG_PIOC_SODR=(VL<<3) & 0x10;
 | 
			
		||||
		//DB02 on PIN35 -> PIO_PC3
 | 
			
		||||
		REG_PIOC_SODR=(VL<<1) & 0x08;
 | 
			
		||||
		//DB03 on PIN34 -> PIO_PC2
 | 
			
		||||
		REG_PIOC_SODR=(VL>>1) & 0x04;
 | 
			
		||||
		//DB04 on PIN33 -> PIO_PC1
 | 
			
		||||
		REG_PIOC_SODR=(VL>>3) & 0x02;
 | 
			
		||||
		//DB05 on PIN32 -> PIO_PD10
 | 
			
		||||
		REG_PIOD_SODR=(VL<<5) & 0x400;
 | 
			
		||||
		//DB06 on PIN31 -> PIO_PA7
 | 
			
		||||
		REG_PIOA_SODR=(VL<<1) & 0x80;
 | 
			
		||||
		//DB07 on PIN30 -> PIO_PD9
 | 
			
		||||
		REG_PIOD_SODR=(VL<<2) & 0x200;
 | 
			
		||||
		//DB08 on PIN22 -> PIO_PB26
 | 
			
		||||
		REG_PIOB_SODR=(VH<<26) & 0x4000000;
 | 
			
		||||
		//DB09 on PIN23 -> PIO_PA14
 | 
			
		||||
		REG_PIOA_SODR=(VH<<13) & 0x4000;
 | 
			
		||||
		//DB10 on PIN24 -> PIO_PA15
 | 
			
		||||
		REG_PIOA_SODR=(VH<<13) & 0x8000;
 | 
			
		||||
		//DB11 on PIN25 -> PIO_PD0
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x01;
 | 
			
		||||
		//DB12 on PIN26 -> PIO_PD1
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x02;
 | 
			
		||||
		//DB13 on PIN27 -> PIO_PD2
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x04;
 | 
			
		||||
		//DB14 on PIN28 -> PIO_PD3
 | 
			
		||||
		REG_PIOD_SODR=(VH>>3) & 0x08;
 | 
			
		||||
		//DB15 on PIN29 -> PIO_PD6
 | 
			
		||||
		REG_PIOD_SODR=(VH>>1) & 0x40;
 | 
			
		||||
#endif
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		break;
 | 
			
		||||
	case LATCHED_16:
 | 
			
		||||
		asm("nop");		// Mode is unsupported
 | 
			
		||||
		break;
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void UTFT::_set_direction_registers(byte mode)
 | 
			
		||||
{
 | 
			
		||||
	if (mode!=LATCHED_16)
 | 
			
		||||
	{
 | 
			
		||||
#ifdef CTE_DUE_SHIELD
 | 
			
		||||
		if (mode==16)
 | 
			
		||||
		{
 | 
			
		||||
			REG_PIOC_OER=0x000FF1FE;
 | 
			
		||||
		}
 | 
			
		||||
		else
 | 
			
		||||
			REG_PIOC_OER=0x000FF000;
 | 
			
		||||
#else
 | 
			
		||||
		REG_PIOA_OER=0x0000c000; //PA14,PA15 enable
 | 
			
		||||
		REG_PIOB_OER=0x04000000; //PB26 enable
 | 
			
		||||
		REG_PIOD_OER=0x0000064f; //PD0-3,PD6,PD9-10 enable
 | 
			
		||||
		if (mode==16)
 | 
			
		||||
		{
 | 
			
		||||
			REG_PIOA_OER=0x00000080; //PA7 enable
 | 
			
		||||
			REG_PIOC_OER=0x0000003e; //PC1 - PC5 enable
 | 
			
		||||
		}
 | 
			
		||||
#endif
 | 
			
		||||
	}
 | 
			
		||||
	else
 | 
			
		||||
	{
 | 
			
		||||
		asm("nop");		// Mode is unsupported
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void UTFT::_fast_fill_16(int ch, int cl, long pix)
 | 
			
		||||
{
 | 
			
		||||
	long blocks;
 | 
			
		||||
 | 
			
		||||
#ifdef CTE_DUE_SHIELD
 | 
			
		||||
    REG_PIOC_CODR=0xFF1FE;
 | 
			
		||||
	REG_PIOC_SODR=(cl<<1) & 0x1FE;
 | 
			
		||||
	REG_PIOC_SODR=(ch<<12) & 0xFF000;
 | 
			
		||||
#else
 | 
			
		||||
	//Clear port registers
 | 
			
		||||
	REG_PIOA_CODR=0xc080; //PA7,PA14,PA15
 | 
			
		||||
	REG_PIOB_CODR=0x4000000; //PB26
 | 
			
		||||
	REG_PIOC_CODR=0x3e; //PC1 - PC5
 | 
			
		||||
	REG_PIOD_CODR=0x64f; //PD0-3,PD6,PD9-10
 | 
			
		||||
                
 | 
			
		||||
	//DB00 on PIN37 -> PIO_PC5
 | 
			
		||||
	REG_PIOC_SODR=(cl<<5) & 0x20;
 | 
			
		||||
	//DB01 on PIN36 -> PIO_PC4
 | 
			
		||||
	REG_PIOC_SODR=(cl<<3) & 0x10;
 | 
			
		||||
	//DB02 on PIN35 -> PIO_PC3
 | 
			
		||||
	REG_PIOC_SODR=(cl<<1) & 0x08;
 | 
			
		||||
	//DB03 on PIN34 -> PIO_PC2
 | 
			
		||||
	REG_PIOC_SODR=(cl>>1) & 0x04;
 | 
			
		||||
	//DB04 on PIN33 -> PIO_PC1
 | 
			
		||||
	REG_PIOC_SODR=(cl>>3) & 0x02;
 | 
			
		||||
	//DB05 on PIN32 -> PIO_PD10
 | 
			
		||||
	REG_PIOD_SODR=(cl<<5) & 0x400;
 | 
			
		||||
	//DB06 on PIN31 -> PIO_PA7
 | 
			
		||||
	REG_PIOA_SODR=(cl<<1) & 0x80;
 | 
			
		||||
	//DB07 on PIN30 -> PIO_PD9
 | 
			
		||||
	REG_PIOD_SODR=(cl<<2) & 0x200;
 | 
			
		||||
	//DB08 on PIN22 -> PIO_PB26
 | 
			
		||||
	REG_PIOB_SODR=(ch<<26) & 0x4000000;
 | 
			
		||||
	//DB09 on PIN23 -> PIO_PA14
 | 
			
		||||
	REG_PIOA_SODR=(ch<<13) & 0x4000;
 | 
			
		||||
	//DB10 on PIN24 -> PIO_PA15
 | 
			
		||||
	REG_PIOA_SODR=(ch<<13) & 0x8000;
 | 
			
		||||
	//DB11 on PIN25 -> PIO_PD0
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x01;
 | 
			
		||||
	//DB12 on PIN26 -> PIO_PD1
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x02;
 | 
			
		||||
	//DB13 on PIN27 -> PIO_PD2
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x04;
 | 
			
		||||
	//DB14 on PIN28 -> PIO_PD3
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x08;
 | 
			
		||||
	//DB15 on PIN29 -> PIO_PD6
 | 
			
		||||
	REG_PIOD_SODR=(ch>>1) & 0x40;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	blocks = pix/16;
 | 
			
		||||
	for (int i=0; i<blocks; i++)
 | 
			
		||||
	{
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);
 | 
			
		||||
	}
 | 
			
		||||
	if ((pix % 16) != 0)
 | 
			
		||||
		for (int i=0; i<(pix % 16)+1; i++)
 | 
			
		||||
		{
 | 
			
		||||
			pulse_low(P_WR, B_WR);
 | 
			
		||||
		}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void UTFT::_fast_fill_8(int ch, long pix)
 | 
			
		||||
{
 | 
			
		||||
	long blocks;
 | 
			
		||||
 | 
			
		||||
#ifdef CTE_DUE_SHIELD
 | 
			
		||||
    REG_PIOC_CODR=0xFF000;
 | 
			
		||||
	REG_PIOC_SODR=(ch<<12) & 0xFF000;
 | 
			
		||||
#else
 | 
			
		||||
	//Clear port registers
 | 
			
		||||
	REG_PIOA_CODR=0xc000; //PA14,PA15
 | 
			
		||||
	REG_PIOB_CODR=0x4000000; //PB26
 | 
			
		||||
	REG_PIOD_CODR=0x64f; //PD0-3,PD6,PD9-10
 | 
			
		||||
 | 
			
		||||
	//DB08 on PIN22 -> PIO_PB26
 | 
			
		||||
	REG_PIOB_SODR=(ch<<26) & 0x4000000;
 | 
			
		||||
	//DB09 on PIN23 -> PIO_PA14
 | 
			
		||||
	REG_PIOA_SODR=(ch<<13) & 0x4000;
 | 
			
		||||
	//DB10 on PIN24 -> PIO_PA15
 | 
			
		||||
	REG_PIOA_SODR=(ch<<13) & 0x8000;
 | 
			
		||||
	//DB11 on PIN25 -> PIO_PD0
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x01;
 | 
			
		||||
	//DB12 on PIN26 -> PIO_PD1
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x02;
 | 
			
		||||
	//DB13 on PIN27 -> PIO_PD2
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x04;
 | 
			
		||||
	//DB14 on PIN28 -> PIO_PD3
 | 
			
		||||
	REG_PIOD_SODR=(ch>>3) & 0x08;
 | 
			
		||||
	//DB15 on PIN29 -> PIO_PD6
 | 
			
		||||
	REG_PIOD_SODR=(ch>>1) & 0x40;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	blocks = pix/16;
 | 
			
		||||
	for (int i=0; i<blocks; i++)
 | 
			
		||||
	{
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
	}
 | 
			
		||||
	if ((pix % 16) != 0)
 | 
			
		||||
		for (int i=0; i<(pix % 16)+1; i++)
 | 
			
		||||
		{
 | 
			
		||||
			pulse_low(P_WR, B_WR);pulse_low(P_WR, B_WR);
 | 
			
		||||
		}
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user