Subversion Repositories svnkaklik

Compare Revisions

No changes between revisions

Ignore whitespace Rev 1 → Rev 2

/roboti/istrobot/merkur/PIC16F873/Kopie (2) - main.c
0,0 → 1,236
#include "main.h"
 
int movement; // smer minuleho pohybu
int line; // na ktere strane byla detekovana cara
unsigned int8 dira; // pocitadlo pro nalezeni preruseni cary
unsigned int8 speed; // rychlost zataceni
unsigned int8 straight; // pocitadlo pro zjisteni rovneho useku
 
// Konstanty pro dynamiku pohybu
#define T_DIRA 16 // po jakem case zataceni se detekuje dira
#define INC_SPEED 5 // prirustek rychlosti v jednom kroku
#define RIGHT_ANGLE 1000 // 90 stupnu
#define CIKCAK 20000 // 45 stupnu
#define BW_PO_DIRE 200 // zpetny chod po dire
#define FW_RYCHLE 200 // cara primo rovne
#define FW_POMALU 100 // trochu mimo caru vnitrni pas
#define FW_STREDNE 150 // trochu mimo caru vnejsi pas
#define TURN_MIN 90 // minimalni rychlost pri zataceni
#define TURN_MAX 150 // miximalni rychlost pri zataceni
#define BRZDENI 40 // doba zpetneho chodu v ms, aby pas stal
#define ROVINKA 8 // doba po kterou se musi jet rovne, aby se brzdilo
 
//motory //Napred vypnout potom zapnout!
#define FR output_low(PIN_B5); output_high(PIN_B4) // Vpred
#define FL output_low(PIN_B7); output_high(PIN_B6)
#define BR output_low(PIN_B4); output_high(PIN_B5) // Vzad
#define BL output_low(PIN_B6); output_high(PIN_B7)
#define STOPR output_low(PIN_B4);output_low(PIN_B5) // Zastav
#define STOPL output_low(PIN_B6);output_low(PIN_B7)
#define L 0b10 // left
#define R 0b01 // right
#define S 0b11 // straight
 
//cidla
#define RSENSOR 1 // Senzory na caru
#define LSENSOR 0
#define BUMPER PIN_C4 // Senzor na cihlu
 
#define DIAG_SERVO PIN_B0 // Propojka pro diagnosticky mod
#define DIAG_SENSORS PIN_B1 // Propojka pro diagnosticky mod
 
#DEFINE SOUND_HI PIN_B3 // komplementarni vystupy pro piezo pipak
#DEFINE SOUND_LO PIN_B2
 
char AXstring[40]; // Buffer pro prenos telemetrie
 
// makro pro PWM
#define GO(motor, direction, power) if(get_timer0()<=power) \
{direction##motor;} \
else \
{stop##motor;}
 
#int_TIMER1 // This function is called every time
void TIMER1_isr() { // the RTCC (timer0) overflows (255->0).
// For this program this is apx 76 times
// per second.
if (speed<TURN_MAX) speed+=INC_SPEED;
if (dira<255) dira++;
if (straight<255) straight++;
}
 
// Primitivni Pipani
void beep(unsigned int16 period, unsigned int16 length)
{
unsigned int16 nn;
 
for(nn=length; nn>0; nn--)
{
output_high(SOUND_HI);output_low(SOUND_LO);
delay_us(period);
output_high(SOUND_LO);output_low(SOUND_HI);
delay_us(period);
}
}
void diagnostika()
{
unsigned int16 n;
 
while (input(DIAG_SERVO)) // Propojka, ktera spousti diagnostiku
{
for (n=500; n<800; n+=100)
{
beep(n,n); //beep UP
};
Delay_ms(1000);
//zastav vse
STOPL; STOPR;
//pravy pas
FR; Delay_ms(1000); STOPR; Delay_ms(1000);
BR; Delay_ms(1000); STOPR; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//levy pas
FL; Delay_ms(1000); STOPL; Delay_ms(1000);
BL; Delay_ms(1000); STOPL; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//oba pasy
FL; FR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
BL; BR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
};
 
while (input(DIAG_SENSORS))
{
int ls, rs;
while(!input(BUMPER)){beep(1100,100); Delay_ms(50);}
set_adc_channel(RSENSOR);
Delay_us(20);
rs=read_adc();
set_adc_channel(LSENSOR);
Delay_us(20);
ls=read_adc();
};
}
void main()
{
STOPL; STOPR; // prepne vystupy na ovladani motoru na output a zastavi
setup_adc_ports(RA0_RA1_RA3_ANALOG);
setup_adc(ADC_CLOCK_DIV_2);
setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1); // Casovac pro PWM
setup_timer_1(T1_INTERNAL|T1_DIV_BY_1); // Casovac pro regulaci
setup_timer_2(T2_DISABLED,0,1);
setup_ccp1(CCP_OFF);
diagnostika();
 
Beep(1000,200); //double beep
Delay_ms(50);
Beep(1000,200);
Delay_ms(1000); // 1s
 
 
speed=TURN_MIN; // povoleni rizeni rychlosti zataceni pres preruseni
enable_interrupts(INT_TIMER1);
enable_interrupts(GLOBAL);
 
// Cik-Cak -------------------------------------------------------------
line=S;
movement=R;
// cik_cak(); // toc se, abys nasel caru
Delay_ms(500);
Beep(1000,200);
Delay_ms(500);
 
dira=0; // inicializace globalnich promennych
straight=255;
 
while(true) // hlavni smycka (jizda podle cary)
{
set_adc_channel(LSENSOR); // kdyz cara nebyla pod pravym cidlem, mozna bude pod levym
Delay_us(10);
if(tresholdL > read_adc())
{
movement = L;
if (straight>ROVINKA)
{GO(R, F, FW_STREDNE+40); GO(L, F, FW_POMALU+40)} // pridej
else
{GO(R, F, FW_STREDNE); GO(L, F, FW_POMALU)};
speed=TURN_MIN;
dira=0;
line=L;
continue;
}
set_adc_channel(RSENSOR); // podivej se jestli neni cara pod pravym cidlem
Delay_us(10);
if(tresholdR > read_adc())
{
movement = R;
if (straight>ROVINKA)
{GO(L, F, FW_STREDNE+40); GO(R, F, FW_POMALU+40)} // pridej
else
{GO(L, F, FW_STREDNE); GO(R, F, FW_POMALU)};
speed=TURN_MIN;
dira=0;
line=R;
continue;
}
if(line==S)
movement = S;
if (straight>ROVINKA)
{FL; FR;} // pokud se jede dlouho rovne, tak pridej
else
{GO(R, F, FW_RYCHLE); GO(L, F, FW_RYCHLE)};
speed=TURN_MIN; // nastav minimalni rychlost pro zataceni
dira=0; // protoze byla cara, tak nuluj pocitadlo diry
continue;
 
 
if (straight>ROVINKA) // pokud byla dlouha rovinka, tak zabrzdi
{
BL; BR;
Delay_ms(BRZDENI);
STOPL;
STOPR;
dira=0;
};
straight=0; // nuluj pocitadlo rovinky
 
if (L==movement) // kdyz jsou obe cidla mimo caru, zatoc na caru
{
GO(R, F, speed);
STOPL;
}
else
{
GO(L, F, speed);
STOPR;
}
 
if (dira>T_DIRA) // pokud se moc dlouho zataci bez detekce cary, vrat se
{
STOPL;
STOPR;
Beep(1000,200); //double beep
Delay_ms(30);
Beep(2000,200);
Delay_ms(30);
if (L==movement) // zpet, podle toho kam se jelo
{
STOPL;
BR;
}
else
{
STOPR;
BL;
};
Delay_ms(BW_PO_DIRE);
STOPL;
STOPR;
cik_cak(); // najdi caru
dira=0;
}
 
} // while(true)
}
 
/roboti/istrobot/merkur/PIC16F873/main.BAK
0,0 → 1,332
#include "main.h"
 
#define TXo PIN_C3 // To the transmitter modulator
#include "AX25.c" // podprogram pro prenos telemetrie
 
//motory //Napred vypnout potom zapnout!
#define FR output_low(PIN_B5); output_high(PIN_B4) // Vpred
#define FL output_low(PIN_B7); output_high(PIN_B6)
#define BR output_low(PIN_B4); output_high(PIN_B5) // Vzad
#define BL output_low(PIN_B6); output_high(PIN_B7)
#define STOPR output_low(PIN_B4);output_low(PIN_B5)
#define STOPL output_low(PIN_B6);output_low(PIN_B7)
 
#define L 0b10 // left
#define R 0b01 // right
#define S 0b11 // straight
 
#define COUVANI 1600 // couvnuti po zjisteni diry
#define MEZERA 5400 // za jak dlouho bude ztracena cara
#define PRES_DIRU 400 // velikost mezery v care
#define ODEZVA 1 // za jak dlouho po opusteni cary se ma zacit zatacet
#define BRZDENI 90 // doba (v ms) ptrebna k zastaveni jednoho motoru
 
//cidla
#define RSENSOR 1 // Senzory na caru
#define LSENSOR 0
#define BUMPER PIN_C4 // sensor na cihlu
 
#define DIAG_SERVO PIN_B0 // Propojka pro diagnosticky mod
#define DIAG_SENSORS PIN_B1 // Propojka pro diagnosticky mod
 
#DEFINE SOUND_HI PIN_B3
#DEFINE SOUND_LO PIN_B2
 
char AXstring[40]; // Buffer pro prenos telemetrie
 
int tresholdL; // rozhodovaci uroven pro prave cidlo
int tresholdR; // rozhodovaci uroven pro prave cidlo
int movement; // smer minuleho pohybu
int line; // na ktere strane byla detekovana cara
unsigned int16 dira; // pocitadlo pro nalezeni preruseni cary
 
// Primitivni Pipani
void beep(unsigned int16 period, unsigned int16 length)
{
unsigned int16 nn;
 
for(nn=length; nn>0; nn--)
{
output_high(SOUND_HI);output_low(SOUND_LO);
delay_us(period);
output_high(SOUND_LO);output_low(SOUND_HI);
delay_us(period);
}
}
 
// Diagnostika pohonu, hejbne vsema motorama ve vsech smerech
void diagnostika()
{
unsigned int16 n;
 
while (input(DIAG_SERVO)) // Propojka, ktera spousti diagnostiku
{
for (n=500; n<800; n+=100)
{
beep(n,n); //beep UP
};
Delay_ms(1000);
//zastav vse
STOPL; STOPR;
//pravy pas
FR; Delay_ms(1000); STOPR; Delay_ms(1000);
BR; Delay_ms(1000); STOPR; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//levy pas
FL; Delay_ms(1000); STOPL; Delay_ms(1000);
BL; Delay_ms(1000); STOPL; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//oba pasy
FL; FR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
BL; BR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
};
 
while (input(DIAG_SENSORS))
{
int ls, rs;
while(!input(BUMPER)){beep(1100,100); Delay_ms(50);}
set_adc_channel(RSENSOR);
Delay_us(20);
rs=read_adc();
set_adc_channel(LSENSOR);
Delay_us(20);
ls=read_adc();
sprintf(AXstring,"L: %U R: %U\0", ls, rs); // Convert DATA to String.
SendPacket(&AXstring[0]);
delay_ms(1000);
};
}
 
void cikcak()
{
int n;
switch(movement) // podivej se na jednu stranu
{
case L:
FL;BR;
movement=R;
break;
case R:
FR;BL;
movement=L;
break;
case S:
FR;BL;
movement=L;
break;
}
set_adc_channel(LSENSOR);
Delay_us(10);
while (tresholdL < read_adc()) // je tam cara?
{
if (n==50) // asi bude na druhe strane
{
STOPR;STOPL;
n=0;
switch(movement)
{
case L:
FL;BR;
movement=R;
break;
case R:
FR;BL;
movement=L;
break;
}
}
Delay_ms(5);
n++;
}
STOPL;STOPR; // nasli jsme caru
line=S;
}
void objizdka()
{
BL;BR;Delay_ms(300);
STOPR;STOPL;
beep(1000,1000);
Delay_ms(500);
beep(1000,1000);
Delay_ms(1000);
 
}
void kalibrace()
{
unsigned int16 i;
int min;
int max;
int current;
int treshold;
 
FL; BR; Delay_ms(130);
chyba1:
FR; BL; //kalibrace leveho cidla
set_adc_channel(LSENSOR);
Delay_us(20);
min=max=read_adc();
for (i=1;i<=500;i++)
{
current=read_adc();
if (max < current) max=current;
if (min > current) min=current;
Delay_us(500);
}
FL; BR;
for (i=1;i<=500;i++)
{
current=read_adc();
if (max < current) max=current;
if (min > current) min=current;
Delay_us(500);
}
STOPL; STOPR; Delay_ms(200);
if((max-min)<50) {Beep(1000,300); GOTO chyba1;}
treshold=(max-min)>>1;
tresholdL=treshold+min;
 
chyba2:
FR; BL;
set_adc_channel(RSENSOR);
Delay_us(20);
min=max=read_adc(); //naplneni min a max nejakou rozumnou hodnotou
for (i=1;i<=500 ;i++)
{
current=read_adc();
if (max < current) max=current; //zmereni minima a maxima
if (min > current) min=current;
Delay_us(500);
}
FL; BR;
for (i=1;i<=500 ;i++)
{
current=read_adc();
if (max < current) max=current; //zmereni minima a maxima
if (min > current) min=current;
Delay_us(500);
}
STOPL; STOPR; Delay_ms(200);
if((max-min)<50) {Beep(1000,300); GOTO chyba2;}
treshold=(max-min)>>1;
tresholdR=treshold+min;
 
FR; BL;
movement=L;
set_adc_channel(LSENSOR);
Delay_us(20);
while (tresholdL < read_adc()) Delay_us(100);
FL; BR; Delay_ms(50);
STOPL; STOPR; Delay_ms(500);
Beep(780,200);
}
 
void main()
{
unsigned int16 rovne; // pocita delku rovne cary
 
STOPL; STOPR;
 
setup_adc_ports(RA0_RA1_RA3_ANALOG);
setup_adc(ADC_CLOCK_DIV_2);
 
port_b_pullups(false);
 
diagnostika();
 
Beep(1000,200); //double beep
Delay_ms(50);
Beep(1000,200);
Delay_ms(1000); // 1s
 
// kalibrace();
tresholdl=tresholdr=80;
// FL; FR;
movement=S;
line=S;
dira=0;
rovne=0;
 
while(true)
{
if(!input(BUMPER)) objizdka();
line=0;
set_adc_channel(RSENSOR); // podivej se jestli neni cara pod pravym cidlem
Delay_us(10);
if(tresholdR > read_adc())
{
dira=0;
line=R;
}
set_adc_channel(LSENSOR); // kdyz cara nebyla pod pravym cidlem, mozna bude pod levym
Delay_us(10);
if(tresholdL > read_adc())
{
dira=0;
line=line | L;
}
switch(line)
{
case S:
FR;FL;
movement=S;
continue;
case L:
STOPL;
FR;movement=L;
continue;
case R:
STOPR;
FL;movement=R;
continue;
default:
}
 
if (dira==ODEZVA) // kdyz uz chvili jedeme po bile plose
{
//BR;BL;Delay_us(rovne >>= 5);
rovne=0; //kdyz sme museli zatocit, uz neni rovna cara
 
switch (line) // musime zatocit
{
case L:
BL;Delay_ms(BRZDENI);STOPL;
FR;
movement=L;
break;
case R:
BR;Delay_ms(BRZDENI);STOPR;
FL;
movement=R;
break;
}
}
if (dira==MEZERA) // kdyz zkoncila cara
{
beep(800,500);
Delay_ms(50);
beep(800,500);
switch (movement) //vrat se zpet na caru
{
case L:
STOPL;STOPR;
BR;Delay_ms(COUVANI);STOPR;
break;
case R:
STOPL;STOPR;
BL;Delay_ms(COUVANI);STOPL;
break;
case S:
BL; BR; Delay_ms(COUVANI);
STOPL; STOPR;
break;
}
 
FR;FL; Delay_ms(PRES_DIRU); // popojedem dopredu mozna tam bude cara
STOPL; STOPR; movement=S;
cikcak(); // najdi caru
dira=0;
}
dira++;
} // while(true)
}
/roboti/istrobot/merkur/PIC16F873/main.HEX
0,0 → 1,200
:1000000000308A001D2C00000A108A100A11820795
:100010004C343A342034253455342034203452348E
:100020003A34203425345534003400347830840098
:10003000FC308005800C800C00080319232821283F
:100040000000800B202800347508F7007408F600C3
:10005000F608031D2E28F708031949288316861170
:100060008312861583160611831206117208F80092
:100070001620831606118312061583168611831225
:1000800086117208F800162076080319F703F603A4
:100090002828003473308400000803195E280130DA
:1000A000A100A001A00B5228A10B51284A30A000AA
:1000B000A00B582800000000800B4F2800346B086C
:1000C000840075088000840A8001EB0A00347608F9
:1000D000A101750203186F287508A0007B28A001F4
:1000E0000830F700F50DA00D760820020318A000D7
:1000F000A10DF70B7228003421087308F500643055
:10010000F60067202008F30021083030031D8F28F7
:100110007418F415F4199528741A20309128F411E4
:100120007412A1072108F5005F207308F5000A305A
:10013000F60067202008F30021083030031DA428B2
:10014000F419A828741A2030A1072108F5005F20AF
:100150003030F3077308F5005F200034B801351C18
:10016000B3283510B42835140034351CE828BC11E8
:100170003C0883168700831287154930A000A00B26
:10018000BF2800000000BC113C08831687008312C2
:1001900087114930A000A00BCB2800000000BC1143
:1001A0003C0883168700831287154930A000A00BF6
:1001B000D72800000000BC113C088316870083127A
:1001C00087111930A000A00BE32800000000FE28D2
:1001D000BC113C0883168700831287158930A00064
:1001E000A00BF028BC113C088316870083128711EE
:1001F0007230A000A00BFA28000000000034F501C6
:100200007508073C031C492974080139F600BA082F
:1002100003190C2900300D290130F700B908031922
:1002200013290030142901307705003A03192729D2
:100230007608F7000310B70CB60C030801397706EF
:10024000013C031D27298430B7060830B606F6089E
:10025000031D2C29AE204429B908031D3029B80AF2
:10026000B90803193529003036290130F70038085C
:10027000053C03193D2900303E2901307705003A3D
:1002800003194429B520AE20B5200310F40CF50A5B
:1002900000290034831606148312061C752A0130C7
:1002A000EF00F430EE006F08033C031C6B29031DC4
:1002B0005D296E081F3C031C6B296F08F3006E0854
:1002C000F2006F08F5006E08F40024206430EE0799
:1002D0000318EF0A53290430F200FA30F3004A20E1
:1002E000F20B6D29831606138312061383168613E9
:1002F0008312861383160612831206128316861241
:1003000083128612831686128312861283160612B1
:10031000831206160430F200FA30F3004A20F20B82
:100320008C298316061283120612831686128312F4
:1003300086120430F200FA30F3004A20F20B9B29B7
:1003400083160612831206128316861283128616ED
:100350000430F200FA30F3004A20F20BAA29831687
:100360000612831206128316861283128612043036
:10037000F200FA30F3004A20F20BB9290330F300FF
:100380007030F200F5016430F40024200430F200F3
:10039000FA30F3004A20F20BC82983168613831221
:1003A000861383160613831206170430F200FA3000
:1003B000F3004A20F20BD729831606138312061383
:1003C00083168613831286130430F200FA30F3008A
:1003D0004A20F20BE62983160613831206138316AE
:1003E0008613831286170430F200FA30F3004A2095
:1003F000F20BF52983160613831206138316861350
:10040000831286130430F200FA30F3004A20F20B14
:10041000042A0330F3007030F200F5016430F40078
:1004200024200430F200FA30F3004A20F20B132AA1
:1004300083168613831286138316061383120617F8
:1004400083168612831286128316061283120616EC
:100450000430F200FA30F3004A20F20B2A2A831605
:1004600006138312061383168613831286138316CC
:100470000612831206128316861283128612043025
:10048000F200FA30F3004A20F20B412A83160613D9
:100490008312061383168613831286178316061299
:1004A0008312061283168612831286160430F20017
:1004B000FA30F3004A20F20B582A831606138312EF
:1004C000061383168613831286138316061283126D
:1004D000061283168612831286120430F200FA3056
:1004E000F3004A20F20B6F2A4A29831686148312DE
:1004F000861C192B3C163C08831687008312071AAA
:100500008D2A0430F3004C30F200F5016430F40021
:1005100024203230F3004A207A2A0830A1001F0834
:10052000C73921049F000630A000A00B952A0000C7
:100530001F151F19992A1E08F1000030A1001F087D
:10054000C73921049F000630A000A00BA52A000097
:100550001F151F19A92A1E08F0003D30EB004C3072
:10056000F5005F203A30F5005F202030F5005F2075
:100570007008F3001830F4007C200530F200720897
:100580000420F20AF5005F200A307202031DBF2A20
:100590007108F3001830F4007C203D30F200351073
:1005A000FF30B700B600B8010130B900BA01BB0195
:1005B0003B08093C031CE12A7E30F400FF20BB0A03
:1005C000D82AB901BB013B080F3C031CF02A253097
:1005D0003B0784000008F300F400FF20BB0AE32A75
:1005E000BB01720884000008003A0319002B72084E
:1005F00084000008F300F400FF20F20ABB0AF12A8D
:100600000130BA00FF30B606B7063608F400FF2006
:100610003708F400FF20BA010130B9007E30F40041
:10062000FF200430F200FA30F3004A20F20B132BC3
:10063000752A8A115E2C83160613831206138316FD
:1006400086138312861783160612831206128316E8
:100650008612831286160230EE009630F3004A208E
:10066000EE0B2D2B831606128312061283168612AA
:1006700083128612831606138312061383168613BB
:10068000831286130330F300E830F2000330F500E4
:10069000E830F40024200230EE00FA30F3004A2063
:1006A000EE0B4D2B0330F300E830F2000330F50081
:1006B000E830F40024200430EE00FA30F3004A2041
:1006C000EE0B5D2B8A118A2C01306702FD3E031868
:1006D000A42B033E102C83168613831286138316D5
:1006E0000613831206178316061283120612831648
:1006F0008612831286160130E700A42B8316861219
:1007000083128612831606128312061683160613A8
:100710008312061383168613831286170230E700AE
:10072000A42B831686128312861283160612831256
:100730000616831606138312061383168613831276
:1007400086170230E700A42B0030A1001F08C7392C
:1007500021049F000330A000A00BAC2B1F151F1914
:10076000AF2B1E0865020318FC2B6E08323C031DDC
:10077000F72B831606128312061283168612831233
:1007800086128316061383120613831686138312AA
:100790008613EE0101306702FE3E0318F72B023E7E
:1007A000172C83168613831286138316061383125F
:1007B00006178316061283120612831686128312F8
:1007C00086160130E700F72B8316861283128612F5
:1007D0008316061283120616831606138312061357
:1007E00083168613831286170230E700F72B053035
:1007F000F3004A20EE0AAE2B83160613831206136B
:10080000831686138312861383160612831206122A
:1008100083168612831286120330E8008A11102E86
:100820000A108A100A1582077E2B6B2B912B0A1057
:100830008A100A158207E42BD12B84011F3083050F
:10084000073083169F0082308312A5009830A600DF
:10085000A7004030A800A900AA006030AB00863095
:10086000AC00B430AD006030AE00A430AF00B000DA
:10087000B1006130B2000330B300F030B400FF309B
:10088000BC00EB018316061383120613831686132E
:10089000831286138316061283120612831686129B
:1008A00083128612043083169F0083121F08383982
:1008B00001389F008316811783124A290330F30001
:1008C000E830F200F501C830F40024203230F300A3
:1008D0004A200330F300E830F200F501C830F4009C
:1008E00024200430EE00FA30F3004A20EE0B732C83
:1008F0005030E600E5000330E700E800EA01E901D6
:10090000ED01EC013C163C08831687008312071AA0
:100910008A2C1B2BE8010830A1001F08C7392104CD
:100920009F000330A000A00B932C1F151F19962CBD
:100930001E0866020319A22C031CA22CEA01E9017D
:100940000130E8000030A1001F08C73921049F00D2
:100950000330A000A00BAA2C1F151F19AD2C1E08D8
:1009600065020319B82C031CB82CEA01E901E8144C
:100970006808A000033020020319C72C02302002AF
:100980000319DA2C013020020319ED2C002D8316F7
:100990008612831286128316061283120616831697
:1009A00086138312861383160613831206170330E9
:1009B000E700822C83160613831206138316861310
:1009C00083128613831686128312861283160612EA
:1009D000831206160230E700822C83160612831259
:1009E00006128316861283128612831686138312CA
:1009F000861383160613831206170130E700822C34
:100A0000690B4A2DEA08031D4A2DED01EC01013066
:100A10006802FE3E03184A2D023E172E8316061367
:100A20008312061383168613831286176430F3002D
:100A30004A20831606138312061383168613831225
:100A40008613831686128312861283160612831269
:100A500006160230E7004A2D83160612831206128C
:100A600083168612831286166430F3004A2083169A
:100A700006128312061283168612831286128316BA
:100A8000861383128613831606138312061701300A
:100A9000E7004A2D6908183C031D122E6A08153C10
:100AA000031D122E0330F3002030F2000130F50058
:100AB000F430F40024203230F3004A200330F300F5
:100AC0002030F2000130F500F430F4002420013031
:100AD0006702FD3E0318E62D033E1D2E8316061306
:100AE0008312061383168613831286138316061247
:100AF000831206128316861283128612831606123A
:100B00008312061283168612831286160830EE00B0
:100B1000C830F3004A20EE0B882D8316061283128C
:100B200006128316861283128612E62D831606138A
:100B300083120613831686138312861383160612F6
:100B400083120612831686128312861283160613E8
:100B50008312061383168613831286170830EE005D
:100B6000C830F3004A20EE0BB02D83160613831213
:100B700006138316861383128613E62D8316061337
:100B800083120613831686138312861783160612A2
:100B90008312061283168612831286160830EE0020
:100BA000C830F3004A20EE0BD02D831606138312B3
:100BB0000613831686138312861383160612831276
:100BC00006128316861283128612E62D831686126B
:100BD0008312861283160612831206168316861354
:100BE0008312861383160613831206170230EE0053
:100BF000C830F3004A20EE0BF82D8316061383123B
:100C00000613831686138312861383160612831225
:100C1000061283168612831286120330E700642BB5
:100C2000EA01E901E90A0319EA0A822C63000A10C1
:100C30008A140A1582072C2D0E2D0A108A140A1503
:080C40008207962D6E2DBE2DDA
:02400E00793FF8
:00000001FF
;PIC16F873
/roboti/istrobot/merkur/PIC16F873/main.LST
0,0 → 1,2057
CCS PCW C Compiler, Version 3.110, 15448
 
Filename: d:\kaklik\programy\pic_c\roboti\merkur\main.LST
 
ROM used: 1572 (38%)
Largest free fragment is 2048
RAM used: 79 (41%) at main() level
90 (47%) worst case
Stack: 3 locations
 
*
0000: MOVLW 00
0001: MOVWF 0A
0002: GOTO 41D
0003: NOP
.................... #include "main.h"
.................... #include <16F873.h>
.................... //////// Standard Header file for the PIC16F873 device ////////////////
.................... #device PIC16F873
.................... #list
....................
.................... #device adc=8
.................... #use delay(clock=4000000)
*
0016: MOVLW 78
0017: MOVWF 04
0018: MOVLW FC
0019: ANDWF 00,F
001A: RRF 00,F
001B: RRF 00,F
001C: MOVF 00,W
001D: BTFSC 03.2
001E: GOTO 023
001F: GOTO 021
0020: NOP
0021: DECFSZ 00,F
0022: GOTO 020
0023: RETLW 00
*
004A: MOVLW 73
004B: MOVWF 04
004C: MOVF 00,W
004D: BTFSC 03.2
004E: GOTO 05E
004F: MOVLW 01
0050: MOVWF 21
0051: CLRF 20
0052: DECFSZ 20,F
0053: GOTO 052
0054: DECFSZ 21,F
0055: GOTO 051
0056: MOVLW 4A
0057: MOVWF 20
0058: DECFSZ 20,F
0059: GOTO 058
005A: NOP
005B: NOP
005C: DECFSZ 00,F
005D: GOTO 04F
005E: RETLW 00
.................... #fuses XT,NOWDT,NOLVP
....................
....................
....................
.................... #define TXo PIN_C3 // To the transmitter modulator
.................... #include "AX25.c" // podprogram pro prenos telemetrie
.................... //#define PTT PIN_A2 // PTT control
.................... //#define TXo PIN_C0 // To the transmitter modulator
.................... #define PERIODAH delay_us(222) // Halfperiod H 222;78/1200 500;430/500
.................... #define TAILH delay_us(78)
.................... #define PERIODAL delay_us(412) // Halfperiod L 412;345/1200 1000;880/500
.................... #define TAILL delay_us(345)
.................... #byte STATUS = 3 // CPUs status register
....................
.................... byte SendData[16] = {'A'<<1, 'L'<<1, 'L'<<1, ' '<<1, ' '<<1, ' '<<1, 0x60,
.................... 'C'<<1, 'Z'<<1, '0'<<1, 'R'<<1, 'R'<<1, 'R'<<1, 0x61,
.................... 0x03, 0xF0};
....................
.................... boolean bit;
.................... int fcslo, fcshi; // variabloes for calculating FCS (CRC)
.................... int stuff; // stuff counter for extra 0
.................... int flag_flag; // if it is sending flag (7E)
.................... int fcs_flag; // if it is sending Frame Check Sequence
.................... int i; // for for
....................
.................... void flipout() //flips the state of output pin a_1
.................... {
.................... stuff = 0; //since this is a 0, reset the stuff counter
*
00AE: CLRF 38
.................... if (bit)
00AF: BTFSS 35.0
00B0: GOTO 0B3
.................... {
.................... bit=FALSE; //if the state of the pin was low, make it high.
00B1: BCF 35.0
.................... }
.................... else
00B2: GOTO 0B4
.................... {
.................... bit=TRUE; //if the state of the pin was high make it low
00B3: BSF 35.0
.................... }
00B4: RETLW 00
.................... }
....................
.................... void fcsbit(byte tbyte)
.................... {
.................... #asm
.................... BCF STATUS,0
*
011A: BCF 03.0
.................... RRF fcshi,F // rotates the entire 16 bits
011B: RRF 37,F
.................... RRF fcslo,F // to the right
.................... #endasm
011C: RRF 36,F
.................... if (((STATUS & 0x01)^(tbyte)) ==0x01)
011D: MOVF 03,W
011E: ANDLW 01
011F: XORWF 77,W
0120: SUBLW 01
0121: BTFSS 03.2
0122: GOTO 127
.................... {
.................... fcshi = fcshi^0x84;
0123: MOVLW 84
0124: XORWF 37,F
.................... fcslo = fcslo^0x08;
0125: MOVLW 08
0126: XORWF 36,F
.................... }
.................... }
....................
.................... void SendBit ()
.................... {
.................... if (bit)
*
00B5: BTFSS 35.0
00B6: GOTO 0E8
.................... {
.................... output_high(TXo);
00B7: BCF 3C.3
00B8: MOVF 3C,W
00B9: BSF 03.5
00BA: MOVWF 07
00BB: BCF 03.5
00BC: BSF 07.3
.................... PERIODAH;
00BD: MOVLW 49
00BE: MOVWF 20
00BF: DECFSZ 20,F
00C0: GOTO 0BF
00C1: NOP
00C2: NOP
.................... output_low(TXo);
00C3: BCF 3C.3
00C4: MOVF 3C,W
00C5: BSF 03.5
00C6: MOVWF 07
00C7: BCF 03.5
00C8: BCF 07.3
.................... PERIODAH;
00C9: MOVLW 49
00CA: MOVWF 20
00CB: DECFSZ 20,F
00CC: GOTO 0CB
00CD: NOP
00CE: NOP
.................... output_high(TXo);
00CF: BCF 3C.3
00D0: MOVF 3C,W
00D1: BSF 03.5
00D2: MOVWF 07
00D3: BCF 03.5
00D4: BSF 07.3
.................... PERIODAH;
00D5: MOVLW 49
00D6: MOVWF 20
00D7: DECFSZ 20,F
00D8: GOTO 0D7
00D9: NOP
00DA: NOP
.................... output_low(TXo);
00DB: BCF 3C.3
00DC: MOVF 3C,W
00DD: BSF 03.5
00DE: MOVWF 07
00DF: BCF 03.5
00E0: BCF 07.3
.................... TAILH;
00E1: MOVLW 19
00E2: MOVWF 20
00E3: DECFSZ 20,F
00E4: GOTO 0E3
00E5: NOP
00E6: NOP
.................... }
.................... else
00E7: GOTO 0FE
.................... {
.................... output_high(TXo);
00E8: BCF 3C.3
00E9: MOVF 3C,W
00EA: BSF 03.5
00EB: MOVWF 07
00EC: BCF 03.5
00ED: BSF 07.3
.................... PERIODAL;
00EE: MOVLW 89
00EF: MOVWF 20
00F0: DECFSZ 20,F
00F1: GOTO 0F0
.................... output_low(TXo);
00F2: BCF 3C.3
00F3: MOVF 3C,W
00F4: BSF 03.5
00F5: MOVWF 07
00F6: BCF 03.5
00F7: BCF 07.3
.................... TAILL;
00F8: MOVLW 72
00F9: MOVWF 20
00FA: DECFSZ 20,F
00FB: GOTO 0FA
00FC: NOP
00FD: NOP
.................... };
00FE: RETLW 00
.................... }
....................
.................... void SendByte (byte inbyte)
.................... {
.................... int k, bt;
....................
.................... for (k=0;k<8;k++) //do the following for each of the 8 bits in the byte
00FF: CLRF 75
0100: MOVF 75,W
0101: SUBLW 07
0102: BTFSS 03.0
0103: GOTO 149
.................... {
.................... bt = inbyte & 0x01; //strip off the rightmost bit of the byte to be sent (inbyte)
0104: MOVF 74,W
0105: ANDLW 01
0106: MOVWF 76
.................... if ((fcs_flag == FALSE) & (flag_flag == FALSE)) fcsbit(bt); //do FCS calc, but only if this
0107: MOVF 3A,F
0108: BTFSC 03.2
0109: GOTO 10C
010A: MOVLW 00
010B: GOTO 10D
010C: MOVLW 01
010D: MOVWF 77
010E: MOVF 39,F
010F: BTFSC 03.2
0110: GOTO 113
0111: MOVLW 00
0112: GOTO 114
0113: MOVLW 01
0114: ANDWF 77,W
0115: XORLW 00
0116: BTFSC 03.2
0117: GOTO 127
0118: MOVF 76,W
0119: MOVWF 77
.................... //is not a flag or fcs byte
.................... if (bt == 0)
*
0127: MOVF 76,F
0128: BTFSS 03.2
0129: GOTO 12C
.................... {
.................... flipout();
012A: CALL 0AE
.................... } // if this bit is a zero, flip the output state
.................... else
012B: GOTO 144
.................... { //otherwise if it is a 1, do the following:
.................... if (flag_flag == FALSE) stuff++; //increment the count of consequtive 1's
012C: MOVF 39,F
012D: BTFSS 03.2
012E: GOTO 130
012F: INCF 38,F
.................... if ((flag_flag == FALSE) & (stuff == 5))
0130: MOVF 39,F
0131: BTFSC 03.2
0132: GOTO 135
0133: MOVLW 00
0134: GOTO 136
0135: MOVLW 01
0136: MOVWF 77
0137: MOVF 38,W
0138: SUBLW 05
0139: BTFSC 03.2
013A: GOTO 13D
013B: MOVLW 00
013C: GOTO 13E
013D: MOVLW 01
013E: ANDWF 77,W
013F: XORLW 00
0140: BTFSC 03.2
0141: GOTO 144
.................... { //stuff an extra 0, if 5 1's in a row
.................... SendBit();
0142: CALL 0B5
.................... flipout(); //flip the output state to stuff a 0
0143: CALL 0AE
.................... }//end of if
.................... }//end of else
.................... // delay_us(850); //introduces a delay that creates 1200 baud
.................... SendBit();
0144: CALL 0B5
.................... inbyte = inbyte>>1; //go to the next bit in the byte
0145: BCF 03.0
0146: RRF 74,F
.................... }//end of for
0147: INCF 75,F
0148: GOTO 100
0149: RETLW 00
.................... }//end of SendByte
....................
.................... void SendPacket(char *data)
.................... {
.................... bit=FALSE;
*
02CF: BCF 35.0
....................
.................... fcslo=fcshi=0xFF; //The 2 FCS Bytes are initialized to FF
02D0: MOVLW FF
02D1: MOVWF 37
02D2: MOVWF 36
.................... stuff = 0; //The variable stuff counts the number of 1's in a row. When it gets to 5
02D3: CLRF 38
.................... // it is time to stuff a 0.
....................
.................... // output_low(PTT); // Blinking LED
.................... // delay_ms(1000);
.................... // output_high(PTT);
....................
.................... flag_flag = TRUE; //The variable flag is true if you are transmitted flags (7E's) false otherwise.
02D4: MOVLW 01
02D5: MOVWF 39
.................... fcs_flag = FALSE; //The variable fcsflag is true if you are transmitting FCS bytes, false otherwise.
02D6: CLRF 3A
....................
.................... for(i=0; i<10; i++) SendByte(0x7E); //Sends flag bytes. Adjust length for txdelay
02D7: CLRF 3B
02D8: MOVF 3B,W
02D9: SUBLW 09
02DA: BTFSS 03.0
02DB: GOTO 2E1
02DC: MOVLW 7E
02DD: MOVWF 74
02DE: CALL 0FF
02DF: INCF 3B,F
02E0: GOTO 2D8
.................... //each flag takes approx 6.7 ms
.................... flag_flag = FALSE; //done sending flags
02E1: CLRF 39
....................
.................... for(i=0; i<16; i++) SendByte(SendData[i]); //send the packet bytes
02E2: CLRF 3B
02E3: MOVF 3B,W
02E4: SUBLW 0F
02E5: BTFSS 03.0
02E6: GOTO 2F0
02E7: MOVLW 25
02E8: ADDWF 3B,W
02E9: MOVWF 04
02EA: MOVF 00,W
02EB: MOVWF 73
02EC: MOVWF 74
02ED: CALL 0FF
02EE: INCF 3B,F
02EF: GOTO 2E3
....................
.................... for(i=0; 0 != *data; i++)
02F0: CLRF 3B
02F1: MOVF 72,W
02F2: MOVWF 04
02F3: MOVF 00,W
02F4: XORLW 00
02F5: BTFSC 03.2
02F6: GOTO 300
.................... {
.................... SendByte(*data); //send the packet bytes
02F7: MOVF 72,W
02F8: MOVWF 04
02F9: MOVF 00,W
02FA: MOVWF 73
02FB: MOVWF 74
02FC: CALL 0FF
.................... data++;
02FD: INCF 72,F
.................... };
02FE: INCF 3B,F
02FF: GOTO 2F1
....................
.................... fcs_flag = TRUE; //about to send the FCS bytes
0300: MOVLW 01
0301: MOVWF 3A
.................... fcslo =fcslo^0xff; //must XOR them with FF before sending
0302: MOVLW FF
0303: XORWF 36,F
.................... fcshi = fcshi^0xff;
0304: XORWF 37,F
.................... SendByte(fcslo); //send the low byte of fcs
0305: MOVF 36,W
0306: MOVWF 74
0307: CALL 0FF
.................... SendByte(fcshi); //send the high byte of fcs
0308: MOVF 37,W
0309: MOVWF 74
030A: CALL 0FF
.................... fcs_flag = FALSE; //done sending FCS
030B: CLRF 3A
.................... flag_flag = TRUE; //about to send flags
030C: MOVLW 01
030D: MOVWF 39
.................... SendByte(0x7e); // Send a flag to end packet
030E: MOVLW 7E
030F: MOVWF 74
0310: CALL 0FF
.................... }
....................
....................
....................
....................
....................
.................... //motory //Napred vypnout potom zapnout!
.................... #define FR output_low(PIN_B5); output_high(PIN_B4) // Vpred
.................... #define FL output_low(PIN_B7); output_high(PIN_B6)
.................... #define BR output_low(PIN_B4); output_high(PIN_B5) // Vzad
.................... #define BL output_low(PIN_B6); output_high(PIN_B7)
.................... #define STOPR output_low(PIN_B4);output_low(PIN_B5)
.................... #define STOPL output_low(PIN_B6);output_low(PIN_B7)
....................
.................... #define L 0b10 // left
.................... #define R 0b01 // right
.................... #define S 0b11 // straight
....................
.................... #define COUVANI 1600 // couvnuti po zjisteni diry
.................... #define MEZERA 5400 // za jak dlouho bude ztracena cara
.................... #define PRES_DIRU 400 // velikost mezery v care
.................... #define ODEZVA 1 // za jak dlouho po opusteni cary se ma zacit zatacet
.................... #define BRZDENI 100 // doba (v ms) ptrebna k zastaveni jednoho motoru
....................
.................... //cidla
.................... #define RSENSOR 1 // Senzory na caru
.................... #define LSENSOR 0
.................... #define BUMPER PIN_C4 // sensor na cihlu
....................
.................... #define DIAG_SERVO PIN_B0 // Propojka pro diagnosticky mod
.................... #define DIAG_SENSORS PIN_B1 // Propojka pro diagnosticky mod
....................
.................... #DEFINE SOUND_HI PIN_B3
.................... #DEFINE SOUND_LO PIN_B2
....................
.................... char AXstring[40]; // Buffer pro prenos telemetrie
....................
.................... int tresholdL; // rozhodovaci uroven pro prave cidlo
.................... int tresholdR; // rozhodovaci uroven pro prave cidlo
.................... int movement; // smer minuleho pohybu
.................... int line; // na ktere strane byla detekovana cara
.................... unsigned int16 dira; // pocitadlo pro nalezeni preruseni cary
....................
.................... // Primitivni Pipani
.................... void beep(unsigned int16 period, unsigned int16 length)
.................... {
.................... unsigned int16 nn;
....................
.................... for(nn=length; nn>0; nn--)
*
0024: MOVF 75,W
0025: MOVWF 77
0026: MOVF 74,W
0027: MOVWF 76
0028: MOVF 76,F
0029: BTFSS 03.2
002A: GOTO 02E
002B: MOVF 77,F
002C: BTFSC 03.2
002D: GOTO 049
.................... {
.................... output_high(SOUND_HI);output_low(SOUND_LO);
002E: BSF 03.5
002F: BCF 06.3
0030: BCF 03.5
0031: BSF 06.3
0032: BSF 03.5
0033: BCF 06.2
0034: BCF 03.5
0035: BCF 06.2
.................... delay_us(period);
0036: MOVF 72,W
0037: MOVWF 78
0038: CALL 016
.................... output_high(SOUND_LO);output_low(SOUND_HI);
0039: BSF 03.5
003A: BCF 06.2
003B: BCF 03.5
003C: BSF 06.2
003D: BSF 03.5
003E: BCF 06.3
003F: BCF 03.5
0040: BCF 06.3
.................... delay_us(period);
0041: MOVF 72,W
0042: MOVWF 78
0043: CALL 016
.................... }
0044: MOVF 76,W
0045: BTFSC 03.2
0046: DECF 77,F
0047: DECF 76,F
0048: GOTO 028
0049: RETLW 00
.................... }
....................
.................... // Diagnostika pohonu, hejbne vsema motorama ve vsech smerech
.................... void diagnostika()
.................... {
.................... unsigned int16 n;
....................
.................... while (input(DIAG_SERVO)) // Propojka, ktera spousti diagnostiku
*
014A: BSF 03.5
014B: BSF 06.0
014C: BCF 03.5
014D: BTFSS 06.0
014E: GOTO 275
.................... {
.................... for (n=500; n<800; n+=100)
014F: MOVLW 01
0150: MOVWF 6F
0151: MOVLW F4
0152: MOVWF 6E
0153: MOVF 6F,W
0154: SUBLW 03
0155: BTFSS 03.0
0156: GOTO 16B
0157: BTFSS 03.2
0158: GOTO 15D
0159: MOVF 6E,W
015A: SUBLW 1F
015B: BTFSS 03.0
015C: GOTO 16B
.................... {
.................... beep(n,n); //beep UP
015D: MOVF 6F,W
015E: MOVWF 73
015F: MOVF 6E,W
0160: MOVWF 72
0161: MOVF 6F,W
0162: MOVWF 75
0163: MOVF 6E,W
0164: MOVWF 74
0165: CALL 024
.................... };
0166: MOVLW 64
0167: ADDWF 6E,F
0168: BTFSC 03.0
0169: INCF 6F,F
016A: GOTO 153
.................... Delay_ms(1000);
016B: MOVLW 04
016C: MOVWF 72
016D: MOVLW FA
016E: MOVWF 73
016F: CALL 04A
0170: DECFSZ 72,F
0171: GOTO 16D
.................... //zastav vse
.................... STOPL; STOPR;
0172: BSF 03.5
0173: BCF 06.6
0174: BCF 03.5
0175: BCF 06.6
0176: BSF 03.5
0177: BCF 06.7
0178: BCF 03.5
0179: BCF 06.7
017A: BSF 03.5
017B: BCF 06.4
017C: BCF 03.5
017D: BCF 06.4
017E: BSF 03.5
017F: BCF 06.5
0180: BCF 03.5
0181: BCF 06.5
.................... //pravy pas
.................... FR; Delay_ms(1000); STOPR; Delay_ms(1000);
0182: BSF 03.5
0183: BCF 06.5
0184: BCF 03.5
0185: BCF 06.5
0186: BSF 03.5
0187: BCF 06.4
0188: BCF 03.5
0189: BSF 06.4
018A: MOVLW 04
018B: MOVWF 72
018C: MOVLW FA
018D: MOVWF 73
018E: CALL 04A
018F: DECFSZ 72,F
0190: GOTO 18C
0191: BSF 03.5
0192: BCF 06.4
0193: BCF 03.5
0194: BCF 06.4
0195: BSF 03.5
0196: BCF 06.5
0197: BCF 03.5
0198: BCF 06.5
0199: MOVLW 04
019A: MOVWF 72
019B: MOVLW FA
019C: MOVWF 73
019D: CALL 04A
019E: DECFSZ 72,F
019F: GOTO 19B
.................... BR; Delay_ms(1000); STOPR; Delay_ms(1000);
01A0: BSF 03.5
01A1: BCF 06.4
01A2: BCF 03.5
01A3: BCF 06.4
01A4: BSF 03.5
01A5: BCF 06.5
01A6: BCF 03.5
01A7: BSF 06.5
01A8: MOVLW 04
01A9: MOVWF 72
01AA: MOVLW FA
01AB: MOVWF 73
01AC: CALL 04A
01AD: DECFSZ 72,F
01AE: GOTO 1AA
01AF: BSF 03.5
01B0: BCF 06.4
01B1: BCF 03.5
01B2: BCF 06.4
01B3: BSF 03.5
01B4: BCF 06.5
01B5: BCF 03.5
01B6: BCF 06.5
01B7: MOVLW 04
01B8: MOVWF 72
01B9: MOVLW FA
01BA: MOVWF 73
01BB: CALL 04A
01BC: DECFSZ 72,F
01BD: GOTO 1B9
.................... Beep(880,100); Delay_ms(1000);
01BE: MOVLW 03
01BF: MOVWF 73
01C0: MOVLW 70
01C1: MOVWF 72
01C2: CLRF 75
01C3: MOVLW 64
01C4: MOVWF 74
01C5: CALL 024
01C6: MOVLW 04
01C7: MOVWF 72
01C8: MOVLW FA
01C9: MOVWF 73
01CA: CALL 04A
01CB: DECFSZ 72,F
01CC: GOTO 1C8
.................... //levy pas
.................... FL; Delay_ms(1000); STOPL; Delay_ms(1000);
01CD: BSF 03.5
01CE: BCF 06.7
01CF: BCF 03.5
01D0: BCF 06.7
01D1: BSF 03.5
01D2: BCF 06.6
01D3: BCF 03.5
01D4: BSF 06.6
01D5: MOVLW 04
01D6: MOVWF 72
01D7: MOVLW FA
01D8: MOVWF 73
01D9: CALL 04A
01DA: DECFSZ 72,F
01DB: GOTO 1D7
01DC: BSF 03.5
01DD: BCF 06.6
01DE: BCF 03.5
01DF: BCF 06.6
01E0: BSF 03.5
01E1: BCF 06.7
01E2: BCF 03.5
01E3: BCF 06.7
01E4: MOVLW 04
01E5: MOVWF 72
01E6: MOVLW FA
01E7: MOVWF 73
01E8: CALL 04A
01E9: DECFSZ 72,F
01EA: GOTO 1E6
.................... BL; Delay_ms(1000); STOPL; Delay_ms(1000);
01EB: BSF 03.5
01EC: BCF 06.6
01ED: BCF 03.5
01EE: BCF 06.6
01EF: BSF 03.5
01F0: BCF 06.7
01F1: BCF 03.5
01F2: BSF 06.7
01F3: MOVLW 04
01F4: MOVWF 72
01F5: MOVLW FA
01F6: MOVWF 73
01F7: CALL 04A
01F8: DECFSZ 72,F
01F9: GOTO 1F5
01FA: BSF 03.5
01FB: BCF 06.6
01FC: BCF 03.5
01FD: BCF 06.6
01FE: BSF 03.5
01FF: BCF 06.7
0200: BCF 03.5
0201: BCF 06.7
0202: MOVLW 04
0203: MOVWF 72
0204: MOVLW FA
0205: MOVWF 73
0206: CALL 04A
0207: DECFSZ 72,F
0208: GOTO 204
.................... Beep(880,100); Delay_ms(1000);
0209: MOVLW 03
020A: MOVWF 73
020B: MOVLW 70
020C: MOVWF 72
020D: CLRF 75
020E: MOVLW 64
020F: MOVWF 74
0210: CALL 024
0211: MOVLW 04
0212: MOVWF 72
0213: MOVLW FA
0214: MOVWF 73
0215: CALL 04A
0216: DECFSZ 72,F
0217: GOTO 213
.................... //oba pasy
.................... FL; FR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
0218: BSF 03.5
0219: BCF 06.7
021A: BCF 03.5
021B: BCF 06.7
021C: BSF 03.5
021D: BCF 06.6
021E: BCF 03.5
021F: BSF 06.6
0220: BSF 03.5
0221: BCF 06.5
0222: BCF 03.5
0223: BCF 06.5
0224: BSF 03.5
0225: BCF 06.4
0226: BCF 03.5
0227: BSF 06.4
0228: MOVLW 04
0229: MOVWF 72
022A: MOVLW FA
022B: MOVWF 73
022C: CALL 04A
022D: DECFSZ 72,F
022E: GOTO 22A
022F: BSF 03.5
0230: BCF 06.6
0231: BCF 03.5
0232: BCF 06.6
0233: BSF 03.5
0234: BCF 06.7
0235: BCF 03.5
0236: BCF 06.7
0237: BSF 03.5
0238: BCF 06.4
0239: BCF 03.5
023A: BCF 06.4
023B: BSF 03.5
023C: BCF 06.5
023D: BCF 03.5
023E: BCF 06.5
023F: MOVLW 04
0240: MOVWF 72
0241: MOVLW FA
0242: MOVWF 73
0243: CALL 04A
0244: DECFSZ 72,F
0245: GOTO 241
.................... BL; BR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
0246: BSF 03.5
0247: BCF 06.6
0248: BCF 03.5
0249: BCF 06.6
024A: BSF 03.5
024B: BCF 06.7
024C: BCF 03.5
024D: BSF 06.7
024E: BSF 03.5
024F: BCF 06.4
0250: BCF 03.5
0251: BCF 06.4
0252: BSF 03.5
0253: BCF 06.5
0254: BCF 03.5
0255: BSF 06.5
0256: MOVLW 04
0257: MOVWF 72
0258: MOVLW FA
0259: MOVWF 73
025A: CALL 04A
025B: DECFSZ 72,F
025C: GOTO 258
025D: BSF 03.5
025E: BCF 06.6
025F: BCF 03.5
0260: BCF 06.6
0261: BSF 03.5
0262: BCF 06.7
0263: BCF 03.5
0264: BCF 06.7
0265: BSF 03.5
0266: BCF 06.4
0267: BCF 03.5
0268: BCF 06.4
0269: BSF 03.5
026A: BCF 06.5
026B: BCF 03.5
026C: BCF 06.5
026D: MOVLW 04
026E: MOVWF 72
026F: MOVLW FA
0270: MOVWF 73
0271: CALL 04A
0272: DECFSZ 72,F
0273: GOTO 26F
.................... };
0274: GOTO 14A
....................
.................... while (input(DIAG_SENSORS))
0275: BSF 03.5
0276: BSF 06.1
0277: BCF 03.5
0278: BTFSS 06.1
0279: GOTO 319
.................... {
.................... int ls, rs;
.................... while(!input(BUMPER)){beep(1100,100); Delay_ms(50);}
027A: BSF 3C.4
027B: MOVF 3C,W
027C: BSF 03.5
027D: MOVWF 07
027E: BCF 03.5
027F: BTFSC 07.4
0280: GOTO 28D
0281: MOVLW 04
0282: MOVWF 73
0283: MOVLW 4C
0284: MOVWF 72
0285: CLRF 75
0286: MOVLW 64
0287: MOVWF 74
0288: CALL 024
0289: MOVLW 32
028A: MOVWF 73
028B: CALL 04A
028C: GOTO 27A
.................... set_adc_channel(RSENSOR);
028D: MOVLW 08
028E: MOVWF 21
028F: MOVF 1F,W
0290: ANDLW C7
0291: IORWF 21,W
0292: MOVWF 1F
.................... Delay_us(20);
0293: MOVLW 06
0294: MOVWF 20
0295: DECFSZ 20,F
0296: GOTO 295
0297: NOP
.................... rs=read_adc();
0298: BSF 1F.2
0299: BTFSC 1F.2
029A: GOTO 299
029B: MOVF 1E,W
029C: MOVWF 71
.................... set_adc_channel(LSENSOR);
029D: MOVLW 00
029E: MOVWF 21
029F: MOVF 1F,W
02A0: ANDLW C7
02A1: IORWF 21,W
02A2: MOVWF 1F
.................... Delay_us(20);
02A3: MOVLW 06
02A4: MOVWF 20
02A5: DECFSZ 20,F
02A6: GOTO 2A5
02A7: NOP
.................... ls=read_adc();
02A8: BSF 1F.2
02A9: BTFSC 1F.2
02AA: GOTO 2A9
02AB: MOVF 1E,W
02AC: MOVWF 70
.................... sprintf(AXstring,"L: %U R: %U\0", ls, rs); // Convert DATA to String.
*
0004: BCF 0A.0
0005: BCF 0A.1
0006: BCF 0A.2
0007: ADDWF 02,F
0008: RETLW 4C
0009: RETLW 3A
000A: RETLW 20
000B: RETLW 25
000C: RETLW 55
000D: RETLW 20
000E: RETLW 20
000F: RETLW 52
0010: RETLW 3A
0011: RETLW 20
0012: RETLW 25
0013: RETLW 55
0014: RETLW 00
0015: RETLW 00
*
007C: MOVF 21,W
007D: MOVF 73,W
007E: MOVWF 75
007F: MOVLW 64
0080: MOVWF 76
0081: CALL 067
0082: MOVF 20,W
0083: MOVWF 73
0084: MOVF 21,W
0085: MOVLW 30
0086: BTFSS 03.2
0087: GOTO 08F
0088: BTFSC 74.0
0089: BSF 74.3
008A: BTFSC 74.3
008B: GOTO 095
008C: BTFSC 74.4
008D: MOVLW 20
008E: GOTO 091
008F: BCF 74.3
0090: BCF 74.4
0091: ADDWF 21,F
0092: MOVF 21,W
0093: MOVWF 75
0094: CALL 05F
0095: MOVF 73,W
0096: MOVWF 75
0097: MOVLW 0A
0098: MOVWF 76
0099: CALL 067
009A: MOVF 20,W
009B: MOVWF 73
009C: MOVF 21,W
009D: MOVLW 30
009E: BTFSS 03.2
009F: GOTO 0A4
00A0: BTFSC 74.3
00A1: GOTO 0A8
00A2: BTFSC 74.4
00A3: MOVLW 20
00A4: ADDWF 21,F
00A5: MOVF 21,W
00A6: MOVWF 75
00A7: CALL 05F
00A8: MOVLW 30
00A9: ADDWF 73,F
00AA: MOVF 73,W
00AB: MOVWF 75
00AC: CALL 05F
00AD: RETLW 00
*
02AD: MOVLW 3D
02AE: MOVWF 6B
02AF: MOVLW 4C
02B0: MOVWF 75
02B1: CALL 05F
02B2: MOVLW 3A
02B3: MOVWF 75
02B4: CALL 05F
02B5: MOVLW 20
02B6: MOVWF 75
02B7: CALL 05F
02B8: MOVF 70,W
02B9: MOVWF 73
02BA: MOVLW 18
02BB: MOVWF 74
02BC: CALL 07C
02BD: MOVLW 05
02BE: MOVWF 72
02BF: MOVF 72,W
02C0: CALL 004
02C1: INCF 72,F
02C2: MOVWF 75
02C3: CALL 05F
02C4: MOVLW 0A
02C5: SUBWF 72,W
02C6: BTFSS 03.2
02C7: GOTO 2BF
02C8: MOVF 71,W
02C9: MOVWF 73
02CA: MOVLW 18
02CB: MOVWF 74
02CC: CALL 07C
.................... SendPacket(&AXstring[0]);
02CD: MOVLW 3D
02CE: MOVWF 72
.................... delay_ms(1000);
*
0311: MOVLW 04
0312: MOVWF 72
0313: MOVLW FA
0314: MOVWF 73
0315: CALL 04A
0316: DECFSZ 72,F
0317: GOTO 313
.................... };
0318: GOTO 275
0319: BCF 0A.3
031A: GOTO 45E (RETURN)
.................... }
....................
.................... void cikcak()
.................... {
.................... int n;
.................... switch(movement) // podivej se na jednu stranu
*
0364: MOVLW 01
0365: SUBWF 67,W
0366: ADDLW FD
0367: BTFSC 03.0
0368: GOTO 3A4
0369: ADDLW 03
036A: GOTO 410
.................... {
.................... case L:
.................... FL;BR;
036B: BSF 03.5
036C: BCF 06.7
036D: BCF 03.5
036E: BCF 06.7
036F: BSF 03.5
0370: BCF 06.6
0371: BCF 03.5
0372: BSF 06.6
0373: BSF 03.5
0374: BCF 06.4
0375: BCF 03.5
0376: BCF 06.4
0377: BSF 03.5
0378: BCF 06.5
0379: BCF 03.5
037A: BSF 06.5
.................... movement=R;
037B: MOVLW 01
037C: MOVWF 67
.................... break;
037D: GOTO 3A4
.................... case R:
.................... FR;BL;
037E: BSF 03.5
037F: BCF 06.5
0380: BCF 03.5
0381: BCF 06.5
0382: BSF 03.5
0383: BCF 06.4
0384: BCF 03.5
0385: BSF 06.4
0386: BSF 03.5
0387: BCF 06.6
0388: BCF 03.5
0389: BCF 06.6
038A: BSF 03.5
038B: BCF 06.7
038C: BCF 03.5
038D: BSF 06.7
.................... movement=L;
038E: MOVLW 02
038F: MOVWF 67
.................... break;
0390: GOTO 3A4
.................... case S:
.................... FR;BL;
0391: BSF 03.5
0392: BCF 06.5
0393: BCF 03.5
0394: BCF 06.5
0395: BSF 03.5
0396: BCF 06.4
0397: BCF 03.5
0398: BSF 06.4
0399: BSF 03.5
039A: BCF 06.6
039B: BCF 03.5
039C: BCF 06.6
039D: BSF 03.5
039E: BCF 06.7
039F: BCF 03.5
03A0: BSF 06.7
.................... movement=L;
03A1: MOVLW 02
03A2: MOVWF 67
.................... break;
03A3: GOTO 3A4
.................... }
*
0410: BCF 0A.0
0411: BCF 0A.1
0412: BSF 0A.2
0413: ADDWF 02,F
0414: GOTO 37E
0415: GOTO 36B
0416: GOTO 391
.................... set_adc_channel(LSENSOR);
*
03A4: MOVLW 00
03A5: MOVWF 21
03A6: MOVF 1F,W
03A7: ANDLW C7
03A8: IORWF 21,W
03A9: MOVWF 1F
.................... Delay_us(10);
03AA: MOVLW 03
03AB: MOVWF 20
03AC: DECFSZ 20,F
03AD: GOTO 3AC
.................... while (tresholdL < read_adc()) // je tam cara??
03AE: BSF 1F.2
03AF: BTFSC 1F.2
03B0: GOTO 3AF
03B1: MOVF 1E,W
03B2: SUBWF 65,W
03B3: BTFSC 03.0
03B4: GOTO 3FC
.................... {
.................... if (n==50) // asi bude na druhe strane
03B5: MOVF 6E,W
03B6: SUBLW 32
03B7: BTFSS 03.2
03B8: GOTO 3F7
.................... {
.................... STOPR;STOPL;
03B9: BSF 03.5
03BA: BCF 06.4
03BB: BCF 03.5
03BC: BCF 06.4
03BD: BSF 03.5
03BE: BCF 06.5
03BF: BCF 03.5
03C0: BCF 06.5
03C1: BSF 03.5
03C2: BCF 06.6
03C3: BCF 03.5
03C4: BCF 06.6
03C5: BSF 03.5
03C6: BCF 06.7
03C7: BCF 03.5
03C8: BCF 06.7
.................... n=0;
03C9: CLRF 6E
.................... switch(movement)
03CA: MOVLW 01
03CB: SUBWF 67,W
03CC: ADDLW FE
03CD: BTFSC 03.0
03CE: GOTO 3F7
03CF: ADDLW 02
03D0: GOTO 417
.................... {
.................... case L:
.................... FL;BR;
03D1: BSF 03.5
03D2: BCF 06.7
03D3: BCF 03.5
03D4: BCF 06.7
03D5: BSF 03.5
03D6: BCF 06.6
03D7: BCF 03.5
03D8: BSF 06.6
03D9: BSF 03.5
03DA: BCF 06.4
03DB: BCF 03.5
03DC: BCF 06.4
03DD: BSF 03.5
03DE: BCF 06.5
03DF: BCF 03.5
03E0: BSF 06.5
.................... movement=R;
03E1: MOVLW 01
03E2: MOVWF 67
.................... break;
03E3: GOTO 3F7
.................... case R:
.................... FR;BL;
03E4: BSF 03.5
03E5: BCF 06.5
03E6: BCF 03.5
03E7: BCF 06.5
03E8: BSF 03.5
03E9: BCF 06.4
03EA: BCF 03.5
03EB: BSF 06.4
03EC: BSF 03.5
03ED: BCF 06.6
03EE: BCF 03.5
03EF: BCF 06.6
03F0: BSF 03.5
03F1: BCF 06.7
03F2: BCF 03.5
03F3: BSF 06.7
.................... movement=L;
03F4: MOVLW 02
03F5: MOVWF 67
.................... break;
03F6: GOTO 3F7
.................... }
*
0417: BCF 0A.0
0418: BCF 0A.1
0419: BSF 0A.2
041A: ADDWF 02,F
041B: GOTO 3E4
041C: GOTO 3D1
.................... }
.................... Delay_ms(5);
*
03F7: MOVLW 05
03F8: MOVWF 73
03F9: CALL 04A
.................... n++;
03FA: INCF 6E,F
.................... }
03FB: GOTO 3AE
.................... STOPL;STOPR; // nasli jsme caru
03FC: BSF 03.5
03FD: BCF 06.6
03FE: BCF 03.5
03FF: BCF 06.6
0400: BSF 03.5
0401: BCF 06.7
0402: BCF 03.5
0403: BCF 06.7
0404: BSF 03.5
0405: BCF 06.4
0406: BCF 03.5
0407: BCF 06.4
0408: BSF 03.5
0409: BCF 06.5
040A: BCF 03.5
040B: BCF 06.5
.................... line=S;
040C: MOVLW 03
040D: MOVWF 68
040E: BCF 0A.3
040F: GOTO 610 (RETURN)
.................... }
.................... void objizdka()
.................... {
.................... BL;BR;Delay_ms(300);
*
031B: BSF 03.5
031C: BCF 06.6
031D: BCF 03.5
031E: BCF 06.6
031F: BSF 03.5
0320: BCF 06.7
0321: BCF 03.5
0322: BSF 06.7
0323: BSF 03.5
0324: BCF 06.4
0325: BCF 03.5
0326: BCF 06.4
0327: BSF 03.5
0328: BCF 06.5
0329: BCF 03.5
032A: BSF 06.5
032B: MOVLW 02
032C: MOVWF 6E
032D: MOVLW 96
032E: MOVWF 73
032F: CALL 04A
0330: DECFSZ 6E,F
0331: GOTO 32D
.................... STOPR;STOPL;
0332: BSF 03.5
0333: BCF 06.4
0334: BCF 03.5
0335: BCF 06.4
0336: BSF 03.5
0337: BCF 06.5
0338: BCF 03.5
0339: BCF 06.5
033A: BSF 03.5
033B: BCF 06.6
033C: BCF 03.5
033D: BCF 06.6
033E: BSF 03.5
033F: BCF 06.7
0340: BCF 03.5
0341: BCF 06.7
.................... beep(1000,1000);
0342: MOVLW 03
0343: MOVWF 73
0344: MOVLW E8
0345: MOVWF 72
0346: MOVLW 03
0347: MOVWF 75
0348: MOVLW E8
0349: MOVWF 74
034A: CALL 024
.................... Delay_ms(500);
034B: MOVLW 02
034C: MOVWF 6E
034D: MOVLW FA
034E: MOVWF 73
034F: CALL 04A
0350: DECFSZ 6E,F
0351: GOTO 34D
.................... beep(1000,1000);
0352: MOVLW 03
0353: MOVWF 73
0354: MOVLW E8
0355: MOVWF 72
0356: MOVLW 03
0357: MOVWF 75
0358: MOVLW E8
0359: MOVWF 74
035A: CALL 024
.................... Delay_ms(1000);
035B: MOVLW 04
035C: MOVWF 6E
035D: MOVLW FA
035E: MOVWF 73
035F: CALL 04A
0360: DECFSZ 6E,F
0361: GOTO 35D
0362: BCF 0A.3
0363: GOTO 48A (RETURN)
....................
.................... }
.................... void kalibrace()
.................... {
.................... unsigned int16 i;
.................... int min;
.................... int max;
.................... int current;
.................... int treshold;
....................
.................... FL; BR; Delay_ms(130);
.................... chyba1:
.................... FR; BL; //kalibrace leveho cidla
.................... set_adc_channel(LSENSOR);
.................... Delay_us(20);
.................... min=max=read_adc();
.................... for (i=1;i<=500;i++)
.................... {
.................... current=read_adc();
.................... if (max < current) max=current;
.................... if (min > current) min=current;
.................... Delay_us(500);
.................... }
.................... FL; BR;
.................... for (i=1;i<=500;i++)
.................... {
.................... current=read_adc();
.................... if (max < current) max=current;
.................... if (min > current) min=current;
.................... Delay_us(500);
.................... }
.................... STOPL; STOPR; Delay_ms(200);
.................... if((max-min)<50) {Beep(1000,300); GOTO chyba1;}
.................... treshold=(max-min)>>1;
.................... tresholdL=treshold+min;
....................
.................... chyba2:
.................... FR; BL;
.................... set_adc_channel(RSENSOR);
.................... Delay_us(20);
.................... min=max=read_adc(); //naplneni min a max nejakou rozumnou hodnotou
.................... for (i=1;i<=500 ;i++)
.................... {
.................... current=read_adc();
.................... if (max < current) max=current; //zmereni minima a maxima
.................... if (min > current) min=current;
.................... Delay_us(500);
.................... }
.................... FL; BR;
.................... for (i=1;i<=500 ;i++)
.................... {
.................... current=read_adc();
.................... if (max < current) max=current; //zmereni minima a maxima
.................... if (min > current) min=current;
.................... Delay_us(500);
.................... }
.................... STOPL; STOPR; Delay_ms(200);
.................... if((max-min)<50) {Beep(1000,300); GOTO chyba2;}
.................... treshold=(max-min)>>1;
.................... tresholdR=treshold+min;
....................
.................... FR; BL;
.................... movement=L;
.................... set_adc_channel(LSENSOR);
.................... Delay_us(20);
.................... while (tresholdL < read_adc()) Delay_us(100);
.................... FL; BR; Delay_ms(50);
.................... STOPL; STOPR; Delay_ms(500);
.................... Beep(780,200);
.................... }
....................
.................... void main()
.................... {
.................... unsigned int16 rovne; // pocita delku rovne cary
*
041D: CLRF 04
041E: MOVLW 1F
041F: ANDWF 03,F
0420: MOVLW 07
0421: BSF 03.5
0422: MOVWF 1F
0423: MOVLW 82
0424: BCF 03.5
0425: MOVWF 25
0426: MOVLW 98
0427: MOVWF 26
0428: MOVWF 27
0429: MOVLW 40
042A: MOVWF 28
042B: MOVWF 29
042C: MOVWF 2A
042D: MOVLW 60
042E: MOVWF 2B
042F: MOVLW 86
0430: MOVWF 2C
0431: MOVLW B4
0432: MOVWF 2D
0433: MOVLW 60
0434: MOVWF 2E
0435: MOVLW A4
0436: MOVWF 2F
0437: MOVWF 30
0438: MOVWF 31
0439: MOVLW 61
043A: MOVWF 32
043B: MOVLW 03
043C: MOVWF 33
043D: MOVLW F0
043E: MOVWF 34
043F: MOVLW FF
0440: MOVWF 3C
0441: CLRF 6B
....................
.................... STOPL; STOPR;
0442: BSF 03.5
0443: BCF 06.6
0444: BCF 03.5
0445: BCF 06.6
0446: BSF 03.5
0447: BCF 06.7
0448: BCF 03.5
0449: BCF 06.7
044A: BSF 03.5
044B: BCF 06.4
044C: BCF 03.5
044D: BCF 06.4
044E: BSF 03.5
044F: BCF 06.5
0450: BCF 03.5
0451: BCF 06.5
....................
.................... setup_adc_ports(RA0_RA1_RA3_ANALOG);
0452: MOVLW 04
0453: BSF 03.5
0454: MOVWF 1F
.................... setup_adc(ADC_CLOCK_DIV_2);
0455: BCF 03.5
0456: MOVF 1F,W
0457: ANDLW 38
0458: IORLW 01
0459: MOVWF 1F
....................
.................... port_b_pullups(false);
045A: BSF 03.5
045B: BSF 01.7
....................
.................... diagnostika();
045C: BCF 03.5
045D: GOTO 14A
....................
.................... Beep(1000,200); //double beep
045E: MOVLW 03
045F: MOVWF 73
0460: MOVLW E8
0461: MOVWF 72
0462: CLRF 75
0463: MOVLW C8
0464: MOVWF 74
0465: CALL 024
.................... Delay_ms(50);
0466: MOVLW 32
0467: MOVWF 73
0468: CALL 04A
.................... Beep(1000,200);
0469: MOVLW 03
046A: MOVWF 73
046B: MOVLW E8
046C: MOVWF 72
046D: CLRF 75
046E: MOVLW C8
046F: MOVWF 74
0470: CALL 024
.................... Delay_ms(1000); // 1s
0471: MOVLW 04
0472: MOVWF 6E
0473: MOVLW FA
0474: MOVWF 73
0475: CALL 04A
0476: DECFSZ 6E,F
0477: GOTO 473
....................
.................... // kalibrace();
.................... tresholdl=tresholdr=80;
0478: MOVLW 50
0479: MOVWF 66
047A: MOVWF 65
.................... // FL; FR;
.................... movement=S;
047B: MOVLW 03
047C: MOVWF 67
.................... line=S;
047D: MOVWF 68
.................... dira=0;
047E: CLRF 6A
047F: CLRF 69
.................... rovne=0;
0480: CLRF 6D
0481: CLRF 6C
....................
.................... while(true)
.................... {
.................... if(!input(BUMPER)) objizdka();
0482: BSF 3C.4
0483: MOVF 3C,W
0484: BSF 03.5
0485: MOVWF 07
0486: BCF 03.5
0487: BTFSC 07.4
0488: GOTO 48A
0489: GOTO 31B
.................... line=0;
048A: CLRF 68
.................... set_adc_channel(RSENSOR); // podivej se jestli neni cara pod pravym cidlem
048B: MOVLW 08
048C: MOVWF 21
048D: MOVF 1F,W
048E: ANDLW C7
048F: IORWF 21,W
0490: MOVWF 1F
.................... Delay_us(10);
0491: MOVLW 03
0492: MOVWF 20
0493: DECFSZ 20,F
0494: GOTO 493
.................... if(tresholdR > read_adc())
0495: BSF 1F.2
0496: BTFSC 1F.2
0497: GOTO 496
0498: MOVF 1E,W
0499: SUBWF 66,W
049A: BTFSC 03.2
049B: GOTO 4A2
049C: BTFSS 03.0
049D: GOTO 4A2
.................... {
.................... dira=0;
049E: CLRF 6A
049F: CLRF 69
.................... line=R;
04A0: MOVLW 01
04A1: MOVWF 68
.................... }
.................... set_adc_channel(LSENSOR); // kdyz cara nebyla pod pravym cidlem, mozna bude pod levym
04A2: MOVLW 00
04A3: MOVWF 21
04A4: MOVF 1F,W
04A5: ANDLW C7
04A6: IORWF 21,W
04A7: MOVWF 1F
.................... Delay_us(10);
04A8: MOVLW 03
04A9: MOVWF 20
04AA: DECFSZ 20,F
04AB: GOTO 4AA
.................... if(tresholdL > read_adc())
04AC: BSF 1F.2
04AD: BTFSC 1F.2
04AE: GOTO 4AD
04AF: MOVF 1E,W
04B0: SUBWF 65,W
04B1: BTFSC 03.2
04B2: GOTO 4B8
04B3: BTFSS 03.0
04B4: GOTO 4B8
.................... {
.................... dira=0;
04B5: CLRF 6A
04B6: CLRF 69
.................... line=line | L;
04B7: BSF 68.1
.................... }
....................
.................... switch(line)
04B8: MOVF 68,W
04B9: MOVWF 20
04BA: MOVLW 03
04BB: SUBWF 20,W
04BC: BTFSC 03.2
04BD: GOTO 4C7
04BE: MOVLW 02
04BF: SUBWF 20,W
04C0: BTFSC 03.2
04C1: GOTO 4DA
04C2: MOVLW 01
04C3: SUBWF 20,W
04C4: BTFSC 03.2
04C5: GOTO 4ED
04C6: GOTO 500
.................... {
.................... case S:
.................... FR;FL;
04C7: BSF 03.5
04C8: BCF 06.5
04C9: BCF 03.5
04CA: BCF 06.5
04CB: BSF 03.5
04CC: BCF 06.4
04CD: BCF 03.5
04CE: BSF 06.4
04CF: BSF 03.5
04D0: BCF 06.7
04D1: BCF 03.5
04D2: BCF 06.7
04D3: BSF 03.5
04D4: BCF 06.6
04D5: BCF 03.5
04D6: BSF 06.6
.................... movement=S;
04D7: MOVLW 03
04D8: MOVWF 67
.................... continue;
04D9: GOTO 482
.................... case L:
.................... STOPL;
04DA: BSF 03.5
04DB: BCF 06.6
04DC: BCF 03.5
04DD: BCF 06.6
04DE: BSF 03.5
04DF: BCF 06.7
04E0: BCF 03.5
04E1: BCF 06.7
.................... FR;movement=L;
04E2: BSF 03.5
04E3: BCF 06.5
04E4: BCF 03.5
04E5: BCF 06.5
04E6: BSF 03.5
04E7: BCF 06.4
04E8: BCF 03.5
04E9: BSF 06.4
04EA: MOVLW 02
04EB: MOVWF 67
.................... continue;
04EC: GOTO 482
.................... case R:
.................... STOPR;
04ED: BSF 03.5
04EE: BCF 06.4
04EF: BCF 03.5
04F0: BCF 06.4
04F1: BSF 03.5
04F2: BCF 06.5
04F3: BCF 03.5
04F4: BCF 06.5
.................... FL;movement=R;
04F5: BSF 03.5
04F6: BCF 06.7
04F7: BCF 03.5
04F8: BCF 06.7
04F9: BSF 03.5
04FA: BCF 06.6
04FB: BCF 03.5
04FC: BSF 06.6
04FD: MOVLW 01
04FE: MOVWF 67
.................... continue;
04FF: GOTO 482
.................... default:
.................... }
....................
.................... if (dira==ODEZVA) // kdyz uz chvili jedeme po bile plose
0500: DECFSZ 69,W
0501: GOTO 54A
0502: MOVF 6A,F
0503: BTFSS 03.2
0504: GOTO 54A
.................... {
.................... //BR;BL;Delay_us(rovne >>= 5);
.................... rovne=0; //kdyz sme museli zatocit, uz neni rovna cara
0505: CLRF 6D
0506: CLRF 6C
....................
.................... switch (line) // musime zatocit
0507: MOVLW 01
0508: SUBWF 68,W
0509: ADDLW FE
050A: BTFSC 03.0
050B: GOTO 54A
050C: ADDLW 02
050D: GOTO 617
.................... {
.................... case L:
.................... BL;Delay_ms(BRZDENI);STOPL;
050E: BSF 03.5
050F: BCF 06.6
0510: BCF 03.5
0511: BCF 06.6
0512: BSF 03.5
0513: BCF 06.7
0514: BCF 03.5
0515: BSF 06.7
0516: MOVLW 64
0517: MOVWF 73
0518: CALL 04A
0519: BSF 03.5
051A: BCF 06.6
051B: BCF 03.5
051C: BCF 06.6
051D: BSF 03.5
051E: BCF 06.7
051F: BCF 03.5
0520: BCF 06.7
.................... FR;
0521: BSF 03.5
0522: BCF 06.5
0523: BCF 03.5
0524: BCF 06.5
0525: BSF 03.5
0526: BCF 06.4
0527: BCF 03.5
0528: BSF 06.4
.................... movement=L;
0529: MOVLW 02
052A: MOVWF 67
.................... break;
052B: GOTO 54A
.................... case R:
.................... BR;Delay_ms(BRZDENI);STOPR;
052C: BSF 03.5
052D: BCF 06.4
052E: BCF 03.5
052F: BCF 06.4
0530: BSF 03.5
0531: BCF 06.5
0532: BCF 03.5
0533: BSF 06.5
0534: MOVLW 64
0535: MOVWF 73
0536: CALL 04A
0537: BSF 03.5
0538: BCF 06.4
0539: BCF 03.5
053A: BCF 06.4
053B: BSF 03.5
053C: BCF 06.5
053D: BCF 03.5
053E: BCF 06.5
.................... FL;
053F: BSF 03.5
0540: BCF 06.7
0541: BCF 03.5
0542: BCF 06.7
0543: BSF 03.5
0544: BCF 06.6
0545: BCF 03.5
0546: BSF 06.6
.................... movement=R;
0547: MOVLW 01
0548: MOVWF 67
.................... break;
0549: GOTO 54A
.................... }
*
0617: BCF 0A.0
0618: BSF 0A.1
0619: BSF 0A.2
061A: ADDWF 02,F
061B: GOTO 52C
061C: GOTO 50E
.................... }
.................... if (dira==MEZERA) // kdyz zkoncila cara
*
054A: MOVF 69,W
054B: SUBLW 18
054C: BTFSS 03.2
054D: GOTO 612
054E: MOVF 6A,W
054F: SUBLW 15
0550: BTFSS 03.2
0551: GOTO 612
.................... {
.................... beep(800,500);
0552: MOVLW 03
0553: MOVWF 73
0554: MOVLW 20
0555: MOVWF 72
0556: MOVLW 01
0557: MOVWF 75
0558: MOVLW F4
0559: MOVWF 74
055A: CALL 024
.................... Delay_ms(50);
055B: MOVLW 32
055C: MOVWF 73
055D: CALL 04A
.................... beep(800,500);
055E: MOVLW 03
055F: MOVWF 73
0560: MOVLW 20
0561: MOVWF 72
0562: MOVLW 01
0563: MOVWF 75
0564: MOVLW F4
0565: MOVWF 74
0566: CALL 024
.................... switch (movement) //vrat se zpet na caru
0567: MOVLW 01
0568: SUBWF 67,W
0569: ADDLW FD
056A: BTFSC 03.0
056B: GOTO 5E6
056C: ADDLW 03
056D: GOTO 61D
.................... {
.................... case L:
.................... STOPL;STOPR;
056E: BSF 03.5
056F: BCF 06.6
0570: BCF 03.5
0571: BCF 06.6
0572: BSF 03.5
0573: BCF 06.7
0574: BCF 03.5
0575: BCF 06.7
0576: BSF 03.5
0577: BCF 06.4
0578: BCF 03.5
0579: BCF 06.4
057A: BSF 03.5
057B: BCF 06.5
057C: BCF 03.5
057D: BCF 06.5
.................... BR;Delay_ms(COUVANI);STOPR;
057E: BSF 03.5
057F: BCF 06.4
0580: BCF 03.5
0581: BCF 06.4
0582: BSF 03.5
0583: BCF 06.5
0584: BCF 03.5
0585: BSF 06.5
0586: MOVLW 08
0587: MOVWF 6E
0588: MOVLW C8
0589: MOVWF 73
058A: CALL 04A
058B: DECFSZ 6E,F
058C: GOTO 588
058D: BSF 03.5
058E: BCF 06.4
058F: BCF 03.5
0590: BCF 06.4
0591: BSF 03.5
0592: BCF 06.5
0593: BCF 03.5
0594: BCF 06.5
.................... break;
0595: GOTO 5E6
.................... case R:
.................... STOPL;STOPR;
0596: BSF 03.5
0597: BCF 06.6
0598: BCF 03.5
0599: BCF 06.6
059A: BSF 03.5
059B: BCF 06.7
059C: BCF 03.5
059D: BCF 06.7
059E: BSF 03.5
059F: BCF 06.4
05A0: BCF 03.5
05A1: BCF 06.4
05A2: BSF 03.5
05A3: BCF 06.5
05A4: BCF 03.5
05A5: BCF 06.5
.................... BL;Delay_ms(COUVANI);STOPL;
05A6: BSF 03.5
05A7: BCF 06.6
05A8: BCF 03.5
05A9: BCF 06.6
05AA: BSF 03.5
05AB: BCF 06.7
05AC: BCF 03.5
05AD: BSF 06.7
05AE: MOVLW 08
05AF: MOVWF 6E
05B0: MOVLW C8
05B1: MOVWF 73
05B2: CALL 04A
05B3: DECFSZ 6E,F
05B4: GOTO 5B0
05B5: BSF 03.5
05B6: BCF 06.6
05B7: BCF 03.5
05B8: BCF 06.6
05B9: BSF 03.5
05BA: BCF 06.7
05BB: BCF 03.5
05BC: BCF 06.7
.................... break;
05BD: GOTO 5E6
.................... case S:
.................... BL; BR; Delay_ms(COUVANI);
05BE: BSF 03.5
05BF: BCF 06.6
05C0: BCF 03.5
05C1: BCF 06.6
05C2: BSF 03.5
05C3: BCF 06.7
05C4: BCF 03.5
05C5: BSF 06.7
05C6: BSF 03.5
05C7: BCF 06.4
05C8: BCF 03.5
05C9: BCF 06.4
05CA: BSF 03.5
05CB: BCF 06.5
05CC: BCF 03.5
05CD: BSF 06.5
05CE: MOVLW 08
05CF: MOVWF 6E
05D0: MOVLW C8
05D1: MOVWF 73
05D2: CALL 04A
05D3: DECFSZ 6E,F
05D4: GOTO 5D0
.................... STOPL; STOPR;
05D5: BSF 03.5
05D6: BCF 06.6
05D7: BCF 03.5
05D8: BCF 06.6
05D9: BSF 03.5
05DA: BCF 06.7
05DB: BCF 03.5
05DC: BCF 06.7
05DD: BSF 03.5
05DE: BCF 06.4
05DF: BCF 03.5
05E0: BCF 06.4
05E1: BSF 03.5
05E2: BCF 06.5
05E3: BCF 03.5
05E4: BCF 06.5
.................... break;
05E5: GOTO 5E6
.................... }
*
061D: BCF 0A.0
061E: BSF 0A.1
061F: BSF 0A.2
0620: ADDWF 02,F
0621: GOTO 596
0622: GOTO 56E
0623: GOTO 5BE
....................
.................... FR;FL; Delay_ms(PRES_DIRU); // popojedem dopredu mozna tam bude cara
*
05E6: BSF 03.5
05E7: BCF 06.5
05E8: BCF 03.5
05E9: BCF 06.5
05EA: BSF 03.5
05EB: BCF 06.4
05EC: BCF 03.5
05ED: BSF 06.4
05EE: BSF 03.5
05EF: BCF 06.7
05F0: BCF 03.5
05F1: BCF 06.7
05F2: BSF 03.5
05F3: BCF 06.6
05F4: BCF 03.5
05F5: BSF 06.6
05F6: MOVLW 02
05F7: MOVWF 6E
05F8: MOVLW C8
05F9: MOVWF 73
05FA: CALL 04A
05FB: DECFSZ 6E,F
05FC: GOTO 5F8
.................... STOPL; STOPR; movement=S;
05FD: BSF 03.5
05FE: BCF 06.6
05FF: BCF 03.5
0600: BCF 06.6
0601: BSF 03.5
0602: BCF 06.7
0603: BCF 03.5
0604: BCF 06.7
0605: BSF 03.5
0606: BCF 06.4
0607: BCF 03.5
0608: BCF 06.4
0609: BSF 03.5
060A: BCF 06.5
060B: BCF 03.5
060C: BCF 06.5
060D: MOVLW 03
060E: MOVWF 67
.................... cikcak(); // najdi caru
060F: GOTO 364
.................... dira=0;
0610: CLRF 6A
0611: CLRF 69
.................... }
.................... dira++;
0612: INCF 69,F
0613: BTFSC 03.2
0614: INCF 6A,F
.................... } // while(true)
0615: GOTO 482
.................... }
....................
0616: SLEEP
/roboti/istrobot/merkur/PIC16F873/main.SYM
0,0 → 1,89
003 STATUS
015-016 CCP_1
015 CCP_1_LOW
016 CCP_1_HIGH
01B-01C CCP_2
01B CCP_2_LOW
01C CCP_2_HIGH
020 @SCRATCH
021 @SCRATCH
021 _RETURN_
022 @SCRATCH
023 @SCRATCH
024 @SCRATCH
025-034 SendData
035.0 bit
036 fcslo
037 fcshi
038 stuff
039 flag_flag
03A fcs_flag
03B i
03C @TRIS_C
03D-064 AXstring
065 tresholdL
066 tresholdR
067 movement
068 line
069-06A dira
06B @sprintf_string
06C-06D main.rovne
06E-06F diagnostika.n
06E cikcak.n
06E objizdka.@SCRATCH
06E main.@SCRATCH
070 ls
071 rs
072 SendPacket.data
072-073 beep.period
072 diagnostika.@SCRATCH
073 delay_ms.P1
073 @PRINTF_U_290.P2
073 SendPacket.@SCRATCH
074 SendByte.inbyte
074-075 beep.length
074 @PRINTF_U_290.P1
075 SendByte.k
075 @SPRINTF.P1
075 @DIV88.P2
076 SendByte.bt
076-077 beep.nn
076 @DIV88.P1
077 fcsbit.tbyte
077 SendByte.@SCRATCH
077 @DIV88.@SCRATCH
078 delay_us.P1
078 fcsbit.@SCRATCH
079 fcsbit.@SCRATCH
-000 kalibrace.i
kalibrace.min
kalibrace.max
kalibrace.current
kalibrace.treshold
 
004A delay_ms
0016 delay_us
00AE flipout
00B5 SendBit
00FF SendByte
0024 beep
014A diagnostika
0004 @const10170
005F @SPRINTF
0067 @DIV88
007C @PRINTF_U_290
0364 cikcak
0410 @goto10199
0417 @goto10214
031B objizdka
041D main
0617 @goto10341
061D @goto10355
0135 chyba1
0135 chyba2
 
Project Files:
d:\kaklik\programy\pic_c\roboti\merkur\main.c
d:\kaklik\programy\pic_c\roboti\merkur\main.h
C:\Program Files\PICC\devices\16F873.h
C:\library\kaklik\CCS\AX25.c
/roboti/istrobot/merkur/PIC16F873/main.c
0,0 → 1,332
#include "main.h"
 
#define TXo PIN_C3 // To the transmitter modulator
#include "AX25.c" // podprogram pro prenos telemetrie
 
//motory //Napred vypnout potom zapnout!
#define FR output_low(PIN_B5); output_high(PIN_B4) // Vpred
#define FL output_low(PIN_B7); output_high(PIN_B6)
#define BR output_low(PIN_B4); output_high(PIN_B5) // Vzad
#define BL output_low(PIN_B6); output_high(PIN_B7)
#define STOPR output_low(PIN_B4);output_low(PIN_B5)
#define STOPL output_low(PIN_B6);output_low(PIN_B7)
 
#define L 0b10 // left
#define R 0b01 // right
#define S 0b11 // straight
 
#define COUVANI 1600 // couvnuti po zjisteni diry
#define MEZERA 5400 // za jak dlouho bude ztracena cara
#define PRES_DIRU 400 // velikost mezery v care
#define ODEZVA 1 // za jak dlouho po opusteni cary se ma zacit zatacet
#define BRZDENI 100 // doba (v ms) ptrebna k zastaveni jednoho motoru
 
//cidla
#define RSENSOR 1 // Senzory na caru
#define LSENSOR 0
#define BUMPER PIN_C4 // sensor na cihlu
 
#define DIAG_SERVO PIN_B0 // Propojka pro diagnosticky mod
#define DIAG_SENSORS PIN_B1 // Propojka pro diagnosticky mod
 
#DEFINE SOUND_HI PIN_B3
#DEFINE SOUND_LO PIN_B2
 
char AXstring[40]; // Buffer pro prenos telemetrie
 
int tresholdL; // rozhodovaci uroven pro prave cidlo
int tresholdR; // rozhodovaci uroven pro prave cidlo
int movement; // smer minuleho pohybu
int line; // na ktere strane byla detekovana cara
unsigned int16 dira; // pocitadlo pro nalezeni preruseni cary
 
// Primitivni Pipani
void beep(unsigned int16 period, unsigned int16 length)
{
unsigned int16 nn;
 
for(nn=length; nn>0; nn--)
{
output_high(SOUND_HI);output_low(SOUND_LO);
delay_us(period);
output_high(SOUND_LO);output_low(SOUND_HI);
delay_us(period);
}
}
 
// Diagnostika pohonu, hejbne vsema motorama ve vsech smerech
void diagnostika()
{
unsigned int16 n;
 
while (input(DIAG_SERVO)) // Propojka, ktera spousti diagnostiku
{
for (n=500; n<800; n+=100)
{
beep(n,n); //beep UP
};
Delay_ms(1000);
//zastav vse
STOPL; STOPR;
//pravy pas
FR; Delay_ms(1000); STOPR; Delay_ms(1000);
BR; Delay_ms(1000); STOPR; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//levy pas
FL; Delay_ms(1000); STOPL; Delay_ms(1000);
BL; Delay_ms(1000); STOPL; Delay_ms(1000);
Beep(880,100); Delay_ms(1000);
//oba pasy
FL; FR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
BL; BR; Delay_ms(1000); STOPL; STOPR; Delay_ms(1000);
};
 
while (input(DIAG_SENSORS))
{
int ls, rs;
while(!input(BUMPER)){beep(1100,100); Delay_ms(50);}
set_adc_channel(RSENSOR);
Delay_us(20);
rs=read_adc();
set_adc_channel(LSENSOR);
Delay_us(20);
ls=read_adc();
sprintf(AXstring,"L: %U R: %U\0", ls, rs); // Convert DATA to String.
SendPacket(&AXstring[0]);
delay_ms(1000);
};
}
 
void cikcak()
{
int n;
switch(movement) // podivej se na jednu stranu
{
case L:
FL;BR;
movement=R;
break;
case R:
FR;BL;
movement=L;
break;
case S:
FR;BL;
movement=L;
break;
}
set_adc_channel(LSENSOR);
Delay_us(10);
while (tresholdL < read_adc()) // je tam cara?
{
if (n==50) // asi bude na druhe strane
{
STOPR;STOPL;
n=0;
switch(movement)
{
case L:
FL;BR;
movement=R;
break;
case R:
FR;BL;
movement=L;
break;
}
}
Delay_ms(5);
n++;
}
STOPL;STOPR; // nasli jsme caru
line=S;
}
void objizdka()
{
BL;BR;Delay_ms(300);
STOPR;STOPL;
beep(1000,1000);
Delay_ms(500);
beep(1000,1000);
Delay_ms(1000);
 
}
void kalibrace()
{
unsigned int16 i;
int min;
int max;
int current;
int treshold;
 
FL; BR; Delay_ms(130);
chyba1:
FR; BL; //kalibrace leveho cidla
set_adc_channel(LSENSOR);
Delay_us(20);
min=max=read_adc();
for (i=1;i<=500;i++)
{
current=read_adc();
if (max < current) max=current;
if (min > current) min=current;
Delay_us(500);
}
FL; BR;
for (i=1;i<=500;i++)
{
current=read_adc();
if (max < current) max=current;
if (min > current) min=current;
Delay_us(500);
}
STOPL; STOPR; Delay_ms(200);
if((max-min)<50) {Beep(1000,300); GOTO chyba1;}
treshold=(max-min)>>1;
tresholdL=treshold+min;
 
chyba2:
FR; BL;
set_adc_channel(RSENSOR);
Delay_us(20);
min=max=read_adc(); //naplneni min a max nejakou rozumnou hodnotou
for (i=1;i<=500 ;i++)
{
current=read_adc();
if (max < current) max=current; //zmereni minima a maxima
if (min > current) min=current;
Delay_us(500);
}
FL; BR;
for (i=1;i<=500 ;i++)
{
current=read_adc();
if (max < current) max=current; //zmereni minima a maxima
if (min > current) min=current;
Delay_us(500);
}
STOPL; STOPR; Delay_ms(200);
if((max-min)<50) {Beep(1000,300); GOTO chyba2;}
treshold=(max-min)>>1;
tresholdR=treshold+min;
 
FR; BL;
movement=L;
set_adc_channel(LSENSOR);
Delay_us(20);
while (tresholdL < read_adc()) Delay_us(100);
FL; BR; Delay_ms(50);
STOPL; STOPR; Delay_ms(500);
Beep(780,200);
}
 
void main()
{
unsigned int16 rovne; // pocita delku rovne cary
 
STOPL; STOPR;
 
setup_adc_ports(RA0_RA1_RA3_ANALOG);
setup_adc(ADC_CLOCK_DIV_2);
 
port_b_pullups(false);
 
diagnostika();
 
Beep(1000,200); //double beep
Delay_ms(50);
Beep(1000,200);
Delay_ms(1000); // 1s
 
// kalibrace();
tresholdl=tresholdr=80;
// FL; FR;
movement=S;
line=S;
dira=0;
rovne=0;
 
while(true)
{
if(!input(BUMPER)) objizdka();
line=0;
set_adc_channel(RSENSOR); // podivej se jestli neni cara pod pravym cidlem
Delay_us(10);
if(tresholdR > read_adc())
{
dira=0;
line=R;
}
set_adc_channel(LSENSOR); // kdyz cara nebyla pod pravym cidlem, mozna bude pod levym
Delay_us(10);
if(tresholdL > read_adc())
{
dira=0;
line=line | L;
}
 
switch(line)
{
case S:
FR;FL;
movement=S;
continue;
case L:
STOPL;
FR;movement=L;
continue;
case R:
STOPR;
FL;movement=R;
continue;
default:
}
 
if (dira==ODEZVA) // kdyz uz chvili jedeme po bile plose
{
//BR;BL;Delay_us(rovne >>= 5);
rovne=0; //kdyz sme museli zatocit, uz neni rovna cara
 
switch (line) // musime zatocit
{
case L:
BL;Delay_ms(BRZDENI);STOPL;
FR;
movement=L;
break;
case R:
BR;Delay_ms(BRZDENI);STOPR;
FL;
movement=R;
break;
}
}
if (dira==MEZERA) // kdyz zkoncila cara
{
beep(800,500);
Delay_ms(50);
beep(800,500);
switch (movement) //vrat se zpet na caru
{
case L:
STOPL;STOPR;
BR;Delay_ms(COUVANI);STOPR;
break;
case R:
STOPL;STOPR;
BL;Delay_ms(COUVANI);STOPL;
break;
case S:
BL; BR; Delay_ms(COUVANI);
STOPL; STOPR;
break;
}
 
FR;FL; Delay_ms(PRES_DIRU); // popojedem dopredu mozna tam bude cara
STOPL; STOPR; movement=S;
cikcak(); // najdi caru
dira=0;
}
dira++;
} // while(true)
}
/roboti/istrobot/merkur/PIC16F873/main.cod
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
/roboti/istrobot/merkur/PIC16F873/main.err
0,0 → 1,0
No Errors
/roboti/istrobot/merkur/PIC16F873/main.h
0,0 → 1,5
#include <16F873.h>
#device adc=8
#use delay(clock=4000000)
#fuses XT,NOWDT,NOLVP
 
/roboti/istrobot/merkur/PIC16F873/main.pjt
0,0 → 1,40
[PROJECT]
Target=main.HEX
Development_Mode=
Processor=0x873F
ToolSuite=CCS
 
[Directories]
Include=C:\Program Files\PICC\devices\;C:\Program Files\PICC\drivers\;C:\library\CCS;
Library=
LinkerScript=
 
[Target Data]
FileList=main.c;
BuildTool=C-COMPILER
OptionString=+FM
AdditionalOptionString=
BuildRequired=1
 
[main.c]
Type=4
Path=
FileList=
BuildTool=
OptionString=
AdditionalOptionString=
 
[mru-list]
1=main.c
 
[Windows]
0=0000 main.c 0 0 796 451 3 0
 
[Opened Files]
1=D:\KAKL\PIC\Tank\main.c
2=D:\KAKL\PIC\Tank\main.h
3=D:\KAKL\PIC\Tank\AX25.c
4=C:\Program Files\PICC\devices\16F88.h
5=
6=
7=
/roboti/istrobot/merkur/PIC16F873/main.sta
0,0 → 1,46
 
ROM used: 1572 (38%)
2048 (50%) including unused fragments
 
2 Average locations per line
4 Average locations per statement
 
RAM used: 79 (41%) at main() level
90 (47%) worst case
 
Lines Stmts % Files
----- ----- --- -----
333 374 85 d:\kaklik\programy\pic_c\roboti\merkur\main.c
6 0 0 d:\kaklik\programy\pic_c\roboti\merkur\main.h
225 0 0 C:\Program Files\PICC\devices\16F873.h
136 67 8 C:\library\kaklik\CCS\AX25.c
----- -----
1400 882 Total
 
Page ROM % RAM Functions:
---- --- --- --- ----------
0 21 1 1 delay_ms
0 14 1 1 delay_us
0 7 0 0 flipout
0 74 5 0 SendBit
0 75 5 4 SendByte
0 38 2 6 beep
0 465 30 3 diagnostika
0 18 1 0 @const10170
0 8 1 1 @SPRINTF
0 21 1 3 @DIV88
0 50 3 2 @PRINTF_U_290
0 172 11 1 cikcak
0 7 0 0 @goto10199
0 6 0 0 @goto10214
0 73 5 1 objizdka
0 506 32 3 main
0 6 0 0 @goto10341
0 7 0 0 @goto10355
 
Segment Used Free
--------- ---- ----
0000-0003 4 0
0004-07FF 1568 476
0800-0FFF 0 2048
 
/roboti/istrobot/merkur/PIC16F873/main.tre
0,0 → 1,124
ÀÄmain
ÀÄmain 0/506 Ram=3
ÃÄ??0??
ÃÄdiagnostika 0/465 Ram=3
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄ@SPRINTF 0/8 Ram=1
³ ÃÄ@SPRINTF 0/8 Ram=1
³ ÃÄ@SPRINTF 0/8 Ram=1
³ ÃÄ@PRINTF_U_290 0/50 Ram=2
³ ³ ÃÄ@DIV88 0/21 Ram=3
³ ³ ÃÄ@SPRINTF 0/8 Ram=1
³ ³ ÃÄ@DIV88 0/21 Ram=3
³ ³ ÃÄ@SPRINTF 0/8 Ram=1
³ ³ ÀÄ@SPRINTF 0/8 Ram=1
³ ÃÄ@const10170 0/18 Ram=0
³ ÃÄ@SPRINTF 0/8 Ram=1
³ ÃÄ@PRINTF_U_290 0/50 Ram=2
³ ³ ÃÄ@DIV88 0/21 Ram=3
³ ³ ÃÄ@SPRINTF 0/8 Ram=1
³ ³ ÃÄ@DIV88 0/21 Ram=3
³ ³ ÃÄ@SPRINTF 0/8 Ram=1
³ ³ ÀÄ@SPRINTF 0/8 Ram=1
³ ÃÄSendPacket (Inline) Ram=2
³ ³ ÃÄSendByte 0/75 Ram=4
³ ³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÀÄSendBit 0/74 Ram=0
³ ³ ÃÄSendByte 0/75 Ram=4
³ ³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÀÄSendBit 0/74 Ram=0
³ ³ ÃÄSendByte 0/75 Ram=4
³ ³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÀÄSendBit 0/74 Ram=0
³ ³ ÃÄSendByte 0/75 Ram=4
³ ³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÀÄSendBit 0/74 Ram=0
³ ³ ÃÄSendByte 0/75 Ram=4
³ ³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ³ ÀÄSendBit 0/74 Ram=0
³ ³ ÀÄSendByte 0/75 Ram=4
³ ³ ÃÄfcsbit (Inline) Ram=3
³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ÃÄSendBit 0/74 Ram=0
³ ³ ÃÄflipout 0/7 Ram=0
³ ³ ÀÄSendBit 0/74 Ram=0
³ ÀÄdelay_ms 0/21 Ram=1
ÃÄbeep 0/38 Ram=6
³ ÃÄdelay_us 0/14 Ram=1
³ ÀÄdelay_us 0/14 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄbeep 0/38 Ram=6
³ ÃÄdelay_us 0/14 Ram=1
³ ÀÄdelay_us 0/14 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄobjizdka 0/73 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÃÄdelay_ms 0/21 Ram=1
³ ÃÄbeep 0/38 Ram=6
³ ³ ÃÄdelay_us 0/14 Ram=1
³ ³ ÀÄdelay_us 0/14 Ram=1
³ ÀÄdelay_ms 0/21 Ram=1
ÃÄ@goto10341 0/6 Ram=0
ÃÄdelay_ms 0/21 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄbeep 0/38 Ram=6
³ ÃÄdelay_us 0/14 Ram=1
³ ÀÄdelay_us 0/14 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄbeep 0/38 Ram=6
³ ÃÄdelay_us 0/14 Ram=1
³ ÀÄdelay_us 0/14 Ram=1
ÃÄ@goto10355 0/7 Ram=0
ÃÄdelay_ms 0/21 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÃÄdelay_ms 0/21 Ram=1
ÀÄcikcak 0/172 Ram=1
ÃÄ@goto10199 0/7 Ram=0
ÃÄ@goto10214 0/6 Ram=0
ÀÄdelay_ms 0/21 Ram=1
/roboti/istrobot/merkur/PIC16F873/prg.bat
0,0 → 1,6
call picpgr stop lpt2
call picpgr erase pic16f873 lpt2
call picpgr program main.hex hex pic16f873 lpt2
call picpgr run lpt2
pause
call picpgr stop lpt2
/roboti/istrobot/merkur/PIC16F873/vssver.scc
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