No changes between revisions
/Modules/PowerSW/PWMLED01B/DOC/PWMLED01B.cs.pdf
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
/Modules/PowerSW/PWMLED01B/DOC/SRC/PWMLED01B.doc
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.bak
0,0 → 1,45
#include "main.h"
 
 
#define MAX 1024
 
// Vystup PWM je na nozickach C1 a C2
 
void main()
{
int16 pwm;
setup_adc_ports(NO_ANALOGS);
setup_adc(ADC_OFF);
setup_spi(SPI_SS_DISABLED);
setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);
setup_timer_1(T1_DISABLED);
setup_timer_2(T2_DIV_BY_1,255,1);
setup_ccp1(CCP_PWM);
setup_ccp2(CCP_PWM);
set_pwm1_duty(0);
set_pwm2_duty(0);
port_b_pullups(TRUE);
pwm=0;
 
 
// Postupne zhasina a rozsveci stridave dve LED
while(TRUE)
{
while(pwm<MAX)
{
pwm++;
delay_ms(10);
set_pwm1_duty(pwm);
set_pwm2_duty(MAX-pwm);
};
while(pwm>0)
{
pwm--;
delay_ms(10);
set_pwm1_duty(pwm);
set_pwm2_duty(MAX-pwm);
}
}
}
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.c
0,0 → 1,45
#include "main.h"
 
 
#define MAX 1024
 
// Vystup PWM je na nozickach C1 a C2
 
void main()
{
int16 pwm;
setup_adc_ports(NO_ANALOGS);
setup_adc(ADC_OFF);
setup_spi(SPI_SS_DISABLED);
setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);
setup_timer_1(T1_DISABLED);
setup_timer_2(T2_DIV_BY_1,255,1);
setup_ccp1(CCP_PWM);
setup_ccp2(CCP_PWM);
set_pwm1_duty(0);
set_pwm2_duty(0);
port_b_pullups(TRUE);
pwm=0;
 
 
// Postupne zhasina a rozsveci stridave dve LED
while(TRUE)
{
while(pwm<MAX)
{
pwm++;
delay_ms(5);
set_pwm1_duty(pwm);
set_pwm2_duty(MAX-pwm);
};
while(pwm>0)
{
pwm--;
delay_ms(5);
set_pwm1_duty(pwm);
set_pwm2_duty(MAX-pwm);
}
}
}
/Modules/PowerSW/PWMLED01B/SW/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/PowerSW/PWMLED01B/SW/PIC16F887/main.err
0,0 → 1,2
Memory usage: ROM=3% RAM=3% - 3%
0 Errors, 0 Warnings.
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.esym
0,0 → 1,402
D G "__PCM__" 0 47 ""4.106""
D G "__DEVICE__" 0 47 "887"
D G "__DATE__" 0 47 ""24-12-15""
D G "__TIME__" 0 47 ""11:07:40"" "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 "MAX" 0 4 "1024"
C L "main" 0 6 1 "FUNCTION"
F G "main" 0 8 "void()"
V L "pwm" 0 10 "int16"
C L "main" 0 6 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
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.h
0,0 → 1,19
#include <16F887.h>
#device adc=8
 
#FUSES NOWDT //No Watch Dog Timer
#FUSES HS //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
#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=20000000)
 
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.hex
0,0 → 1,35
:1000000000308A0018280000233084008313000881
:10001000031917280630F800F701F70B0D28F80B25
:100020000C287B30F700F70B1328800B0A280800F8
:10003000840183131F308305831603170908C03911
:10004000890003131F129F120030031788008312C8
:10005000870188018901FF300313A000831603176D
:100060000908C039890003131F129F1200300317BB
:100070008800831203131F109412A0122008831605
:100080008700831220162008831687008312A01190
:1000900020088316870001308312940000308316F5
:1000A00094000108C739083881008312900100309C
:1000B000F80004389200FF3083169200831220115A
:1000C00020088316870083120711831609130C304A
:1000D0008312970083169B019C0101309D008312BF
:1000E000A010200883168700831287100C309D0013
:1000F0000130800095019B018316950081138312C6
:10010000A201A1012208033C031CB828A10A03197B
:10011000A20A0530A30004202208F9002108F800F3
:10012000F90CF80CF90CF80CF90C78089500F90C9E
:10013000790C3039F7001708CF3977049700210878
:10014000003CA3000430A4002208031C220FA402D8
:10015000A40CA30CA40CA30CA40C23089B00A40CBB
:10016000240C3039F7001D08CF3977049D00822810
:10017000A108031DBE28A2080319F12821080319AC
:10018000A203A1030530A30004202208F9002108DE
:10019000F800F90CF80CF90CF80CF90C780895003B
:1001A000F90C790C3039F7001708CF39770497002C
:1001B0002108003CA3000430A4002208031C220FE5
:1001C000A402A40CA30CA40CA30CA40C23089B0055
:1001D000A40C240C3039F7001D08CF3977049D009A
:0601E000B828822863002C
:04400E00F22CFF3F52
:00000001FF
;PIC16F887
;CRC=1714 CREATED="24-12-15 11:07"
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.lst
0,0 → 1,326
CCS PCM C Compiler, Version 4.106, 47914 24-12-15 11:07
 
Filename: C:\Users\Honza\Documents\PIC\ledbar\main.lst
 
ROM used: 243 words (3%)
Largest free fragment is 2048
RAM used: 10 (3%) at main() level
10 (3%) worst case
Stack: 1 locations
 
*
0000: MOVLW 00
0001: MOVWF 0A
0002: GOTO 018
0003: NOP
.................... #include "main.h"
.................... #include <16F887.h>
.................... //////// Standard Header file for the PIC16F887 device ////////////////
.................... #device PIC16F887
.................... #list
....................
.................... #device adc=8
....................
.................... #FUSES NOWDT //No Watch Dog Timer
.................... #FUSES HS //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
.................... #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=20000000)
*
0004: MOVLW 23
0005: MOVWF 04
0006: BCF 03.7
0007: MOVF 00,W
0008: BTFSC 03.2
0009: GOTO 017
000A: MOVLW 06
000B: MOVWF 78
000C: CLRF 77
000D: DECFSZ 77,F
000E: GOTO 00D
000F: DECFSZ 78,F
0010: GOTO 00C
0011: MOVLW 7B
0012: MOVWF 77
0013: DECFSZ 77,F
0014: GOTO 013
0015: DECFSZ 00,F
0016: GOTO 00A
0017: RETURN
....................
....................
....................
....................
.................... #define MAX 1024
....................
.................... // Vystup PWM je na nozickach C1 a C2
....................
.................... void main()
.................... {
0018: CLRF 04
0019: BCF 03.7
001A: MOVLW 1F
001B: ANDWF 03,F
001C: BSF 03.5
001D: BSF 03.6
001E: MOVF 09,W
001F: ANDLW C0
0020: MOVWF 09
0021: BCF 03.6
0022: BCF 1F.4
0023: BCF 1F.5
0024: MOVLW 00
0025: BSF 03.6
0026: MOVWF 08
0027: BCF 03.5
0028: CLRF 07
0029: CLRF 08
002A: CLRF 09
.................... int16 pwm;
....................
.................... setup_adc_ports(NO_ANALOGS);
*
002E: BSF 03.5
002F: BSF 03.6
0030: MOVF 09,W
0031: ANDLW C0
0032: MOVWF 09
0033: BCF 03.6
0034: BCF 1F.4
0035: BCF 1F.5
0036: MOVLW 00
0037: BSF 03.6
0038: MOVWF 08
.................... setup_adc(ADC_OFF);
0039: BCF 03.5
003A: BCF 03.6
003B: BCF 1F.0
.................... setup_spi(SPI_SS_DISABLED);
003C: BCF 14.5
003D: BCF 20.5
003E: MOVF 20,W
003F: BSF 03.5
0040: MOVWF 07
0041: BCF 03.5
0042: BSF 20.4
0043: MOVF 20,W
0044: BSF 03.5
0045: MOVWF 07
0046: BCF 03.5
0047: BCF 20.3
0048: MOVF 20,W
0049: BSF 03.5
004A: MOVWF 07
004B: MOVLW 01
004C: BCF 03.5
004D: MOVWF 14
004E: MOVLW 00
004F: BSF 03.5
0050: MOVWF 14
.................... setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);
0051: MOVF 01,W
0052: ANDLW C7
0053: IORLW 08
0054: MOVWF 01
.................... setup_timer_1(T1_DISABLED);
0055: BCF 03.5
0056: CLRF 10
.................... setup_timer_2(T2_DIV_BY_1,255,1);
0057: MOVLW 00
0058: MOVWF 78
0059: IORLW 04
005A: MOVWF 12
005B: MOVLW FF
005C: BSF 03.5
005D: MOVWF 12
.................... setup_ccp1(CCP_PWM);
005E: BCF 03.5
005F: BCF 20.2
0060: MOVF 20,W
0061: BSF 03.5
0062: MOVWF 07
0063: BCF 03.5
0064: BCF 07.2
0065: BSF 03.5
0066: BCF 09.6
0067: MOVLW 0C
0068: BCF 03.5
0069: MOVWF 17
006A: BSF 03.5
006B: CLRF 1B
006C: CLRF 1C
006D: MOVLW 01
006E: MOVWF 1D
.................... setup_ccp2(CCP_PWM);
006F: BCF 03.5
0070: BCF 20.1
0071: MOVF 20,W
0072: BSF 03.5
0073: MOVWF 07
0074: BCF 03.5
0075: BCF 07.1
0076: MOVLW 0C
0077: MOVWF 1D
0078: MOVLW 01
0079: MOVWF 00
.................... set_pwm1_duty(0);
007A: CLRF 15
.................... set_pwm2_duty(0);
007B: CLRF 1B
....................
.................... port_b_pullups(TRUE);
007C: BSF 03.5
007D: MOVWF 15
007E: BCF 01.7
.................... pwm=0;
007F: BCF 03.5
0080: CLRF 22
0081: CLRF 21
....................
....................
.................... // Postupne zhasina a rozsveci stridave dve LED
.................... while(TRUE)
.................... {
.................... while(pwm<MAX)
.................... {
0082: MOVF 22,W
0083: SUBLW 03
0084: BTFSS 03.0
0085: GOTO 0B8
.................... pwm++;
0086: INCF 21,F
0087: BTFSC 03.2
0088: INCF 22,F
.................... delay_ms(5);
0089: MOVLW 05
008A: MOVWF 23
008B: CALL 004
.................... set_pwm1_duty(pwm);
008C: MOVF 22,W
008D: MOVWF 79
008E: MOVF 21,W
008F: MOVWF 78
0090: RRF 79,F
0091: RRF 78,F
0092: RRF 79,F
0093: RRF 78,F
0094: RRF 79,F
0095: MOVF 78,W
0096: MOVWF 15
0097: RRF 79,F
0098: RRF 79,W
0099: ANDLW 30
009A: MOVWF 77
009B: MOVF 17,W
009C: ANDLW CF
009D: IORWF 77,W
009E: MOVWF 17
.................... set_pwm2_duty(MAX-pwm);
009F: MOVF 21,W
00A0: SUBLW 00
00A1: MOVWF 23
00A2: MOVLW 04
00A3: MOVWF 24
00A4: MOVF 22,W
00A5: BTFSS 03.0
00A6: INCFSZ 22,W
00A7: SUBWF 24,F
00A8: RRF 24,F
00A9: RRF 23,F
00AA: RRF 24,F
00AB: RRF 23,F
00AC: RRF 24,F
00AD: MOVF 23,W
00AE: MOVWF 1B
00AF: RRF 24,F
00B0: RRF 24,W
00B1: ANDLW 30
00B2: MOVWF 77
00B3: MOVF 1D,W
00B4: ANDLW CF
00B5: IORWF 77,W
00B6: MOVWF 1D
.................... };
00B7: GOTO 082
.................... while(pwm>0)
.................... {
00B8: MOVF 21,F
00B9: BTFSS 03.2
00BA: GOTO 0BE
00BB: MOVF 22,F
00BC: BTFSC 03.2
00BD: GOTO 0F1
.................... pwm--;
00BE: MOVF 21,W
00BF: BTFSC 03.2
00C0: DECF 22,F
00C1: DECF 21,F
.................... delay_ms(5);
00C2: MOVLW 05
00C3: MOVWF 23
00C4: CALL 004
.................... set_pwm1_duty(pwm);
00C5: MOVF 22,W
00C6: MOVWF 79
00C7: MOVF 21,W
00C8: MOVWF 78
00C9: RRF 79,F
00CA: RRF 78,F
00CB: RRF 79,F
00CC: RRF 78,F
00CD: RRF 79,F
00CE: MOVF 78,W
00CF: MOVWF 15
00D0: RRF 79,F
00D1: RRF 79,W
00D2: ANDLW 30
00D3: MOVWF 77
00D4: MOVF 17,W
00D5: ANDLW CF
00D6: IORWF 77,W
00D7: MOVWF 17
.................... set_pwm2_duty(MAX-pwm);
00D8: MOVF 21,W
00D9: SUBLW 00
00DA: MOVWF 23
00DB: MOVLW 04
00DC: MOVWF 24
00DD: MOVF 22,W
00DE: BTFSS 03.0
00DF: INCFSZ 22,W
00E0: SUBWF 24,F
00E1: RRF 24,F
00E2: RRF 23,F
00E3: RRF 24,F
00E4: RRF 23,F
00E5: RRF 24,F
00E6: MOVF 23,W
00E7: MOVWF 1B
00E8: RRF 24,F
00E9: RRF 24,W
00EA: ANDLW 30
00EB: MOVWF 77
00EC: MOVF 1D,W
00ED: ANDLW CF
00EE: IORWF 77,W
00EF: MOVWF 1D
.................... }
00F0: GOTO 0B8
.................... }
00F1: GOTO 082
.................... }
00F2: SLEEP
 
Configuration Fuses:
Word 1: 2CF2 HS NOWDT NOPUT MCLR NOPROTECT NOCPD NOBROWNOUT IESO FCMEN NOLVP NODEBUG
Word 2: 3FFF NOWRT BORV40
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.pjt
0,0 → 1,24
[PROJECT]
Target=C:\Users\Honza\Documents\PIC\ledbar\main.hex
Development_Mode=
Processor_Text=PIC16F887
ToolSuite=CCS
Processor=0x887F
[C:\Users\Honza\Documents\PIC\ledbar\main]
Type=4
Path=
FileList=
BuildTool=
OptionString=
AdditionalOptionString=
[mru-list]
1=C:\Users\Honza\Documents\PIC\ledbar\main.c
[Windows]
0=0000 %S 0 0 796 451 3 0
[Units]
Link=0
Count=1
1=C:\Users\Honza\Documents\PIC\ledbar\main
[Opened Files]
1=main.c
2=
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.sta
0,0 → 1,47
 
ROM used: 243 (3%)
243 (3%) including unused fragments
 
0 Average locations per line
9 Average locations per statement
 
RAM used: 10 (3%) at main() level
10 (3%) worst case
 
Stack used: 1 worst case (out of 8 total available)
 
Lines Stmts % Files
----- ----- --- -----
46 27 100 main.c
20 0 0 main.h
423 0 0 ..\..\..\..\..\Program Files (x86)\PICC\devices\16F887.h
----- -----
489 27 Total
 
Page ROM % RAM Vol Diff Functions:
---- --- --- --- --- ---- ----------
0 20 8 1 @delay_ms1
0 219 90 4 660 5.8 main
 
Program metrics:
Functions 1
Statements 27
Comments 85
Volume (V) 662
Difficilty (D) 5.7
Effort to implement (E) 3750
Time to implement (T) 3 minutes
Est Delivered Bugs (B) 0
Cyclomatic Complexity 1
Maintainability (MI) 133
 
Segment Used Free
----------- ---- ----
00000-00003 4 0
00004-007FF 239 1805
00800-00FFF 0 2048
01000-017FF 0 2048
01800-01FFF 0 2048
 
 
 
/Modules/PowerSW/PWMLED01B/SW/PIC16F887/main.sym
0,0 → 1,62
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.pwm
023 @delay_ms1.P1
023 main.@SCRATCH1
024 main.@SCRATCH2
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:
0004 @delay_ms1
0018 main
0018 @cinit
 
 
User Memory space:
 
User Memory space:
 
Project Directory:
C:\Users\Honza\Documents\PIC\ledbar\
 
Project Files:
main.c
main.h
..\..\..\..\..\Program Files (x86)\PICC\devices\16F887.h
 
Units:
C:\Users\Honza\Documents\PIC\ledbar\main (main)
 
Compiler Settings:
Processor: PIC16F887
Pointer Size: 16
ADC Range: 0-255
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/PowerSW/PWMLED01B/SW/PIC16F887/main.tre
0,0 → 1,5
ÀÄmain
ÀÄmain 0/219 Ram=4
ÃÄ??0??
ÃÄ@delay_ms1 0/20 Ram=1
ÀÄ@delay_ms1 0/20 Ram=1