Zaslal: st březen 13 2013, 9:06 Předmět: PIC 30F3013
Dobrý den,
začínám programovat tento procesor v assembleru a chtěl bych se zeptat zkušenějších jak poznám jestli instrukce počítá se znaménkem nebo bez?Například mám instrukci ADDC W0,W0,W0 a někdy se nastaví příznak N a OV a C zůstane log0. Předpokládám že jde o přetečení do znaménka. U popisu instrukcí jsem nenašel jestli počítají se znaménkem, nebo bez. Jak to tedy je, počítají všechny instrukce znaménkově, nebo záleží na operandech a nebo se to dá někde nastavit? Dále bych se chtěl zeptat jaký je přesný význam příznaků Carry a Overflow. Děkuji.
Nevím, jak je to zrovna u tohoto PICu, ale většinou (6502, 8080, 8086, PIC16F84) to bývá takto:
Ta instrukce ADD je jedna a funguje jak znaménkově (v doplňkovém kódu), tak neznaménkově.
Výsledek je totiž v obou případech stejný.
Liší se pouze to, jak poznat přetečení.
Pokud sčítáš bez znaménka, poznáš přetečení podle C=1 (C je carry).
Na tom asi není nic překvapivého.
Pokud sčítáš se znaménkem, poznáš přetečení podle O=1 (O je overflow).
Bývá tam ještě příznak N (někdy se možná značí S), do kterého se dává nejvyšší bit výsledku, takže pokud počítáš znaménkově, poznáš tak, že výsledek je záporný.
To O (overflow) se, myslím, nastavuje tehdy, pokud sečteš nezáporná čísla a vyjde záporné, nebo sečteš záporná a vyjde nezáporné.
Jinak snad nemůže nastat.
A procesor to počítá snad tak, že se přenos do nejvyššího řádu liší od přenosu z nejvyššího řádu.
To je asi dobré vědět, kdybys sčítal delší čísla pomocí více instrukcí.
Stejně se pak postupuje při porovnávání čísel.
Instrukce na porovnání je jedna - cmp, sub apod.
Pak ale použiješ jinou instrukci skoku pro znaménkové a pro neznaménkové porovnání.
Díky za odpověď,
teď po vysvětlení co je to overflow už je mi jasný že ADD a SUB budou fungovat stejně pro znaménkové i neznaménkové číslo. Já myslel že to musí procesor nějak vědět, protože těch výpočetních instrukcí je víc a mě dělala problém ještě instrukce porovnání se skokem CPSGT a CPSLT. Teď jsem znovu pročetl manuál a zjistil jsem že se ta instrukce jmenuje signed compare, skip if..., takže jsem podle rady vyzkoušel CP a test carry a chodí to jak potřebuju. Další výpočetní instrukce jsou dělení a násobení a tam je to také obsaženo v názvu instrukce. Takže problém vyřešen, děkuji.
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
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.