Problem with comparison.
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.bak |
---|
0,0 → 1,62 |
#include "main.h" |
#define LCD_ENABLE_PIN PIN_E0 //// |
#define LCD_RS_PIN PIN_E1 //// |
#define LCD_RW_PIN PIN_E2 //// |
#define LCD_DATA4 PIN_D4 //// |
#define LCD_DATA5 PIN_D5 //// |
#define LCD_DATA6 PIN_D6 //// |
#define LCD_DATA7 PIN_D7 |
#include <lcd.c> |
#define BEEPER PIN_B5 |
int beep() |
{ |
unsigned int i; |
i=0; |
for(i=0;i<100;i++) |
{ |
output_low(BEEP); |
delay_ms(1); |
output_low(BEEP); |
delay_ms(1); |
} |
} |
void main() |
{ |
int16 i=0; |
setup_adc_ports(NO_ANALOGS|VSS_VDD); |
setup_adc(ADC_CLOCK_DIV_2); |
setup_spi(SPI_SS_DISABLED); |
setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1); |
setup_timer_1(T1_DISABLED); |
setup_timer_2(T2_DISABLED,0,1); |
setup_ccp1(CCP_OFF); |
setup_comparator(NC_NC_NC_NC); // This device COMP currently not supported by the PICWizard |
setup_oscillator(OSC_8MHZ); |
lcd_init(); |
lcd_putc("(c) Kaklik 2013"); |
lcd_gotoxy(3,2); |
lcd_putc("www.mlab.cz"); |
Delay_ms(2000); |
lcd_init(); |
while (TRUE) |
{ |
lcd_gotoxy(1,1); |
printf(lcd_putc,"LCD test"); |
lcd_gotoxy(1,2); |
printf(lcd_putc,"%c %x ",i,i); |
i++; |
beep(); |
Delay_ms(500); |
} |
} |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.c |
---|
0,0 → 1,62 |
#include "main.h" |
#define LCD_ENABLE_PIN PIN_E0 //// |
#define LCD_RS_PIN PIN_E1 //// |
#define LCD_RW_PIN PIN_E2 //// |
#define LCD_DATA4 PIN_D4 //// |
#define LCD_DATA5 PIN_D5 //// |
#define LCD_DATA6 PIN_D6 //// |
#define LCD_DATA7 PIN_D7 |
#include <lcd.c> |
#define BEEPER PIN_B5 |
int beep() |
{ |
unsigned int i; |
i=0; |
for(i=0;i<100;i++) |
{ |
output_low(BEEPER); |
delay_ms(1); |
output_high(BEEPER); |
delay_ms(1); |
} |
} |
void main() |
{ |
int16 i=0; |
setup_adc_ports(NO_ANALOGS|VSS_VDD); |
setup_adc(ADC_CLOCK_DIV_2); |
setup_spi(SPI_SS_DISABLED); |
setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1); |
setup_timer_1(T1_DISABLED); |
setup_timer_2(T2_DISABLED,0,1); |
setup_ccp1(CCP_OFF); |
setup_comparator(NC_NC_NC_NC); // This device COMP currently not supported by the PICWizard |
setup_oscillator(OSC_8MHZ); |
lcd_init(); |
lcd_putc("(c) Kaklik 2013"); |
lcd_gotoxy(3,2); |
lcd_putc("www.mlab.cz"); |
Delay_ms(2000); |
lcd_init(); |
while (TRUE) |
{ |
lcd_gotoxy(1,1); |
printf(lcd_putc,"LCD test"); |
lcd_gotoxy(1,2); |
printf(lcd_putc,"%c %x ",i,i); |
i++; |
beep(); |
Delay_ms(500); |
} |
} |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.cof |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.err |
---|
0,0 → 1,3 |
>>> Warning 208 "main.c" Line 14(5,9): Function not void and does not return a value beep |
Memory usage: ROM=8% RAM=2% - 6% |
0 Errors, 1 Warnings. |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.esym |
---|
0,0 → 1,460 |
D G "__PCM__" 0 64 ""4.106"" |
D G "__DEVICE__" 0 64 "887" |
D G "__DATE__" 0 64 ""27-4-14"" |
D G "__TIME__" 0 64 ""20:11:56"" "Standard Header file for the PIC16F887 device ////////////////" |
d G "PIN_A0" 2 20 "40" |
d G "PIN_A1" 2 21 "41" |
d G "PIN_A2" 2 22 "42" |
d G "PIN_A3" 2 23 "43" |
d G "PIN_A4" 2 24 "44" |
d G "PIN_A5" 2 25 "45" |
d G "PIN_A6" 2 26 "46" |
d G "PIN_A7" 2 27 "47" |
d G "PIN_B0" 2 29 "48" |
d G "PIN_B1" 2 30 "49" |
d G "PIN_B2" 2 31 "50" |
d G "PIN_B3" 2 32 "51" |
d G "PIN_B4" 2 33 "52" |
d G "PIN_B5" 2 34 "53" |
d G "PIN_B6" 2 35 "54" |
d G "PIN_B7" 2 36 "55" |
d G "PIN_C0" 2 38 "56" |
d G "PIN_C1" 2 39 "57" |
d G "PIN_C2" 2 40 "58" |
d G "PIN_C3" 2 41 "59" |
d G "PIN_C4" 2 42 "60" |
d G "PIN_C5" 2 43 "61" |
d G "PIN_C6" 2 44 "62" |
d G "PIN_C7" 2 45 "63" |
d G "PIN_D0" 2 47 "64" |
d G "PIN_D1" 2 48 "65" |
d G "PIN_D2" 2 49 "66" |
d G "PIN_D3" 2 50 "67" |
d G "PIN_D4" 2 51 "68" |
d G "PIN_D5" 2 52 "69" |
d G "PIN_D6" 2 53 "70" |
d G "PIN_D7" 2 54 "71" |
d G "PIN_E0" 2 56 "72" |
d G "PIN_E1" 2 57 "73" |
d G "PIN_E2" 2 58 "74" |
d G "PIN_E3" 2 59 "75" |
d G "FALSE" 2 62 "0" |
d G "TRUE" 2 63 "1" |
d G "BYTE" 2 65 "int8" |
d G "BOOLEAN" 2 66 "int1" |
d G "getc" 2 68 "getch" |
d G "fgetc" 2 69 "getch" |
d G "getchar" 2 70 "getch" |
d G "putc" 2 71 "putchar" |
d G "fputc" 2 72 "putchar" |
d G "fgets" 2 73 "gets" |
d G "fputs" 2 74 "puts" |
d G "WDT_FROM_SLEEP" 2 79 "3" |
d G "WDT_TIMEOUT" 2 80 "11" |
d G "MCLR_FROM_SLEEP" 2 81 "19" |
d G "MCLR_FROM_RUN" 2 82 "27" |
d G "NORMAL_POWER_UP" 2 83 "25" |
d G "BROWNOUT_RESTART" 2 84 "26" |
d G "T0_INTERNAL" 2 91 "0" |
d G "T0_EXT_L_TO_H" 2 92 "32" |
d G "T0_EXT_H_TO_L" 2 93 "48" |
d G "T0_DIV_1" 2 95 "8" |
d G "T0_DIV_2" 2 96 "0" |
d G "T0_DIV_4" 2 97 "1" |
d G "T0_DIV_8" 2 98 "2" |
d G "T0_DIV_16" 2 99 "3" |
d G "T0_DIV_32" 2 100 "4" |
d G "T0_DIV_64" 2 101 "5" |
d G "T0_DIV_128" 2 102 "6" |
d G "T0_DIV_256" 2 103 "7" |
d G "T0_8_BIT" 2 106 "0" |
d G "RTCC_INTERNAL" 2 108 "0" "The following are provided for compatibility" |
d G "RTCC_EXT_L_TO_H" 2 109 "32" "with older compiler versions" |
d G "RTCC_EXT_H_TO_L" 2 110 "48" |
d G "RTCC_DIV_1" 2 111 "8" |
d G "RTCC_DIV_2" 2 112 "0" |
d G "RTCC_DIV_4" 2 113 "1" |
d G "RTCC_DIV_8" 2 114 "2" |
d G "RTCC_DIV_16" 2 115 "3" |
d G "RTCC_DIV_32" 2 116 "4" |
d G "RTCC_DIV_64" 2 117 "5" |
d G "RTCC_DIV_128" 2 118 "6" |
d G "RTCC_DIV_256" 2 119 "7" |
d G "RTCC_8_BIT" 2 120 "0" |
d G "WDT_18MS" 2 132 "8" |
d G "WDT_36MS" 2 133 "9" |
d G "WDT_72MS" 2 134 "10" |
d G "WDT_144MS" 2 135 "11" |
d G "WDT_288MS" 2 136 "12" |
d G "WDT_576MS" 2 137 "13" |
d G "WDT_1152MS" 2 138 "14" |
d G "WDT_2304MS" 2 139 "15" |
d G "WDT_ON" 2 143 "0x4100" |
d G "WDT_OFF" 2 144 "0" |
d G "WDT_DIV_16" 2 145 "0x100" |
d G "WDT_DIV_8" 2 146 "0x300" |
d G "WDT_DIV_4" 2 147 "0x500" |
d G "WDT_DIV_2" 2 148 "0x700" |
d G "WDT_TIMES_1" 2 149 "0x900" "Default" |
d G "WDT_TIMES_2" 2 150 "0xB00" |
d G "WDT_TIMES_4" 2 151 "0xD00" |
d G "WDT_TIMES_8" 2 152 "0xF00" |
d G "WDT_TIMES_16" 2 153 "0x1100" |
d G "WDT_TIMES_32" 2 154 "0x1300" |
d G "WDT_TIMES_64" 2 155 "0x1500" |
d G "WDT_TIMES_128" 2 156 "0x1700" |
d G "T1_DISABLED" 2 162 "0" |
d G "T1_INTERNAL" 2 163 "5" |
d G "T1_EXTERNAL" 2 164 "7" |
d G "T1_EXTERNAL_SYNC" 2 165 "3" |
d G "T1_CLK_OUT" 2 167 "8" |
d G "T1_DIV_BY_1" 2 169 "0" |
d G "T1_DIV_BY_2" 2 170 "0x10" |
d G "T1_DIV_BY_4" 2 171 "0x20" |
d G "T1_DIV_BY_8" 2 172 "0x30" |
d G "T1_GATE" 2 174 "0x40" |
d G "T1_GATE_INVERTED" 2 175 "0xC0" |
d G "T2_DISABLED" 2 180 "0" |
d G "T2_DIV_BY_1" 2 181 "4" |
d G "T2_DIV_BY_4" 2 182 "5" |
d G "T2_DIV_BY_16" 2 183 "6" |
d G "CCP_OFF" 2 189 "0" |
d G "CCP_CAPTURE_FE" 2 190 "4" |
d G "CCP_CAPTURE_RE" 2 191 "5" |
d G "CCP_CAPTURE_DIV_4" 2 192 "6" |
d G "CCP_CAPTURE_DIV_16" 2 193 "7" |
d G "CCP_COMPARE_SET_ON_MATCH" 2 194 "8" |
d G "CCP_COMPARE_CLR_ON_MATCH" 2 195 "9" |
d G "CCP_COMPARE_INT" 2 196 "0xA" |
d G "CCP_COMPARE_RESET_TIMER" 2 197 "0xB" |
d G "CCP_PWM" 2 198 "0xC" |
d G "CCP_PWM_PLUS_1" 2 199 "0x1c" |
d G "CCP_PWM_PLUS_2" 2 200 "0x2c" |
d G "CCP_PWM_PLUS_3" 2 201 "0x3c" |
d G "CCP_PWM_H_H" 2 206 "0x0c" |
d G "CCP_PWM_H_L" 2 207 "0x0d" |
d G "CCP_PWM_L_H" 2 208 "0x0e" |
d G "CCP_PWM_L_L" 2 209 "0x0f" |
d G "CCP_PWM_FULL_BRIDGE" 2 211 "0x40" |
d G "CCP_PWM_FULL_BRIDGE_REV" 2 212 "0xC0" |
d G "CCP_PWM_HALF_BRIDGE" 2 213 "0x80" |
d G "CCP_SHUTDOWN_ON_COMP1" 2 215 "0x100000" |
d G "CCP_SHUTDOWN_ON_COMP2" 2 216 "0x200000" |
d G "CCP_SHUTDOWN_ON_COMP" 2 217 "0x300000" |
d G "CCP_SHUTDOWN_ON_INT0" 2 218 "0x400000" |
d G "CCP_SHUTDOWN_ON_COMP1_INT0" 2 219 "0x500000" |
d G "CCP_SHUTDOWN_ON_COMP2_INT0" 2 220 "0x600000" |
d G "CCP_SHUTDOWN_ON_COMP_INT0" 2 221 "0x700000" |
d G "CCP_SHUTDOWN_AC_L" 2 223 "0x000000" |
d G "CCP_SHUTDOWN_AC_H" 2 224 "0x040000" |
d G "CCP_SHUTDOWN_AC_F" 2 225 "0x080000" |
d G "CCP_SHUTDOWN_BD_L" 2 227 "0x000000" |
d G "CCP_SHUTDOWN_BD_H" 2 228 "0x010000" |
d G "CCP_SHUTDOWN_BD_F" 2 229 "0x020000" |
d G "CCP_SHUTDOWN_RESTART" 2 231 "0x80000000" |
d G "CCP_PULSE_STEERING_A" 2 233 "0x01000000" |
d G "CCP_PULSE_STEERING_B" 2 234 "0x02000000" |
d G "CCP_PULSE_STEERING_C" 2 235 "0x04000000" |
d G "CCP_PULSE_STEERING_D" 2 236 "0x08000000" |
d G "CCP_PULSE_STEERING_SYNC" 2 237 "0x10000000" |
d G "SPI_MASTER" 2 245 "0x20" |
d G "SPI_SLAVE" 2 246 "0x24" |
d G "SPI_L_TO_H" 2 247 "0" |
d G "SPI_H_TO_L" 2 248 "0x10" |
d G "SPI_CLK_DIV_4" 2 249 "0" |
d G "SPI_CLK_DIV_16" 2 250 "1" |
d G "SPI_CLK_DIV_64" 2 251 "2" |
d G "SPI_CLK_T2" 2 252 "3" |
d G "SPI_SS_DISABLED" 2 253 "1" |
d G "SPI_SAMPLE_AT_END" 2 255 "0x8000" |
d G "SPI_XMIT_L_TO_H" 2 256 "0x4000" |
d G "UART_ADDRESS" 2 262 "2" |
d G "UART_DATA" 2 263 "4" |
d G "UART_AUTODETECT" 2 264 "8" |
d G "UART_AUTODETECT_NOWAIT" 2 265 "9" |
d G "UART_WAKEUP_ON_RDA" 2 266 "10" |
d G "UART_SEND_BREAK" 2 267 "13" |
d G "NC_NC_NC_NC" 2 273 "0x00" |
d G "NC_NC" 2 274 "0x00" |
d G "CP1_A0_A3" 2 277 "0x00090080" |
d G "CP1_A1_A3" 2 278 "0x000A0081" |
d G "CP1_B3_A3" 2 279 "0x00880082" |
d G "CP1_B1_A3" 2 280 "0x00280083" |
d G "CP1_A0_VREF" 2 281 "0x00010084" |
d G "CP1_A1_VREF" 2 282 "0x00020085" |
d G "CP1_B3_VREF" 2 283 "0x00800086" |
d G "CP1_B1_VREF" 2 284 "0x00200087" |
d G "CP1_OUT_ON_A4" 2 286 "0x00000020" |
d G "CP1_INVERT" 2 287 "0x00000010" |
d G "CP1_ABSOLUTE_VREF" 2 288 "0x20000000" |
d G "CP2_A0_A2" 2 291 "0x00058000" |
d G "CP2_A1_A2" 2 292 "0x00068100" |
d G "CP2_B3_A2" 2 293 "0x00848200" |
d G "CP2_B1_A2" 2 294 "0x00248300" |
d G "CP2_A0_VREF" 2 295 "0x00018400" |
d G "CP2_A1_VREF" 2 296 "0x00028500" |
d G "CP2_B3_VREF" 2 297 "0x00808600" |
d G "CP2_B1_VREF" 2 298 "0x00208700" |
d G "CP2_OUT_ON_A5" 2 300 "0x00002000" |
d G "CP2_INVERT" 2 301 "0x00001000" |
d G "CP2_ABSOLUTE_VREF" 2 302 "0x10000000" |
d G "CP2_T1_SYNC" 2 305 "0x01000000" |
d G "CP2_T1_GATE" 2 306 "0x02000000" |
d G "VREF_LOW" 2 315 "0xa0" |
d G "VREF_HIGH" 2 316 "0x80" |
d G "OSC_31KHZ" 2 322 "1" |
d G "OSC_125KHZ" 2 323 "0x11" |
d G "OSC_250KHZ" 2 324 "0x21" |
d G "OSC_500KHZ" 2 325 "0x31" |
d G "OSC_1MHZ" 2 326 "0x41" |
d G "OSC_2MHZ" 2 327 "0x51" |
d G "OSC_4MHZ" 2 328 "0x61" |
d G "OSC_8MHZ" 2 329 "0x71" |
d G "OSC_INTRC" 2 330 "1" |
d G "OSC_NORMAL" 2 331 "0" |
d G "OSC_STATE_STABLE" 2 333 "4" |
d G "OSC_31KHZ_STABLE" 2 334 "2" |
d G "ADC_OFF" 2 342 "0" "ADC Off" |
d G "ADC_CLOCK_DIV_2" 2 343 "0x100" |
d G "ADC_CLOCK_DIV_8" 2 344 "0x40" |
d G "ADC_CLOCK_DIV_32" 2 345 "0x80" |
d G "ADC_CLOCK_INTERNAL" 2 346 "0xc0" "Internal 2-6us" |
d G "sAN0" 2 350 "1" "| A0" |
d G "sAN1" 2 351 "2" "| A1" |
d G "sAN2" 2 352 "4" "| A2" |
d G "sAN3" 2 353 "8" "| A3" |
d G "sAN4" 2 354 "16" "| A5" |
d G "sAN5" 2 355 "32" "| E0" |
d G "sAN6" 2 356 "64" "| E1" |
d G "sAN7" 2 357 "128" "| E2" |
d G "sAN8" 2 358 "0x10000" "| B2" |
d G "sAN9" 2 359 "0x20000" "| B3" |
d G "sAN10" 2 360 "0x40000" "| B1" |
d G "sAN11" 2 361 "0x80000" "| B4" |
d G "sAN12" 2 362 "0x100000" "| B0" |
d G "sAN13" 2 363 "0x200000" "| B5" |
d G "NO_ANALOGS" 2 364 "0" "None" |
d G "ALL_ANALOG" 2 365 "0x1F00FF" "A0 A1 A2 A3 A5 E0 E1 E2 B0 B1 B2 B3 B4 B5" |
d G "VSS_VDD" 2 368 "0x0000" "| Range 0-Vdd" |
d G "VSS_VREF" 2 369 "0x1000" "| Range 0-Vref" |
d G "VREF_VREF" 2 370 "0x3000" "| Range Vref-Vref" |
d G "VREF_VDD" 2 371 "0x2000" "| Range Vref-Vdd" |
d G "ADC_START_AND_READ" 2 375 "7" "This is the default if nothing is specified" |
d G "ADC_START_ONLY" 2 376 "1" |
d G "ADC_READ_ONLY" 2 377 "6" |
d G "L_TO_H" 2 389 "0x40" |
d G "H_TO_L" 2 390 "0" |
d G "GLOBAL" 2 392 "0x0BC0" |
d G "INT_RTCC" 2 393 "0x000B20" |
d G "INT_RB" 2 394 "0x01FF0B08" |
d G "INT_EXT_L2H" 2 395 "0x50000B10" |
d G "INT_EXT_H2L" 2 396 "0x60000B10" |
d G "INT_EXT" 2 397 "0x000B10" |
d G "INT_AD" 2 398 "0x008C40" |
d G "INT_TBE" 2 399 "0x008C10" |
d G "INT_RDA" 2 400 "0x008C20" |
d G "INT_TIMER1" 2 401 "0x008C01" |
d G "INT_TIMER2" 2 402 "0x008C02" |
d G "INT_CCP1" 2 403 "0x008C04" |
d G "INT_CCP2" 2 404 "0x008D01" |
d G "INT_SSP" 2 405 "0x008C08" |
d G "INT_BUSCOL" 2 406 "0x008D08" |
d G "INT_EEPROM" 2 407 "0x008D10" |
d G "INT_TIMER0" 2 408 "0x000B20" |
d G "INT_OSC_FAIL" 2 409 "0x008D80" |
d G "INT_COMP" 2 410 "0x008D20" |
d G "INT_COMP2" 2 411 "0x008D40" |
d G "INT_ULPWU" 2 412 "0x008D04" |
d G "INT_RB0" 2 413 "0x0010B08" |
d G "INT_RB1" 2 414 "0x0020B08" |
d G "INT_RB2" 2 415 "0x0040B08" |
d G "INT_RB3" 2 416 "0x0080B08" |
d G "INT_RB4" 2 417 "0x0100B08" |
d G "INT_RB5" 2 418 "0x0200B08" |
d G "INT_RB6" 2 419 "0x0400B08" |
d G "INT_RB7" 2 420 "0x0800B08" |
D G "LCD_ENABLE_PIN" 0 3 "PIN_E0" |
D G "LCD_RS_PIN" 0 4 "PIN_E1" |
D G "LCD_RW_PIN" 0 5 "PIN_E2" |
D G "LCD_DATA4" 0 6 "PIN_D4" |
D G "LCD_DATA5" 0 7 "PIN_D5" |
D G "LCD_DATA6" 0 8 "PIN_D6" |
D G "LCD_DATA7" 0 9 "PIN_D7" |
T G "LCD_PIN_MAP" 3 81 "{int1 enable,int1 rs,int1 rw,int1 unused,int4 data}" "this is to improve compatability with previous LCD drivers that accepted" |
D G "lcd_output_enable" 3 103 "(x) output_bit(LCD_ENABLE_PIN, x)" |
D G "lcd_enable_tris" 3 104 "() output_drive(LCD_ENABLE_PIN)" |
D G "lcd_output_rs" 3 111 "(x) output_bit(LCD_RS_PIN, x)" |
D G "lcd_rs_tris" 3 112 "() output_drive(LCD_RS_PIN)" |
D G "lcd_output_rw" 3 119 "(x) output_bit(LCD_RW_PIN, x)" |
D G "lcd_rw_tris" 3 120 "() output_drive(LCD_RW_PIN)" |
D G "LCD_TYPE" 3 170 "2" "0=5x7, 1=5x10, 2=2 lines" |
D G "LCD_LINE_TWO" 3 174 "0x40" "LCD RAM address for the second line" |
D G "LCD_LINE_LENGTH" 3 178 "20" |
V G "LCD_INIT_STRING" 3 181 "int8[4]" |
C L "lcd_read_nibble" 3 2 2 "FUNCTION" |
F G "lcd_read_nibble" 3 185 "int8()" |
F G "lcd_read_byte" 3 187 "int8()" |
V L "low" 3 189 "int8" |
V L "high" 3 189 "int8" |
F G "lcd_read_nibble" 3 234 "int8()" |
V L "n" 3 237 "int8" |
C L "lcd_read_nibble" 3 2 1 "FUNCTION" |
F G "lcd_send_nibble" 3 251 "void(int8 n)" |
V L "n" 3 251 "int8" |
C L "lcd_send_nibble" 3 2 1 "FUNCTION" |
F G "lcd_send_byte" 3 269 "void(int8 address,int8 n)" |
V L "address" 3 269 "int8" |
V L "n" 3 269 "int8" |
F G "lcd_init" 3 294 "void()" |
V L "i" 3 296 "int8" |
F G "lcd_gotoxy" 3 335 "void(int8 x,int8 y)" |
V L "x" 3 335 "int8" |
V L "y" 3 335 "int8" |
V L "address" 3 337 "int8" |
F G "lcd_putc" 3 353 "void(int8 c)" |
V L "c" 3 353 "int8" |
F G "lcd_getc" 3 396 "int8(int8 x,int8 y)" |
V L "x" 3 396 "int8" |
V L "y" 3 396 "int8" |
V L "value" 3 398 "int8" |
C L "lcd_getc" 3 2 1 "FUNCTION" |
D G "BEEPER" 0 12 "PIN_B5" |
F G "beep" 0 14 "int8()" |
V L "i" 0 16 "int8" |
F G "MAIN" 0 29 "void()" |
V L "i" 0 31 "int16" |
C L "MAIN" 0 40 1 "FUNCTION" |
F B "reset_cpu" 0 0 |
F B "abs" 1 0 |
F B "sleep_ulpwu" 1 0 |
F B "sleep" 0 0 |
F B "delay_cycles" 1 0 |
F B "read_bank" 2 0 |
F B "write_bank" 3 0 |
F B "shift_left" 2 2 |
F B "shift_right" 2 2 |
F B "rotate_left" 2 0 |
F B "rotate_right" 2 0 |
F B "_mul" 2 0 |
F B "memset" 3 0 |
F B "isamoung" 2 0 |
F B "isamong" 2 0 |
F B "bit_set" 2 0 |
F B "bit_clear" 2 0 |
F B "bit_test" 2 0 |
F B "toupper" 1 0 |
F B "tolower" 1 0 |
F B "swap" 1 0 |
F B "printf" 1 255 |
F B "fprintf" 1 255 |
F B "sprintf" 1 255 |
F B "make8" 2 0 |
F B "make16" 2 0 |
F B "make32" 1 255 |
F B "label_address" 1 1 |
F B "goto_address" 1 0 |
F B "_va_arg" 1 0 |
F B "offsetofbit" 2 2 |
F B "enable_interrupts" 1 0 |
F B "disable_interrupts" 1 0 |
F B "interrupt_active" 1 0 |
F B "clear_interrupt" 1 0 |
F B "jump_to_isr" 1 0 |
F B "ext_int_edge" 1 2 |
F B "read_eeprom" 1 0 |
F B "write_eeprom" 2 0 |
F B "read_program_eeprom" 1 0 |
F B "write_program_eeprom" 2 0 |
F B "write_program_memory" 4 0 |
F B "write_program_memory8" 4 0 |
F B "read_program_memory" 4 0 |
F B "read_program_memory8" 4 0 |
F B "erase_program_eeprom" 1 0 |
F B "strcpy" 2 0 |
F B "memcpy" 3 0 |
F B "strstr100" 2 0 |
F B "output_high" 1 0 |
F B "output_low" 1 0 |
F B "input" 1 0 |
F B "input_state" 1 0 |
F B "output_float" 1 0 |
F B "output_drive" 1 0 |
F B "output_bit" 1 1 |
F B "output_toggle" 1 0 |
F B "output_a" 1 0 |
F B "output_b" 1 0 |
F B "output_c" 1 0 |
F B "output_d" 1 0 |
F B "output_e" 1 0 |
F B "input_a" 0 0 |
F B "input_b" 0 0 |
F B "input_c" 0 0 |
F B "input_d" 0 0 |
F B "input_e" 0 0 |
F B "set_tris_a" 1 0 |
F B "set_tris_b" 1 0 |
F B "set_tris_c" 1 0 |
F B "set_tris_d" 1 0 |
F B "set_tris_e" 1 0 |
F B "get_tris_a" 0 0 |
F B "get_tris_b" 0 0 |
F B "get_tris_c" 0 0 |
F B "get_tris_d" 0 0 |
F B "get_tris_e" 0 0 |
F B "input_change_a" 0 0 |
F B "input_change_b" 0 0 |
F B "input_change_c" 0 0 |
F B "input_change_d" 0 0 |
F B "input_change_e" 0 0 |
F B "port_b_pullups" 1 0 |
F B "setup_counters" 2 0 |
F B "setup_wdt" 1 0 |
F B "restart_cause" 0 0 |
F B "restart_wdt" 0 0 |
F B "get_rtcc" 0 0 |
F B "set_rtcc" 1 0 |
F B "get_timer0" 0 0 |
F B "set_timer0" 1 0 |
F B "setup_comparator" 1 0 |
F B "setup_port_a" 1 0 |
F B "setup_adc_ports" 1 0 |
F B "setup_adc" 1 0 |
F B "set_adc_channel" 1 0 |
F B "read_adc" 0 1 |
F B "adc_done" 0 0 |
F B "setup_timer_0" 1 0 |
F B "setup_vref" 1 0 |
F B "setup_timer_1" 1 0 |
F B "get_timer1" 0 0 |
F B "set_timer1" 1 0 |
F B "setup_timer_2" 3 0 |
F B "get_timer2" 0 0 |
F B "set_timer2" 1 0 |
F B "setup_ccp1" 1 2 |
F B "set_pwm1_duty" 1 0 |
F B "setup_ccp2" 1 0 |
F B "set_pwm2_duty" 1 0 |
F B "setup_oscillator" 1 2 |
F B "setup_spi" 1 0 |
F B "spi_read" 0 1 |
F B "spi_write" 1 0 |
F B "spi_data_is_in" 0 0 |
F B "setup_spi2" 1 0 |
F B "spi_read2" 0 1 |
F B "spi_write2" 1 0 |
F B "spi_data_is_in2" 0 0 |
F B "brownout_enable" 1 0 |
F B "delay_ms" 1 0 |
F B "delay_us" 1 0 |
F B "i2c_read" 0 2 |
F B "i2c_write" 1 2 |
F B "i2c_start" 0 2 |
F B "i2c_stop" 0 1 |
F B "i2c_isr_state" 0 1 |
F B "putchar" 1 2 |
F B "puts" 1 2 |
F B "getch" 0 1 |
F B "gets" 1 3 |
F B "kbhit" 0 1 |
F B "set_uart_speed" 1 3 |
F B "setup_uart" 1 3 |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.hex |
---|
0,0 → 1,88 |
:1000000001308A00E52900000A108A100A118207CF |
:1000100028340C3401340634A8312910CB306B3627 |
:10002000E9352019B0183300F73B77176D36613189 |
:10003000AE317A00CC214410F432733A00012730FB |
:10004000840083130008031932280230F800F701F6 |
:10005000F70B2828F80B27289730F700F70B2E28E6 |
:10006000800B252808002E18372808123828081673 |
:10007000831608128312AE183F288812402888166B |
:100080008316881283122E19472808134828081748 |
:10009000831608138312AE194F2888135028881727 |
:1000A0008316881300008312091483160910582838 |
:1000B0005928831209108316091083120800AF0112 |
:1000C0008316081600308312081A0130AF04831615 |
:1000D000881600308312881A0130F7000310F70DDC |
:1000E0007708AF048316081700308312081B01300D |
:1000F000F700F70DF70DFC30F7057708AF0483160E |
:10010000881700308312881B0130F700F70DF70DB8 |
:10011000F70DF830F7057708AF042F08F80008004E |
:10012000831609108910091183128910831689100A |
:1001300008168816081788178312091583160911DF |
:1001400000008312091483160910000083125F2037 |
:100150007808AE00091083160910000083120914F4 |
:1001600083160910B32883125F207808AD000910A8 |
:1001700083160910081288120813881383122E0E92 |
:10018000F700F030F70577082D04F8007808AD0087 |
:10019000AD1FCC2883169828AB08031DD1288910E1 |
:1001A000D22889148316891000008312091183163E |
:1001B00009110000831209108316091083122C0EF6 |
:1001C000AD000F30AD052D08AE0033202C080F39DF |
:1001D000AD00AE0033200800831608128812081301 |
:1001E0008813091089100911831289108316891048 |
:1001F000831209118316091183120910831609103D |
:100200000F308312A7001F200130A3002308033CF6 |
:10021000031C12290330AE0033200530A7001F2035 |
:10022000A30A06290230AE003320A3012308033CB1 |
:10023000031C232923080420A400AB012408AC00DC |
:100240009020A30A16290800280B27292A294030C4 |
:10025000A9002B29A90101302702A9072908803804 |
:10026000AA00AB012A08AC00902008002608073A33 |
:10027000031944290B3A03194929063A031951294C |
:10028000023A031957295C290130A700A80024214C |
:100290006229AB010130AC0090200230A7001F2082 |
:1002A00062290130A7000230A80024216229AB0195 |
:1002B0001030AC00902062290130AB002608AC0061 |
:1002C000902062290800831603178C170C14000075 |
:1002D000000083120C087F390319A7290313A30018 |
:1002E00003170D080313A40003170F080313A50039 |
:1002F0002308A6003621240803178D0003132508C0 |
:1003000003178F0083168C170C1400000000831253 |
:100310000C0D0E0D7F390319A7290313A300031732 |
:100320000D080313A40003170F080313A5002308E7 |
:10033000A6003621240803178D0003132508031790 |
:100340008F008D0A03198F0A031363290317031300 |
:100350000800A41BBB290F30F700230EF7050A3055 |
:1003600077020318B6293030F707B8292408F707B1 |
:100370007708A60036210F30A3050A3023020318A0 |
:10038000C3293030C529A4132408A3072308A600D5 |
:1003900036218A110A128D2AA301A3012308633C86 |
:1003A000031CE22983168612831286120130A700ED |
:1003B0001F2083168612831286160130A7001F2085 |
:1003C000A30ACE298A110A12942A840183131F30AA |
:1003D0008305713083168F000F08031787110C30C7 |
:1003E00003139900A230980090308312980083166E |
:1003F00003170908C039890003131F129F12003028 |
:10040000031788008312870188018901FF300313D5 |
:10041000A000A201A101831603170908C0398900B1 |
:1004200003131F129F120030031788008312031357 |
:100430001F139F1383169F1783121F149412A01269 |
:100440002008831687008312201620088316870051 |
:100450008312A011200883168700013083129400B4 |
:100460000030831694000108C739083881008312D0 |
:1004700090010030F8009200003083169200831241 |
:1004800020152008831687008312970183169B018D |
:100490009C0101309D0083120317870188018901A7 |
:1004A0007130831603138F000F088312EC200C3079 |
:1004B00003178D0000308F00031363210330A70062 |
:1004C0000230A8002421143003178D0000308F0063 |
:1004D000031363210830A300FA30A7001F20A30BE9 |
:1004E0006C2AEC200130A700A80024211A30031741 |
:1004F0008D0000308F00031363210130A70002300C |
:10050000A80024212108A60036212030A60036218B |
:100510002108A3005730A400A9292030A6003621C5 |
:10052000A10A0319A20ACC290230A300FA30A700BD |
:0A0530001F20A30B962A722A630015 |
:04400E00F52CFF3F4F |
:00000001FF |
;PIC16F887 |
;CRC=C148 CREATED="27-4-14 20:11" |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.lst |
---|
0,0 → 1,1053 |
CCS PCM C Compiler, Version 4.106, 47914 27-4-14 20:11 |
Filename: D:\Honza\MLAB\Modules\HumanInterfaces\LCD2L4P02A\SW\PIC\PIC16F887\main.lst |
ROM used: 669 words (8%) |
Largest free fragment is 2048 |
RAM used: 9 (2%) at main() level |
22 (6%) worst case |
Stack: 5 locations |
* |
0000: MOVLW 01 |
0001: MOVWF 0A |
0002: GOTO 1E5 |
0003: NOP |
.................... #include "main.h" |
.................... #include <16F887.h> |
.................... //////// Standard Header file for the PIC16F887 device //////////////// |
.................... #device PIC16F887 |
.................... #list |
.................... |
.................... #device adc=10 |
.................... |
.................... #FUSES NOWDT //No Watch Dog Timer |
.................... #FUSES INTRC //Internal RC Osc |
.................... #FUSES NOPUT //No Power Up Timer |
.................... #FUSES MCLR //Master Clear pin enabled |
.................... #FUSES NOPROTECT //Code not protected from reading |
.................... #FUSES NOCPD //No EE protection |
.................... #FUSES NOBROWNOUT //No brownout reset |
.................... #FUSES IESO //Internal External Switch Over mode enabled |
.................... #FUSES FCMEN //Fail-safe clock monitor enabled |
.................... #FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O |
.................... #FUSES NODEBUG //No Debug mode for ICD |
.................... #FUSES NOWRT //Program memory not write protected |
.................... #FUSES BORV40 //Brownout reset at 4.0V |
.................... |
.................... #use delay(clock=8000000) |
* |
001F: MOVLW 27 |
0020: MOVWF 04 |
0021: BCF 03.7 |
0022: MOVF 00,W |
0023: BTFSC 03.2 |
0024: GOTO 032 |
0025: MOVLW 02 |
0026: MOVWF 78 |
0027: CLRF 77 |
0028: DECFSZ 77,F |
0029: GOTO 028 |
002A: DECFSZ 78,F |
002B: GOTO 027 |
002C: MOVLW 97 |
002D: MOVWF 77 |
002E: DECFSZ 77,F |
002F: GOTO 02E |
0030: DECFSZ 00,F |
0031: GOTO 025 |
0032: RETURN |
.................... #use i2c(master, sda=PIN_C4, scl=PIN_C3) |
.................... #use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8) |
.................... |
.................... |
.................... |
.................... #define LCD_ENABLE_PIN PIN_E0 //// |
.................... #define LCD_RS_PIN PIN_E1 //// |
.................... #define LCD_RW_PIN PIN_E2 //// |
.................... #define LCD_DATA4 PIN_D4 //// |
.................... #define LCD_DATA5 PIN_D5 //// |
.................... #define LCD_DATA6 PIN_D6 //// |
.................... #define LCD_DATA7 PIN_D7 |
.................... #include <lcd.c> |
.................... /////////////////////////////////////////////////////////////////////////////// |
.................... //// LCD.C //// |
.................... //// Driver for common LCD modules //// |
.................... //// //// |
.................... //// lcd_init() Must be called before any other function. //// |
.................... //// //// |
.................... //// lcd_putc(c) Will display c on the next position of the LCD. //// |
.................... //// \a Set cursor position to upper left //// |
.................... //// \f Clear display, set cursor to upper left //// |
.................... //// \n Go to start of second line //// |
.................... //// \b Move back one position //// |
.................... //// If LCD_EXTENDED_NEWLINE is defined, the \n character //// |
.................... //// will erase all remanining characters on the current //// |
.................... //// line, and move the cursor to the beginning of the next //// |
.................... //// line. //// |
.................... //// If LCD_EXTENDED_NEWLINE is defined, the \r character //// |
.................... //// will move the cursor to the start of the current //// |
.................... //// line. //// |
.................... //// //// |
.................... //// lcd_gotoxy(x,y) Set write position on LCD (upper left is 1,1) //// |
.................... //// //// |
.................... //// lcd_getc(x,y) Returns character at position x,y on LCD //// |
.................... //// //// |
.................... //// CONFIGURATION //// |
.................... //// The LCD can be configured in one of two ways: a.) port access or //// |
.................... //// b.) pin access. Port access requires the entire 7 bit interface //// |
.................... //// connected to one GPIO port, and the data bits (D4:D7 of the LCD) //// |
.................... //// connected to sequential pins on the GPIO. Pin access //// |
.................... //// has no requirements, all 7 bits of the control interface can //// |
.................... //// can be connected to any GPIO using several ports. //// |
.................... //// //// |
.................... //// To use port access, #define LCD_DATA_PORT to the SFR location of //// |
.................... //// of the GPIO port that holds the interface, -AND- edit LCD_PIN_MAP //// |
.................... //// of this file to configure the pin order. If you are using a //// |
.................... //// baseline PIC (PCB), then LCD_OUTPUT_MAP and LCD_INPUT_MAP also must //// |
.................... //// be defined. //// |
.................... //// //// |
.................... //// Example of port access: //// |
.................... //// #define LCD_DATA_PORT getenv("SFR:PORTD") //// |
.................... //// //// |
.................... //// To use pin access, the following pins must be defined: //// |
.................... //// LCD_ENABLE_PIN //// |
.................... //// LCD_RS_PIN //// |
.................... //// LCD_RW_PIN //// |
.................... //// LCD_DATA4 //// |
.................... //// LCD_DATA5 //// |
.................... //// LCD_DATA6 //// |
.................... //// LCD_DATA7 //// |
.................... //// //// |
.................... //// Example of pin access: //// |
.................... //// #define LCD_ENABLE_PIN PIN_E0 //// |
.................... //// #define LCD_RS_PIN PIN_E1 //// |
.................... //// #define LCD_RW_PIN PIN_E2 //// |
.................... //// #define LCD_DATA4 PIN_D4 //// |
.................... //// #define LCD_DATA5 PIN_D5 //// |
.................... //// #define LCD_DATA6 PIN_D6 //// |
.................... //// #define LCD_DATA7 PIN_D7 //// |
.................... //// //// |
.................... /////////////////////////////////////////////////////////////////////////////// |
.................... //// (C) Copyright 1996,2010 Custom Computer Services //// |
.................... //// This source code may only be used by licensed users of the CCS C //// |
.................... //// compiler. This source code may only be distributed to other //// |
.................... //// licensed users of the CCS C compiler. No other use, reproduction //// |
.................... //// or distribution is permitted without written permission. //// |
.................... //// Derivative programs created using this software in object code //// |
.................... //// form are not restricted in any way. //// |
.................... /////////////////////////////////////////////////////////////////////////// |
.................... |
.................... // define the pinout. |
.................... // only required if port access is being used. |
.................... typedef struct |
.................... { // This structure is overlayed |
.................... BOOLEAN enable; // on to an I/O port to gain |
.................... BOOLEAN rs; // access to the LCD pins. |
.................... BOOLEAN rw; // The bits are allocated from |
.................... BOOLEAN unused; // low order up. ENABLE will |
.................... int data : 4; // be LSB pin of that port. |
.................... #if defined(__PCD__) // The port used will be LCD_DATA_PORT. |
.................... int reserved: 8; |
.................... #endif |
.................... } LCD_PIN_MAP; |
.................... |
.................... // this is to improve compatability with previous LCD drivers that accepted |
.................... // a define labeled 'use_portb_lcd' that configured the LCD onto port B. |
.................... #if ((defined(use_portb_lcd)) && (use_portb_lcd==TRUE)) |
.................... #define LCD_DATA_PORT getenv("SFR:PORTB") |
.................... #endif |
.................... |
.................... #if defined(__PCB__) |
.................... // these definitions only need to be modified for baseline PICs. |
.................... // all other PICs use LCD_PIN_MAP or individual LCD_xxx pin definitions. |
.................... /* EN, RS, RW, UNUSED, DATA */ |
.................... const LCD_PIN_MAP LCD_OUTPUT_MAP = {0, 0, 0, 0, 0}; |
.................... const LCD_PIN_MAP LCD_INPUT_MAP = {0, 0, 0, 0, 0xF}; |
.................... #endif |
.................... |
.................... ////////////////////// END CONFIGURATION /////////////////////////////////// |
.................... |
.................... #ifndef LCD_ENABLE_PIN |
.................... #define lcd_output_enable(x) lcdlat.enable=x |
.................... #define lcd_enable_tris() lcdtris.enable=0 |
.................... #else |
.................... #define lcd_output_enable(x) output_bit(LCD_ENABLE_PIN, x) |
.................... #define lcd_enable_tris() output_drive(LCD_ENABLE_PIN) |
.................... #endif |
.................... |
.................... #ifndef LCD_RS_PIN |
.................... #define lcd_output_rs(x) lcdlat.rs=x |
.................... #define lcd_rs_tris() lcdtris.rs=0 |
.................... #else |
.................... #define lcd_output_rs(x) output_bit(LCD_RS_PIN, x) |
.................... #define lcd_rs_tris() output_drive(LCD_RS_PIN) |
.................... #endif |
.................... |
.................... #ifndef LCD_RW_PIN |
.................... #define lcd_output_rw(x) lcdlat.rw=x |
.................... #define lcd_rw_tris() lcdtris.rw=0 |
.................... #else |
.................... #define lcd_output_rw(x) output_bit(LCD_RW_PIN, x) |
.................... #define lcd_rw_tris() output_drive(LCD_RW_PIN) |
.................... #endif |
.................... |
.................... // original version of this library incorrectly labeled LCD_DATA0 as LCD_DATA4, |
.................... // LCD_DATA1 as LCD_DATA5, and so on. this block of code makes the driver |
.................... // compatible with any code written for the original library |
.................... #if (defined(LCD_DATA0) && defined(LCD_DATA1) && defined(LCD_DATA2) && defined(LCD_DATA3) && !defined(LCD_DATA4) && !defined(LCD_DATA5) && !defined(LCD_DATA6) && !defined(LCD_DATA7)) |
.................... #define LCD_DATA4 LCD_DATA0 |
.................... #define LCD_DATA5 LCD_DATA1 |
.................... #define LCD_DATA6 LCD_DATA2 |
.................... #define LCD_DATA7 LCD_DATA3 |
.................... #endif |
.................... |
.................... #ifndef LCD_DATA4 |
.................... #ifndef LCD_DATA_PORT |
.................... #if defined(__PCB__) |
.................... #define LCD_DATA_PORT 0x06 //portb |
.................... #define set_tris_lcd(x) set_tris_b(x) |
.................... #else |
.................... #if defined(PIN_D0) |
.................... #define LCD_DATA_PORT getenv("SFR:PORTD") //portd |
.................... #else |
.................... #define LCD_DATA_PORT getenv("SFR:PORTB") //portb |
.................... #endif |
.................... #endif |
.................... #endif |
.................... |
.................... #if defined(__PCB__) |
.................... LCD_PIN_MAP lcd, lcdlat; |
.................... #byte lcd = LCD_DATA_PORT |
.................... #byte lcdlat = LCD_DATA_PORT |
.................... #elif defined(__PCM__) |
.................... LCD_PIN_MAP lcd, lcdlat, lcdtris; |
.................... #byte lcd = LCD_DATA_PORT |
.................... #byte lcdlat = LCD_DATA_PORT |
.................... #byte lcdtris = LCD_DATA_PORT+0x80 |
.................... #elif defined(__PCH__) |
.................... LCD_PIN_MAP lcd, lcdlat, lcdtris; |
.................... #byte lcd = LCD_DATA_PORT |
.................... #byte lcdlat = LCD_DATA_PORT+9 |
.................... #byte lcdtris = LCD_DATA_PORT+0x12 |
.................... #elif defined(__PCD__) |
.................... LCD_PIN_MAP lcd, lcdlat, lcdtris; |
.................... #word lcd = LCD_DATA_PORT |
.................... #word lcdlat = LCD_DATA_PORT+2 |
.................... #word lcdtris = LCD_DATA_PORT-0x02 |
.................... #endif |
.................... #endif //LCD_DATA4 not defined |
.................... |
.................... #ifndef LCD_TYPE |
.................... #define LCD_TYPE 2 // 0=5x7, 1=5x10, 2=2 lines |
.................... #endif |
.................... |
.................... #ifndef LCD_LINE_TWO |
.................... #define LCD_LINE_TWO 0x40 // LCD RAM address for the second line |
.................... #endif |
.................... |
.................... #ifndef LCD_LINE_LENGTH |
.................... #define LCD_LINE_LENGTH 20 |
.................... #endif |
.................... |
.................... BYTE const LCD_INIT_STRING[4] = {0x20 | (LCD_TYPE << 2), 0xc, 1, 6}; |
.................... // These bytes need to be sent to the LCD |
.................... // to start it up. |
.................... |
.................... BYTE lcd_read_nibble(void); |
.................... |
.................... BYTE lcd_read_byte(void) |
.................... { |
.................... BYTE low,high; |
.................... |
.................... #if defined(__PCB__) |
.................... set_tris_lcd(LCD_INPUT_MAP); |
.................... #else |
.................... #if (defined(LCD_DATA4) && defined(LCD_DATA5) && defined(LCD_DATA6) && defined(LCD_DATA7)) |
.................... output_float(LCD_DATA4); |
* |
0098: BSF 08.4 |
.................... output_float(LCD_DATA5); |
0099: BSF 08.5 |
.................... output_float(LCD_DATA6); |
009A: BSF 08.6 |
.................... output_float(LCD_DATA7); |
009B: BSF 08.7 |
.................... #else |
.................... lcdtris.data = 0xF; |
.................... #endif |
.................... #endif |
.................... |
.................... lcd_output_rw(1); |
009C: BCF 03.5 |
009D: BSF 09.2 |
009E: BSF 03.5 |
009F: BCF 09.2 |
.................... delay_cycles(1); |
00A0: NOP |
.................... lcd_output_enable(1); |
00A1: BCF 03.5 |
00A2: BSF 09.0 |
00A3: BSF 03.5 |
00A4: BCF 09.0 |
.................... delay_cycles(1); |
00A5: NOP |
.................... high = lcd_read_nibble(); |
00A6: BCF 03.5 |
00A7: CALL 05F |
00A8: MOVF 78,W |
00A9: MOVWF 2E |
.................... |
.................... lcd_output_enable(0); |
00AA: BCF 09.0 |
00AB: BSF 03.5 |
00AC: BCF 09.0 |
.................... delay_cycles(1); |
00AD: NOP |
.................... lcd_output_enable(1); |
00AE: BCF 03.5 |
00AF: BSF 09.0 |
00B0: BSF 03.5 |
00B1: BCF 09.0 |
.................... delay_us(1); |
00B2: GOTO 0B3 |
.................... low = lcd_read_nibble(); |
00B3: BCF 03.5 |
00B4: CALL 05F |
00B5: MOVF 78,W |
00B6: MOVWF 2D |
.................... |
.................... lcd_output_enable(0); |
00B7: BCF 09.0 |
00B8: BSF 03.5 |
00B9: BCF 09.0 |
.................... |
.................... #if defined(__PCB__) |
.................... set_tris_lcd(LCD_OUTPUT_MAP); |
.................... #else |
.................... #if (defined(LCD_DATA4) && defined(LCD_DATA5) && defined(LCD_DATA6) && defined(LCD_DATA7)) |
.................... output_drive(LCD_DATA4); |
00BA: BCF 08.4 |
.................... output_drive(LCD_DATA5); |
00BB: BCF 08.5 |
.................... output_drive(LCD_DATA6); |
00BC: BCF 08.6 |
.................... output_drive(LCD_DATA7); |
00BD: BCF 08.7 |
.................... #else |
.................... lcdtris.data = 0x0; |
.................... #endif |
.................... #endif |
.................... |
.................... return( (high<<4) | low); |
00BE: BCF 03.5 |
00BF: SWAPF 2E,W |
00C0: MOVWF 77 |
00C1: MOVLW F0 |
00C2: ANDWF 77,F |
00C3: MOVF 77,W |
00C4: IORWF 2D,W |
00C5: MOVWF 78 |
.................... } |
.................... |
.................... BYTE lcd_read_nibble(void) |
.................... { |
.................... #if (defined(LCD_DATA4) && defined(LCD_DATA5) && defined(LCD_DATA6) && defined(LCD_DATA7)) |
* |
005F: CLRF 2F |
.................... BYTE n = 0x00; |
.................... |
.................... /* Read the data port */ |
.................... n |= input(LCD_DATA4); |
0060: BSF 03.5 |
0061: BSF 08.4 |
0062: MOVLW 00 |
0063: BCF 03.5 |
0064: BTFSC 08.4 |
0065: MOVLW 01 |
0066: IORWF 2F,F |
.................... n |= input(LCD_DATA5) << 1; |
0067: BSF 03.5 |
0068: BSF 08.5 |
0069: MOVLW 00 |
006A: BCF 03.5 |
006B: BTFSC 08.5 |
006C: MOVLW 01 |
006D: MOVWF 77 |
006E: BCF 03.0 |
006F: RLF 77,F |
0070: MOVF 77,W |
0071: IORWF 2F,F |
.................... n |= input(LCD_DATA6) << 2; |
0072: BSF 03.5 |
0073: BSF 08.6 |
0074: MOVLW 00 |
0075: BCF 03.5 |
0076: BTFSC 08.6 |
0077: MOVLW 01 |
0078: MOVWF 77 |
0079: RLF 77,F |
007A: RLF 77,F |
007B: MOVLW FC |
007C: ANDWF 77,F |
007D: MOVF 77,W |
007E: IORWF 2F,F |
.................... n |= input(LCD_DATA7) << 3; |
007F: BSF 03.5 |
0080: BSF 08.7 |
0081: MOVLW 00 |
0082: BCF 03.5 |
0083: BTFSC 08.7 |
0084: MOVLW 01 |
0085: MOVWF 77 |
0086: RLF 77,F |
0087: RLF 77,F |
0088: RLF 77,F |
0089: MOVLW F8 |
008A: ANDWF 77,F |
008B: MOVF 77,W |
008C: IORWF 2F,F |
.................... |
.................... return(n); |
008D: MOVF 2F,W |
008E: MOVWF 78 |
.................... #else |
.................... return(lcd.data); |
.................... #endif |
.................... } |
008F: RETURN |
.................... |
.................... void lcd_send_nibble(BYTE n) |
.................... { |
.................... #if (defined(LCD_DATA4) && defined(LCD_DATA5) && defined(LCD_DATA6) && defined(LCD_DATA7)) |
.................... /* Write to the data port */ |
.................... output_bit(LCD_DATA4, bit_test(n, 0)); |
* |
0033: BTFSC 2E.0 |
0034: GOTO 037 |
0035: BCF 08.4 |
0036: GOTO 038 |
0037: BSF 08.4 |
0038: BSF 03.5 |
0039: BCF 08.4 |
.................... output_bit(LCD_DATA5, bit_test(n, 1)); |
003A: BCF 03.5 |
003B: BTFSC 2E.1 |
003C: GOTO 03F |
003D: BCF 08.5 |
003E: GOTO 040 |
003F: BSF 08.5 |
0040: BSF 03.5 |
0041: BCF 08.5 |
.................... output_bit(LCD_DATA6, bit_test(n, 2)); |
0042: BCF 03.5 |
0043: BTFSC 2E.2 |
0044: GOTO 047 |
0045: BCF 08.6 |
0046: GOTO 048 |
0047: BSF 08.6 |
0048: BSF 03.5 |
0049: BCF 08.6 |
.................... output_bit(LCD_DATA7, bit_test(n, 3)); |
004A: BCF 03.5 |
004B: BTFSC 2E.3 |
004C: GOTO 04F |
004D: BCF 08.7 |
004E: GOTO 050 |
004F: BSF 08.7 |
0050: BSF 03.5 |
0051: BCF 08.7 |
.................... #else |
.................... lcdlat.data = n; |
.................... #endif |
.................... |
.................... delay_cycles(1); |
0052: NOP |
.................... lcd_output_enable(1); |
0053: BCF 03.5 |
0054: BSF 09.0 |
0055: BSF 03.5 |
0056: BCF 09.0 |
.................... delay_us(2); |
0057: GOTO 058 |
0058: GOTO 059 |
.................... lcd_output_enable(0); |
0059: BCF 03.5 |
005A: BCF 09.0 |
005B: BSF 03.5 |
005C: BCF 09.0 |
.................... } |
005D: BCF 03.5 |
005E: RETURN |
.................... |
.................... void lcd_send_byte(BYTE address, BYTE n) |
.................... { |
.................... #if defined(__PCB__) |
.................... set_tris_lcd(LCD_OUTPUT_MAP); |
.................... #else |
.................... lcd_enable_tris(); |
* |
0090: BSF 03.5 |
0091: BCF 09.0 |
.................... lcd_rs_tris(); |
0092: BCF 09.1 |
.................... lcd_rw_tris(); |
0093: BCF 09.2 |
.................... #endif |
.................... |
.................... lcd_output_rs(0); |
0094: BCF 03.5 |
0095: BCF 09.1 |
0096: BSF 03.5 |
0097: BCF 09.1 |
.................... while ( bit_test(lcd_read_byte(),7) ) ; |
* |
00C6: MOVF 78,W |
00C7: MOVWF 2D |
00C8: BTFSS 2D.7 |
00C9: GOTO 0CC |
00CA: BSF 03.5 |
00CB: GOTO 098 |
.................... lcd_output_rs(address); |
00CC: MOVF 2B,F |
00CD: BTFSS 03.2 |
00CE: GOTO 0D1 |
00CF: BCF 09.1 |
00D0: GOTO 0D2 |
00D1: BSF 09.1 |
00D2: BSF 03.5 |
00D3: BCF 09.1 |
.................... delay_cycles(1); |
00D4: NOP |
.................... lcd_output_rw(0); |
00D5: BCF 03.5 |
00D6: BCF 09.2 |
00D7: BSF 03.5 |
00D8: BCF 09.2 |
.................... delay_cycles(1); |
00D9: NOP |
.................... lcd_output_enable(0); |
00DA: BCF 03.5 |
00DB: BCF 09.0 |
00DC: BSF 03.5 |
00DD: BCF 09.0 |
.................... lcd_send_nibble(n >> 4); |
00DE: BCF 03.5 |
00DF: SWAPF 2C,W |
00E0: MOVWF 2D |
00E1: MOVLW 0F |
00E2: ANDWF 2D,F |
00E3: MOVF 2D,W |
00E4: MOVWF 2E |
00E5: CALL 033 |
.................... lcd_send_nibble(n & 0xf); |
00E6: MOVF 2C,W |
00E7: ANDLW 0F |
00E8: MOVWF 2D |
00E9: MOVWF 2E |
00EA: CALL 033 |
.................... } |
00EB: RETURN |
.................... |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
.................... unsigned int8 g_LcdX, g_LcdY; |
.................... #endif |
.................... |
.................... void lcd_init(void) |
.................... { |
.................... BYTE i; |
.................... |
.................... #if defined(__PCB__) |
.................... set_tris_lcd(LCD_OUTPUT_MAP); |
.................... #else |
.................... #if (defined(LCD_DATA4) && defined(LCD_DATA5) && defined(LCD_DATA6) && defined(LCD_DATA7)) |
.................... output_drive(LCD_DATA4); |
00EC: BSF 03.5 |
00ED: BCF 08.4 |
.................... output_drive(LCD_DATA5); |
00EE: BCF 08.5 |
.................... output_drive(LCD_DATA6); |
00EF: BCF 08.6 |
.................... output_drive(LCD_DATA7); |
00F0: BCF 08.7 |
.................... #else |
.................... lcdtris.data = 0x0; |
.................... #endif |
.................... lcd_enable_tris(); |
00F1: BCF 09.0 |
.................... lcd_rs_tris(); |
00F2: BCF 09.1 |
.................... lcd_rw_tris(); |
00F3: BCF 09.2 |
.................... #endif |
.................... |
.................... lcd_output_rs(0); |
00F4: BCF 03.5 |
00F5: BCF 09.1 |
00F6: BSF 03.5 |
00F7: BCF 09.1 |
.................... lcd_output_rw(0); |
00F8: BCF 03.5 |
00F9: BCF 09.2 |
00FA: BSF 03.5 |
00FB: BCF 09.2 |
.................... lcd_output_enable(0); |
00FC: BCF 03.5 |
00FD: BCF 09.0 |
00FE: BSF 03.5 |
00FF: BCF 09.0 |
.................... |
.................... delay_ms(15); |
0100: MOVLW 0F |
0101: BCF 03.5 |
0102: MOVWF 27 |
0103: CALL 01F |
.................... for(i=1;i<=3;++i) |
0104: MOVLW 01 |
0105: MOVWF 23 |
0106: MOVF 23,W |
0107: SUBLW 03 |
0108: BTFSS 03.0 |
0109: GOTO 112 |
.................... { |
.................... lcd_send_nibble(3); |
010A: MOVLW 03 |
010B: MOVWF 2E |
010C: CALL 033 |
.................... delay_ms(5); |
010D: MOVLW 05 |
010E: MOVWF 27 |
010F: CALL 01F |
.................... } |
0110: INCF 23,F |
0111: GOTO 106 |
.................... |
.................... lcd_send_nibble(2); |
0112: MOVLW 02 |
0113: MOVWF 2E |
0114: CALL 033 |
.................... for(i=0;i<=3;++i) |
0115: CLRF 23 |
0116: MOVF 23,W |
0117: SUBLW 03 |
0118: BTFSS 03.0 |
0119: GOTO 123 |
.................... lcd_send_byte(0,LCD_INIT_STRING[i]); |
011A: MOVF 23,W |
011B: CALL 004 |
011C: MOVWF 24 |
011D: CLRF 2B |
011E: MOVF 24,W |
011F: MOVWF 2C |
0120: CALL 090 |
.................... |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
0121: INCF 23,F |
0122: GOTO 116 |
.................... g_LcdX = 0; |
.................... g_LcdY = 0; |
.................... #endif |
.................... } |
0123: RETURN |
.................... |
.................... void lcd_gotoxy(BYTE x, BYTE y) |
.................... { |
.................... BYTE address; |
.................... |
.................... if(y!=1) |
0124: DECFSZ 28,W |
0125: GOTO 127 |
0126: GOTO 12A |
.................... address=LCD_LINE_TWO; |
0127: MOVLW 40 |
0128: MOVWF 29 |
.................... else |
0129: GOTO 12B |
.................... address=0; |
012A: CLRF 29 |
.................... |
.................... address+=x-1; |
012B: MOVLW 01 |
012C: SUBWF 27,W |
012D: ADDWF 29,F |
.................... lcd_send_byte(0,0x80|address); |
012E: MOVF 29,W |
012F: IORLW 80 |
0130: MOVWF 2A |
0131: CLRF 2B |
0132: MOVF 2A,W |
0133: MOVWF 2C |
0134: CALL 090 |
.................... |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
.................... g_LcdX = x - 1; |
.................... g_LcdY = y - 1; |
.................... #endif |
.................... } |
0135: RETURN |
.................... |
.................... void lcd_putc(char c) |
.................... { |
.................... switch (c) |
.................... { |
0136: MOVF 26,W |
0137: XORLW 07 |
0138: BTFSC 03.2 |
0139: GOTO 144 |
013A: XORLW 0B |
013B: BTFSC 03.2 |
013C: GOTO 149 |
013D: XORLW 06 |
013E: BTFSC 03.2 |
013F: GOTO 151 |
0140: XORLW 02 |
0141: BTFSC 03.2 |
0142: GOTO 157 |
0143: GOTO 15C |
.................... case '\a' : lcd_gotoxy(1,1); break; |
0144: MOVLW 01 |
0145: MOVWF 27 |
0146: MOVWF 28 |
0147: CALL 124 |
0148: GOTO 162 |
.................... |
.................... case '\f' : lcd_send_byte(0,1); |
0149: CLRF 2B |
014A: MOVLW 01 |
014B: MOVWF 2C |
014C: CALL 090 |
.................... delay_ms(2); |
014D: MOVLW 02 |
014E: MOVWF 27 |
014F: CALL 01F |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
.................... g_LcdX = 0; |
.................... g_LcdY = 0; |
.................... #endif |
.................... break; |
0150: GOTO 162 |
.................... |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
.................... case '\r' : lcd_gotoxy(1, g_LcdY+1); break; |
.................... case '\n' : |
.................... while (g_LcdX++ < LCD_LINE_LENGTH) |
.................... { |
.................... lcd_send_byte(1, ' '); |
.................... } |
.................... lcd_gotoxy(1, g_LcdY+2); |
.................... break; |
.................... #else |
.................... case '\n' : lcd_gotoxy(1,2); break; |
0151: MOVLW 01 |
0152: MOVWF 27 |
0153: MOVLW 02 |
0154: MOVWF 28 |
0155: CALL 124 |
0156: GOTO 162 |
.................... #endif |
.................... |
.................... case '\b' : lcd_send_byte(0,0x10); break; |
0157: CLRF 2B |
0158: MOVLW 10 |
0159: MOVWF 2C |
015A: CALL 090 |
015B: GOTO 162 |
.................... |
.................... #if defined(LCD_EXTENDED_NEWLINE) |
.................... default : |
.................... if (g_LcdX < LCD_LINE_LENGTH) |
.................... { |
.................... lcd_send_byte(1, c); |
.................... g_LcdX++; |
.................... } |
.................... break; |
.................... #else |
.................... default : lcd_send_byte(1,c); break; |
015C: MOVLW 01 |
015D: MOVWF 2B |
015E: MOVF 26,W |
015F: MOVWF 2C |
0160: CALL 090 |
0161: GOTO 162 |
.................... #endif |
.................... } |
.................... } |
0162: RETURN |
.................... |
.................... char lcd_getc(BYTE x, BYTE y) |
.................... { |
.................... char value; |
.................... |
.................... lcd_gotoxy(x,y); |
.................... while ( bit_test(lcd_read_byte(),7) ); // wait until busy flag is low |
.................... lcd_output_rs(1); |
.................... value = lcd_read_byte(); |
.................... lcd_output_rs(0); |
.................... |
.................... return(value); |
.................... } |
.................... |
.................... |
.................... #define BEEPER PIN_B5 |
.................... |
.................... int beep() |
.................... { |
.................... unsigned int i; |
.................... |
.................... i=0; |
* |
01CC: CLRF 23 |
.................... for(i=0;i<100;i++) |
01CD: CLRF 23 |
01CE: MOVF 23,W |
01CF: SUBLW 63 |
01D0: BTFSS 03.0 |
01D1: GOTO 1E2 |
.................... { |
.................... output_low(BEEPER); |
01D2: BSF 03.5 |
01D3: BCF 06.5 |
01D4: BCF 03.5 |
01D5: BCF 06.5 |
.................... delay_ms(1); |
01D6: MOVLW 01 |
01D7: MOVWF 27 |
01D8: CALL 01F |
.................... output_high(BEEPER); |
01D9: BSF 03.5 |
01DA: BCF 06.5 |
01DB: BCF 03.5 |
01DC: BSF 06.5 |
.................... delay_ms(1); |
01DD: MOVLW 01 |
01DE: MOVWF 27 |
01DF: CALL 01F |
.................... } |
01E0: INCF 23,F |
01E1: GOTO 1CE |
.................... } |
01E2: BCF 0A.3 |
01E3: BCF 0A.4 |
01E4: GOTO 294 (RETURN) |
.................... |
.................... |
.................... void main() |
.................... { |
01E5: CLRF 04 |
01E6: BCF 03.7 |
01E7: MOVLW 1F |
01E8: ANDWF 03,F |
01E9: MOVLW 71 |
01EA: BSF 03.5 |
01EB: MOVWF 0F |
01EC: MOVF 0F,W |
01ED: BSF 03.6 |
01EE: BCF 07.3 |
01EF: MOVLW 0C |
01F0: BCF 03.6 |
01F1: MOVWF 19 |
01F2: MOVLW A2 |
01F3: MOVWF 18 |
01F4: MOVLW 90 |
01F5: BCF 03.5 |
01F6: MOVWF 18 |
01F7: BSF 03.5 |
01F8: BSF 03.6 |
01F9: MOVF 09,W |
01FA: ANDLW C0 |
01FB: MOVWF 09 |
01FC: BCF 03.6 |
01FD: BCF 1F.4 |
01FE: BCF 1F.5 |
01FF: MOVLW 00 |
0200: BSF 03.6 |
0201: MOVWF 08 |
0202: BCF 03.5 |
0203: CLRF 07 |
0204: CLRF 08 |
0205: CLRF 09 |
* |
0209: CLRF 22 |
020A: CLRF 21 |
.................... int16 i=0; |
.................... |
.................... setup_adc_ports(NO_ANALOGS|VSS_VDD); |
020B: BSF 03.5 |
020C: BSF 03.6 |
020D: MOVF 09,W |
020E: ANDLW C0 |
020F: MOVWF 09 |
0210: BCF 03.6 |
0211: BCF 1F.4 |
0212: BCF 1F.5 |
0213: MOVLW 00 |
0214: BSF 03.6 |
0215: MOVWF 08 |
.................... setup_adc(ADC_CLOCK_DIV_2); |
0216: BCF 03.5 |
0217: BCF 03.6 |
0218: BCF 1F.6 |
0219: BCF 1F.7 |
021A: BSF 03.5 |
021B: BSF 1F.7 |
021C: BCF 03.5 |
021D: BSF 1F.0 |
.................... setup_spi(SPI_SS_DISABLED); |
021E: BCF 14.5 |
021F: BCF 20.5 |
0220: MOVF 20,W |
0221: BSF 03.5 |
0222: MOVWF 07 |
0223: BCF 03.5 |
0224: BSF 20.4 |
0225: MOVF 20,W |
0226: BSF 03.5 |
0227: MOVWF 07 |
0228: BCF 03.5 |
0229: BCF 20.3 |
022A: MOVF 20,W |
022B: BSF 03.5 |
022C: MOVWF 07 |
022D: MOVLW 01 |
022E: BCF 03.5 |
022F: MOVWF 14 |
0230: MOVLW 00 |
0231: BSF 03.5 |
0232: MOVWF 14 |
.................... setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1); |
0233: MOVF 01,W |
0234: ANDLW C7 |
0235: IORLW 08 |
0236: MOVWF 01 |
.................... setup_timer_1(T1_DISABLED); |
0237: BCF 03.5 |
0238: CLRF 10 |
.................... setup_timer_2(T2_DISABLED,0,1); |
0239: MOVLW 00 |
023A: MOVWF 78 |
023B: MOVWF 12 |
023C: MOVLW 00 |
023D: BSF 03.5 |
023E: MOVWF 12 |
.................... setup_ccp1(CCP_OFF); |
023F: BCF 03.5 |
0240: BSF 20.2 |
0241: MOVF 20,W |
0242: BSF 03.5 |
0243: MOVWF 07 |
0244: BCF 03.5 |
0245: CLRF 17 |
0246: BSF 03.5 |
0247: CLRF 1B |
0248: CLRF 1C |
0249: MOVLW 01 |
024A: MOVWF 1D |
.................... setup_comparator(NC_NC_NC_NC); // This device COMP currently not supported by the PICWizard |
024B: BCF 03.5 |
024C: BSF 03.6 |
024D: CLRF 07 |
024E: CLRF 08 |
024F: CLRF 09 |
.................... setup_oscillator(OSC_8MHZ); |
0250: MOVLW 71 |
0251: BSF 03.5 |
0252: BCF 03.6 |
0253: MOVWF 0F |
0254: MOVF 0F,W |
.................... |
.................... lcd_init(); |
0255: BCF 03.5 |
0256: CALL 0EC |
.................... lcd_putc("(c) Kaklik 2013"); |
0257: MOVLW 0C |
0258: BSF 03.6 |
0259: MOVWF 0D |
025A: MOVLW 00 |
025B: MOVWF 0F |
025C: BCF 03.6 |
025D: CALL 163 |
.................... lcd_gotoxy(3,2); |
025E: MOVLW 03 |
025F: MOVWF 27 |
0260: MOVLW 02 |
0261: MOVWF 28 |
0262: CALL 124 |
.................... lcd_putc("www.mlab.cz"); |
0263: MOVLW 14 |
0264: BSF 03.6 |
0265: MOVWF 0D |
0266: MOVLW 00 |
0267: MOVWF 0F |
0268: BCF 03.6 |
0269: CALL 163 |
.................... Delay_ms(2000); |
026A: MOVLW 08 |
026B: MOVWF 23 |
026C: MOVLW FA |
026D: MOVWF 27 |
026E: CALL 01F |
026F: DECFSZ 23,F |
0270: GOTO 26C |
.................... lcd_init(); |
0271: CALL 0EC |
.................... |
.................... while (TRUE) |
.................... { |
.................... lcd_gotoxy(1,1); |
0272: MOVLW 01 |
0273: MOVWF 27 |
0274: MOVWF 28 |
0275: CALL 124 |
.................... |
.................... printf(lcd_putc,"LCD test"); |
0276: MOVLW 1A |
0277: BSF 03.6 |
0278: MOVWF 0D |
0279: MOVLW 00 |
027A: MOVWF 0F |
027B: BCF 03.6 |
027C: CALL 163 |
.................... lcd_gotoxy(1,2); |
027D: MOVLW 01 |
027E: MOVWF 27 |
027F: MOVLW 02 |
0280: MOVWF 28 |
0281: CALL 124 |
.................... printf(lcd_putc,"%c %x ",i,i); |
0282: MOVF 21,W |
0283: MOVWF 26 |
0284: CALL 136 |
0285: MOVLW 20 |
0286: MOVWF 26 |
0287: CALL 136 |
0288: MOVF 21,W |
0289: MOVWF 23 |
028A: MOVLW 57 |
028B: MOVWF 24 |
028C: GOTO 1A9 |
028D: MOVLW 20 |
028E: MOVWF 26 |
028F: CALL 136 |
.................... i++; |
0290: INCF 21,F |
0291: BTFSC 03.2 |
0292: INCF 22,F |
.................... beep(); |
0293: GOTO 1CC |
.................... Delay_ms(500); |
0294: MOVLW 02 |
0295: MOVWF 23 |
0296: MOVLW FA |
0297: MOVWF 27 |
0298: CALL 01F |
0299: DECFSZ 23,F |
029A: GOTO 296 |
.................... } |
029B: GOTO 272 |
.................... |
.................... } |
029C: SLEEP |
Configuration Fuses: |
Word 1: 2CF5 INTRC NOWDT NOPUT MCLR NOPROTECT NOCPD NOBROWNOUT IESO FCMEN NOLVP NODEBUG |
Word 2: 3FFF NOWRT BORV40 |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.sta |
---|
0,0 → 1,62 |
ROM used: 669 (8%) |
669 (8%) including unused fragments |
1 Average locations per line |
6 Average locations per statement |
RAM used: 9 (2%) at main() level |
22 (6%) worst case |
Stack used: 5 worst case (out of 8 total available) |
Lines Stmts % Files |
----- ----- --- ----- |
63 31 26 main.c |
22 0 0 main.h |
423 0 0 C:\Program Files (x86)\PICC\devices\16F887.h |
408 88 74 C:\Program Files (x86)\PICC\drivers\lcd.c |
----- ----- |
916 119 Total |
Page ROM % RAM Vol Diff Functions: |
---- --- --- --- --- ---- ---------- |
0 20 3 1 @delay_ms1 |
0 8 1 0 @const80 |
Inline 3 751 4.5 lcd_read_byte |
0 49 7 2 254 3.7 lcd_read_nibble |
0 44 7 1 391 2.4 lcd_send_nibble |
0 92 14 3 402 3.6 lcd_send_byte |
0 56 8 2 666 5.0 lcd_init |
0 18 3 4 191 5.8 lcd_gotoxy |
0 45 7 1 354 4.7 lcd_putc |
0 25 4 1 185 3.1 beep |
0 184 28 3 707 3.8 MAIN |
0 8 1 0 @const109 |
0 70 10 3 @PSTRINGC7_98 |
0 6 1 0 @const111 |
0 5 1 0 @const112 |
0 35 5 2 @PRINTF_X_98 |
Program metrics: |
Functions 9 |
Statements 119 |
Comments 172 |
Volume (V) 6043 |
Difficilty (D) 35.6 |
Effort to implement (E) 215138 |
Time to implement (T) 3 hours, 19 minutes |
Est Delivered Bugs (B) 1 |
Cyclomatic Complexity 9 |
Maintainability (MI) 119 |
Segment Used Free |
----------- ---- ---- |
00000-00003 4 0 |
00004-007FF 665 1379 |
00800-00FFF 0 2048 |
01000-017FF 0 2048 |
01800-01FFF 0 2048 |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.sym |
---|
0,0 → 1,98 |
004-005 @READ_PROGRAM_MEMORY8.P1 |
004 @WRITE_PROGRAM_MEMORY8.P2 |
015 CCP_1_LOW |
015 CCP_1 |
016 CCP_1_HIGH |
01B CCP_2 |
01B CCP_2_LOW |
01C CCP_2_HIGH |
020 @TRIS_C |
021-022 MAIN.i |
023 lcd_init.i |
023 beep.i |
023 @PRINTF_X_98.P1 |
023 MAIN.@SCRATCH1 |
023 @PSTRINGC7_98.@SCRATCH1 |
024 @PRINTF_X_98.P1 |
024 lcd_init.@SCRATCH1 |
024 @PSTRINGC7_98.@SCRATCH2 |
025 @PSTRINGC7_98.@SCRATCH3 |
026 lcd_putc.c |
027 @delay_ms1.P1 |
027 lcd_gotoxy.x |
028 lcd_gotoxy.y |
029 lcd_gotoxy.address |
02A lcd_gotoxy.@SCRATCH1 |
02B lcd_send_byte.address |
02C lcd_send_byte.n |
02D lcd_read_byte.low |
02D lcd_send_byte.@SCRATCH1 |
02E lcd_send_nibble.n |
02E lcd_read_byte.high |
02F lcd_read_nibble.n |
02F lcd_read_byte.@SCRATCH1 |
030 lcd_read_nibble.@SCRATCH1 |
077 @SCRATCH |
078 @SCRATCH |
078 _RETURN_ |
079 @SCRATCH |
07A @SCRATCH |
107.6 C1OUT |
108.6 C2OUT |
10D-10E @READ_PROGRAM_MEMORY8.P1 |
10D-10E @WRITE_PROGRAM_MEMORY8.P2 |
ROM Allocation: |
001F @delay_ms1 |
0004 LCD_INIT_STRING |
0098 lcd_read_byte |
005F lcd_read_nibble |
0033 lcd_send_nibble |
0090 lcd_send_byte |
00EC lcd_init |
0124 lcd_gotoxy |
0136 lcd_putc |
01CC beep |
01E5 MAIN |
000C @const109 |
0163 @PSTRINGC7_98 |
0014 @const111 |
001A @const112 |
01A9 @PRINTF_X_98 |
01E5 @cinit |
User Memory space: |
User Memory space: |
Project Directory: |
D:\Honza\MLAB\Modules\HumanInterfaces\LCD2L4P02A\SW\PIC\PIC16F887\ |
Project Files: |
main.c |
main.h |
C:\Program Files (x86)\PICC\devices\16F887.h |
C:\Program Files (x86)\PICC\drivers\lcd.c |
Units: |
D:\Honza\MLAB\Modules\HumanInterfaces\LCD2L4P02A\SW\PIC\PIC16F887\main (main) |
Compiler Settings: |
Processor: PIC16F887 |
Pointer Size: 16 |
ADC Range: 0-1023 |
Opt Level: 9 |
Short,Int,Long: UNSIGNED: 1,8,16 |
Float,Double: 32,32 |
Output Files: |
Errors: main.err |
Ext Symbols: main.esym |
INHX8: main.hex |
Symbols: main.sym |
List: main.lst |
Debug/COFF: main.cof |
Project: main.PJT |
Call Tree: main.tre |
Statistics: main.sta |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.tre |
---|
0,0 → 1,431 |
ÀÄmain |
ÀÄMAIN 0/184 Ram=3 |
ÃÄ??0?? |
ÃÄlcd_init 0/56 Ram=2 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@const80 0/8 Ram=0 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄ@PSTRINGC7_98 0/70 Ram=3 |
³ ÃÄlcd_putc 0/45 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄ@PSTRINGC7_98 0/70 Ram=3 |
³ ÃÄlcd_putc 0/45 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄ@delay_ms1 0/20 Ram=1 |
ÃÄlcd_init 0/56 Ram=2 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@const80 0/8 Ram=0 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄ@PSTRINGC7_98 0/70 Ram=3 |
³ ÃÄlcd_putc 0/45 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄ@PRINTF_X_98 0/35 Ram=2 |
³ ÃÄlcd_putc 0/45 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄlcd_putc 0/45 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÃÄlcd_gotoxy 0/18 Ram=4 |
³ ³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÃÄlcd_send_byte 0/92 Ram=3 |
³ ³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ³ ÀÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_byte 0/92 Ram=3 |
³ ÃÄlcd_read_byte (Inline) Ram=3 |
³ ³ ÃÄlcd_read_nibble 0/49 Ram=2 |
³ ³ ÀÄlcd_read_nibble 0/49 Ram=2 |
³ ÃÄlcd_send_nibble 0/44 Ram=1 |
³ ÀÄlcd_send_nibble 0/44 Ram=1 |
ÃÄbeep 0/25 Ram=1 |
³ ÃÄ@delay_ms1 0/20 Ram=1 |
³ ÀÄ@delay_ms1 0/20 Ram=1 |
ÀÄ@delay_ms1 0/20 Ram=1 |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.h |
---|
0,0 → 1,21 |
#include <16F887.h> |
#device adc=10 |
#FUSES NOWDT //No Watch Dog Timer |
#FUSES INTRC //Internal RC Osc |
#FUSES NOPUT //No Power Up Timer |
#FUSES MCLR //Master Clear pin enabled |
#FUSES NOPROTECT //Code not protected from reading |
#FUSES NOCPD //No EE protection |
#FUSES NOBROWNOUT //No brownout reset |
#FUSES IESO //Internal External Switch Over mode enabled |
#FUSES FCMEN //Fail-safe clock monitor enabled |
#FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O |
#FUSES NODEBUG //No Debug mode for ICD |
#FUSES NOWRT //Program memory not write protected |
#FUSES BORV40 //Brownout reset at 4.0V |
#use delay(clock=8000000) |
#use i2c(master, sda=PIN_C4, scl=PIN_C3) |
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8) |
/Modules/HumanInterfaces/LCD2L4P02A/SW/PIC/PIC16F887/main.pjt |
---|
0,0 → 1,36 |
[PROJECT] |
Target=main.hex |
Development_Mode= |
Processor_Text=PIC16F887 |
ToolSuite=CCS |
Processor=0x887F |
[main] |
Type=4 |
Path= |
FileList= |
BuildTool= |
OptionString= |
AdditionalOptionString= |
[mru-list] |
1=main.c |
[Windows] |
0=0000 %S 0 0 796 451 3 0 |
[Opened Files] |
1=main.c |
2= |
3=C:\Program Files (x86)\PICC\devices\16F887.h |
4=C:\Program Files (x86)\PICC\drivers\lcd.c |
5=..\SHT25.h |
6=..\SHT25.c |
7=..\LTS01.h |
8=..\LTS01.c |
9=..\HMC5883L.h |
10=..\HMC5883L.c |
11=C:\Program Files (x86)\PICC\drivers\math.h |
12= |
[Target Data] |
OptionString=-p +FM |
FileList=main.c |
[Units] |
Count=1 |
1=main (main) |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/LCD_zkouska.c |
---|
0,0 → 1,74 |
//Program pro vyzkouseni funkcnosti modulu s LCD a mikropocitacem ATmega8 |
//MLAB 21.11.2011 (JACHO) |
//vytvoreno v programu AVR studio 4 |
//Propojení pinù modulu s LCD a ATmega8 (jejich nastavení se provádí v lcd.h) |
//PIN_D0 PC3 |
//PIN_D1 PB4 |
//PIN_D2 PB5 |
//PIN_D3 PB3 |
//PIN_E PB1 |
//PIN_RS PB2 |
//pri spravne funkci se na LCD zobrazi na prvem a druhem radku LCD je OK |
//je dulezite spravne propojit modulu, napajet je a mit spravne nastaveny konstrast (pro zacatek potenciometr do prostred drahy) |
#include <avr/io.h> |
#include <stdio.h> |
#include <avr/iom8.h> |
#include "lcd.h" |
#include "lcd.c" |
#include <util/delay.h> |
#define MAXDISPLBUFFER 20 //buffer pro lcd display |
//----------------------------------------------------------------------------- |
int main(void) |
{ |
LCD_init(); //Inicializace LCD |
char zasobnik[19]; |
sprintf(zasobnik,"LCD je OK"); //vlozi text do zasobnik |
LCD_gotoxy(0,0); //definuje kam se zacne zapisovat na LCD |
ProcesDispl(zasobnik); |
LCD_gotoxy(0,2); |
ProcesDispl(zasobnik); |
_delay_ms(1); |
return 0; |
} |
void ProcesDispl(char *data) //zajiuje tisk øetìzce na lcd |
{ |
uint8_t a,b; |
for (a=0;a<MAXDISPLBUFFER;a++) |
{ |
switch (*(data+a)) |
{ |
case 0: *data = 0;return; |
case '\n': LCD_gotoxy(1,2);break; //posun na druhej øádek |
case '\r': LCD_gotoxy(1,1);break; |
case '\a': LCD_gotoxy(6,2);break; //posun na 2.øádek 6.políèko |
case '\f': LCD_gotoxy(1,1); |
for (b=0;b<8;b++) LCD_putc(0x20); |
LCD_gotoxy(1,2); |
for (b=0;b<8;b++) LCD_putc(0x20); |
LCD_gotoxy(1,1); |
break; |
default : LCD_putc(*(data+a)); |
} |
} |
*data = 0; |
} |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/lcd_zkouska.aws |
---|
0,0 → 1,0 |
<AVRWorkspace><IOSettings><CurrentRegisters/></IOSettings><part name="ATMEGA8"/><Files><File00000 Name="D:\Honza\MLAB\Modules\HumanInterfaces\LCD2L4P02A\SW\AVR\LCD_zkouska.c" Position="268 99 989 381" LineCol="14 56"/></Files></AVRWorkspace> |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/Makefile |
---|
0,0 → 1,77 |
############################################################################### |
# Makefile for the project LCD_zkouska |
############################################################################### |
## General Flags |
PROJECT = LCD_zkouska |
MCU = atmega8 |
TARGET = LCD_zkouska.elf |
CC = avr-gcc |
CPP = avr-g++ |
## Options common to compile, link and assembly rules |
COMMON = -mmcu=$(MCU) |
## Compile options common for all C compilation units. |
CFLAGS = $(COMMON) |
CFLAGS += -Wall -gdwarf-2 -Os -std=gnu99 -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums |
CFLAGS += -MD -MP -MT $(*F).o -MF dep/$(@F).d |
## Assembly specific flags |
ASMFLAGS = $(COMMON) |
ASMFLAGS += $(CFLAGS) |
ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2 |
## Linker flags |
LDFLAGS = $(COMMON) |
LDFLAGS += -Wl,-Map=LCD_zkouska.map |
## Intel Hex file production flags |
HEX_FLASH_FLAGS = -R .eeprom -R .fuse -R .lock -R .signature |
HEX_EEPROM_FLAGS = -j .eeprom |
HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load" |
HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings |
## Objects that must be built in order to link |
OBJECTS = LCD_zkouska.o |
## Objects explicitly added by the user |
LINKONLYOBJECTS = |
## Build |
all: $(TARGET) LCD_zkouska.hex LCD_zkouska.eep LCD_zkouska.lss size |
## Compile |
LCD_zkouska.o: ../LCD_zkouska.c |
$(CC) $(INCLUDES) $(CFLAGS) -c $< |
##Link |
$(TARGET): $(OBJECTS) |
$(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET) |
%.hex: $(TARGET) |
avr-objcopy -O ihex $(HEX_FLASH_FLAGS) $< $@ |
%.eep: $(TARGET) |
-avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0 |
%.lss: $(TARGET) |
avr-objdump -h -S $< > $@ |
size: ${TARGET} |
@echo |
@avr-size -C --mcu=${MCU} ${TARGET} |
## Clean target |
.PHONY: clean |
clean: |
-rm -rf $(OBJECTS) LCD_zkouska.elf dep/* LCD_zkouska.hex LCD_zkouska.eep LCD_zkouska.lss LCD_zkouska.map |
## Other dependencies |
-include $(shell mkdir dep 2>NUL) $(wildcard dep/*) |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/LCD_zkouska.eep |
---|
0,0 → 1,0 |
:00000001FF |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/LCD_zkouska.elf |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/LCD_zkouska.hex |
---|
0,0 → 1,38 |
:1000000014C026C025C024C023C022C021C020C0E7 |
:100010001FC01EC01DC01CC01BC01AC019C018C004 |
:1000200017C016C015C0280C010611241FBECFE54D |
:10003000D4E0DEBFCDBF10E0A0E6B0E0E2E3F2E046 |
:1000400002C005900D92AA36B107D9F7BAD0EFC019 |
:10005000D7CFA39ABC9ABD9ABB9AB99ABA9A089577 |
:10006000AB98C498C598C39880FDAB9A81FDC49A9B |
:1000700082FDC59A83FDC39AC19A81E08A95F1F702 |
:10008000C19808951F93182F82958F70E9DF812FF3 |
:10009000E7DF8DE08A95F1F71F910895C29AF2DFAC |
:1000A0000895FCDF0895C298EDDFC29A08950F937A |
:1000B0001F93CF93DF93CDDF88E893E10197F1F7AA |
:1000C000C198C29804EF11E0C8010197F1F783E0ED |
:1000D000C7DFC8010197F1F783E0C2DFC8010197CC |
:1000E000F1F783E0BDDF1DE0812F8A95F1F782E013 |
:1000F000B7DF1A95F1F706E210E0C4EFD1E0F8019E |
:100100008491D1DFCE010197F1F70F5F1F4FF0E02F |
:1001100009321F07A1F7DF91CF911F910F91089529 |
:1001200081E0C1DF84EF91E00197F1F708958150FC |
:10013000623009F4805C8068B6DF0895EF92FF9228 |
:100140001F93CF93DF937C01C0E0D0E0F701EC0F69 |
:10015000FD1F80818A3061F08B3028F4882349F1BB |
:10016000873011F50BC08C3061F08D30E9F402C09E |
:1001700081E005C081E061E0DADF17C086E062E07F |
:10018000FBCF81E061E0D3DF10E080E287DF1F5F1B |
:100190001830D9F781E062E0CADF10E080E27EDF4C |
:1001A0001F5F1830D9F7E6CF79DF2196C431D1052A |
:1001B00069F6F7011082DF91CF911F91FF90EF90C8 |
:1001C00008950F931F93DF93CF93CDB7DEB7639757 |
:1001D0000FB6F894DEBF0FBECDBF69DF8E010F5F93 |
:1001E0001F4FC80160E670E01BD080E060E09FDF39 |
:1001F000C801A4DF80E062E09ADFC8019FDF8AEFD8 |
:1002000090E00197F1F780E090E063960FB6F894E4 |
:10021000DEBF0FBECDBFCF91DF911F910F9108952B |
:10022000FB01DC0101900D920020E1F70895F894A4 |
:02023000FFCFFE |
:0A0232004C4344206A65204F4B0046 |
:00000001FF |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/LCD_zkouska.lss |
---|
0,0 → 1,550 |
LCD_zkouska.elf: file format elf32-avr |
Sections: |
Idx Name Size VMA LMA File off Algn |
0 .text 00000232 00000000 00000000 00000074 2**1 |
CONTENTS, ALLOC, LOAD, READONLY, CODE |
1 .data 0000000a 00800060 00000232 000002a6 2**0 |
CONTENTS, ALLOC, LOAD, DATA |
2 .debug_aranges 00000020 00000000 00000000 000002b0 2**0 |
CONTENTS, READONLY, DEBUGGING |
3 .debug_pubnames 000000d2 00000000 00000000 000002d0 2**0 |
CONTENTS, READONLY, DEBUGGING |
4 .debug_info 00000577 00000000 00000000 000003a2 2**0 |
CONTENTS, READONLY, DEBUGGING |
5 .debug_abbrev 000001da 00000000 00000000 00000919 2**0 |
CONTENTS, READONLY, DEBUGGING |
6 .debug_line 00000413 00000000 00000000 00000af3 2**0 |
CONTENTS, READONLY, DEBUGGING |
7 .debug_frame 000000c0 00000000 00000000 00000f08 2**2 |
CONTENTS, READONLY, DEBUGGING |
8 .debug_str 00000192 00000000 00000000 00000fc8 2**0 |
CONTENTS, READONLY, DEBUGGING |
9 .debug_loc 0000017f 00000000 00000000 0000115a 2**0 |
CONTENTS, READONLY, DEBUGGING |
10 .debug_ranges 000000a8 00000000 00000000 000012d9 2**0 |
CONTENTS, READONLY, DEBUGGING |
Disassembly of section .text: |
00000000 <__vectors>: |
0: 14 c0 rjmp .+40 ; 0x2a <__ctors_end> |
2: 26 c0 rjmp .+76 ; 0x50 <__bad_interrupt> |
4: 25 c0 rjmp .+74 ; 0x50 <__bad_interrupt> |
6: 24 c0 rjmp .+72 ; 0x50 <__bad_interrupt> |
8: 23 c0 rjmp .+70 ; 0x50 <__bad_interrupt> |
a: 22 c0 rjmp .+68 ; 0x50 <__bad_interrupt> |
c: 21 c0 rjmp .+66 ; 0x50 <__bad_interrupt> |
e: 20 c0 rjmp .+64 ; 0x50 <__bad_interrupt> |
10: 1f c0 rjmp .+62 ; 0x50 <__bad_interrupt> |
12: 1e c0 rjmp .+60 ; 0x50 <__bad_interrupt> |
14: 1d c0 rjmp .+58 ; 0x50 <__bad_interrupt> |
16: 1c c0 rjmp .+56 ; 0x50 <__bad_interrupt> |
18: 1b c0 rjmp .+54 ; 0x50 <__bad_interrupt> |
1a: 1a c0 rjmp .+52 ; 0x50 <__bad_interrupt> |
1c: 19 c0 rjmp .+50 ; 0x50 <__bad_interrupt> |
1e: 18 c0 rjmp .+48 ; 0x50 <__bad_interrupt> |
20: 17 c0 rjmp .+46 ; 0x50 <__bad_interrupt> |
22: 16 c0 rjmp .+44 ; 0x50 <__bad_interrupt> |
24: 15 c0 rjmp .+42 ; 0x50 <__bad_interrupt> |
00000026 <LCD_INIT_STRING>: |
26: 28 0c 01 06 (... |
0000002a <__ctors_end>: |
2a: 11 24 eor r1, r1 |
2c: 1f be out 0x3f, r1 ; 63 |
2e: cf e5 ldi r28, 0x5F ; 95 |
30: d4 e0 ldi r29, 0x04 ; 4 |
32: de bf out 0x3e, r29 ; 62 |
34: cd bf out 0x3d, r28 ; 61 |
00000036 <__do_copy_data>: |
36: 10 e0 ldi r17, 0x00 ; 0 |
38: a0 e6 ldi r26, 0x60 ; 96 |
3a: b0 e0 ldi r27, 0x00 ; 0 |
3c: e2 e3 ldi r30, 0x32 ; 50 |
3e: f2 e0 ldi r31, 0x02 ; 2 |
40: 02 c0 rjmp .+4 ; 0x46 <.do_copy_data_start> |
00000042 <.do_copy_data_loop>: |
42: 05 90 lpm r0, Z+ |
44: 0d 92 st X+, r0 |
00000046 <.do_copy_data_start>: |
46: aa 36 cpi r26, 0x6A ; 106 |
48: b1 07 cpc r27, r17 |
4a: d9 f7 brne .-10 ; 0x42 <.do_copy_data_loop> |
4c: ba d0 rcall .+372 ; 0x1c2 <main> |
4e: ef c0 rjmp .+478 ; 0x22e <_exit> |
00000050 <__bad_interrupt>: |
50: d7 cf rjmp .-82 ; 0x0 <__vectors> |
00000052 <LCD_init_IO_PIN>: |
0x06 // inkrement pozice kurzoru (posun kurzoru doprava) |
}; |
void LCD_init_IO_PIN(void) |
{ |
DDR_D0 |= _BV(PIN_D0); |
52: a3 9a sbi 0x14, 3 ; 20 |
DDR_D1 |= _BV(PIN_D1); |
54: bc 9a sbi 0x17, 4 ; 23 |
DDR_D2 |= _BV(PIN_D2); |
56: bd 9a sbi 0x17, 5 ; 23 |
DDR_D3 |= _BV(PIN_D3); |
58: bb 9a sbi 0x17, 3 ; 23 |
DDR_E |= _BV(PIN_E); |
5a: b9 9a sbi 0x17, 1 ; 23 |
DDR_RS |= _BV(PIN_RS); |
5c: ba 9a sbi 0x17, 2 ; 23 |
} |
5e: 08 95 ret |
00000060 <LCD_send_nibble>: |
_delay_us(40); |
} |
void LCD_send_nibble(uint8_t data) |
{ |
L_D0;L_D1;L_D2;L_D3; |
60: ab 98 cbi 0x15, 3 ; 21 |
62: c4 98 cbi 0x18, 4 ; 24 |
64: c5 98 cbi 0x18, 5 ; 24 |
66: c3 98 cbi 0x18, 3 ; 24 |
if (data & 0x1) H_D0; |
68: 80 fd sbrc r24, 0 |
6a: ab 9a sbi 0x15, 3 ; 21 |
if (data & 0x2) H_D1; |
6c: 81 fd sbrc r24, 1 |
6e: c4 9a sbi 0x18, 4 ; 24 |
if (data & 0x4) H_D2; |
70: 82 fd sbrc r24, 2 |
72: c5 9a sbi 0x18, 5 ; 24 |
if (data & 0x8) H_D3; |
74: 83 fd sbrc r24, 3 |
76: c3 9a sbi 0x18, 3 ; 24 |
H_E; |
78: c1 9a sbi 0x18, 1 ; 24 |
can be achieved. |
*/ |
void |
_delay_loop_1(uint8_t __count) |
{ |
__asm__ volatile ( |
7a: 81 e0 ldi r24, 0x01 ; 1 |
7c: 8a 95 dec r24 |
7e: f1 f7 brne .-4 ; 0x7c <LCD_send_nibble+0x1c> |
_delay_us(1); |
L_E; |
80: c1 98 cbi 0x18, 1 ; 24 |
} |
82: 08 95 ret |
00000084 <LCD_send>: |
H_RS; |
LCD_send(data); |
} |
void LCD_send(uint8_t data) |
{ |
84: 1f 93 push r17 |
86: 18 2f mov r17, r24 |
LCD_send_nibble(data >> 4); |
88: 82 95 swap r24 |
8a: 8f 70 andi r24, 0x0F ; 15 |
8c: e9 df rcall .-46 ; 0x60 <LCD_send_nibble> |
LCD_send_nibble(data); |
8e: 81 2f mov r24, r17 |
90: e7 df rcall .-50 ; 0x60 <LCD_send_nibble> |
92: 8d e0 ldi r24, 0x0D ; 13 |
94: 8a 95 dec r24 |
96: f1 f7 brne .-4 ; 0x94 <LCD_send+0x10> |
_delay_us(40); |
} |
98: 1f 91 pop r17 |
9a: 08 95 ret |
0000009c <LCD_send_data>: |
H_RS; |
} |
void LCD_send_data(uint8_t data) |
{ |
H_RS; |
9c: c2 9a sbi 0x18, 2 ; 24 |
LCD_send(data); |
9e: f2 df rcall .-28 ; 0x84 <LCD_send> |
} |
a0: 08 95 ret |
000000a2 <LCD_putc>: |
} |
} |
void LCD_putc(uint8_t data) |
{ |
LCD_send_data(data); |
a2: fc df rcall .-8 ; 0x9c <LCD_send_data> |
} |
a4: 08 95 ret |
000000a6 <LCD_send_command>: |
void LCD_send_command(uint8_t data) |
{ |
L_RS; |
a6: c2 98 cbi 0x18, 2 ; 24 |
LCD_send(data); |
a8: ed df rcall .-38 ; 0x84 <LCD_send> |
H_RS; |
aa: c2 9a sbi 0x18, 2 ; 24 |
} |
ac: 08 95 ret |
000000ae <LCD_init>: |
DDR_E |= _BV(PIN_E); |
DDR_RS |= _BV(PIN_RS); |
} |
void LCD_init(void) |
{ |
ae: 0f 93 push r16 |
b0: 1f 93 push r17 |
b2: cf 93 push r28 |
b4: df 93 push r29 |
uint8_t a; |
LCD_init_IO_PIN(); |
b6: cd df rcall .-102 ; 0x52 <LCD_init_IO_PIN> |
milliseconds can be achieved. |
*/ |
void |
_delay_loop_2(uint16_t __count) |
{ |
__asm__ volatile ( |
b8: 88 e8 ldi r24, 0x88 ; 136 |
ba: 93 e1 ldi r25, 0x13 ; 19 |
bc: 01 97 sbiw r24, 0x01 ; 1 |
be: f1 f7 brne .-4 ; 0xbc <LCD_init+0xe> |
_delay_ms(20); |
L_E; |
c0: c1 98 cbi 0x18, 1 ; 24 |
L_RS; |
c2: c2 98 cbi 0x18, 2 ; 24 |
c4: 04 ef ldi r16, 0xF4 ; 244 |
c6: 11 e0 ldi r17, 0x01 ; 1 |
c8: c8 01 movw r24, r16 |
ca: 01 97 sbiw r24, 0x01 ; 1 |
cc: f1 f7 brne .-4 ; 0xca <LCD_init+0x1c> |
for (a=0;a<3;a++) |
{ |
_delay_ms(2); |
LCD_send_nibble(0x3); |
ce: 83 e0 ldi r24, 0x03 ; 3 |
d0: c7 df rcall .-114 ; 0x60 <LCD_send_nibble> |
d2: c8 01 movw r24, r16 |
d4: 01 97 sbiw r24, 0x01 ; 1 |
d6: f1 f7 brne .-4 ; 0xd4 <LCD_init+0x26> |
d8: 83 e0 ldi r24, 0x03 ; 3 |
da: c2 df rcall .-124 ; 0x60 <LCD_send_nibble> |
dc: c8 01 movw r24, r16 |
de: 01 97 sbiw r24, 0x01 ; 1 |
e0: f1 f7 brne .-4 ; 0xde <LCD_init+0x30> |
e2: 83 e0 ldi r24, 0x03 ; 3 |
e4: bd df rcall .-134 ; 0x60 <LCD_send_nibble> |
can be achieved. |
*/ |
void |
_delay_loop_1(uint8_t __count) |
{ |
__asm__ volatile ( |
e6: 1d e0 ldi r17, 0x0D ; 13 |
e8: 81 2f mov r24, r17 |
ea: 8a 95 dec r24 |
ec: f1 f7 brne .-4 ; 0xea <LCD_init+0x3c> |
} |
_delay_us(40); |
LCD_send_nibble(0x2); |
ee: 82 e0 ldi r24, 0x02 ; 2 |
f0: b7 df rcall .-146 ; 0x60 <LCD_send_nibble> |
f2: 1a 95 dec r17 |
f4: f1 f7 brne .-4 ; 0xf2 <LCD_init+0x44> |
f6: 06 e2 ldi r16, 0x26 ; 38 |
f8: 10 e0 ldi r17, 0x00 ; 0 |
milliseconds can be achieved. |
*/ |
void |
_delay_loop_2(uint16_t __count) |
{ |
__asm__ volatile ( |
fa: c4 ef ldi r28, 0xF4 ; 244 |
fc: d1 e0 ldi r29, 0x01 ; 1 |
_delay_us(40); |
for (a=0;a<3;a++) |
{ |
LCD_send_command(pgm_read_byte(&(LCD_INIT_STRING[a]))); |
fe: f8 01 movw r30, r16 |
100: 84 91 lpm r24, Z+ |
102: d1 df rcall .-94 ; 0xa6 <LCD_send_command> |
104: ce 01 movw r24, r28 |
106: 01 97 sbiw r24, 0x01 ; 1 |
108: f1 f7 brne .-4 ; 0x106 <LCD_init+0x58> |
10a: 0f 5f subi r16, 0xFF ; 255 |
10c: 1f 4f sbci r17, 0xFF ; 255 |
} |
_delay_us(40); |
LCD_send_nibble(0x2); |
_delay_us(40); |
for (a=0;a<3;a++) |
10e: f0 e0 ldi r31, 0x00 ; 0 |
110: 09 32 cpi r16, 0x29 ; 41 |
112: 1f 07 cpc r17, r31 |
114: a1 f7 brne .-24 ; 0xfe <LCD_init+0x50> |
{ |
LCD_send_command(pgm_read_byte(&(LCD_INIT_STRING[a]))); |
_delay_ms(2); |
} |
} |
116: df 91 pop r29 |
118: cf 91 pop r28 |
11a: 1f 91 pop r17 |
11c: 0f 91 pop r16 |
11e: 08 95 ret |
00000120 <LCD_clear>: |
} |
void LCD_clear(void) |
{ |
LCD_send_command(1); |
120: 81 e0 ldi r24, 0x01 ; 1 |
122: c1 df rcall .-126 ; 0xa6 <LCD_send_command> |
124: 84 ef ldi r24, 0xF4 ; 244 |
126: 91 e0 ldi r25, 0x01 ; 1 |
128: 01 97 sbiw r24, 0x01 ; 1 |
12a: f1 f7 brne .-4 ; 0x128 <LCD_clear+0x8> |
_delay_ms(2); |
} |
12c: 08 95 ret |
0000012e <LCD_gotoxy>: |
void LCD_gotoxy( uint8_t x, uint8_t y) |
{ |
uint8_t Adr; |
Adr=x-1; |
12e: 81 50 subi r24, 0x01 ; 1 |
if(y==2) |
130: 62 30 cpi r22, 0x02 ; 2 |
132: 09 f4 brne .+2 ; 0x136 <LCD_gotoxy+0x8> |
Adr+=LCD_LINE_2; |
134: 80 5c subi r24, 0xC0 ; 192 |
LCD_send_command(0x80|Adr); |
136: 80 68 ori r24, 0x80 ; 128 |
138: b6 df rcall .-148 ; 0xa6 <LCD_send_command> |
} |
13a: 08 95 ret |
0000013c <ProcesDispl>: |
} |
void ProcesDispl(char *data) //zajiuje tisk øetìzce na lcd |
{ |
13c: ef 92 push r14 |
13e: ff 92 push r15 |
140: 1f 93 push r17 |
142: cf 93 push r28 |
144: df 93 push r29 |
146: 7c 01 movw r14, r24 |
148: c0 e0 ldi r28, 0x00 ; 0 |
14a: d0 e0 ldi r29, 0x00 ; 0 |
uint8_t a,b; |
for (a=0;a<MAXDISPLBUFFER;a++) |
{ |
switch (*(data+a)) |
14c: f7 01 movw r30, r14 |
14e: ec 0f add r30, r28 |
150: fd 1f adc r31, r29 |
152: 80 81 ld r24, Z |
154: 8a 30 cpi r24, 0x0A ; 10 |
156: 61 f0 breq .+24 ; 0x170 <ProcesDispl+0x34> |
158: 8b 30 cpi r24, 0x0B ; 11 |
15a: 28 f4 brcc .+10 ; 0x166 <ProcesDispl+0x2a> |
15c: 88 23 and r24, r24 |
15e: 49 f1 breq .+82 ; 0x1b2 <ProcesDispl+0x76> |
160: 87 30 cpi r24, 0x07 ; 7 |
162: 11 f5 brne .+68 ; 0x1a8 <ProcesDispl+0x6c> |
164: 0b c0 rjmp .+22 ; 0x17c <ProcesDispl+0x40> |
166: 8c 30 cpi r24, 0x0C ; 12 |
168: 61 f0 breq .+24 ; 0x182 <ProcesDispl+0x46> |
16a: 8d 30 cpi r24, 0x0D ; 13 |
16c: e9 f4 brne .+58 ; 0x1a8 <ProcesDispl+0x6c> |
16e: 02 c0 rjmp .+4 ; 0x174 <ProcesDispl+0x38> |
{ |
case 0: *data = 0;return; |
case '\n': LCD_gotoxy(1,2);break; //posun na druhej øádek |
170: 81 e0 ldi r24, 0x01 ; 1 |
172: 05 c0 rjmp .+10 ; 0x17e <ProcesDispl+0x42> |
case '\r': LCD_gotoxy(1,1);break; |
174: 81 e0 ldi r24, 0x01 ; 1 |
176: 61 e0 ldi r22, 0x01 ; 1 |
178: da df rcall .-76 ; 0x12e <LCD_gotoxy> |
17a: 17 c0 rjmp .+46 ; 0x1aa <ProcesDispl+0x6e> |
case '\a': LCD_gotoxy(6,2);break; //posun na 2.øádek 6.políèko |
17c: 86 e0 ldi r24, 0x06 ; 6 |
17e: 62 e0 ldi r22, 0x02 ; 2 |
180: fb cf rjmp .-10 ; 0x178 <ProcesDispl+0x3c> |
case '\f': LCD_gotoxy(1,1); |
182: 81 e0 ldi r24, 0x01 ; 1 |
184: 61 e0 ldi r22, 0x01 ; 1 |
186: d3 df rcall .-90 ; 0x12e <LCD_gotoxy> |
188: 10 e0 ldi r17, 0x00 ; 0 |
} |
} |
void LCD_putc(uint8_t data) |
{ |
LCD_send_data(data); |
18a: 80 e2 ldi r24, 0x20 ; 32 |
18c: 87 df rcall .-242 ; 0x9c <LCD_send_data> |
for (b=0;b<8;b++) LCD_putc(0x20); |
18e: 1f 5f subi r17, 0xFF ; 255 |
190: 18 30 cpi r17, 0x08 ; 8 |
192: d9 f7 brne .-10 ; 0x18a <ProcesDispl+0x4e> |
LCD_gotoxy(1,2); |
194: 81 e0 ldi r24, 0x01 ; 1 |
196: 62 e0 ldi r22, 0x02 ; 2 |
198: ca df rcall .-108 ; 0x12e <LCD_gotoxy> |
19a: 10 e0 ldi r17, 0x00 ; 0 |
19c: 80 e2 ldi r24, 0x20 ; 32 |
19e: 7e df rcall .-260 ; 0x9c <LCD_send_data> |
for (b=0;b<8;b++) LCD_putc(0x20); |
1a0: 1f 5f subi r17, 0xFF ; 255 |
1a2: 18 30 cpi r17, 0x08 ; 8 |
1a4: d9 f7 brne .-10 ; 0x19c <ProcesDispl+0x60> |
1a6: e6 cf rjmp .-52 ; 0x174 <ProcesDispl+0x38> |
1a8: 79 df rcall .-270 ; 0x9c <LCD_send_data> |
1aa: 21 96 adiw r28, 0x01 ; 1 |
void ProcesDispl(char *data) //zajiuje tisk øetìzce na lcd |
{ |
uint8_t a,b; |
for (a=0;a<MAXDISPLBUFFER;a++) |
1ac: c4 31 cpi r28, 0x14 ; 20 |
1ae: d1 05 cpc r29, r1 |
1b0: 69 f6 brne .-102 ; 0x14c <ProcesDispl+0x10> |
LCD_gotoxy(1,1); |
break; |
default : LCD_putc(*(data+a)); |
} |
} |
*data = 0; |
1b2: f7 01 movw r30, r14 |
1b4: 10 82 st Z, r1 |
} |
1b6: df 91 pop r29 |
1b8: cf 91 pop r28 |
1ba: 1f 91 pop r17 |
1bc: ff 90 pop r15 |
1be: ef 90 pop r14 |
1c0: 08 95 ret |
000001c2 <main>: |
//----------------------------------------------------------------------------- |
int main(void) |
{ |
1c2: 0f 93 push r16 |
1c4: 1f 93 push r17 |
1c6: df 93 push r29 |
1c8: cf 93 push r28 |
1ca: cd b7 in r28, 0x3d ; 61 |
1cc: de b7 in r29, 0x3e ; 62 |
1ce: 63 97 sbiw r28, 0x13 ; 19 |
1d0: 0f b6 in r0, 0x3f ; 63 |
1d2: f8 94 cli |
1d4: de bf out 0x3e, r29 ; 62 |
1d6: 0f be out 0x3f, r0 ; 63 |
1d8: cd bf out 0x3d, r28 ; 61 |
LCD_init(); //Inicializace LCD |
1da: 69 df rcall .-302 ; 0xae <LCD_init> |
sprintf(zasobnik,"LCD je OK"); |
1dc: 8e 01 movw r16, r28 |
1de: 0f 5f subi r16, 0xFF ; 255 |
1e0: 1f 4f sbci r17, 0xFF ; 255 |
1e2: c8 01 movw r24, r16 |
1e4: 60 e6 ldi r22, 0x60 ; 96 |
1e6: 70 e0 ldi r23, 0x00 ; 0 |
1e8: 1b d0 rcall .+54 ; 0x220 <strcpy> |
LCD_gotoxy(0,0); |
1ea: 80 e0 ldi r24, 0x00 ; 0 |
1ec: 60 e0 ldi r22, 0x00 ; 0 |
1ee: 9f df rcall .-194 ; 0x12e <LCD_gotoxy> |
ProcesDispl(zasobnik); |
1f0: c8 01 movw r24, r16 |
1f2: a4 df rcall .-184 ; 0x13c <ProcesDispl> |
LCD_gotoxy(0,2); |
1f4: 80 e0 ldi r24, 0x00 ; 0 |
1f6: 62 e0 ldi r22, 0x02 ; 2 |
1f8: 9a df rcall .-204 ; 0x12e <LCD_gotoxy> |
ProcesDispl(zasobnik); |
1fa: c8 01 movw r24, r16 |
1fc: 9f df rcall .-194 ; 0x13c <ProcesDispl> |
1fe: 8a ef ldi r24, 0xFA ; 250 |
200: 90 e0 ldi r25, 0x00 ; 0 |
202: 01 97 sbiw r24, 0x01 ; 1 |
204: f1 f7 brne .-4 ; 0x202 <main+0x40> |
return 0; |
} |
206: 80 e0 ldi r24, 0x00 ; 0 |
208: 90 e0 ldi r25, 0x00 ; 0 |
20a: 63 96 adiw r28, 0x13 ; 19 |
20c: 0f b6 in r0, 0x3f ; 63 |
20e: f8 94 cli |
210: de bf out 0x3e, r29 ; 62 |
212: 0f be out 0x3f, r0 ; 63 |
214: cd bf out 0x3d, r28 ; 61 |
216: cf 91 pop r28 |
218: df 91 pop r29 |
21a: 1f 91 pop r17 |
21c: 0f 91 pop r16 |
21e: 08 95 ret |
00000220 <strcpy>: |
220: fb 01 movw r30, r22 |
222: dc 01 movw r26, r24 |
224: 01 90 ld r0, Z+ |
226: 0d 92 st X+, r0 |
228: 00 20 and r0, r0 |
22a: e1 f7 brne .-8 ; 0x224 <strcpy+0x4> |
22c: 08 95 ret |
0000022e <_exit>: |
22e: f8 94 cli |
00000230 <__stop_program>: |
230: ff cf rjmp .-2 ; 0x230 <__stop_program> |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/LCD_zkouska.map |
---|
0,0 → 1,372 |
Archive member included because of file (symbol) |
c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o (exit) |
c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
LCD_zkouska.o (__do_copy_data) |
c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a(strcpy.o) |
LCD_zkouska.o (strcpy) |
Memory Configuration |
Name Origin Length Attributes |
text 0x00000000 0x00002000 xr |
data 0x00800060 0x0000ffa0 rw !x |
eeprom 0x00810000 0x00010000 rw !x |
fuse 0x00820000 0x00000400 rw !x |
lock 0x00830000 0x00000400 rw !x |
signature 0x00840000 0x00000400 rw !x |
*default* 0x00000000 0xffffffff |
Linker script and memory map |
LOAD c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
LOAD LCD_zkouska.o |
LOAD c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a |
LOAD c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a |
LOAD c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a |
.hash |
*(.hash) |
.dynsym |
*(.dynsym) |
.dynstr |
*(.dynstr) |
.gnu.version |
*(.gnu.version) |
.gnu.version_d |
*(.gnu.version_d) |
.gnu.version_r |
*(.gnu.version_r) |
.rel.init |
*(.rel.init) |
.rela.init |
*(.rela.init) |
.rel.text |
*(.rel.text) |
*(.rel.text.*) |
*(.rel.gnu.linkonce.t*) |
.rela.text |
*(.rela.text) |
*(.rela.text.*) |
*(.rela.gnu.linkonce.t*) |
.rel.fini |
*(.rel.fini) |
.rela.fini |
*(.rela.fini) |
.rel.rodata |
*(.rel.rodata) |
*(.rel.rodata.*) |
*(.rel.gnu.linkonce.r*) |
.rela.rodata |
*(.rela.rodata) |
*(.rela.rodata.*) |
*(.rela.gnu.linkonce.r*) |
.rel.data |
*(.rel.data) |
*(.rel.data.*) |
*(.rel.gnu.linkonce.d*) |
.rela.data |
*(.rela.data) |
*(.rela.data.*) |
*(.rela.gnu.linkonce.d*) |
.rel.ctors |
*(.rel.ctors) |
.rela.ctors |
*(.rela.ctors) |
.rel.dtors |
*(.rel.dtors) |
.rela.dtors |
*(.rela.dtors) |
.rel.got |
*(.rel.got) |
.rela.got |
*(.rela.got) |
.rel.bss |
*(.rel.bss) |
.rela.bss |
*(.rela.bss) |
.rel.plt |
*(.rel.plt) |
.rela.plt |
*(.rela.plt) |
.text 0x00000000 0x232 |
*(.vectors) |
.vectors 0x00000000 0x26 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
0x00000000 __vectors |
0x00000000 __vector_default |
*(.vectors) |
*(.progmem.gcc*) |
*(.progmem*) |
.progmem.data 0x00000026 0x4 LCD_zkouska.o |
0x00000026 LCD_INIT_STRING |
0x0000002a . = ALIGN (0x2) |
0x0000002a __trampolines_start = . |
*(.trampolines) |
.trampolines 0x0000002a 0x0 linker stubs |
*(.trampolines*) |
0x0000002a __trampolines_end = . |
*(.jumptables) |
*(.jumptables*) |
*(.lowtext) |
*(.lowtext*) |
0x0000002a __ctors_start = . |
*(.ctors) |
0x0000002a __ctors_end = . |
0x0000002a __dtors_start = . |
*(.dtors) |
0x0000002a __dtors_end = . |
SORT(*)(.ctors) |
SORT(*)(.dtors) |
*(.init0) |
.init0 0x0000002a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
0x0000002a __init |
*(.init0) |
*(.init1) |
*(.init1) |
*(.init2) |
.init2 0x0000002a 0xc c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
*(.init2) |
*(.init3) |
*(.init3) |
*(.init4) |
.init4 0x00000036 0x16 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
0x00000036 __do_copy_data |
*(.init4) |
*(.init5) |
*(.init5) |
*(.init6) |
*(.init6) |
*(.init7) |
*(.init7) |
*(.init8) |
*(.init8) |
*(.init9) |
.init9 0x0000004c 0x4 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
*(.init9) |
*(.text) |
.text 0x00000050 0x2 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
0x00000050 __vector_1 |
0x00000050 __vector_12 |
0x00000050 __bad_interrupt |
0x00000050 __vector_6 |
0x00000050 __vector_3 |
0x00000050 __vector_11 |
0x00000050 __vector_13 |
0x00000050 __vector_17 |
0x00000050 __vector_7 |
0x00000050 __vector_5 |
0x00000050 __vector_4 |
0x00000050 __vector_9 |
0x00000050 __vector_2 |
0x00000050 __vector_15 |
0x00000050 __vector_8 |
0x00000050 __vector_14 |
0x00000050 __vector_10 |
0x00000050 __vector_16 |
0x00000050 __vector_18 |
.text 0x00000052 0x1ce LCD_zkouska.o |
0x00000120 LCD_clear |
0x00000060 LCD_send_nibble |
0x000000a6 LCD_send_command |
0x000000ae LCD_init |
0x00000084 LCD_send |
0x00000052 LCD_init_IO_PIN |
0x0000009c LCD_send_data |
0x000001c2 main |
0x000000a2 LCD_putc |
0x0000012e LCD_gotoxy |
0x0000013c ProcesDispl |
.text 0x00000220 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
.text 0x00000220 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
.text 0x00000220 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a(strcpy.o) |
0x00000220 . = ALIGN (0x2) |
*(.text.*) |
.text.libgcc 0x00000220 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
.text.libgcc 0x00000220 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
.text.avr-libc |
0x00000220 0xe c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a(strcpy.o) |
0x00000220 strcpy |
0x0000022e . = ALIGN (0x2) |
*(.fini9) |
.fini9 0x0000022e 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
0x0000022e exit |
0x0000022e _exit |
*(.fini9) |
*(.fini8) |
*(.fini8) |
*(.fini7) |
*(.fini7) |
*(.fini6) |
*(.fini6) |
*(.fini5) |
*(.fini5) |
*(.fini4) |
*(.fini4) |
*(.fini3) |
*(.fini3) |
*(.fini2) |
*(.fini2) |
*(.fini1) |
*(.fini1) |
*(.fini0) |
.fini0 0x0000022e 0x4 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
*(.fini0) |
0x00000232 _etext = . |
.data 0x00800060 0xa load address 0x00000232 |
0x00800060 PROVIDE (__data_start, .) |
*(.data) |
.data 0x00800060 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
.data 0x00800060 0xa LCD_zkouska.o |
.data 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
.data 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
.data 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a(strcpy.o) |
*(.data*) |
*(.rodata) |
*(.rodata*) |
*(.gnu.linkonce.d*) |
0x0080006a . = ALIGN (0x2) |
0x0080006a _edata = . |
0x0080006a PROVIDE (__data_end, .) |
.bss 0x0080006a 0x0 |
0x0080006a PROVIDE (__bss_start, .) |
*(.bss) |
.bss 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4/crtm8.o |
.bss 0x0080006a 0x0 LCD_zkouska.o |
.bss 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_exit.o) |
.bss 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/avr4\libgcc.a(_copy_data.o) |
.bss 0x0080006a 0x0 c:/winavr-20100110/bin/../lib/gcc/avr/4.3.3/../../../../avr/lib/avr4\libc.a(strcpy.o) |
*(.bss*) |
*(COMMON) |
0x0080006a PROVIDE (__bss_end, .) |
0x00000232 __data_load_start = LOADADDR (.data) |
0x0000023c __data_load_end = (__data_load_start + SIZEOF (.data)) |
.noinit 0x0080006a 0x0 |
0x0080006a PROVIDE (__noinit_start, .) |
*(.noinit*) |
0x0080006a PROVIDE (__noinit_end, .) |
0x0080006a _end = . |
0x0080006a PROVIDE (__heap_start, .) |
.eeprom 0x00810000 0x0 |
*(.eeprom*) |
0x00810000 __eeprom_end = . |
.fuse |
*(.fuse) |
*(.lfuse) |
*(.hfuse) |
*(.efuse) |
.lock |
*(.lock*) |
.signature |
*(.signature*) |
.stab |
*(.stab) |
.stabstr |
*(.stabstr) |
.stab.excl |
*(.stab.excl) |
.stab.exclstr |
*(.stab.exclstr) |
.stab.index |
*(.stab.index) |
.stab.indexstr |
*(.stab.indexstr) |
.comment |
*(.comment) |
.debug |
*(.debug) |
.line |
*(.line) |
.debug_srcinfo |
*(.debug_srcinfo) |
.debug_sfnames |
*(.debug_sfnames) |
.debug_aranges 0x00000000 0x20 |
*(.debug_aranges) |
.debug_aranges |
0x00000000 0x20 LCD_zkouska.o |
.debug_pubnames |
0x00000000 0xd2 |
*(.debug_pubnames) |
.debug_pubnames |
0x00000000 0xd2 LCD_zkouska.o |
.debug_info 0x00000000 0x577 |
*(.debug_info) |
.debug_info 0x00000000 0x577 LCD_zkouska.o |
*(.gnu.linkonce.wi.*) |
.debug_abbrev 0x00000000 0x1da |
*(.debug_abbrev) |
.debug_abbrev 0x00000000 0x1da LCD_zkouska.o |
.debug_line 0x00000000 0x413 |
*(.debug_line) |
.debug_line 0x00000000 0x413 LCD_zkouska.o |
.debug_frame 0x00000000 0xc0 |
*(.debug_frame) |
.debug_frame 0x00000000 0xc0 LCD_zkouska.o |
.debug_str 0x00000000 0x192 |
*(.debug_str) |
.debug_str 0x00000000 0x192 LCD_zkouska.o |
0x1d0 (size before relaxing) |
.debug_loc 0x00000000 0x17f |
*(.debug_loc) |
.debug_loc 0x00000000 0x17f LCD_zkouska.o |
.debug_macinfo |
*(.debug_macinfo) |
OUTPUT(LCD_zkouska.elf elf32-avr) |
LOAD linker stubs |
.debug_ranges 0x00000000 0xa8 |
.debug_ranges 0x00000000 0xa8 LCD_zkouska.o |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/default/dep/LCD_zkouska.o.d |
---|
0,0 → 1,53 |
LCD_zkouska.o: ../LCD_zkouska.c \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/io.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/sfr_defs.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/inttypes.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/stdint.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/iom8.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/portpins.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/common.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/version.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/fuse.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/lock.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/stdio.h \ |
c:\winavr-20100110\bin\../lib/gcc/avr/4.3.3/include/stdarg.h \ |
c:\winavr-20100110\bin\../lib/gcc/avr/4.3.3/include/stddef.h ../lcd.h \ |
../lcd.c c:/winavr-20100110/lib/gcc/../../avr/include/util/delay.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/util/delay_basic.h \ |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/pgmspace.h |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/io.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/sfr_defs.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/inttypes.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/stdint.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/iom8.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/portpins.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/common.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/version.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/fuse.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/lock.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/stdio.h: |
c:\winavr-20100110\bin\../lib/gcc/avr/4.3.3/include/stdarg.h: |
c:\winavr-20100110\bin\../lib/gcc/avr/4.3.3/include/stddef.h: |
../lcd.h: |
../lcd.c: |
c:/winavr-20100110/lib/gcc/../../avr/include/util/delay.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/util/delay_basic.h: |
c:/winavr-20100110/lib/gcc/../../avr/include/avr/pgmspace.h: |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/LCD_zkouska.aps |
---|
0,0 → 1,0 |
<AVRStudio><MANAGEMENT><ProjectName>LCD_zkouska</ProjectName><Created>21-Nov-2011 21:14:11</Created><LastEdit>21-Nov-2011 21:22:19</LastEdit><ICON>241</ICON><ProjectType>0</ProjectType><Created>21-Nov-2011 21:14:11</Created><Version>4</Version><Build>4, 18, 0, 685</Build><ProjectTypeName>AVR GCC</ProjectTypeName></MANAGEMENT><CODE_CREATION><ObjectFile>default\LCD_zkouska.elf</ObjectFile><EntryFile></EntryFile><SaveFolder>C:\Users\Honza\Documents\c\LCD_zkouska\</SaveFolder></CODE_CREATION><DEBUG_TARGET><CURRENT_TARGET>ICE50</CURRENT_TARGET><CURRENT_PART>ATmega8.xml</CURRENT_PART><BREAKPOINTS></BREAKPOINTS><IO_EXPAND><HIDE>false</HIDE></IO_EXPAND><REGISTERNAMES><Register>R00</Register><Register>R01</Register><Register>R02</Register><Register>R03</Register><Register>R04</Register><Register>R05</Register><Register>R06</Register><Register>R07</Register><Register>R08</Register><Register>R09</Register><Register>R10</Register><Register>R11</Register><Register>R12</Register><Register>R13</Register><Register>R14</Register><Register>R15</Register><Register>R16</Register><Register>R17</Register><Register>R18</Register><Register>R19</Register><Register>R20</Register><Register>R21</Register><Register>R22</Register><Register>R23</Register><Register>R24</Register><Register>R25</Register><Register>R26</Register><Register>R27</Register><Register>R28</Register><Register>R29</Register><Register>R30</Register><Register>R31</Register></REGISTERNAMES><COM>Auto</COM><COMType>0</COMType><WATCHNUM>0</WATCHNUM><WATCHNAMES><Pane0></Pane0><Pane1></Pane1><Pane2></Pane2><Pane3></Pane3></WATCHNAMES><BreakOnTrcaeFull>0</BreakOnTrcaeFull></DEBUG_TARGET><Debugger><Triggers></Triggers></Debugger><AVRGCCPLUGIN><FILES><SOURCEFILE>LCD_zkouska.c</SOURCEFILE><OTHERFILE>default\LCD_zkouska.lss</OTHERFILE><OTHERFILE>default\LCD_zkouska.map</OTHERFILE></FILES><CONFIGS><CONFIG><NAME>default</NAME><USESEXTERNALMAKEFILE>NO</USESEXTERNALMAKEFILE><EXTERNALMAKEFILE></EXTERNALMAKEFILE><PART>atmega8</PART><HEX>1</HEX><LIST>1</LIST><MAP>1</MAP><OUTPUTFILENAME>LCD_zkouska.elf</OUTPUTFILENAME><OUTPUTDIR>default\</OUTPUTDIR><ISDIRTY>1</ISDIRTY><OPTIONS/><INCDIRS/><LIBDIRS/><LIBS/><LINKOBJECTS/><OPTIONSFORALL>-Wall -gdwarf-2 -Os -std=gnu99 -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums</OPTIONSFORALL><LINKEROPTIONS></LINKEROPTIONS><SEGMENTS/></CONFIG></CONFIGS><LASTCONFIG>default</LASTCONFIG><USES_WINAVR>1</USES_WINAVR><GCC_LOC>C:\WinAVR-20100110\bin\avr-gcc.exe</GCC_LOC><MAKE_LOC>C:\WinAVR-20100110\utils\bin\make.exe</MAKE_LOC></AVRGCCPLUGIN><IOView><usergroups/><sort sorted="0" column="0" ordername="1" orderaddress="1" ordergroup="1"/></IOView><Files><File00000><FileId>00000</FileId><FileName>LCD_zkouska.c</FileName><Status>1</Status></File00000><File00001><FileId>00001</FileId><FileName>c:\winavr-20100110\avr\include\util\delay.h</FileName><Status>1</Status></File00001></Files><Events><Bookmarks></Bookmarks></Events><Trace><Filters></Filters></Trace></AVRStudio> |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/lcd.c |
---|
0,0 → 1,147 |
/* mija 2008 |
source file for lcd HITACHI 16x2,8x2,... |
!!! must be set PINs,PORTs,DDR in lcd.h |
ver.: 0.0 TESTED |
*/ |
#include <avr/io.h> |
#include <util/delay.h> |
#include <avr/pgmspace.h> |
#include "lcd.h" |
//#include <stdio.h> |
//************************************************************* |
#define H_D0 PORT_D0 |=_BV(PIN_D0) |
#define L_D0 PORT_D0 &= ~(_BV(PIN_D0)) |
#define H_D1 PORT_D1 |=_BV(PIN_D1) |
#define L_D1 PORT_D1 &= ~(_BV(PIN_D1)) |
#define H_D2 PORT_D2 |=_BV(PIN_D2) |
#define L_D2 PORT_D2 &= ~(_BV(PIN_D2)) |
#define H_D3 PORT_D3 |=_BV(PIN_D3) |
#define L_D3 PORT_D3 &= ~(_BV(PIN_D3)) |
#define H_E PORT_E |=_BV(PIN_E) |
#define L_E PORT_E &= ~(_BV(PIN_E)) |
#define H_RS PORT_RS |=_BV(PIN_RS) |
#define L_RS PORT_RS &= ~(_BV(PIN_RS)) |
//************************************************************* |
// Definice konstant pro LCD display |
// |
#define LCD_CURSOR_ON_ 0x0E // kurzor jako blikajici radka pod znakem |
#define LCD_CURSOR_OFF_ 0x0C // zadny kurzor |
#define LCD_LINE_2 0x40 // adresa 1. znaku 2. radky |
// Definice rezimu LCD displeje |
// |
uint8_t PROGMEM LCD_INIT_STRING[4] = |
{ |
0x28, // intrfejs 4 bity, 2 radky, font 5x7 |
LCD_CURSOR_OFF_, // display on, kurzor off, |
0x01, // clear displeje |
0x06 // inkrement pozice kurzoru (posun kurzoru doprava) |
}; |
void LCD_init_IO_PIN(void) |
{ |
DDR_D0 |= _BV(PIN_D0); |
DDR_D1 |= _BV(PIN_D1); |
DDR_D2 |= _BV(PIN_D2); |
DDR_D3 |= _BV(PIN_D3); |
DDR_E |= _BV(PIN_E); |
DDR_RS |= _BV(PIN_RS); |
} |
void LCD_init(void) |
{ |
uint8_t a; |
LCD_init_IO_PIN(); |
_delay_ms(20); |
L_E; |
L_RS; |
for (a=0;a<3;a++) |
{ |
_delay_ms(2); |
LCD_send_nibble(0x3); |
} |
_delay_us(40); |
LCD_send_nibble(0x2); |
_delay_us(40); |
for (a=0;a<3;a++) |
{ |
LCD_send_command(pgm_read_byte(&(LCD_INIT_STRING[a]))); |
_delay_ms(2); |
} |
} |
void LCD_putc(uint8_t data) |
{ |
LCD_send_data(data); |
} |
void LCD_send_command(uint8_t data) |
{ |
L_RS; |
LCD_send(data); |
H_RS; |
} |
void LCD_send_data(uint8_t data) |
{ |
H_RS; |
LCD_send(data); |
} |
void LCD_send(uint8_t data) |
{ |
LCD_send_nibble(data >> 4); |
LCD_send_nibble(data); |
_delay_us(40); |
} |
void LCD_send_nibble(uint8_t data) |
{ |
L_D0;L_D1;L_D2;L_D3; |
if (data & 0x1) H_D0; |
if (data & 0x2) H_D1; |
if (data & 0x4) H_D2; |
if (data & 0x8) H_D3; |
H_E; |
_delay_us(1); |
L_E; |
} |
void LCD_clear(void) |
{ |
LCD_send_command(1); |
_delay_ms(2); |
} |
void LCD_gotoxy( uint8_t x, uint8_t y) |
{ |
uint8_t Adr; |
Adr=x-1; |
if(y==2) |
Adr+=LCD_LINE_2; |
LCD_send_command(0x80|Adr); |
} |
/Modules/HumanInterfaces/LCD2L4P02A/SW/AVR/lcd.h |
---|
0,0 → 1,75 |
/* mija 2008 |
*.h file for defines lcd.c |
data PIN_D0 |
PIN_D1 |
PIN_D2 |
PIN_D3 |
write PIN_E |
commamnd/data PIN_RS |
!!!!NOTE must be set PIN with PORT and DDR |
*/ |
//************************************************************* |
#define PIN_D0 PC3 |
#define PORT_D0 PORTC |
#define DDR_D0 DDRC |
#define PIN_D1 PB4 |
#define PORT_D1 PORTB |
#define DDR_D1 DDRB |
#define PIN_D2 PB5 |
#define PORT_D2 PORTB |
#define DDR_D2 DDRB |
#define PIN_D3 PB3 |
#define PORT_D3 PORTB |
#define DDR_D3 DDRB |
#define PIN_E PB1 |
#define PORT_E PORTB |
#define DDR_E DDRB |
#define PIN_RS PB2 |
#define PORT_RS PORTB |
#define DDR_RS DDRB |
//************************************************************* |
void LCD_init(void); |
void LCD_putc(uint8_t data); |
void LCD_gotoxy( uint8_t x, uint8_t y); |
void LCD_clear(void); |
void LCD_send_data(uint8_t data); |
void LCD_send_command(uint8_t data); |
void LCD_send(uint8_t data); |
void LCD_send_nibble(uint8_t data); |
void LCD_init_IO_PIN(void); |
//************************************************************* |
//********************** example printf *********************** |
/* |
#inlcude <stdio.h> |
static int put_lcd(char c, FILE *stream); |
static FILE mystdout = FDEV_SETUP_STREAM(put_lcd, NULL,_FDEV_SETUP_WRITE); |
static int put_lcd(char c, FILE *stream) |
{ |
switch (c) |
{ |
case '\n': LCD_gotoxy(1,2);break; |
case '\r': LCD_gotoxy(1,1);break; |
default : LCD_putc(c); |
} |
return 0; |
}*/ |
//************************************************************* |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/img/LCD2L4P02A_QRcode.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/LCD2L4P02A.doc |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/Detail_RX.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/LCD2L4P02A_Bot_Big.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/LCD2L4P02A_Bot_Big_noRX.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/LCD2L4P02A_Bot_Small_noRX.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/LCD2L4P02A_Top_Big.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/Piezo_Ring.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/SRC/PIC/Piezo_Wires.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A.cs.html |
---|
0,0 → 1,809 |
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> |
<html> |
<head> |
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> |
<title> LCD2L4P02A </title> |
<meta name="keywords" content="LCD Hitachi HD44780 display tlačítka piezoelement"> |
<meta name="description" content="Modul dvouřádkového LCD displeje se čtyřmi tlačítky a piezoelementem"> |
<!-- AUTOINCLUDE START "Page/Head.cs.ihtml" DO NOT REMOVE --> |
<link rel="StyleSheet" href="../../../../../Web/CSS/MLAB.css" type="text/css" title="MLAB základní styl"> |
<link rel="StyleSheet" href="../../../../../Web/CSS/MLAB_Print.css" type="text/css" media="print"> |
<link rel="shortcut icon" type="image/x-icon" href="../../../../../Web/PIC/MLAB.ico"> |
<script type="text/javascript" src="../../../../../Web/JS/MLAB_Menu.js"></script> |
<!-- AUTOINCLUDE END --> |
</head> |
<body lang="cs"> |
<!-- AUTOINCLUDE START "Page/Header.cs.ihtml" DO NOT REMOVE --> |
<!-- ============== HLAVICKA ============== --> |
<div class="Header"> |
<script type="text/javascript"> |
<!-- |
SetRelativePath("../../../../../"); |
DrawHeader(); |
// --> |
</script> |
<noscript> |
<p><b> Pro zobrazení (vložení) hlavičky je potřeba JavaScript </b></p> |
</noscript> |
</div> |
<!-- AUTOINCLUDE END --> |
<!-- AUTOINCLUDE START "Page/Menu.cs.ihtml" DO NOT REMOVE --> |
<!-- ============== MENU ============== --> |
<div class="Menu"> |
<script type="text/javascript"> |
<!-- |
SetRelativePath("../../../../../"); |
DrawMenu(); |
// --> |
</script> |
<noscript> |
<p><b> Pro zobrazení (vložení) menu je potřeba JavaScript </b></p> |
</noscript> |
</div> |
<!-- AUTOINCLUDE END --> |
<!-- ============== TEXT ============== --> |
<div class="Text"> |
<p class="Title"> |
Modul LCD displeje se čtyřmi tlačítky a piezoelementem |
</p> |
<p class=Autor> |
Milan Horkel, Jakub Kákona |
</p> |
<p class="Subtitle"> |
Modul LCD2L4P obsahuje dvouřádkový LCD displej s obvyklým Hitachi |
řadičem a čtveřici tlačítek. Dále je vybaven piezoelementem |
s oddělovačem 74HC04. Modul se používá jako univerzální |
uživatelský interfejs při pokusech s mikroprocesorovými |
konstrukcemi. |
</p> |
<p class="Subtitle"> |
<img width="565" height="348" src="LCD2L4P02A_files/image001.jpg" |
alt="Pohled na modul displeje"> |
</p> |
<p> |
<a href="../LCD2L4P02A.cs.pdf"><img class="NoBorder" |
src="../../../../../Web/PIC/FileIco_PDF.ico" |
alt="Acrobat"> PDF verze</a> |
</p> |
<h1> Technické parametry </h1> |
<table> |
<tr> |
<th> Parametr </th> |
<th> Hodnota </th> |
<th> Poznámka </th> |
</tr> |
<tr> |
<td> Napájení </td> |
<td> +5V nebo +3V/-2V </td> |
<td> Záporné napětí pro řízení kontrastu </td> |
</tr> |
<tr> |
<td> Spotřeba </td> |
<td> cca 1mA </td> |
<td> Při +5V (dle displeje, bez zvuku) </td> |
</tr> |
<tr> |
<td> Displej </td> |
<td> LCD, 2 řádky po 16 znacích </td> |
<td> Hitachi řadič </td> |
</tr> |
<tr> |
<td> Tlačítka </td> |
<td> 4 spínací tlačítka do země </td> |
<td> Volitelný pull-up odpor </td> |
</tr> |
<tr> |
<td> Piezoelement </td> |
<td> 1ks </td> |
<td> Buzený z obvodu 74HC04 protitaktně </td> |
</tr> |
<tr> |
<td> Rozměry </td> |
<td> 61 x 101 x 22 mm </td> |
<td> Výška nad nosnou deskou </td> |
</tr> |
</table> |
<h1> Popis konstrukce </h1> |
<h2> Úvodem </h2> |
<p> |
Na modulu je osazen obyčejný standardní dvouřádkový LCD displej |
s Hitachi řadičem (to jsou skoro všechny dostupné řádkové |
displeje). Z displeje je vyveden jen 4 bitový interfejs a |
příslušné řídící signály. Pomocí propojek je možné připojit trimr pro |
řízení kontrastu displeje a trvale nastavit řídící signál RW na režim |
jen zápis (v obvyklých konstrukcích se z LCD displeje nic nečte, |
ušetří se vývod procesoru). |
</p> |
<p> |
Pod displejem jsou umístěna 4 velká spínací tlačítka do země. Pomocí |
řady propojek označené „PULL UPS“ je možné připojit pull-up odpory |
do plusu (hodnota 10k). |
</p> |
<p> |
Pod displejem je schovaný piezoelement, který je buzený protitaktně |
z obvodu 74HC04. |
</p> |
<h2> Zapojení modulu </h2> |
<p> |
<img width="382" height="145" src="LCD2L4P02A_files/image002.png" |
alt="Schéma zdroje"> |
</p> |
<p> |
Dioda D1 je ochranná dioda proti přepólování napájení. |
</p> |
<p> |
<img width="805" height="408" src="LCD2L4P02A_files/image003.png" |
alt="Schéma displeje"> |
</p> |
<p> |
Standardní napájení je +5V, ale v případě potřeby může být |
napájení menší. Aby bylo na displeji něco vidět, je třeba dosáhnout |
rozdílu kladného napájecího napětí a napětí pro kontrast |
(označené Vo) cca 5V. Napětí pro kontrast pak bude záporné. |
Napájecí proud pro řízení kontrastu je velmi malý a dá se snadno |
nastřídat. Při sníženém napájecím napětí je podstatně snížena spotřeba. |
Spotřebu lze u některých displejů dále snížit zvětšením odporů na |
displeji (dělič pro výrobu interních napětí pro displej, odpory jsou |
zapojené v sérii a někdy mají zbytečně malou hodnotu). |
</p> |
<p> |
Odpory 1k jsou zapojeny proto, aby při experimentech nebylo tak snadné |
poškodit výstupy z displeje. Pokud se do displeje jen zapisuje je |
třeba uzemnit signál RW. Proto je J4 tam, kde je. |
</p> |
<p> |
Podsvícení je jen propojeno na displej. Podsvícení bývá realizováno LED |
diodami zapojenými v sérii a je jej třeba budit zdrojem proudu. |
</p> |
<p> |
<img width="385" height="595" src="LCD2L4P02A_files/image004.png" |
alt="Schéma tlačítek"> |
</p> |
<p> |
Zapojení tlačítek je přímočaré. Odpory R6 až R9 jsou volitelné |
(propojkami J9) pull-up odpory. Tlačítka jsou napevno zapojená „do země“. |
</p> |
<p> |
Piezoelement (pod displejem) je buzen protitaktně přímo z výstupů |
obvodu U2. Aby volný vstup nechytal rušení (brum), je zapojení doplněno |
odporem RX, který zajišťuje stabilní úroveň na vstupu, pokud není buzen |
z vnějšku. |
</p> |
<p> |
<img width="775" height="275" src="LCD2L4P02A_files/image005.png" |
alt="Schéma budiče piezoelementu"> |
</p> |
<h1> Osazení a oživení </h1> |
<h2> Osazení </h2> |
<p> |
Před osazením LCD displeje nezapomeneme osadit piezoelement. Ten se |
lepí na mezikruží vystřižené z oboustranně lepící samolepky. |
Vznikne tak tlaková komůrka a výsledný zvuk je mnohem silnější. |
Mezikruží musí být nalepeno tak, aby dírka byla uvnitř. |
</p> |
<p> |
<img width="202" height="210" src="LCD2L4P02A_files/image008.jpg" |
alt="Nalepené mezikruží"> |
|
<img width="219" height="210" src="LCD2L4P02A_files/image009.jpg" |
alt="Nalepený piezoelement"> |
</p> |
<p> |
Displej je přichycen šrouby M2.5 a mezi desku displeje a plošný spoj |
modulu musíme vložit distanční válečky, například 1 nebo 2 matičky M3. |
Displej nesmí být opřen o plošný spoj ani o piezoelement. |
</p> |
<p> |
Propojovací hřebínek na LCD je vhodné zapájet až po přišroubování |
displeje. |
</p> |
<p> |
<img width="230" height="210" src="LCD2L4P02A_files/image010.jpg" |
alt="Osazený rezistor RX"> |
</p> |
<p> |
Odpor RX bohužel nemá na plošném spoji plošky a musí se tak přibastlit |
pomocí kousku drátu. Obrázek napoví. Když se neosadí, bude piezoelement |
chytat brumy z nepřipojeného vstupu. Vyzkoušejte si to, CMOS |
obvody jsou proklatě citlivé. |
</p> |
<p> |
Při mytí desky pozor na tlačítka. Pokud do nich zateče rozpuštěná |
kalafuna je třeba je opatrně rozebrat (snadné) a vyčistit. |
</p> |
<p> |
<img width="539" height="329" src="LCD2L4P02A_files/image006.jpg" |
alt="Osazení, pohled ze strany součástek"> |
</p> |
<p> |
<img width="542" height="135" src="LCD2L4P02A_files/image007.jpg" |
alt="Osazení, pohled ze strany spojů"> |
</p> |
<table class="Soupiska"> |
<tr> |
<th> Počet </th> |
<th> Reference </th> |
<th> Hodnota </th> |
<th> Pouzdro </th> |
</tr> |
<tr> |
<th colspan="4"> Odpory </th> |
</tr> |
<tr> |
<td> 4x </td> |
<td> R1, R2, R3, R4 </td> |
<td> 1k </td> |
<td> R0805 </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> R6, R7, R8, R9 </td> |
<td> 10k </td> |
<td> R0805 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> R5 </td> |
<td> 47k </td> |
<td> R0805 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> RX </td> |
<td> 1M </td> |
<td> R0805 </td> |
</tr> |
<tr> |
<th colspan="4"> Odporové trimry </th> |
</tr> |
<tr> |
<td> 1x </td> |
<td> P1 </td> |
<td> 47k </td> |
<td> PT10V </td> |
</tr> |
<tr> |
<th colspan="4"> Keramické kondenzátory </th> |
</tr> |
<tr> |
<td> 1x </td> |
<td> C1 </td> |
<td> 100nF </td> |
<td> C0805 </td> |
</tr> |
<tr> |
<th colspan="4"> Tantalové kondenzátory </th> |
</tr> |
<tr> |
<td> 1x </td> |
<td> C2 </td> |
<td> 4u7/16V </td> |
<td> ELYTB </td> |
</tr> |
<tr> |
<th colspan="4"> Polovodiče </th> |
</tr> |
<tr> |
<td> 1x </td> |
<td> D1 </td> |
<td> 1N4004 </td> |
<td> DO41 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> U1 </td> |
<td> LCD_MODULE </td> |
<td> LCD_SC1602A </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> U2 </td> |
<td> 74HC04/SO </td> |
<td> SO14_150 </td> |
</tr> |
<tr> |
<th colspan="4"> Mechanické součástky </th> |
</tr> |
<tr> |
<td> 4x </td> |
<td> SW1,SW2,SW3,SW4 </td> |
<td> P-DT6GE </td> |
<td> PUSH120 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> J4 </td> |
<td> JUMP1 </td> |
<td> JUMP1 </td> |
</tr> |
<tr> |
<td> 3x </td> |
<td> J2, J5, J7 </td> |
<td> JUMP2 </td> |
<td> JUMP2 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> J6 </td> |
<td> JUMP3 </td> |
<td> JUMP3 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> J1 </td> |
<td> JUMP2X3 </td> |
<td> JUMP2X3 </td> |
</tr> |
<tr> |
<td> 2x </td> |
<td> J8, J9 </td> |
<td> JUMP2X4 </td> |
<td> JUMP2X4 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> J3 </td> |
<td> JUMP2X8 </td> |
<td> JUMP2X8 </td> |
</tr> |
<tr> |
<td> 1x </td> |
<td> SP1 </td> |
<td> KBI-2734 </td> |
<td> JUMP2 </td> |
</tr> |
<tr> |
<th colspan="4"> Konstrukční součástky </th> |
</tr> |
<tr> |
<td> 2x </td> |
<td> </td> |
<td colspan="2"> Jumper </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Šroub M2.5x8, válcová hlava </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Matice M2.5 </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Matice M3 </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Šroub M3x12, křížový, válcová hlava </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Podložka M3 </td> |
</tr> |
<tr> |
<td> 4x </td> |
<td> </td> |
<td colspan="2"> Sloupek M3x5 </td> |
</tr> |
</table> |
<h2> Oživení </h2> |
<p> |
Pokud je plošný spoj a součásti v pořádku, není co oživovat. Pro |
otestování je vhodné použít některý z příkladů z tohoto webu. |
Jsou připraveny příklady v jazyce C pro procesory PIC i AVR. |
</p> |
<h1> Ovládání LCD displeje s HD44780 </h1> |
<h2> Úvodem o řadiči </h2> |
<p> |
Většina jednořádkových, dvouřádkových a čtyřřádkových LCD displejů je |
řízena stařičkým Hitachi řadičem HD44780 nebo některým z jeho |
klonů. |
</p> |
<p> |
Řadič obsahuje paměť RAM (nazývanou DD RAM) pro zapisované znaky o |
kapacitě 2x40 znaků. |
</p> |
<p> |
Dále obsahuje paměť RAM (nazývanou CG RAM) pro definici 8 |
uživatelských znaků. |
</p> |
<p> |
K řadiči může být připojen vlastní LCD displej (sklo) s různě |
zapojenými segmenty. Některé delší jednořádkové displeje jsou ve |
skutečnosti dvouřádkové (levá polovina displeje je první řádka a pravá |
polovina displeje je druhá řádka). Čtyřřádkové displeje jsou ve |
skutečnosti dvouřádkové s tím, že segmenty jsou fyzicky na skle |
umístěny do dvou řádek. |
</p> |
<p> |
Řadič samotný umí jen režim jednořádkový a dvouřádkový. Po resetu je |
nastaven jednořádkový režim a proto po zapnutí napájení u dvouřádkového |
displeje svítí první řádka dokud nedojde ke správné inicializaci. |
</p> |
<h2> Řízení </h2> |
<p> |
LCD displej se ovládá zápisem do řídících registrů (RS=0), do paměti |
pro zobrazovaný text (DD RAM) nebo do paměti definice znaků |
(CG RAM). Z pamětí DD RAM a CG RAM je možné rovněž |
číst ale tato funkce nebývá potřebná a je možné trvale čtení |
deaktivovat (RW=0). |
</p> |
<p> |
Zápis (i čtení) může buď probíhat najednou po 8 bitech nebo nadvakrát |
po 4 bitech. Druhý způsob je výhodný z hlediska snížení počtu |
portů procesoru, ke kterému je displej připojen. Pozor, pro čtyřbitový |
provoz se používají vývody D7 až D4. |
</p> |
<p> |
Obsah paměti DD RAM definuje (v ASCII kódu + japonské znaky), co |
se bude zobrazovat. První polovina paměti RAM je vyhrazena pro první |
řádku a druhá polovina pro druhou řádku. Není-li displej 2x40 znaků |
(nebo čtyřřádkový 4x20 znaků) je vidět jen kus, výřez, z celé |
DD RAM paměti. |
</p> |
<p> |
Uživatelsky definované znaky (celkem 8 kusů) jsou zobrazovány když se |
do DD RAM zapíše kód 0 až 7 nebo 8 až 15. Tvar znaků je uložen v |
CG RAM po řádcích. |
</p> |
<p> |
Je možné volit, zda se při zápisu znaků do DD RAM automaticky |
zvyšuje adresa do které se zapisuje nebo zda se posouvá okno. Posouvání |
okna je možné řídit nezávisle a je tak možné snadno realizovat běžící |
text. |
</p> |
<p> |
Pozor na časování. Některé instrukce potřebují pro své provedení delší |
čas. Pokud nečteme stav busy bitu, je třeba počkat příslušnou dobu |
v čekací smyčce. Některé displeje mohou být o něco pomalejší a pak |
se nepovede inicializace. Rychlost displeje je také závislý na jeho |
napájení (5V nebo 3.3V). Konzervativní hodnoty časů jsou uvedeny |
v tabulce. |
</p> |
<table> |
<tr> |
<th rowspan="2"> Instrukce </th> |
<th colspan="2" class="Center"> Řízení </th> |
<th colspan="8" class="Center"> Datová sběrnice </th> |
</tr> |
<tr> |
<th> RS </th> |
<th> RW </th> |
<th> D7 </th> |
<th> D6 </th> |
<th> D5 </th> |
<th> D4 </th> |
<th> D3 </th> |
<th> D2 </th> |
<th> D1 </th> |
<th> D0 </th> |
</tr> |
<tr> |
<td> <b>Smaž displej a nuluj adresu DD</b> (2ms) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
</tr> |
<tr> |
<td> <b>Nuluj adresu DD na 0 a zruš posunutí</b> (2ms) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> * </td> |
</tr> |
<tr> |
<td> <b>Nastavení pohybu kurzoru</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> ID </td> |
<td> S </td> |
</tr> |
<tr> |
<td> <b>Nastavení módu displeje</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> D </td> |
<td> C </td> |
<td> B </td> |
</tr> |
<tr> |
<td> <b>Okamžitý posuv kurzoru nebo textu</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> SC </td> |
<td> RL </td> |
<td> * </td> |
<td> * </td> |
</tr> |
<tr> |
<td> <b>Nastavení funkce displeje</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> DL </td> |
<td> N </td> |
<td> F </td> |
<td> * </td> |
<td> * </td> |
</tr> |
<tr> |
<td> <b>Nastavení adresy CG</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> A5 </td> |
<td> A4 </td> |
<td> A3 </td> |
<td> A2 </td> |
<td> A1 </td> |
<td> A0 </td> |
</tr> |
<tr> |
<td> <b>Nastavení adresy DD</b> (40µs) </td> |
<td> 0 </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> A6 </td> |
<td> A5 </td> |
<td> A4 </td> |
<td> A3 </td> |
<td> A2 </td> |
<td> A1 </td> |
<td> A0 </td> |
</tr> |
<tr> |
<td> <b>Čtení adresy a busy bitu</b> </td> |
<td> 0 </td> |
<td> 1 </td> |
<td> BF </td> |
<td> A6 </td> |
<td> A5 </td> |
<td> A4 </td> |
<td> A3 </td> |
<td> A2 </td> |
<td> A1 </td> |
<td> A0 </td> |
</tr> |
<tr> |
<td> <b>Zápis dat</b> (40µs) </td> |
<td> 1 </td> |
<td> 0 </td> |
<td> D7 </td> |
<td> D6 </td> |
<td> D5 </td> |
<td> D4 </td> |
<td> D3 </td> |
<td> D2 </td> |
<td> D1 </td> |
<td> D0 </td> |
</tr> |
<tr> |
<td> <b>Čtení dat</b> (40µs) </td> |
<td> 1 </td> |
<td> 1 </td> |
<td> D7 </td> |
<td> D6 </td> |
<td> D5 </td> |
<td> D4 </td> |
<td> D3 </td> |
<td> D2 </td> |
<td> D1 </td> |
<td> D0 </td> |
</tr> |
</table> |
<table> |
<tr> |
<th> Bit </th> |
<th> Popis </th> |
</tr> |
<tr> |
<td> S=1 </td> |
<td> Při zápisu/čtení dat se bude posouvat celý displej (směr určuje bit ID) </td> |
</tr> |
<tr> |
<td> S=0 </td> |
<td> Při zápisu/čtení dat se bude posouvat jen kursor (směr určuje bit ID) </td> |
</tr> |
<tr> |
<td> ID=1 </td> |
<td> Při zápisu/čtení dat je ukazatel adresy inkrementován </td> |
</tr> |
<tr> |
<td> ID=0 </td> |
<td> Při zápisu/čtení dat je ukazatel adresy dekrementován </td> |
</tr> |
<tr> |
<td> B=1 </td> |
<td> Blikající znak na pozici kurzoru </td> |
</tr> |
<tr> |
<td> B=0 </td> |
<td> Znak nebliká </td> |
</tr> |
<tr> |
<td> C=1 </td> |
<td> Zapnutí kurzoru </td> |
</tr> |
<tr> |
<td> C=0 </td> |
<td> Vypnutí kurzoru </td> |
</tr> |
<tr> |
<td> D=1 </td> |
<td> Zapnutí displeje </td> |
</tr> |
<tr> |
<td> D=0 </td> |
<td> Vypnutí displeje </td> |
</tr> |
<tr> |
<td> RL=1 </td> |
<td> Okamžitý posuv doprava </td> |
</tr> |
<tr> |
<td> RL=0 </td> |
<td> Okamžitý posuv doleva </td> |
</tr> |
<tr> |
<td> SC=1 </td> |
<td> Okamžitý posuv textu </td> |
</tr> |
<tr> |
<td> SC=0 </td> |
<td> Okamžitý posuv kurzoru </td> |
</tr> |
<tr> |
<td> F=1 </td> |
<td> Znaky v rastru 5x10 </td> |
</tr> |
<tr> |
<td> F=0 </td> |
<td> Znaky v rastru 5x7 (běžné) </td> |
</tr> |
<tr> |
<td> N=1 </td> |
<td> Počet řádek displeje 2 nebo 4 </td> |
</tr> |
<tr> |
<td> N=0 </td> |
<td> Počet řádek displeje 1 (některé jednořádkové displeje jsou |
dvouřádkové – místo řádek mají levou a pravou polovinu) </td> |
</tr> |
<tr> |
<td> DL=1 </td> |
<td> Přenos dat 8 bitů </td> |
</tr> |
<tr> |
<td> DL=0 </td> |
<td> Přenos dat 4 bity (používají se vodiče D7 až D4) </td> |
</tr> |
<tr> |
<td> BF=1 </td> |
<td> Busy – probíhá vnitřní operace </td> |
</tr> |
<tr> |
<td> BF=0 </td> |
<td> Ready – je možné posílat instrukce </td> |
</tr> |
</table> |
<h1> Programové vybavení </h1> |
<p> |
Na tomto webu jsou připraveny knihovní funkce pro ovládání LCD displeje |
pro procesory PIC a AVR napsané v jazyce C. |
</p> |
</div> |
<!-- AUTOINCLUDE START "Page/Footer.cs.ihtml" DO NOT REMOVE --> |
<!-- ============== PATIČKA ============== --> |
<div class="Footer"> |
<script type="text/javascript"> |
<!-- |
SetRelativePath("../../../../../"); |
DrawFooter(); |
// --> |
</script> |
<noscript> |
<p><b> Pro zobrazení (vložení) hlavičky je potřeba JavaScript </b></p> |
</noscript> |
</div> |
<!-- AUTOINCLUDE END --> |
</body> |
</html> |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image001.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image002.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image003.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image004.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image005.png |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image006.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image007.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image008.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image009.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/HTML/LCD2L4P02A_files/image010.jpg |
---|
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Property changes: |
Added: svn:mime-type |
+application/octet-stream |
\ No newline at end of property |
/Modules/HumanInterfaces/LCD2L4P02A/DOC/LCD2L4P02A.cs.pdf |
---|
0,0 → 1,10227 |
+%âãÏÓ |
+0000000016 00000 n |
+0000001428 00000 n |
+0000002133 00000 n |
+0000002359 00000 n |
+0000002594 00000 n |
+0000003402 00000 n |
+0000003631 00000 n |
+0000003652 00000 n |
+0000004329 00000 n |
+0000004350 00000 n |
+0000004918 00000 n |
+0000004939 00000 n |
+0000005530 00000 n |
+0000005551 00000 n |
+0000006118 00000 n |
+0000006435 00000 n |
+0000006650 00000 n |
+0000006810 00000 n |
+0000007020 00000 n |
+0000007330 00000 n |
+0000007483 00000 n |
+0000008202 00000 n |
+0000008916 00000 n |
+0000008938 00000 n |
+0000009642 00000 n |
+0000010335 00000 n |
+0000010557 00000 n |
+0000011222 00000 n |
+0000011438 00000 n |
+0000011460 00000 n |
+0000012183 00000 n |
+0000012538 00000 n |
+0000012699 00000 n |
+0000012721 00000 n |
+0000013339 00000 n |
+0000013361 00000 n |
+0000013981 00000 n |
+0000027145 00000 n |
+0000027374 00000 n |
+0000035129 00000 n |
+0000035269 00000 n |
+0000035573 00000 n |
+0000075672 00000 n |
+0000075899 00000 n |
+0000076145 00000 n |
+0000094281 00000 n |
+0000108084 00000 n |
+0000108299 00000 n |
+0000108505 00000 n |
+0000126729 00000 n |
+0000133079 00000 n |
+0000156992 00000 n |
+0000001533 00000 n |
+0000002111 00000 n |
+stream |
+HtKhQ ¿¹Ijª³H¦Slë&LÕj|4HÝ ¶Vq°]¤¢¸!øFbKp¨ ¢ât!4`_5J5ºJ÷nç¦ôÀ=ÿë,þsïàúIx§Ñùpâ~Páýf³írz¢3uÄQw½±âØû³Ë»ù?DËÈzfzM»ÕÂíaLõ\[èÎvu[ÛÇ[g÷¹Ö²½F,üÔWÝ+_Y93#HçÎֺο*F5uràm®ÿäѯSþxûÇasih,Q(=Z5ïù2³:(¬2þÈsêDlÄãc×7`*^Í6q{ÚÎHdH&Ñh#0ÒlHù/Ç6m£íö);îµO´a³Ý¾+µB=!*R6)É/©_fRÄm1æá2;òâ9xÄczà5ÁJ²G¯sKfqIþ$åSx\µÎºs<ÔWCõQpNXWõh5J§4«ð¡å¸,]yŨEѹp²2ç¡ìø¶HU.ô-É |
+stream |
+«4'Ré|·ç*eÞbÐÊbÊ]I´¹ñ ×=Ñʹ"M,«0A*Ny:KFÚ"z4Ý |
+stream |
+Hl»!{bÊl |
+ýû¨L`º:W¨týIh·a\ øù¤Å¤×O^<õ¼AEc¬ß3^\{ uÎcªá<Ý4BMÚâßÓû+ª,üQ%7'å\¯×gÊÐ]ñ÷ï¯ôíãíõ;ýx¥ré#o¨IRäË^ ¯ÏDj³9nzpLµ>®#r9¯CÎ Yïûa÷(Úf3FÐÇb²|çìùßÜñY8³g`d±²¹xp[Þ |
+!?ybð63´Ãè,·ðYnOðKãx¦$ì%Ijc¥t |
+䣳> |
+uâlM§õ^dÂÓ»u$;}6Kúò5,¡s(½ÊsU/.ÿl1Ý |
+stream |
+Hl=1 û9ÅI |
+NÍÓ?ðÖ,ý[[t$9³¥m¯8ó°ºù>ã-U[J=,5£==ýTν¥ä=©ÒÉöÊÄ LnýpÓ |
+)ܤd:ù8Ïë·aÑ%º÷ã)ި춱×??¥?¯ß®·ý{WûØ}"k¡ZÇýx¿^_o/ÙÔ Û.öFf[QX!÷ìØk/ |
+Ïe0nà§WS;û-3½]G |
+7$LKÁϺ!Üåèwt(â6ßd0¶»~}$"8=QysyºÛîpzr § |
+stream |
+Kx;ÝÑ|àjNü°ÑîV?Z¾Ø,\Òkxdóæ{?'fþ6<×ê!ngpº¨!ÅÑb«YçòaÞÕÕÕÓ¶°D¯ÇòÅxµ/õÄWÅFÅæ,= |
+J(à Â.+ °¥ÄÄ~´Ë2cå»Îî^px½YÈ|³·\W©{Ñ¿õJ¢¼KóÖAgoFñ&káÈ«4ûE¼K«Ó¿è«½P¹=|³ôvñû8}qs·Ãû°;W\ì=²DD\ò¢~L¨@¤ |
+stream |
+HT?oà Åw>Å©2 n3T²uúWµÛÀÙEª1Âxð·/`+i8=¿Ó»£Çºª @ßý¨Ð«=NãìÂ{c |
+Ê·¤áfµíF(KB?¢9¿Àîôtz~¬öm{س o^£7¶]{W|~Åfvî´;B/Ò½Êþå¯^»8"k¾%5NN*ôÒö%cX8WÐêÿ>¹]©s§¾¥'×߬$µ²YñUî6&õLÓ_¢ªÙû8E^Qâ-ºÑ¥$é_ æ/u |
+stream |
+HT=oÄ w~ Ç«n IÛ¡RÄ,¹~ªI»s`R¤CüûBݵ¶ì×¼7]Û9¿W=F0ÖiÂÙ/¤Î8ZeÚª¸W[TÀܯsÄ©sÆC]3þÄ9Ò |
+ãͳ/rBàù«6¬¡Úêrwâ5ÎA*$éFº(ÊR @§ÿë¬ú¥ÎF}Ib×é¢lRº,±ûT¾%ÿ÷bN-DÉ÷¶ÍV6d^ö|ÈoçÃ~ 'r |
+stream |
+ÓÐ×Y×1 |
+¹TÚ×ýU4 síK¿êâ]]'«g^@J'©, |
+Û6lT/[gnØd4¸ëkX`í³æ}ÊÌ.·BÚ"Ðd»ã%!Üæ Âßòá%ÖBTÂôÎñÕíÚñ%¯â:BÞÿùÎ_»å©û*òàEdäÒ |
+stream |
+HT»nÛ@ìù[ïIò Eâ N À.pÁP'âãb`ÿMe |
+,b$ÊpFx³³3³{ôÄ¿<rµIzo½«8ÖÀ!ÞxJ%% äÚÃÔ{Ç8Oß`Ä0*%Ó#fÅ(cLõH¬³s2@±]i&øA..zàHË¡¶d¡RõøÁÒ«ìÊæ=¶½Tjø¿mÝØhußÿ;ÉR ÚHmøwñ3ÍbVò¶äó@XtìÂäØå¹µ9 ëCá+ÊõWÀÖB÷ð#él»l|ÿèlaK[µà eÅ5aÅ)Ç&s(æoäÑyn½^F®´zE?g1i-Ëí(\,Cd`þo=Ócè.T7¢ðÕ÷4vnÿôÜ`äöU Eõ< ¡qÓÃ`g~5òï².imÑä/aõÆn} í6Ts#_IèEòçsþ" -äûƦ÷Ð@ÙëW$¯Ý®v©m\íº2|iÅ/|³»ªië}Ú2£ÃMú{?=)#öb XD\DHÜ Bÿié]}.9\;ï÷!î-itb¨Ã |
+Bй&.Góäxe£©ÂPEÃ?ÐÑïué-nÔ§û!Bû5$½¯²4ÿÑï:)m[?Àq-¤øË=Â{ª©Õm2RÁ[W®ÅOÎJKÍÈ{ô1cRùoա̱f¨ñR(:¤ê~jëmÎÁG§§ |
+stream |
+HTÁn ï>Å·ÙHt»ºiân¶mªÝ»Â`I*Ôo_kÛáf yq.´¼Ù8TZXúÉr[¥!f Wò;ïjÄËy±+´ìátÈ»£aw¹^®·ó¾ªâ=} òjZ¥[ØU û¸»r2æ;Ô#PÈ2(#ßjóRwä¯þ7VÍy×Jz©9ÚZ·'J¥Èܳ$Ôâ<Jªü³¶{Fýkúyââ'OñÁSrôħC( ätÎeÍÇ~²³*1¸ä!o\Yz\SÑRó2Ým|²ÖMÉÂÒ¾Ò¸ýéÍÒé²¢o ÀE[ |
+stream |
+stream |
+stream |
+H\UTUþö9ç¿Áp üpy)ÃpÅ·¢`\D^B¢©c©>ÊE>ZJ9FX]l44gB'Q34ßN®43cærzÏlWÍýÖ×>ÿ¿ÏÙßÞgï ´ÃHøN7×üÉqq)¿ÙXýñîìáX |
+K4¿³#èÿèX4Ãßü\÷ |
+ l*ÏéWÄ/ü~ô{ tÜÈã𢲹óåñ~ 8ºtÖt¶mð&ðì(sÍ/ï èÌþfùåWT¿D_:ùk c$Bøé&«ÑÐWøáoúg~lÌÝS¢/Kýñ¿ ëñ.ÂqpMð,Æ¢ÃÐOÐèìHÃvDPÒa#pS1×pÑÈÄ%òãu(G êüz/{y#;±JiâØÎáÈkulÖÇõymÁ5 |
+È`ëtFã-ø¡GõãÖ |
+!u´n"¹¨RªRÏÄ ìÆÊdkçÛíF)ÏÚF6jÒ-ú:þ 3x¥×±ïBè-S÷`"Ï`4\üõ7¸@þ Stª7ñÛ:Ü1â°´2Ç4¬ÆV®ÆY\ÅÏäC}iÕ3NÒã<sËÄËXÈ}± «WØK lÂÆÕ²¡'²øÛZÔrüOq2)è¬5â=Ct ¯k^Èfïâ ǸOñìÃd«z¨¹F'K9Ã|îµ8É<.qÝÆCêŸ"^õd½]_c.^Á ÃÌÂ<¼ßò®Äø;=íسY2wõ:®m$2÷1ì=×®â]Ú FÆYβ3Å Mã©ÖÒzj¤tAXD¨-nI·<&¿UýC'ñJèÁqí"Þ׸Úë8ßí8#@ËåùÄ ÆØ&Å%¹L®UåË¿zéJX¹Ëq^ÆG\ )9ô¤z¾gæoßÉÒWÚe_ù¬(säJY-ÿ,¿VsT½ºh7\F½ÕåyÑsRgê7¸óèÏýSÀÝ4ù3æ`¢k¸_Öá=ÔsÞ_àÎà;üw Ê9zwÝ2ZÃØD;è ¢#t ´B1¢E?1D¤tQ(1ªÅ qVÜÝät¹X.aÔÈ=òRJ}FQg9f¶fXó¼¾z|ûI¯'9O.yà ö<çYï9๮'éÌ?±èÍLW0ËMܵ¸÷à0¾Â¹6®÷HÁDvîïÚFãh#1¦0\GEÅ´^§ |
+zVÓÛmØȹÕÒ´ñíc¡únÑ=ÁM,$wsqb g*1b<£PÌb9bïPøTìg¥¿±Ò%gËMr§<(OË(¡*N%«IªPU¨fuRWÃi5ÆAKWK¢%ËRbÙhùÄrÃòØj±µæYYO[µW«Õ8ïÝøå/ÎÒL/]Ô|ÑÂç"H+(+fe©\#¿1 |
+è®4é"UÊb9Soéâ¡EÄ&C$YUÐT/®û⺠|
+ â&E«·è31K¦ |
+Kkã |
+@CxÄ!Y!+ôïdÔPQ#NÂT ?ZøT¯xÒ×¢XT![%PÌuÿÐÏõ,VR/yZÕà´è.gÕ8N#T¸xA¤zVÜ'Ô·i6Êém¤Ðçô5h»¬£¢=ï[t þ|É¡tZz#§#E +î,¹ßrBö%bøIR<÷Î~¼È' ZD±¦9YMNQaëý}ÏþVÅ6ÎUÜg[¥ãçÅ1$ñÙ¸ÆÈÆrôÁ>îÁ±H/¡|ÖýQ¬T8òaµ´1·Å|_0ÖÂiõ!ëÿQVýLºWÈäÕhÕúer²2å²þV1òñ<6ce·q |
+cÈ(ÓSÃ]þ-^à;ç{dæ7[Y¬Ì³yÆfORËq^eÎùU¬¼ëu gXÌwÔH¾ Xo@*ïÝx]¡«0MoÕSQ z;ëï<½ý°ÂÈÈ{¾äûè/Tź¬G[Ì°ñ9*Õ9ÖÎ!z> ®GW(oÑ«(î[lÂÓÑ¢A§Ër¾¡Z0N×éòF.eåÝZ«ÁÚ³=Zî]¤Í2dð3Éè߯oâÓ}âãzÇ:bzõ· !=ºwëüT-°¿_gßN;´÷ñnçeµJ |
+lÇ~;»·w!¶ùórÇr¶üù©b.»LC¹sæ n*~"Ô(Eüd mIÛ jSÛ°6¤µ©*ÒÒª2( mSRÚÒ&!h¼ýÞìíå|ÐB«Zþîͼ7oæÍ÷æÍÖÇweJª¿.È]ÓÜ´7Å3¥!þM$0%±¤Ã¯ ÍA¬%v$â²y¼'gwk(sëÖ#Æc¹>)4-Z¶5Ô[Xé·?¤ÂhÐl!k~ÀH¬\XÔS@æ²'&DK*+zü£·öÊM5Fæd6Ö¤e²%s«qYÚ¯ |
+[d,B8XÁÕAX7°§9ü³f«ç`þ |
+Ѥ{ü}ö©=+öjX«Ô"´-è1ÝM=ews[¼ß\ÁÝ-ñ^¡úäDÏÈâýAÜÏ+ËLî¹ú¬è>9>Ð!êRM2duBçsy |
+í#*Ó6Ríîc½êD*C{2d¥Þ{ξÊr,ǵBo#uA^þ£@w/@s|ð1ÏQ¶´Q=Ã{µo ½v,Bû3Ðl]ºü¥hÏr óEQc¯F{4ÚóàÑh¢Ð»Ã:; /@_ðX¬à±³T½¤xS]¢ |
+ %}óÝ=±ýlÓ¿AíËcÛ*>·í,¬QgʳÚÚëAq6¨íhzEÞK4 ûû¨Ñ:hw¢ýWظÈsªÑ÷ã%xδS½EÈÊõ×7T'¦CPmßß zÀ~áo*í =ÄÂkú4I»J hG>¢?§ýßàìAëá÷ë>²?ÁõÌÓþ8¬_Å>àsWZº1öd/ #qï1ÖÇ:óÎ9_Æ À±Ìp:ºþ?&1ÌxÝ×Oßå1w,ÆO/qÌplr|plÈøG<ÉåsÜßp99óñ,í |
+ |
+|ìL¡ce¾ð9²Í<7ÇÇK!/vâ^¹ÁûäÊ §B®-sc+rì3U#r¥bfqÌ:¾v©´!ÊùÈ9áR×ÎO# j'å³ïøÜ]êú"MS²%÷è m:PÏ"þÛÑ~ |
+ÀÅÚyzCÒA1YT<nû§[¼äÀmgÒl()#Sößòÿnzí¿ym[¤×°Wòþ]] |
+ï_Þ2ä=Y¯;>¦õQ8f ïáóÔææ50CþóÔ={çÍ5s¯Ý®¿`·«ívìó'ú.Ðö Qb÷¤kjf¤î²B·²<ç©(]Gô4u ¹jGQÃ:/ëç_h¼ç¦¼ÛfH{99«pï ÿþ«åÑsê+D*òù&i>£þwîbÚ¤²«îwPT¢Z.|6Þ#¨È³¡Cr>Ê<¶_×|4 ³rïe>{ý.å %ë¸Z1æÜkXÞãûi |
+Ð;9@ÎØ Ë oÓ<õ´NÀûà |
+ômTàÝBj ø Õ÷pϽCSdÏ \ iÒ"³Çç.×çÿ×|ï6àiiÃuÜÇ2hrѾڪ\DÝÞ»@¿ý|×î9ÿÉÏ:?Ä |
+¨XÐbbÁBÁvLb».%3í´ÓBqÔqFãcú Mß9{oLZÿqw¾ßw~ó¸ç{Îï×Çļ²cI¿õ~¬÷ú~0¾°z¨A>{W#¬os¿¸gͯJ®÷]ì%I¹ûMÜý6ð<¬Íÿ'àÛyxxëÝ%X«9ê2²\[Üs-Áuuè=B3Àq.àËìGù7(o |
+P~¶£àý`l5w`Æ9ÂÀ'ÔLäïìÐÆúdÝ¡[ÀóÉ6.òïßج?ø°>dfg7¥¨cµó}è;Á¿¾2ÙÖ ÊC× |
+Àx¯Hÿo/ðûÐgoZgµ·Þ·Çq¦}ÖúxÏÈOq¦LDSð0» Å&ÊRÏâñb¬³ûSå9£GÓÿnóÆÊKïËÆÐÇjo¼zjÞ1n=%/±ôTÜçO]{V>I2GòÝân¡öÜÍý1¤~Ç#ßuGhÂ: |
+"¶ýíɤÈæ}æ]Øc½@´²h{óQ`Û<E¶5¾$]`Ï`ªÃìøôæ»cXàt]"vôn;& |
+yC¾P^¨]-ôú |
+ó |
+ÛUîå>ÇÛÕæÊîÊKW*Õhe]eS%+Æ«Eɳ}{ébWdÒÇB¶× F8d!ê UéäJ¬]°v* |
+>¿¢@=F®°uä!9Pt*«Á[§táß©t2X_0 ©S !IvwÄLÄÐq¸ |
+ûm»mmkm«lËlmómÙ¶¶¶»ÇÛ'Ú'ØívÍ®Ú;±g$ûÃ_a椩Bª²ìV»¾Bí |
+ûnØ@+b½HÅÆìØÕx «jbiÞidês¡i!Ïã¬(}¨5eÁÝß´ÿ°^õ±M]WüÞûâ¯ÄØyñGü>üLÊÃØq¾©×8q ðµ´v פ!ĤÄqµ ttC mIźJ[:±f¬ ÅNHê@W2Bc«`Zÿ@LcZÍk´eý£dç>#h%þ´s®Ïùå÷îùÝëó¾~q®ÌÉήXæ=W<¤UW¼3³©ß[ I2íX ÔÄcø IF¡~|°#þD20¢ÂfHaHij*l« |
+Ѭ(@ðf |
+ú\RA/æò@ |
+k'5 #ÕÈ£Îå!Õ|(LfúúdFMêd&#R'sRPV²N¦l¬Ü¤Ï< |
+ðÆÛóbß>j{û3·¤þÌ©Ïöö=&ÜGýRGõEwŲ}áþÞpoTêíÏNF:¿ë¹"£lN¡¹¦:î¤á)«æꤹ¦ÂSj®ÎgÚqçÎXVÚãÝ;KJa?ô8x»|JÝO |
+µ9°3uÅm&h¼1:úÈ' |¢aLP<]`m< R |
+ÛGðeª2`ºÜÃ)EAT(Á¡ Uð7yp*`) ` ¤zSôßÒÔ>ÂìDHã¤Ý2Ò¡mY/¡MÕ3HS#cP±æ0ªÒk5!N@| q |
+!Ã&ÎÍÎXZJº¹Íò>NgSCÛòÛÙÄCÉmùådµÞO.'?mÍÿ}9Ùürý}m òJ·:´Fl÷xm²Öað!£¾JãÃÅ¥>ëµ×p2 \.y½¨%Ö |
+.ØØT©-ø5Þz§.X ®¦Æ¦¢?¹ÝO}ú£É¿õúµWÜ{W.¬L/Ç¿91¾Ö⨰h¬Ô]cåãÛ¹N$OWÌþêü½?à]¶;Po$A½÷i¶¢TOHxÆÃL¤[6R}TÄï{¯HW|Ìfϯ|sW®ßëaØ {åM(Èç>DRî?"¾,ÃGù·|gðù}ï¾UUË¿èy}ÍÛwñ/ÉgÚwÑw3ð oÕWjA6l'{À^»aýÀ^Ï~ñZ=q:±Õí0 "kHïv Ííp |
+R¬=à |
+B°ç,áníïêèh%½]«Û©ëÑ1ºwtDgõ9üfجq¹ÄTV=Þ"Ð÷ÖX5áè$Ldð@9¶o42õzmy9éÖ«ë W¯mV#Ën«ê´Ú©ÓúóÞ\ |
+X¡m¼zgÆØs«K3-5ÐÍW´¶æØ kjAþ!%"X+Þ5æ |
+àYUh dk0ׯñJR´Ù¬Z¶ÁFRj6ÔQu}+'WêøÒjÖéÝÚpÿBݳ²Õ¹f[þÇÍÆOÁ\ϱ{ß*w.]<²¡$¯¹×Ér³{ù.µþ:}8ç]9ôüþÞèd9m7®Þe¶0ÓHÀÿÑá,!]±0OìZµZµZµBZl2èzA(&}¥\¹ÕÏWn\·X`PoyE¹¬$Z/ç±þ#XcGÖ"QR¤Öúê)M4V>§!Îò]E].í.]Ìsê^ÒhÆÐpÎq ¿ÁßAÓð&ü,×í|Aêáz#ÜóåÇåæ n |
+:x¼PcjÂÍxÈán#Þa7£EF=hM ZDw:z/e?b';íxÒí9l[´Ð¤³Z^еmD,7§§]b(y?¸CV±5O²@ö¡»¬VMq«Ïr1'\%ñÚ@ss3n¦[¡!Ø»cç˵8 óå-¥]a[x0Ùÿ]í±qe|gw½;wgïã{ïÛï±^gç¶^Çy¸vÒ%!qè%§$ÿ ±M©UUURH+T$8XE ¢J/µT¨ÒJ&¥B¢jã*P©¾oÎNng¾ûfç÷û}ßh%¥kyÈÞÇxäÝ\W'b/Ýlçr6N |
+ëJ(eo>õ÷ =÷Ó¶)ÝN?tâÁ/\>öHo7yôÊotë&QÎïɵçB§ÌÔбþ3°é4ì~7 kPå\R8³jC\£ |
+èâV)^J¨àrÄ |
+W×u°8_<«ËHÂ4³eEaóî[l¯]E,>û×óFP@c¹\f¨\ÌÏ·×æõïMq/Àá ;K¡îDý)Á¦I4¸Ueßy |
+P(^ü+¶6wwÙÍ55IA3ûDv«Jl·P)v)Ò?ùü<³j5ðµ|½\Îw2_ÁÓøçFýG#åh «ß¢V¢Çp%½òuS Í·´t³î}ºãRÔs(pÄ8>ùRL&G=´±!ô°4Í?#kü¶ötòGüO"WäßVßÑùE®Ð1ØÝ´ç7òïÕ;2èÜôM^ð¼à¾9ÔãÙÉïòì5÷óû=Çø ~:0}>pÉsÉ;G¯xªÞßñãßm\öéL8yAæDZÆoá£*Kò1ȺðüGC¡¡[!1¿)8Á Tï_`uÓôð?'x"òëÔhT4&ó`,Sèåô<½EºvB«ô]*ÑÈM#®6×_P\eD8ES,E¸£=ñÀ·TRÃõ3>1±geüm¥<^j b´@Hå't8¢COHy4Ør |
+*Ò9þWnÜéJfZMgÄ©8c8åÌ8UGàÍáFÖ ÑíTº_Ä;Q\©×ëàRßz©ôÉÒgä<vgðG¢$f£B8A¤HC,Aòò;LîÊãðÃ8¤!=@°Âdͨ'k=,[Ãøx'vaí"Ãþe(¾m«[nWìßóø)Ò1¼º5¸³C5c [%Á<¿tmø<±zú Md2vNÝK?3þäj²l$ãÌ®dÿ153<k«ÄUàY¹²E[]ĹduQÁDgtÐY[g¤ÐÍuëø7E:rÃ"aLFèýÌõ±D"Fô@ |
+"T¿¬?8 ðSPTÐó ¨ä®Mþ/Aû@ú@öPýê |
+K"4¨Ädú?Ìt~($ÐÄ 1!±@WÏ»¯l`1¨¼×þÞ=}}'ï¾{ÏïüÎ15è3rRçVÁnÉåB°+!¿wÈfì`&äëÕSUU`¾ÃmªÃuHTHÆð'ªºèJV=Ó°q+ÑÒ79êWµjÁFZgEF\gÅ5 |
+°je`UWi¬¸Ô[A |
+Rb$$ ðÁâz/Ú¤6|÷éÓå2ê+ÿ Ó)0Å"ÒÇãxZ©q¿ã9â¡<âÜ C9/Æì$u 5C´@ßä>Ùøf_ô |
+ìÓàB#nïä}\Ô[ìJ§dfÙ.dF(¿6za|cѸ¶ÃÚ|~Ä$Xs7*b 8æâkãT¼Smµ©e'E<À5Ð#Á Í7¨"µ°óc²!7׸ZþD¢¯7MREÚéìëå~Â[¡ûQ`8=[âz`v2(DÀ4Ð|Vç(ml«WÄ`³iµ[·Þξ߮áúÆû¨.KÀHuåú-KõçV¹#Ì°{Sb8µÙ MLSoXh,¬Òçñt·Ù|é@ÜìÙâéÎ`¤Yaêùuÿþö,ζvο·Lã1úKúZè2MÑ#@°a$ñÁÃø¤RÓNÒúÂü88{z{&ñïòéi!7ÙÑ|_ $ß×t%áíy^ V2BswÆîºËÝíJ;PƧ%/sd ±I$`R ðÒöÅ#d *¨.@bÌ×N·dÅ{æHìY©Vë͵¥öÎ9®g¬ïåï¯}òD¿ÎÑ`öjqM¤$¦M=wÅ'O®ó.[óî¦5gýK#lÄ®Ó)ª¶µ[ØÑ[änLd^?vg¿ñjÎL» |
+59S5×XÚ7ØòBì±6có⺹¯2¥·W§ZZGmpÖäØõ¤úíø$Ñû-z "ßÊ@QV[ÎÃóñæ-ÿOà+Ò=ÿò˪NÞÕÑÛA/ O"À®ÿÇswñÀ"øù¯¡]ö-ó ¦^"D!B"D!B"DüÀÉw ßPmA |
+D!ùÑ*dÇËe$ßð?è²mçSCºäU¥IøãõÖùqòÌDÓõÇK;i¤¬*¸÷@¿ 1!D, |
+stream |
+°õ^U6ëdµw+ó'ù]6³zúUoï: }5 úK7'o |
+ÖòGËYÐy@gÊàu¯òYóF?âÉâµpôYYìG··gS9RgùVE&öW0íµª¹¥UEÁãWظ©F?u7dÄæ%~.[ï` yÙÒ[oñ-ïn¼ó ux*ðþ÷©w½ChÀÇC×µP&±ä(bRY¾ÌôÅÆaØöI,Áat£xó |
+b¥üwDzb |
+Pu4ÆÉ8§¬À ÁlTÑ2Óc®77o`ÉÍÛÅLMæwêæßÆ;^Á£ £,cË×0[å Ì2óÎÀg9ùh¢cÂÅÞKqâiÌf/;MÃ<ÎVÝ1åØÃ4F §:ÙÌ7Ðc,d¯[°q_R¤Új¾a¶"©xëi@3ÁÛËÃ1Qê!¬©ÄïñG"Þj¤®f©Ï¢+úc"g»wþn%LKåGJ®9ÑËËÚøÈA}i=!úJ±]ÎEGìÏT |
+Æ{3{?K.:("EÜ©ìUnÙ7£ùDñ*^Ã{Åjô½@ÑW"[L¯r²G9m÷sÕOaÖa/nRgL ôs*§ETC/Ój¢StYÄÓâº,säQe$Óxåe ºJ]c»ôÿ¼i¦«PÈý°³Û¹²ChÁ¦s¸H*EP4FNHÏ3-¡uôkª£=ÔÀQNÑEºBÿ¢tKÉ& SôdÒÅ\ñ¬Ø$¶¦Sâªø=¥KÒ++9«¹é¼ 8ÅdÓÕZõuµNÝ«¾¯¶Ú"í/!ìä;o§Ü>Dpu°6¸?Ø`^@,¡QèÎÞÏ4Ï»;î]|BR(Æ02SiÍ¡ ä´v rßGG¥Ïé:ç%ºr~X#Å8¦§D©#6¢A|&~v!;ÊX"GÉ)²TÎÕ²Vò¤ü»¼(¿?2J¸ÒCé©$+.e2U¯lW.)ÔÉê õ[¸mmÑöOû£öL{½Ð>Åþý ýÓ0wç8ßâË¥[Àz1@IÍ¢ûy*Jd¾àNu´Z,¦ÑK]h&ÑX´*ÉõGâuñ½&ó)ÆcèßæÍÖUy_ʸ¦áÚÙóB[$-×mØOC8æ²â'ð¥<GveþªS]»ewÁQ%SõÀ)·aCq@¸y:Ý |
+2xÐÀG¤÷ï×÷á´TWJÞ%'õÒ{:µ>Ð=Ñ×-¶kÎb:FGEFw³ÛTE |
+Bª[ÏõiF²ÏPõÑ£Ó¬µîgÿÏÐX{¿¡ùBfÚýYl9ý,³Ú,³Ú-)FË@FZªæÖ5£)G×iR¡ùu9ºW3® øü¿!ÄG1ïtòÍ_£äÓÜFîòÛÃîê#³õìÒð´TÔG0Á§WÕS\& çZ/ÅI=Çm$è9VLrûKB;'Ñéô¦¥]¬O3 4:ºB&È 1lÙ=F«°ªÁ>õX`mc¦ù\%z²Ç~¯£ãæqÏ}ÿÓwÎöÔÜ«Mw| f-ÍøU¡ç^ÓúõzÙïI¹¾@.^Ë æ×8Xéõ´CjV%VUmõênKâ¡ôzy`Æ0PTíÜïpd2ÏÃáÖ<ºÓ¨{ý9Ýë»"PTý,-á~MZj}L§6`ë£;Þa"£îeJÛu!.dnqyEíÈþ7¡kGç[?¥(Ìfüñï2JøD*Ù¾@ÌPKní7Ô¤]Ü w~íêýÿ-)æ,ÖêöVcý]Þp¹«EìÙ|¦cfh=0-uA£Ðõª_ |
+[¿wh_ßé´xMc¦ñÂXVèi[k¸Y}]^Cø,ͱ»ØfÙ]MûvÎÜ ë¯h¬ÜþíÓ»|¨AÝþº´M7^Ï+äÑÜßlóþË}µWU]áï<ï¡\i ;Hbx |
+i)¡´h«~V?ݺ¤Ä§mo¸)k_}µYǤб¨9M«\ÝÑ*s[Cü¨Ì-<©kzfÉ¢¢æ1¬+lM"J«V"¤yRªöáV~Y©ZS)¼±EÒ}-º«ù::ÓÕEN~rÆdæÆGJÉ¢t¹ÊÀUÈáòq!¥ÿÙQÛSÉ;ÃCþ¾fnC2±<0 |
+ß±òQ¨U XoÀv1 |
+ó8`ÛÊwÛ¤/Ûç&æùÄHO·XOä̶ÒclqoCqp4î·ò«ïÕ{ëÍwpÌ-°ß&0[Ú°Ï»ÕÔfýFêjÈ ëX^Ë~^y@ ßjd¦~"ÇÙëw¼q³ÌmÎ[\KÇÌ&vs»ÈYÄ |
+åÜ×5ëÓ Äpr¥Ü2â>±óO˾kù=sÙö]¶Y+ þK |
+\»Ä¤ôþk¬õ×õlSE¿þ lÉbgX÷2ÇAØÄ(b |
+¹ô(ÈøäqqÔ+æcÉg?^YÎ|/¦FmæßkÞõð ñ1ãèÇ;Çl9ÕýÀ3ØíÆ«s9çðy¯ qZã2ÕÝÂóÝÏSÚ±Ç_¿rÆÉ)ç3~ûDëÕÇr¿b/¯oõMßörç0÷»Àqì,ç¨}Ê9fsÙÓYþa9G¹îcwj¡Óãݧý»ÔÕã&ÿµf`wQçÍGxRÝ£ùʾö ì°®pßy*{k½¤?iw©YBÄ>®cQÁ|¤X+>Q{Ü,÷ÜÆ~úYî¢*oò½ }g`¨º/¢¶S:ީ¢³ |
+˾Ïîïâ«Ê¿G²CøvÁ¹HÎ×. d<È$(§SNòýéïõO(}Âþ1V`Àùg¢>QNÜ×þdýY¬±xxæB¶'åà9,Ø/±î¥¾²y´ã6ã ØÄßW¶ïÄx>¶>Ì9"&çAH[Õ0 |
+0ÁKQGªÆã |
+]ûSÒ¿Ò7ªÞú!×æÒá(ñ¥Ù·ÈiöIÊåOآƮ ò+Ä:@Ø°®ÂºJTp0¢¾M·ÁUÒ ÐDöNͤÙ大E°Kìw¤zý^×o³ºþû®ßvBO²I§Lfä±CÛ¡ë¿ý&Uã3Áb6á!ëA ´^0lU%·ÉTrLâ+³$ùLׯS"QvȧsÌÅ gÕ3° ]æxý.ÃGaqáùáË°¸ð|o?,.</îÅ gÛX\xº{aqáiïf¿øuÍ㲿ýê |
+ÚØÒÒÒb`{øEnxßN$ëê0bÇï:Y=GÕ7¨ºª§¨ÚOÕ½TÝOÕÕTÝDU/U%ª:©ªPõ<]¡P©ò«{ÜJU'©zªqªz¨ZKÕªº¨_I3wríÓº |
+ë*äïô3Í>úèƺ1ÝxíÇ /î)rUesr]ªdýe«|;kØ |
+®bÑQ¡~^ÏÓ æP,IÓzqÑù¡ÇNââqÄ%:³qdzqµ(¸®WP@jõ¸Ú=Î@y\"^%jjôRë1ñR×Ý1µ©ÕcJT2©ÇL¨<FkÖC$ !NI¡åDÒC$Z®l¼R98rPoI wb¤lu*cB÷¿ýõ·x½4ÕÛÚî¯÷UûAöÒîíeºÅåJlñ&xú¶lÝÎõæ~-VÝÒ¶V\¦d÷ðì¦êPô»¢¥?lRÂÕC±T[G£ÿ¶Î¶ÕØñÊ:xe¼6ÿ²ý<»·åçmùy[mJÞÑçxG4!XkOV§¹óµ¯Âk)±ïjÖ'o»loÅ9H~IÌÞf©nѬg=|2ȳðNñ¬"$ÛrYe{Ü8ç²ìH.®n!ÞÁø )?Êþãø!i`xVzãû!/¬)CñB"Z]gD¬ë&L&¤öñ[ÒVåÓÌæp:3M\ÄU<QfyÚjVP¼ÿùæt+Tv>E' ñ 9#]KAW7;zÇ%¾=Äc¸Á8õÒx¾½Û$k~¿ysVnr:[ |
+EâùáýñQâëÖ«¸°¹q»k!°¦Û.aü¶²ü¸ã|QëÈ|*LI9íN0ÖÚUöÙ¨ÍLÒAv¡C2Ê$-6EElÉbµri±@ÚÍfÈzÞúÅ+H`:0mó9ç© |
+¥ÀBe©uakiçÂÎÒ¾ }¥'Ø á¸õ´ýt¹E´>V¸=/ìX0hÙeU¯XεXJ,?²|¢ª^ÛNÛ>`£iöªòÝÂ;Õn!'ɹN |
+Íf&wú(¡ë5E¢ÕjÜPTUû«1{e)¥ÙlÜ@»ý?ìKhAÇ¿ÙÝìnbÚìn4éÃDÓÚ=¤mÒhìÚl¤X R¡ÊVÅâ!A<(RK«ñäÅS µÁÚ[©E¨¨| "Øb1ßDìI¼ÔÃó×þeþßÌî`r:±¬¢2²£Æ³nA"É8©$IIÍÕ±9®,áú¬t®TëV¦«'Ô {?×ÅM}¹L^ÏeJk×5Q¬EÌÍM`¥î#¢ |
+44Ð8ú#KÝÁF>éu¹°%R ä9tk¿Ý*%+ô"YÓ4sj"¨Z"ÊüHùé9jRXQ5ê£;hz#ux¼ý¹¯¿½££¿bK§6_¯ï4d |
+Â7fÅU*é¶ÄÅ8ç² §«SíÎ?CC¢aóKWOút·÷í,ø| e"F®`ÑÜD6Fù%ǾyùØæXþ@|Åâ¯Sbå°_-Á[xGÌt¨«Ê·Æã½t¢·¢Þ *é{QÄ |
+Ú)bj»4Nï¯dS:!9V+¬¤FÆ oþnÁø;üîUäÌ*qÁ`0Á`0Á`0ÿ@¼ '@À ¡¬XûøkxT5zj¿Ëø"WË@ÓøûúFZO?Ï.},* ;±kG=? N |
+ |
+stream |
+<^P¦³löæÍ¿ÇZdz¦9¯%T1<¿£¾Ð#¿î² |
+Ý u¿küÝtS-útXÝÅêôáÙüÏbÞGîQ, Ãð^B&ª0Mø0B©ØP |
+Ã`æ>½ÇòÚ|J;ÐÀ8ËQv&£H 4 |
+¡¡4Å@Ê£BÆ"ZLoQ9½M«è½6làØjècÚÅØM{g¨~ Ût_pÉÕ*ÂE´èϦ!bÃ(e§%æò ÕÏÅqVúÈP%r¦Ü(·Ëò´üEMÖ´ñZV®5i'µóÚS=P·ë zµ~ÀÔÍoÊ26>3Ý4µMæLsy¡ù´Yy²ZýãÞ_ÿ¢MM4[ïªÍÍ|/ü¥S_NY1'KäjùO÷¤A©BÉéj«LOd_R°Ôe>VBQ¸*/·(B{v2"Lè§4_\¿ÉoÂ9$7¨Qå²\ýz55ëÕâ$íðA3ßêåb=OúZJdkñúSqÞ?Öçq¾ÔKÖªq]ZÅÏtÖ±j§aZxUô§:VÜgÔwh&ôéú@´MÖÒpÑOË%¼©?BÇeÈiåHaÂ2Å=%÷NÈ>D¬ß`IáÚùïÏ|ªD8kÕäÅÁëYï¸÷µ*¶~^¯ä:Û"m¼""ïÆuF6!{¹W FlÀBµ¦²î`ýh bD«¥ ¹-â÷ÂO³Næ]°þaÕÏ »x¾YÐZGVjvV¦\ÖßJÆT¼ÂMXkÚ©Â(² á®æ*¿WùÍù÷@ó-Y¬Ì3yÆ&w:ËpÞ`Îùgj鬼ëT1GXÄoÔp~£HG |
+cWÀ<ÒÏù7À¦ÅFï ZXKìHÄMeð>xOöîÖèQæ$×ÌôÅúZc}Sj´|k°¿´4<`}H¥ÑÑ×æ"¿èl(ë+!cùÖ #%5Õ}¾BÛ}£Ò¼üìÆL¶äpn5-ÏøUaô%3°: Kâ:ö4ÖÌ#cõ<Ã_BÙ óXg>I¾zð}¬oºB>=`Ü$¿þé'#9i;ä»IÜä(ÉäNÛ¬ª2++9@<(l\(û³kª·¤©oð@à>z¾íLÔ×ÂùÁ ïTV¡cö4Çí~Vùû)\[0E%dÌ |
+YÑ/¼r¼ LÔ#¥dÈþêBçux |
+N çsx<Íæ %ÿø¦´Æ³c@&V¢F> |