Vítejte na Elektro Bastlírn?
Nuke - Elektro Bastlirna
  Vytvořit účet Hlavní · Fórum · DDump · Profil · Zprávy · Hledat na fóru · Příspěvky na provoz EB

Vlákno na téma KORONAVIRUS - nutná registrace


Nuke - Elektro Bastlirna: Diskuzní fórum

 FAQFAQ   HledatHledat   Uživatelské skupinyUživatelské skupiny   ProfilProfil   Soukromé zprávySoukromé zprávy   PřihlášeníPřihlášení 

PIC - RS323 - ztráta komunikace - ošetření programu

 
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů
Zobrazit předchozí téma :: Zobrazit následující téma  
Autor Zpráva
Jirka



Založen: Jul 01, 2005
Příspěvky: 2031
Bydliště: zbídačený kraj

PříspěvekZaslal: st červenec 30 2008, 16:42    Předmět: PIC - RS323 - ztráta komunikace - ošetření programu Citovat

Pro komunikaci PIC16F628A přes RS232 s připojeným zařízením používám tuto rutinu http://www.piclist.com/techref/microchip/16F/628/UARTtest.htm .
Má ale takový háček. Pokud je připojené zařízení nedostupné (off-line, vypnuté) a procesor odešle dotaz do zařízení, marně čeká na odpověď, a program (procesor) vytuhne.

Jak jednoduše ošetřit, aby, např. po dvou vteřinách, co marně čeká na odpověď, procesor signalizoval chybu připojeného zařízení a dále pokračoval ve své činnosti?

_________________
*****
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
ZdenekHQ
Administrátor


Založen: Jul 21, 2006
Příspěvky: 25741
Bydliště: skoro Brno

PříspěvekZaslal: st červenec 30 2008, 17:11    Předmět: Citovat

Přidej do čekací RX smyčky čítač a čekací smyčku tak, aby se čítač incrementoval např. po 1ms. Po přetečení nastavit nějakej bit a "return".

V principu je to blbě, tohle se má řešit přes přerušení, buffer a jeho vyhodnocení po každým příjmu znaku. Hlavní program ať si mezi tím dělá, co chce. I kdyby měl jenom čekat na správnej obsah bufferu.

_________________
Pro moje oslovení klidně použijte jméno Zdeněk
Správně navržené zapojení je jako recept na dobré jídlo.
Můžete vynechat půlku ingrediencí, nebo přidat jiné,
ale jste si jistí, že vám to bude chutnat[?
]
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
ZdenekHQ
Administrátor


Založen: Jul 21, 2006
Příspěvky: 25741
Bydliště: skoro Brno

PříspěvekZaslal: st červenec 30 2008, 17:17    Předmět: Citovat

Mimochodem - dobrý je,když dalším časovačem se maže celej buffer, pokud nepřijde další znak do x milisekund a samozřejmě smazat buffer po přijmutí kompletní odpovědi.
_________________
Pro moje oslovení klidně použijte jméno Zdeněk
Správně navržené zapojení je jako recept na dobré jídlo.
Můžete vynechat půlku ingrediencí, nebo přidat jiné,
ale jste si jistí, že vám to bude chutnat[?
]
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
Kado



Založen: Oct 27, 2007
Příspěvky: 44
Bydliště: PB, SVK

PříspěvekZaslal: st červenec 30 2008, 17:19    Předmět: Citovat

Mozes to spravit tak, ze pouzijes prerusenie od casovaca, pricom pri odoslani spravy do pc zapnes casovac, pricom cakas az napocita do definovanej hodnoty, kt. signalizuje chybu.
takto: v preruseni od c/c inkrementujes premennu (napr. prerusenie kazdych 0,1sec)
v rutine "receive" hned na zaciatku testujes premennu ci nedosiahla (alebo nie je vacsia) ako dana hodnota /napr. cakanie 2sec a prerusenie kazdych 0,1sec je to hodnota #20) ak nedosiahla premenna danu hodnotu, tak citas priznak (neviem co to je u PIC, asi priznak plneho prijim. registra), potom skok na receive a zasa test nasej premennej, a ak dosiahla stanovenu hodnotu resp. prekrocila, tak skok na nejake navestie "receive_error", kde vypnes casovac a vypises spravu, ze time_out err (alebo nieco podobne) a opustis rutinu.
EDIT:uz ma predbehli
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Jirka



Založen: Jul 01, 2005
Příspěvky: 2031
Bydliště: zbídačený kraj

PříspěvekZaslal: st červenec 30 2008, 17:25    Předmět: Citovat

ZdenekHQ napsal(a):

Takže myslíš tady do kódu vložit ten čítač a vyhodnocovat ho?
kód:
; -------------------------------------------
; RECEIVE CHARACTER FROM RS232 AND STORE IN W
; -------------------------------------------
; This routine does not return until a character is received.
;
receive btfss PIR1,RCIF         ; (5) check for received data

            ; SEM VLOŽIT ČÍTAČ

        goto Receive

        movf RCREG,W            ; save received data in W
        return
;
; -------------------------------------------------------------

_________________
*****
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
Jirka



Založen: Jul 01, 2005
Příspěvky: 2031
Bydliště: zbídačený kraj

PříspěvekZaslal: st červenec 30 2008, 17:37    Předmět: Citovat

Kado napsal(a):

Asi to chápu, to je v podstatě stejný, jak psal ZdenekHQ

Zkusím se s tím poprat...

_________________
*****
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
ZdenekHQ
Administrátor


Založen: Jul 21, 2006
Příspěvky: 25741
Bydliště: skoro Brno

PříspěvekZaslal: st červenec 30 2008, 17:48    Předmět: Citovat

Já jsem zvyklej na Atmel, takže s asm z PIC mám trošku problémy.. Ale myslím, že ano, dáš tam incrementaci čítače + vložíš čekací smyčku, abys nemusel při rychlosti procesoru čítat moc velký čísla. Ale jde to i přes ten čítač v přerušení, volanej např. po 1ms a nulovanej po příjmu znaku.

Tu popsanou metodu jsem použil na průmyslové mašině s komunikací MODBUS, trápili to, čím se dalo a měli 0 procent chyb. Ovšem tam se používá CRC, i když např. při délce zprávy 3 byty a 2-bytovém CRC jsem našel kolizi dat...

EDIT : Teď jsem se na to mrkl ještě jednou - důležitý je, aby součástí smyčky bylo jak vyhodnocení příjmu znaku, tak ten čítač ! Tady se mě to nějak nezdá...

_________________
Pro moje oslovení klidně použijte jméno Zdeněk
Správně navržené zapojení je jako recept na dobré jídlo.
Můžete vynechat půlku ingrediencí, nebo přidat jiné,
ale jste si jistí, že vám to bude chutnat[?
]
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
Marie Fůrie
Neregistrovaný





PříspěvekZaslal: st červenec 30 2008, 18:08    Předmět: Citovat

Já to většinou řeším pomocí hw časovače, nastavím ho třeba na 20ms a v přerušení inkrementuju proměnnou (bez přetékání). Např. 8bit proměnná mi dá něco přes 5s. Kdykoliv pak potřebuji ošetřit timeout, proměnnou vynuluji a pak ji testuji na potřebnou hodnotu (třeba 100 pro 2s).
Návrat nahoru
Zobrazit příspěvky z předchozích:   
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů Časy uváděny v GMT + 1 hodina
Strana 1 z 1

 
Přejdi na:  
Nemůžete odesílat nové téma do tohoto fóra.
Nemůžete odpovídat na témata v tomto fóru.
Nemůžete upravovat své příspěvky v tomto fóru.
Nemůžete mazat své příspěvky v tomto fóru.
Nemůžete hlasovat v tomto fóru.
Nemůžete připojovat soubory k příspěvkům
Můžete stahovat a prohlížet přiložené soubory

Powered by phpBB © 2001, 2005 phpBB Group
Forums ©
Nuke - Elektro Bastlirna

Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.


PHP-Nuke Copyright © 2005 by Francisco Burzi. This is free software, and you may redistribute it under the GPL. PHP-Nuke comes with absolutely no warranty, for details, see the license.
Čas potřebný ke zpracování stránky 0.14 sekund