Atmega8 - použití reset pinu jako výstupu
Moderátor: Moderátoři
Atmega8 - použití reset pinu jako výstupu
Zdravím. Poradili byste mi prosím, jak v prostředí arduino IDE ovládat pin atmegy8 č.1 (reset) jako výstup? Potřebuji v setup() nadefinovat pin jako výstupní a pak jej v loop() ovládat. Jde mi jen o fragmenty kódu v jazyku C, které by šly použít v programovacím prostředí arduino IDE. Pojistky přepínat umím a vysokonapěťově mazat obvod umím též. Ale jazyk C se teprve učím...
Úplně jednoduše to nejde, Arduino tento port "nemapuje", aby šel ovládat pomocí pinMode(), digitalWrite(), ...
Musíš buď pomocí PINC, DDRC a PORTC nebo upravit zdrojové texty Arduina. Konkrétně v pins_arduino.h dvě konstanty PROGMEM digital_pin_to_port_PGM[] a PROGMEM digital_pin_to_bit_mask_PGM[]
V této úpravě je navíc ještě pin 20 a 21 namapován na PB6 a PB7 (XTAL1, XTAL2) pro desky, které používají interní RC oscilátor. PC6 (RESET) je pak pin 22.
Nezapomeň, že jakmile pomocí fuses "odstavíš" reset, tak nenahraješ nic přes bootloader ani přes ISP.
Musíš buď pomocí PINC, DDRC a PORTC nebo upravit zdrojové texty Arduina. Konkrétně v pins_arduino.h dvě konstanty PROGMEM digital_pin_to_port_PGM[] a PROGMEM digital_pin_to_bit_mask_PGM[]
Kód: Vybrat vše
const uint8_t PROGMEM digital_pin_to_port_PGM[] = {
PD, /* 0 */
PD,
PD,
PD,
PD,
PD,
PD,
PD,
PB, /* 8 */
PB,
PB,
PB,
PB,
PB,
PC, /* 14 */
PC,
PC,
PC,
PC,
PC,
PB, /* 20 - PB6 */
PB, /* 21 - PB7 */
PC, /* 22 - PC6 */
};
const uint8_t PROGMEM digital_pin_to_bit_mask_PGM[] = {
_BV(0), /* 0, port D */
_BV(1),
_BV(2),
_BV(3),
_BV(4),
_BV(5),
_BV(6),
_BV(7),
_BV(0), /* 8, port B */
_BV(1),
_BV(2),
_BV(3),
_BV(4),
_BV(5),
_BV(0), /* 14, port C */
_BV(1),
_BV(2),
_BV(3),
_BV(4),
_BV(5),
_BV(6), /* 20 - PB6 */
_BV(7), /* 21 - PB7 */
_BV(6), /* 22 - PC6 */
};
Nezapomeň, že jakmile pomocí fuses "odstavíš" reset, tak nenahraješ nic přes bootloader ani přes ISP.
- ross4435897
- Příspěvky: 426
- Registrován: 10 lis 2009, 01:00
- Bydliště: Brno
Takto by to šlo, jenom bych čistě pro přehlednost zapsal:
DDRC |= (1<<PC6);
PINC použiješ jenom v případě kdyby příslušný pin byl vstupní (odpovídá funkci digitalRead() ).
To fakt už nemáš žádnou další volnou nožičku, že se chceš vzdát všech výhod ISP ? Budeš muset pokaždé vyndavat procesor ... Co spíš zvolit variantu s interním RC oscilátorem a použít PB6 a PB7 ? Osobně jsem se vždy "ubránil" odstavení resetu.
DDRC |= (1<<PC6);
PINC použiješ jenom v případě kdyby příslušný pin byl vstupní (odpovídá funkci digitalRead() ).
To fakt už nemáš žádnou další volnou nožičku, že se chceš vzdát všech výhod ISP ? Budeš muset pokaždé vyndavat procesor ... Co spíš zvolit variantu s interním RC oscilátorem a použít PB6 a PB7 ? Osobně jsem se vždy "ubránil" odstavení resetu.
Atmegou řídím přímo dva dvojité displeje (viz. http://www.elweb.cz/clanky.php?clanek=105 , zde je to řízené PICem) a v tomto řešení moc místa na optimálnější propojení nebylo - na rozdíl od článku jsem na jednotlivé segmenty ještě i dával smd odpory, ale i tak se mi to málem na danou velikost desky nevešlo. Naštěstí mám na resetu desetinnou tečku, takže to nebrání ladění i bez ní, ovládat jí budu až na závěr. Vím, že je třeba pro nové naprogramování čip nejdříve vysokonapěťově smazat, eraser na to mám a používám ho.FHonza píše:Takto by to šlo, jenom bych čistě pro přehlednost zapsal:
DDRC |= (1<<PC6);
PINC použiješ jenom v případě kdyby příslušný pin byl vstupní (odpovídá funkci digitalRead() ).
To fakt už nemáš žádnou další volnou nožičku, že se chceš vzdát všech výhod ISP ? Budeš muset pokaždé vyndavat procesor ... Co spíš zvolit variantu s interním RC oscilátorem a použít PB6 a PB7 ? Osobně jsem se vždy "ubránil" odstavení resetu.
Při ladění jsem narazil ještě na jeden zajímavý problém - prostředí IDE mi brání použít přerušení od timeru0, protože ho používá a definuje soubor wiring.c. Při pokusu o vytvoření obsluhy přerušení ISR(TIMER0_OVF_vect) mi prostředí IDE píše problém s dvojí deklarací. Nevíte, co s tím? Jak jinak udělat programově přerušení od přetečení čítače v prostředí IDE pro atmega8, pokud nechci prostředí IDE modifikovat? U atmega328p to jde, ale to má interruptů od přetečení čítačů víc...
MAX7219 používám, je to skvělá součástka pro řízení displeje. Mne ale problém s přerušením zaujal hlavně proto, že bych rád uměl na atmega8 s přerušením pracovat. Jak prosím nadefinovat ten timer2 v arduino IDE, aby přerušoval přetečením? Mi se to bohužel nepodařilo...FHonza píše:Co použít Timer2 ? Ten je použit pouze funkcí tone().
Osobně bych místo "obsazení" resetu použil MAX7219 a řídil ty segmentovky po třech drátech. Nebo zapoj všechny čtyři segmenty na společný multiplex.
MAX7219 ti můžu poslat (jak v DIL, tak SMD)
Wow, skvělé. Už to funguje:FHonza píše:Stejně: ISR(TIMER2_OVF_vect)
nebo se dá použít knihovna MsTimer2. Definuje jednoduchý objekt, do kterého se dá "podstrčit" callback funkce. Viz tady
TCCR2 = _BV(CS21) | _BV(CS20);
TIMSK = _BV(TOIE2);
sei();
...
ISR(TIMER2_OVF_vect)
...