Subversion Repositories Projects

Compare Revisions

Ignore whitespace Rev 63 → Rev 64

/IR-TX-BL/branches/PWM-CTRL_V0.02/Doku/fuses.JPG
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
Property changes:
Added: svn:mime-type
+application/octet-stream
\ No newline at end of property
/IR-TX-BL/branches/PWM-CTRL_V0.02/PWM-CTRL.pnproj
0,0 → 1,0
<Project name="IR-Tx"><File path="main.c"></File><File path="main.h"></File><File path="uart.h"></File><File path="uart.c"></File><File path="twislave.c"></File><File path="twislave.h"></File></Project>
/IR-TX-BL/branches/PWM-CTRL_V0.02/PWM-CTRL.pnws
0,0 → 1,0
<Workspace><File path="c:\mikrokopter\projects\ir-tx-bl\branches\led-ctrl_v0.01\main.c"></File><Project path="c:\mikrokopter\projects\ir-tx-bl\branches\led-ctrl_v0.01\led-ctrl.pnproj"></Project></Workspace>
/IR-TX-BL/branches/PWM-CTRL_V0.02/PWM-CTRL_V0_02.eep
0,0 → 1,2
:060000000000FFFFFFFFFE
:00000001FF
/IR-TX-BL/branches/PWM-CTRL_V0.02/PWM-CTRL_V0_02.hex
0,0 → 1,194
:1000000012C02CC02BC02AC029C03AC027C026C0AD
:1000100026C0AAC023C022C021C020C01FC01EC04D
:100020001DC033C31BC011241FBECFE5D4E0DEBF0B
:10003000CDBF11E0A0E6B0E0ECEFFAE002C0059021
:100040000D92AA36B107D9F711E0AAE6B1E001C0D6
:100050001D92AA38B107E1F779D14FC5D1CF1F92D0
:100060000F920FB60F9211248F9380916B018F5FC7
:1000700080936B018F910F900FBE0F901F9018957A
:100080001F920F920FB60F9211242F933F934F930D
:100090008F939F930EB406FE0CC08EB58F7B8EBDE2
:1000A00010926B0186B597B5909376018093750198
:1000B00051C08EB580648EBD26B537B580916B0179
:1000C0008091750190917601281B390B3093740152
:1000D00020937301C9018955924087509740D0F50C
:1000E0002553384030F084E398E090937401809376
:1000F000730180917301909174018458934030F49E
:1001000084E893E0909374018093730120916000E0
:1001100030916100C901880F991F820F931F2091B0
:10012000730130917401820F931F96958795969570
:1001300087959093740180937301909361008093ED
:10014000600080916A01823328F480916A018F5F98
:1001500080936A019F918F914F913F912F910F90C2
:100160000FBE0F901F9018951F920F920FB60F920F
:1001700011242F933F938F939F9338B322B3809191
:1001800062018F5F809362018F3FE1F43E602863DC
:1001900080917C018093710180917801809370013E
:1001A00080917E0180936F018091790180936E012F
:1001B00080917D0180936D018091770180936C0126
:1001C000109262019091620180917101891709F486
:1001D000377F80917001891709F43B7F80916F010F
:1001E000891709F43D7F80916E01891709F4277FF3
:1001F00080916D01891709F42F7E80916C01891718
:1002000009F42F7D38BB22BB809172018F5F8093F0
:100210007201813259F41092720180917A019091A9
:100220007B01019690937B0180937A019F918F913E
:100230003F912F910F900FBE0F901F901895AC011A
:1002400020917A0130917B01232F3327E0917A01AD
:10025000F0917B0180917A0190917B01622F892F2F
:1002600099272817390739F080917A0190917B01FD
:10027000892F9927682F4F5F5F4F862F90E0982F27
:1002800088272E2F30E0822B932B840F951F089503
:10029000AC0120917A0130917B01232F3327E0912B
:1002A0007A01F0917B0180917A0190917B01622F1C
:1002B000892F99272817390739F080917A01909171
:1002C0007B01892F9927682F862F90E0982F882708
:1002D0002E2F30E0822B932B481B590B452F55278F
:1002E0004695842F807490E0089581E083BF89B79C
:1002F000816089BF08951FBC82EC8EBD89B784627E
:1003000089BF08952091600030916100232F332729
:100310006091600070916100809160009091610037
:10032000422F892F99272817390739F080916000CB
:1003300090916100892F9927482F842F90E0982F62
:100340008827262F30E0822B932B08952F923F92FF
:100350004F925F926F927F928F929F92AF92BF92D5
:10036000CF92DF92EF92FF920F931F93CF93DF9381
:10037000CDB7DEB722970FB6F894DEBF0FBECDBF64
:100380008EE087BB18BA88E084BB15BA88EB81BBC6
:1003900012BA10927C011092780110927E01109294
:1003A000790110927D01109277011FBC82EC8EBD05
:1003B00089B7846289BF81E083BF89B7816089BFC3
:1003C000789444E050E0DA015FD3A0E0B0E022E0AE
:1003D00030E0EA5AF545B9F080EB94E00C0159D3CE
:1003E00088E097E0D9010C0154D38AEA95E5DA0157
:1003F0000C014FD320EB422E24E0522E98E0292E00
:1004000097E0392E05C040D32F01D9013DD31F01FC
:1004100088E893E114DF9A83898388E893E10FDF0A
:100420005C0188EE93E00BDF6C0110E0662477241A
:1004300088248A94982C01C018E080916A01853143
:1004400080F0AB985FDF7C0184EF91E0F8DE5C0127
:100450006E147F0408F43701E814F90420F447010E
:1004600002C0AB9A7201C50113DF882331F088E81E
:1004700093E1E5DE5C0110926A01163008F039C0A4
:10048000F1E4EF16F6E0FF0618F010FD08C006C014
:1004900088E7E81685E0F80610F410FD1F5FC60136
:1004A000F7DE882399F080917C01809580937C0110
:1004B0008091780180958093780180917E0180956C
:1004C00080937E018AEF90E0BADE6C01163089F4E9
:1004D000979A88EB9BE0B3DE9A838983A0E0B0E033
:1004E0000401D7D2A2E0B0E00301D3D2240113016A
:1004F00002C01730C1F4C601CBDE882399F0809189
:100500007C01809580937C01809178018095809317
:10051000780180917E01809580937E0189E190E051
:100520008EDE6C0117E089819A81B2DE882311F09A
:10053000979803C0183009F080CFEEEFFFEFEE0E72
:10054000FF1EE418F5080027F7FC0095102F910115
:10055000241935092450304040E050E060E070EC50
:1005600084ED91E054D2C801B70132D220E23EE4DA
:1005700040E050E04CD2B90137FF03C060E070E0CA
:1005800005C02250364014F061E076E06F3F7105FF
:1005900009F030F460937C011092780110927E0192
:1005A000CB01805091408F3F910509F038F48FEFD7
:1005B00080937C011092780160937E01CB01805082
:1005C00092408F3F910509F048F4862F80958093E3
:1005D0007C01109278018FEF80937E01CB018050D7
:1005E00093408F3F910509F038F410927C0160939D
:1005F00078018FEF80937E01CB01805094408F3F34
:10060000910509F048F410927C018FEF80937801F6
:10061000862F809580937E01CB01805095408F3F3F
:10062000910509F038F460937C018FEF8093780195
:1006300010927E01605076400CF4FECE8FEF8093D6
:100640007C018093780110927E01F6CE1F93182FC3
:100650008A3011F48DE0FADF5D9BFECF1CB980E09B
:1006600090E01F910895599A88E18AB986E880BD83
:1006700089E189B960E070E086E293E03ED00895B8
:1006800082E682B985EC86BF08951F920F920FB65D
:100690000F9211248F939F9381B190E0887F907087
:1006A0008038910599F08138910534F40097C9F0AC
:1006B00080369105C9F40FC0883B910559F0883FF9
:1006C000910561F0883A910579F404C083B1809373
:1006D0007F0101C013B886B7806807C086B78069FC
:1006E00086BF86B7806986BF85EC86BF9F918F9154
:1006F0000F900FBE0F901F901895EF92FF920F93DF
:100700001F93CF93DF938C017B01892B11F4672B0F
:10071000C9F16EE070E081E090E03BD0FC01009711
:1007200089F1DC0180E88383E114F10471F0F38640
:10073000E28681E883838091800190918101892BF9
:1007400021F4F0938101E093800101151105E1F09E
:1007500011870087838182608383809182019091D9
:100760008301892B89F4F0938301E09382018091C6
:10077000840190918501892B39F4F0938501E093F0
:10078000840102C0A0E0B0E0CD01E6E0CDB7DEB765
:10079000A5C10F931F93CF93DF93689F8001699F3B
:1007A000100D789F100D1124C8010DD0EC01009799
:1007B00021F0A80160E070E004D1CE01DF91CF917B
:1007C0001F910F910895CF93DF93AC01029710F41E
:1007D00042E050E0A0918801B0918901FD01C0E0A4
:1007E000D0E020E030E020C080819181841795071F
:1007F00069F482819381209719F09B838A8304C0D6
:1008000090938901809388019F0132C0481759074E
:1008100038F42115310519F08217930708F49C016B
:10082000EF010280F381E02D3097F1F621153105BB
:1008300099F1C901841B950B049708F4A901E0E024
:10084000F0E028C08D919C91119782179307F9F4DD
:100850004817590781F4ED018A819B81309719F07F
:100860009383828304C090938901809388019D01C2
:100870002E5F3F4F4CC0841B950BFD01E80FF91F05
:100880004193519302978D939C939F0140C0FD012A
:10089000A281B3811097B1F6809186019091870172
:1008A000892B41F4809165019091660190938701B5
:1008B00080938601209167013091680121153105EF
:1008C00049F48DB7282F30E0809163019091640145
:1008D000281B390BA0918601B09187012A1B3B0B85
:1008E0002417350790F0CA0102962817390768F0D7
:1008F0009D012E5F3F4FC901840F951F9093870183
:10090000809386014D935C9302C020E030E0C901E2
:10091000DF91CF910895CF93DF93009709F44EC0F4
:10092000EC0122971B821A82A0918801B091890163
:10093000109711F140E050E001C0DC01AC17BD0799
:1009400000F1BB83AA83FE0121913191E20FF31FD5
:10095000EA17FB0771F48D919C911197280F391FAD
:100960002E5F3F4F39832883FD01828193819B83D2
:100970008A834115510559F4D0938901C0938801A8
:100980001DC0FD0182819381AD010097B1F6FA018E
:10099000D383C28321913191E20FF31FEC17FD073E
:1009A00069F488819981280F391F2E5F3F4FFA0122
:1009B000318320838A819B8193838283DF91CF91CE
:1009C0000895DC0101C06D9341505040E0F7089557
:1009D000629FD001739FF001829FE00DF11D649F23
:1009E000E00DF11D929FF00D839FF00D749FF00DAF
:1009F000659FF00D9927729FB00DE11DF91F639F50
:100A0000B00DE11DF91FBD01CF011124089597FB21
:100A1000092E05260ED057FD04D014D00AD0001C94
:100A200038F450954095309521953F4F4F4F5F4F8B
:100A30000895F6F790958095709561957F4F8F4F4B
:100A40009F4F0895A1E21A2EAA1BBB1BFD010DC0EA
:100A5000AA1FBB1FEE1FFF1FA217B307E407F5076E
:100A600020F0A21BB30BE40BF50B661F771F881F4A
:100A7000991F1A9469F760957095809590959B01E0
:100A8000AC01BD01CF01089509D0E02D07D0F02DB4
:100A900008950CD0012C0AD011240895E199FECFBD
:100AA000BFBBAEBBE09A11960DB20895E199FECF9F
:100AB000BFBBAEBB0DBA11960FB6F894E29AE19A9D
:100AC0000FBE08952A88398848885F846E847D84A3
:100AD0008C849B84AA84B984C884DF80EE80FD80E6
:100AE0000C811B81AA81B981CE0FD11D0FB6F8945C
:0C0AF000DEBF0FBECDBFED010895FFCFAB
:100AFC00F005000102030405060708090A0B0C0D9A
:100B0C000E0F000102030405060708090A0B0C0D61
:100B1C000E0F000102030405060708090A0B0C0D51
:100B2C000E0F000102030405060708090A0B0C0D41
:100B3C000E0F000102030405060708090A0B0C0D31
:100B4C000E0F000102030405060708090A0B0C0D21
:100B5C000E0F000102030405060708090A0B0C0D11
:100B6C000E0F000102030405060708090A0B0C0D01
:100B7C000E0F000102030405060708090A0B0C0DF1
:100B8C000E0F000102030405060708090A0B0C0DE1
:100B9C000E0F000102030405060708090A0B0C0DD1
:100BAC000E0F000102030405060708090A0B0C0DC1
:100BBC000E0F000102030405060708090A0B0C0DB1
:100BCC000E0F000102030405060708090A0B0C0DA1
:100BDC000E0F000102030405060708090A0B0C0D91
:100BEC000E0F000102030405060708090A0B0C0D81
:0A0BFC000E0FFE20008A0100000029
:00000001FF
/IR-TX-BL/branches/PWM-CTRL_V0.02/main.c
0,0 → 1,434
//############################################################################
// - PWM CTRL
// - Main
// - ATMEGA8 mit 8MHz
// - Nur für den privaten Gebrauch
// - Keine Garantie auf Fehlerfreiheit
// - Kommerzielle Nutzung nur mit meiner Zustimmung
// - walter Meyer @ www.freakware.de
// - 11.12.2007
// - Make sure Fuses are programmed for internal 8 MHz RC Oscilator
//############################################################################*/
 
#include "main.h"
#include "uart.h"
#include "twislave.h"
 
volatile unsigned int PPM_SIGNAL = 1520;
volatile unsigned char PPM_NEW = 0;
volatile unsigned char TMR1OvF = 0;
volatile unsigned int TMR1MS;
volatile unsigned char CH0;
volatile unsigned char CH1;
volatile unsigned char CH2;
volatile unsigned char CH3;
volatile unsigned char CH4;
volatile unsigned char CH5;
 
uint16_t EEMEM EEPMIN=0x0000;
uint16_t EEMEM EEPMAX=0xffff;
uint16_t EEMEM EEPSIG=0xffff;
 
 
//led kennlinie, (noch nicht implementiert, nur vorbereitet)
unsigned char kl[256]={
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15
};
 
 
 
/*##############################################################################*/
SIGNAL(SIG_OVERFLOW1)
{
TMR1OvF++;
}
 
 
SIGNAL(SIG_INPUT_CAPTURE1)
{
static unsigned int pos_ICR;
static unsigned int ppm;
if ((TCCR1B & (1<<ICES1)) != 0) //rising edge
{
TCCR1B &= ~(1<<ICES1); //set falling egde
TMR1OvF = 0;
pos_ICR = ICR1;
}
else //falling edge
{
TCCR1B |= (1<<ICES1); //set rising egde
ppm = (ICR1 - pos_ICR + (int) TMR1OvF * 65536);
if ((ppm > 600) && (ppm < 2400))
{
if (ppm > 2100) ppm = 2100;
if (ppm < 900) ppm = 900;
ppm = (PPM_SIGNAL * 3 + ppm) / 4;
PPM_SIGNAL = ppm;
if (PPM_NEW < 50) PPM_NEW++;
}
}
 
}
 
/*##############################################################################*/
SIGNAL(SIG_OVERFLOW0)
{
// this function is called every 32us,
// it is very important that it's execution time is as short as possible
// currently it's about 20us
 
static unsigned char counter = 254;
static unsigned char ms1 = 0;
static unsigned char ch0_tmp = 0;
static unsigned char ch1_tmp = 0;
static unsigned char ch2_tmp = 0;
static unsigned char ch3_tmp = 0;
static unsigned char ch4_tmp = 0;
static unsigned char ch5_tmp = 0;
unsigned char PORTB_BAK;
unsigned char PORTD_BAK;
 
PORTB_BAK = PORTB;
PORTD_BAK = PORTD;
 
if (counter++ == 254)
{
PORTB_BAK LEDON (CH0_B | CH1_B | CH2_B); //new cycle, output on
PORTD_BAK LEDON (CH3_D | CH4_D | CH5_D); //
ch0_tmp = CH0;
ch1_tmp = CH1;
ch2_tmp = CH2;
ch3_tmp = CH3;
ch4_tmp = CH4;
ch5_tmp = CH5;
counter = 0;
}
 
if (ch0_tmp == counter) PORTB_BAK LEDOFF CH0_B; //channel value reached, output off
if (ch1_tmp == counter) PORTB_BAK LEDOFF CH1_B; //
if (ch2_tmp == counter) PORTB_BAK LEDOFF CH2_B; //
if (ch3_tmp == counter) PORTD_BAK LEDOFF CH3_D; //
if (ch4_tmp == counter) PORTD_BAK LEDOFF CH4_D; //
if (ch5_tmp == counter) PORTD_BAK LEDOFF CH5_D; //
PORTB = PORTB_BAK;
PORTD = PORTD_BAK;
if (ms1++ == 32)
{
ms1=0;
TMR1MS++;
}
 
 
 
}
 
 
/*##############################################################################*/
unsigned int SetDelay (unsigned int t)
{
unsigned char hi_byte;
unsigned char lo_byte;
 
hi_byte = (TMR1MS >> 8);
lo_byte = (TMR1MS & 0xff);
if (hi_byte != (TMR1MS >> 8)) hi_byte = (TMR1MS >> 8);
 
return(((hi_byte << 8) | lo_byte) + t + 1);
}
 
 
/*##############################################################################*/
char CheckDelay(unsigned int t)
{
unsigned char hi_byte;
unsigned char lo_byte;
 
hi_byte = (TMR1MS >> 8);
lo_byte = (TMR1MS & 0xff);
if (hi_byte != (TMR1MS >> 8)) hi_byte = (TMR1MS >> 8);
 
return(((t - ((hi_byte << 8) | lo_byte)) & 0x8000) >> 9);
}
 
 
 
/*##############################################################################*/
void StartPWM(void)
{
//Timer 0 Config
TCCR0 = (0<<CS02)|(0<<CS01)|(1<<CS00); // (@8MHz) = 1/8us Clk = 256/8 = 32us overflow
TIMSK setbit (1<<TOIE0); // enable Int
 
}
 
 
/*##############################################################################*/
void StartPPM(void)
{
//Timer1 Config
TCCR1A = (0<<COM1A1)|(0<<COM1A0)|(0<<COM1B1)|(0<<COM1B0)|
(0<<FOC1A) |(0<<FOC1B) |(0<<WGM10) |(0<<WGM11);
TCCR1B = (1<<ICNC1)|(1<<ICES1)|(0<<WGM13)|
(0<<WGM12)|(0<<CS12)|(1<<CS11)|(0<<CS10); //ICP_POS_FLANKE
 
// interrupts
TIMSK |= (1<<TICIE1)|(1<<TOIE1); //ICP_INT_ENABLE and TIMER1_INT_ENABLE
 
}
 
 
/*##############################################################################*/
unsigned int GetPPM(void)
{
//this routines seems to be nesseccary, as reading a 16 bit value
//on a 8 bit machine is not atomic, so if an interrupt apears between reading
//low and high byte of the 16 bit value a wrong result is possible
unsigned char temp_hi;
unsigned char temp_lo;
 
temp_hi = (PPM_SIGNAL >> 8);
temp_lo = (PPM_SIGNAL & 0xff);
if (temp_hi != (PPM_SIGNAL >> 8)) temp_hi = (PPM_SIGNAL >> 8);
return( (temp_hi << 8) | temp_lo);
 
}
 
 
/*##############################################################################*/
// MAIN
/*##############################################################################*/
int main (void)
{
 
#define STEP 256
#define MUL 1
#define REDUCE 2
#define EEPSIGNATURE 0x55aa
 
#define inimin 1200
#define inimax 1800
 
unsigned int ppm;
signed int color;
unsigned int setupdly;
unsigned int ppmtodly;
unsigned int flashdly;
unsigned char setup;
unsigned int lmax;
unsigned int lmin;
unsigned int max;
unsigned int min;
signed long temp1;
signed long temp2;
 
DDRB = (CH0_B|CH1_B|CH2_B);
PORTB = 0x00;
 
DDRC = (ledred);
PORTC = 0x00;
 
DDRD = (ledgreen|CH3_D|CH4_D|CH5_D);
PORTD = 0x00;
 
CH0 = 0;
CH1 = 0;
CH2 = 0;
CH3 = 0;
CH4 = 0;
CH5 = 0;
 
lmax = 0x0000;
lmin = 0xffff;
 
// StartUART();
StartPPM();
//StartI2C();
StartPWM();
sei();
 
min = inimin; //default min
max = inimax; //default max
 
if (eeprom_read_word(&EEPSIG) != EEPSIGNATURE) //check eep if signature is there
{
eeprom_write_word(&EEPMIN, min); //no, write initial min
eeprom_write_word(&EEPMAX, max); //and max values
eeprom_write_word(&EEPSIG, EEPSIGNATURE); //along with eep signature
}
else
{
 
min = eeprom_read_word(&EEPMIN); //signature ok
max = eeprom_read_word(&EEPMAX); //read min and max
}
 
 
setup = 0; //reset setup toggle counter
setupdly = SetDelay(5000);
ppmtodly = SetDelay(5000);
flashdly = SetDelay(1000);
while (1)
{
 
if (PPM_NEW > 20) //ppm Signal ok
{
PORTC clrbit ledred;
ppm = GetPPM();
ppmtodly = SetDelay(500); //reset timeout
if (lmax < ppm) lmax=ppm; //update impulse max
if (lmin > ppm) lmin=ppm; //and min boundarys
}
else
{
PORTC setbit ledred; //ppm signal not ok
ppm = min; //set ppm to minimum
}
 
if (CheckDelay(ppmtodly)) //timeout
{
ppmtodly = SetDelay(5000);
PPM_NEW = 0; //set ppm signal not ok
}
 
 
if (setup < 6)
{
if ((ppm > 1600) && ((setup&1)==0)) setup++; //
if ((ppm < 1400) && ((setup&1)==1)) setup++; //
 
if (CheckDelay(flashdly))
{
CH0 = CH0 ^ 0xff;
CH1 = CH1 ^ 0xff;
CH2 = CH2 ^ 0xff;
flashdly = SetDelay(250);
}
}
 
if (setup == 6) //if stick is toggled 6 times
{ //within setup timeout
PORTD setbit ledgreen; //store ppm min and max
setupdly = SetDelay(3000); //for 2000ms
eeprom_write_word(&EEPMIN, lmin); //in eeprom
eeprom_write_word(&EEPMAX, lmax);
min = lmin;
max = lmax;
setup = 7; //enter PWM toggle mode
 
}
 
 
if (setup == 7)
{
if (CheckDelay(flashdly)) //each 25ms toggle PWM's
{
CH0 = CH0 ^ 0xff;
CH1 = CH1 ^ 0xff;
CH2 = CH2 ^ 0xff;
flashdly = SetDelay(25);
}
}
 
if (CheckDelay(setupdly)) //setup timeout reached
{
setup = 8; //lockdown setup
PORTD clrbit ledgreen;
}
 
if (setup == 8)
{
 
temp1 = ((long)STEP * 6 * 20000) / ((max-REDUCE) - (min+REDUCE));
temp2 = (((int)ppm - ((int)min+REDUCE)) * temp1);
color = temp2 / 20000;
if (color < 0) color = 0;
if (color > ((STEP*6)+1)) color = ((STEP*6)+1);
 
//printf("p %u ",ppm);
//printf("pm %u ",(min+REDUCE));
//printf("t1 %li ",temp1);
//printf("t2 %li ",temp2);
//printf("c %i\n ",color);
// Farbablauf: rot > Violett > blau > tuerkis > gruen > gelb >
if ((color >= (STEP * 0)) && (color < (STEP * 1)))
{
CH0 = MUL * ((color - (STEP * 0))); //fade in red > red (red only)
CH1 = 0;
CH2 = 0;
}
if ((color >= (STEP * 1)) && (color < (STEP * 2)))
{
CH0 = ((STEP-1) * MUL);
CH1 = 0;
CH2 = MUL * ((color - (STEP * 1))); //fade in blue > purple (red + blue)
}
if ((color >= (STEP * 2)) && (color < (STEP * 3)))
{
CH0 = MUL * ((STEP - 1) - (color - (STEP * 2))); //fade out red > blue (blue only)
CH1 = 0;
CH2 = ((STEP-1) * MUL);
}
if ((color >= (STEP * 3)) && (color < (STEP * 4)))
{
CH0 = 0;
CH1 = MUL * ((color - (STEP * 3))); //fade in green > cyan (blue + green)
CH2 = ((STEP-1) * MUL);
}
if ((color >= (STEP * 4)) && (color < (STEP * 5)))
{
CH0 = 0;
CH1 = ((STEP-1) * MUL);
CH2 = MUL * ((STEP - 1) - (color - (STEP * 4))); //fade out blue > green (green only)
}
if ((color >= (STEP * 5)) && (color < (STEP * 6)))
{
CH0 = MUL * ((color - (STEP * 5))); //fade in red > yellow (green + red)
CH1 = ((STEP-1) * MUL);
CH2 = 0;
}
if (color >= (STEP * 6))
{
CH0 = ((STEP-1) * MUL); //fade in red > yellow (green + red)
CH1 = ((STEP-1) * MUL);
CH2 = 0;
}
}
 
 
}
 
}
 
/IR-TX-BL/branches/PWM-CTRL_V0.02/main.h
0,0 → 1,40
#ifndef _MAIN_H
#define _MAIN_H
 
 
#define SYSCLK 8000000L
 
 
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <avr/io.h>
#include <avr/interrupt.h>
#include <avr/eeprom.h>
 
 
#define setbit |=
#define clrbit &=~
#define invbit ^=
//#define correction -60
 
#define LEDON setbit
#define LEDOFF clrbit
 
#define ledred (1<<3) //on Port C
#define ledgreen (1<<7) //on Port D
 
#define CH0_B (1<<3)
#define CH1_B (1<<2)
#define CH2_B (1<<1)
#define CH3_D (1<<3)
#define CH4_D (1<<4)
#define CH5_D (1<<5)
 
 
#endif //_MAIN_H
 
 
 
 
 
/IR-TX-BL/branches/PWM-CTRL_V0.02/makefile
0,0 → 1,387
#--------------------------------------------------------------------
# MCU name
MCU = atmega8
#-------------------------------------------------------------------
HAUPT_VERSION = 0
NEBEN_VERSION = 02
#-------------------------------------------------------------------
 
# Output format. (can be srec, ihex, binary)
FORMAT = ihex
 
# Target file name (without extension).
TARGET = PWM-CTRL_V$(HAUPT_VERSION)_$(NEBEN_VERSION)
 
# Optimization level, can be [0, 1, 2, 3, s]. 0 turns off optimization.
# (Note: 3 is not always the best optimization level. See avr-libc FAQ.)
OPT = s
 
##########################################################################################################
# List C source files here. (C dependencies are automatically generated.)
SRC = main.c uart.c twislave.c
##########################################################################################################
 
# If there is more than one source file, append them above, or modify and
# uncomment the following:
#SRC += foo.c bar.c
 
# You can also wrap lines by appending a backslash to the end of the line:
#SRC += baz.c \
#xyzzy.c
 
 
 
# List Assembler source files here.
# Make them always end in a capital .S. Files ending in a lowercase .s
# will not be considered source files but generated files (assembler
# output from the compiler), and will be deleted upon "make clean"!
# Even though the DOS/Win* filesystem matches both .s and .S the same,
# it will preserve the spelling of the filenames, and gcc itself does
# care about how the name is spelled on its command-line.
ASRC =
 
 
# List any extra directories to look for include files here.
# Each directory must be seperated by a space.
EXTRAINCDIRS =
 
 
# Optional compiler flags.
# -g: generate debugging information (for GDB, or for COFF conversion)
# -O*: optimization level
# -f...: tuning, see gcc manual and avr-libc documentation
# -Wall...: warning level
# -Wa,...: tell GCC to pass this to the assembler.
# -ahlms: create assembler listing
CFLAGS = -g -O$(OPT) \
-funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums \
-Wall -Wstrict-prototypes \
-Wa,-adhlns=$(<:.c=.lst) \
$(patsubst %,-I%,$(EXTRAINCDIRS))
 
 
# Set a "language standard" compiler flag.
# Unremark just one line below to set the language standard to use.
# gnu99 = C99 + GNU extensions. See GCC manual for more information.
#CFLAGS += -std=c89
#CFLAGS += -std=gnu89
#CFLAGS += -std=c99
CFLAGS += -std=gnu99
 
CFLAGS += -DVERSION_HAUPTVERSION=$(HAUPT_VERSION) -DVERSION_NEBENVERSION=$(NEBEN_VERSION)
 
ifeq ($(AVR_CTRL_PLATINE), 1)
CFLAGS += -DAVR_CTRL_PLATINE=$(AVR_CTRL_PLATINE)
endif
 
 
 
# Optional assembler flags.
# -Wa,...: tell GCC to pass this to the assembler.
# -ahlms: create listing
# -gstabs: have the assembler create line number information; note that
# for use in COFF files, additional information about filenames
# and function names needs to be present in the assembler source
# files -- see avr-libc docs [FIXME: not yet described there]
ASFLAGS = -Wa,-adhlns=$(<:.S=.lst),-gstabs
 
 
 
# Optional linker flags.
# -Wl,...: tell GCC to pass this to linker.
# -Map: create map file
# --cref: add cross reference to map file
LDFLAGS = -Wl,-Map=$(TARGET).map,--cref
 
 
 
# Additional libraries
 
# Minimalistic printf version
#LDFLAGS += -Wl,-u,vfprintf -lprintf_min
 
# Floating point printf version (requires -lm below)
#LDFLAGS += -Wl,-u,vfprintf -lprintf_flt
 
# -lm = math library
LDFLAGS += -lm
 
 
 
 
# Programming support using avrdude. Settings and variables.
 
# Programming hardware: alf avr910 avrisp bascom bsd
# dt006 pavr picoweb pony-stk200 sp12 stk200 stk500
#
# Type: avrdude -c ?
# to get a full listing.
#
 
AVRDUDE_PROGRAMMER = ponyser
#AVRDUDE_PROGRAMMER = stk200
 
#AVRDUDE_PORT = com1 # programmer connected to serial device
AVRDUDE_PORT = com1
 
AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex
#AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep
 
AVRDUDE_FLAGS = -F -p $(MCU) -P $(AVRDUDE_PORT) -c $(AVRDUDE_PROGRAMMER)
 
# Uncomment the following if you want avrdude's erase cycle counter.
# Note that this counter needs to be initialized first using -Yn,
# see avrdude manual.
#AVRDUDE_ERASE += -y
 
# Uncomment the following if you do /not/ wish a verification to be
# performed after programming the device.
#AVRDUDE_FLAGS += -V -E noreset
 
 
# Increase verbosity level. Please use this when submitting bug
# reports about avrdude. See <http://savannah.nongnu.org/projects/avrdude>
# to submit bug reports.
#AVRDUDE_FLAGS += -v -v
 
 
 
 
# ---------------------------------------------------------------------------
 
# Define directories, if needed.
DIRAVR = c:/winavr
DIRAVRBIN = $(DIRAVR)/bin
DIRAVRUTILS = $(DIRAVR)/utils/bin
DIRINC = .
DIRLIB = $(DIRAVR)/avr/lib
 
 
# Define programs and commands.
SHELL = sh
 
CC = avr-gcc
 
OBJCOPY = avr-objcopy
OBJDUMP = avr-objdump
SIZE = avr-size
 
 
# Programming support using avrdude.
AVRDUDE = avrdude
 
 
REMOVE = rm -f
COPY = cp
 
HEXSIZE = $(SIZE) --target=$(FORMAT) $(TARGET).hex
ELFSIZE = $(SIZE) -A $(TARGET).elf
 
 
 
# Define Messages
# English
MSG_ERRORS_NONE = Errors: none
MSG_BEGIN = -------- begin --------
MSG_END = -------- end --------
MSG_SIZE_BEFORE = Size before:
MSG_SIZE_AFTER = Size after:
MSG_COFF = Converting to AVR COFF:
MSG_EXTENDED_COFF = Converting to AVR Extended COFF:
MSG_FLASH = Creating load file for Flash:
MSG_EEPROM = Creating load file for EEPROM:
MSG_EXTENDED_LISTING = Creating Extended Listing:
MSG_SYMBOL_TABLE = Creating Symbol Table:
MSG_LINKING = Linking:
MSG_COMPILING = Compiling:
MSG_ASSEMBLING = Assembling:
MSG_CLEANING = Cleaning project:
 
 
 
 
# Define all object files.
OBJ = $(SRC:.c=.o) $(ASRC:.S=.o)
 
# Define all listing files.
LST = $(ASRC:.S=.lst) $(SRC:.c=.lst)
 
# Combine all necessary flags and optional flags.
# Add target processor to flags.
ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS)
ALL_ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp $(ASFLAGS)
 
 
 
# Default target.
all: begin gccversion sizebefore $(TARGET).elf $(TARGET).hex $(TARGET).eep \
$(TARGET).lss $(TARGET).sym sizeafter finished end
 
 
# Eye candy.
# AVR Studio 3.x does not check make's exit code but relies on
# the following magic strings to be generated by the compile job.
begin:
@echo
@echo $(MSG_BEGIN)
 
finished:
@echo $(MSG_ERRORS_NONE)
 
end:
@echo $(MSG_END)
@echo
 
 
# Display size of file.
sizebefore:
@if [ -f $(TARGET).elf ]; then echo; echo $(MSG_SIZE_BEFORE); $(ELFSIZE); echo; fi
 
sizeafter:
@if [ -f $(TARGET).elf ]; then echo; echo $(MSG_SIZE_AFTER); $(ELFSIZE); echo; fi
 
 
 
# Display compiler version information.
gccversion :
@$(CC) --version
 
 
 
 
# Convert ELF to COFF for use in debugging / simulating in
# AVR Studio or VMLAB.
COFFCONVERT=$(OBJCOPY) --debugging \
--change-section-address .data-0x800000 \
--change-section-address .bss-0x800000 \
--change-section-address .noinit-0x800000 \
--change-section-address .eeprom-0x810000
 
 
coff: $(TARGET).elf
@echo
@echo $(MSG_COFF) $(TARGET).cof
$(COFFCONVERT) -O coff-avr $< $(TARGET).cof
 
 
extcoff: $(TARGET).elf
@echo
@echo $(MSG_EXTENDED_COFF) $(TARGET).cof
$(COFFCONVERT) -O coff-ext-avr $< $(TARGET).cof
 
 
 
 
# Program the device.
program: $(TARGET).hex $(TARGET).eep
$(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM)
 
 
 
 
# Create final output files (.hex, .eep) from ELF output file.
%.hex: %.elf
@echo
@echo $(MSG_FLASH) $@
$(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@
 
%.eep: %.elf
@echo
@echo $(MSG_EEPROM) $@
-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
--change-section-lma .eeprom=0 -O $(FORMAT) $< $@
 
# Create extended listing file from ELF output file.
%.lss: %.elf
@echo
@echo $(MSG_EXTENDED_LISTING) $@
$(OBJDUMP) -h -S $< > $@
 
# Create a symbol table from ELF output file.
%.sym: %.elf
@echo
@echo $(MSG_SYMBOL_TABLE) $@
avr-nm -n $< > $@
 
 
 
# Link: create ELF output file from object files.
.SECONDARY : $(TARGET).elf
.PRECIOUS : $(OBJ)
%.elf: $(OBJ)
@echo
@echo $(MSG_LINKING) $@
$(CC) $(ALL_CFLAGS) $(OBJ) --output $@ $(LDFLAGS)
 
 
# Compile: create object files from C source files.
%.o : %.c
@echo
@echo $(MSG_COMPILING) $<
$(CC) -c $(ALL_CFLAGS) $< -o $@
 
 
# Compile: create assembler files from C source files.
%.s : %.c
$(CC) -S $(ALL_CFLAGS) $< -o $@
 
 
# Assemble: create object files from assembler source files.
%.o : %.S
@echo
@echo $(MSG_ASSEMBLING) $<
$(CC) -c $(ALL_ASFLAGS) $< -o $@
 
 
 
 
 
 
# Target: clean project.
clean: begin clean_list finished end
 
clean_list :
@echo
@echo $(MSG_CLEANING)
# $(REMOVE) $(TARGET).hex
# $(REMOVE) $(TARGET).eep
# $(REMOVE) $(TARGET).obj
$(REMOVE) $(TARGET).cof
$(REMOVE) $(TARGET).elf
$(REMOVE) $(TARGET).map
$(REMOVE) $(TARGET).obj
$(REMOVE) $(TARGET).a90
$(REMOVE) $(TARGET).sym
$(REMOVE) $(TARGET).lnk
$(REMOVE) $(TARGET).lss
$(REMOVE) $(OBJ)
$(REMOVE) $(LST)
$(REMOVE) $(SRC:.c=.s)
$(REMOVE) $(SRC:.c=.d)
 
 
# Automatically generate C source code dependencies.
# (Code originally taken from the GNU make user manual and modified
# (See README.txt Credits).)
#
# Note that this will work with sh (bash) and sed that is shipped with WinAVR
# (see the SHELL variable defined above).
# This may not work with other shells or other seds.
#
%.d: %.c
set -e; $(CC) -MM $(ALL_CFLAGS) $< \
| sed 's,\(.*\)\.o[ :]*,\1.o \1.d : ,g' > $@; \
[ -s $@ ] || rm -f $@
 
 
# Remove the '-' if you want to see the dependency files generated.
-include $(SRC:.c=.d)
 
 
 
# Listing of phony targets.
.PHONY : all begin finish end sizebefore sizeafter gccversion coff extcoff \
clean clean_list program
 
 
 
/IR-TX-BL/branches/PWM-CTRL_V0.02/twislave.c
0,0 → 1,62
//############################################################################
// - PWM CTRL
// - ATMEGA8 mit 8MHz
// - Nur für den privaten Gebrauch
// - Keine Garantie auf Fehlerfreiheit
// - Kommerzielle Nutzung nur mit meiner Zustimmung
// - walter Meyer @ www.freakware.de
//############################################################################*/
#include <avr/io.h>
#include <util/twi.h>
#include "main.h"
#include "twislave.h"
 
unsigned char I2C_IN;
 
 
//############################################################################
//I2C (TWI) Interface Init
void StartI2C(void)
//############################################################################
{
TWAR = 0x62; //I2C client address
TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWIE) | (1<<TWEA);
}
 
//############################################################################
//ISR, die bei einem Ereignis auf dem Bus ausgelöst wird. Im Register TWSR befindet
//sich dann ein Statuscode, anhand dessen die Situation festgestellt werden kann.
SIGNAL (TWI_vect)
//############################################################################
{
switch (TWSR & 0xF8)
{
case SR_SLA_ACK:
TWCR |= (1<<TWINT);
return;
 
case SR_PREV_ACK: //receive
I2C_IN = TWDR;
TWCR |= (1<<TWINT);
return;
 
case SW_SLA_ACK: //send 0x00
TWDR = 0x00;
TWCR |= (1<<TWINT);
return;
 
case SW_DATA_ACK: //send 0x00
TWDR = 0x00;
TWCR |= (1<<TWINT);
return;
 
case TWI_BUS_ERR_2: //bus error / reset bus
TWCR |=(1<<TWSTO) | (1<<TWINT);
 
case TWI_BUS_ERR_1: //bus error / reset bus
TWCR |=(1<<TWSTO) | (1<<TWINT);
}
TWCR =(1<<TWEA) | (1<<TWINT) | (1<<TWEN) | (1<<TWIE); // TWI Reset
}
 
 
/IR-TX-BL/branches/PWM-CTRL_V0.02/twislave.h
0,0 → 1,31
#ifndef _TWI_SLAVE_H_
#define _TWI_SLAVE_H_
 
extern unsigned char I2C_IN;
 
extern void StartI2C(void);
 
#define TWI_BUS_ERR_1 0x00
#define TWI_BUS_ERR_2 0xF8
 
// Status Slave RX Mode
#define SR_SLA_ACK 0x60
#define SR_LOST_ACK 0x68
#define SR_GEN_CALL_ACK 0x70
#define GEN_LOST_ACK 0x78
#define SR_PREV_ACK 0x80
#define SR_PREV_NACK 0x88
#define GEN_PREV_ACK 0x90
#define GEN_PREV_NACK 0x98
#define STOP_CONDITION 0xA0
#define REPEATED_START 0xA0
 
// Status Slave TX mode
#define SW_SLA_ACK 0xA8
#define SW_LOST_ACK 0xB0
#define SW_DATA_ACK 0xB8
#define SW_DATA_NACK 0xC0
#define SW_LAST_ACK 0xC8
 
#endif
 
/IR-TX-BL/branches/PWM-CTRL_V0.02/uart.c
0,0 → 1,38
//############################################################################
// - PWM CTRL
// - ATMEGA8 mit 8MHz
// - Nur für den privaten Gebrauch
// - Keine Garantie auf Fehlerfreiheit
// - Kommerzielle Nutzung nur mit meiner Zustimmung
// - walter Meyer @ www.freakware.de
//############################################################################*/
 
#include "main.h"
#include "uart.h"
 
void StartUART(void)
{
// UART Double Speed (U2X)
UCSRA |= (1<<U2X);
/* Enable receiver and transmitter, no RX Int, no TX Int */
UCSRB = (1<<RXEN)|(1<<TXEN); // (1<<RXCIE)|(1<<TXCIE)
/* Set frame format: 8data, 1stop bit */
UCSRC = (1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);
 
//Teiler wird gesetzt
UBRRL= (SYSCLK / (BAUD_RATE * 8L) -1 );
 
//öffnet einen Kanal für printf (STDOUT)
fdevopen (uart_putchar, NULL);
 
}
 
int uart_putchar (char c)
{
if (c == '\n') uart_putchar('\r');
loop_until_bit_is_set(UCSRA, UDRE);
UDR = c;
return (0);
}
/IR-TX-BL/branches/PWM-CTRL_V0.02/uart.h
0,0 → 1,11
#ifndef _UART_H
#define _UART_H
 
extern void StartUART (void);
extern int uart_putchar (char c);
 
 
#define BAUD_RATE 38400 //Baud Rate für die Serielle Schnittstelle
 
 
#endif //_UART_H