Forum: Mikrocontroller und Digitale Elektronik PIC BRA vs GOTO


von Kijan (Gast)


Lesenswert?

Hi leutz
Ich wollte mein Programm von einem 18F auf ein 16F portieren (aus 
Kosten- und Platzgründen).
Jetzt bin ich grad beim Überprüfen des Befehlssatzes.
Ich hab in meinem Programm BRA benutzt. Dieses hat der 16F aber nicht.
GOTO scheint das gleiche zu machen. Es soll irgendwie BRA ein relativer 
Sprung und GOTO ein absoluter Sprung sein. Und BRA hat ein Wort und GOTO 
2.

Aber was heißt das für mich? Ich hab den Unterschied nicht ganz 
verstanden.
Währe schön wenn mich jemand aufklären könnte.

MFG
Kijan

von (prx) A. K. (prx)


Lesenswert?

Das ROM der PIC16 ist banked. PIC18 nicht. D.h. PIC18 kann mit GOTO/CALL 
überall hin springen, PIC16 nicht. Dort muss für Sprünge zwischen den 
Banks vor dem Sprung die Ziel-Bank in Form irgendwelcher Statusbits 
definiert werden.

http://www.sprut.de/electronic/pic/grund/adress.htm#call

Das hat sehr interessante Konsequenzen für die Organisation des Codes, 
d.h. die Verteilung der Funktionen auf die Banks (Pages) muss sorgfältig 
geplant werden.

Wem Zeit Geld ist, der steigt nicht von PIC18 auf PIC16 um, es sei denn 
es geht um grosse Stückzahlen.

von Kijan (Gast)


Lesenswert?

Hi
Danke für deine Antwort.
In dem Beispiel steht was von ORG und ne Adresse.
Ich hab bei meinen Sprüngen momentan kein ORG. Müsst ich jetzt zu jeder 
Marke so einen ORG befehl packen? Um dann somit zu sagen wo sie liegen?

von (prx) A. K. (prx)


Lesenswert?

Ich denke, du solltest mal PIC16 Assembler von Grund auf lernen, bevor 
dur die Portierung durchführst. Komplett frei von jeder Kenntnis sowohl 
der PIC16 als auch der PIC18 ist das ziemlich aussichtslos.

Die PICs sind so konstruiert, dass man mit endlichem Aufwand vom Kleinen 
zum Grossen migrieren kann. Umgekehrt wird hart.

von Kijan (Gast)


Lesenswert?

Ganz ohne Kenntnisse bin ich ja nicht. Also zumindest was 18F angeht. 
Habe das Programm ja selber geschrieben. Nur wollte ich es halt auf den 
16F portieren da der eigentlich ausreicht.
Klar werd ich mich da noch mal reinknien müssen in den 16F.
Ich wollt ja erst mal nur wissen warum es halt 2 Befehle für einen 
Sprung gibt. Warum hat der 18F eigentlich GOTO und dazu noch BRA.

von Peter D. (peda)


Lesenswert?

A. K. schrieb:
> Die PICs sind so konstruiert, dass man mit endlichem Aufwand vom Kleinen
> zum Grossen migrieren kann. Umgekehrt wird hart.

Ja, das ist ein großer Nachteil, daß die PICs so große Unterschiede im 
Befehlssatz haben.

Bei den AVRs haben dagegen alle vom 6-Pinner bis 100-Pinner den gleichen 
Befehlssatz (außer dem MUL-Befehl bei >= 28-Pinnern).


Peter

von (prx) A. K. (prx)


Lesenswert?

Kijan schrieb:

> Warum hat der 18F eigentlich GOTO und dazu noch BRA.

Platzersparnis. BRA ist kürzer, dafür ist die Reichweite geringer.

von (prx) A. K. (prx)


Lesenswert?

Kijan schrieb:

> In dem Beispiel steht was von ORG und ne Adresse.

Das ORG steht dort im Beispiel nur als Indikator für den Wert einer 
Zieladresse ausserhalb der aktuellen Page/Bank.

von Kijan (Gast)


Lesenswert?

A. K. schrieb:
> Kijan schrieb:
>
>
>
>> In dem Beispiel steht was von ORG und ne Adresse.
>
>
>
> Das ORG steht dort im Beispiel nur als Indikator für den Wert einer
>
> Zieladresse ausserhalb der aktuellen Page/Bank.

Also wenn ich das richtig verstehe muss ich halt immer die richtige Bank 
ansprechen zu der ich hinspringen will.
Wenn aber dieser ORG Befehl eine Adresse außerhalb der aktuellen Bank 
angiebt, muss ich dann immer noch die richtige Bank ansprechen?

von (prx) A. K. (prx)


Lesenswert?

Im Sprut-Link steht es doch haarklein drin was man tun muss. Man muss 
wissen, ob das Sprungziel in der aktuellen Bank oder einer anderen Bank 
liegt. Befindet es sich in einer anderen Bank, dann muss man vor dem 
Sprung (GOTO/CALL) die PCLATH Bits entsprechend setzen.

Noch detaillierter gibt's das nur noch bei PIC Spezialisten - ich selbst 
bin keiner, ich habe nur einen ungefähren Überblick über deren 
Arbeitsweise. Bei fernando-heitor.de gibt es mehr davon als hier.

von Peter D. (peda)


Lesenswert?

Ich würde das PCLATH immer setzen, dann ist der Code verschieblich.
Ansonsten, Du fügst irgendwo was ein und es kracht.


Peter

von Master S. (snowman)


Lesenswert?

nur mal eine zwischenfrage: hast du auch mal den blick zu den PIC24er 
gewagt? die gibt's auch ganz schön klein und sind oft preislich 
attraktiver als die 18er, jedoch 3.3V ..ist nur so eine idee ;-)

von Stephan_ (Gast)


Lesenswert?

Warum willst Du den von PIC18 zu PIC16 wechseln? Platzgründe: die 18er 
gibt es auch mit 18 und 20 PINs und teuer sind die kleinen 18er auch 
nicht. Dafür viel mächtiger und einfacher zu programmieren. Die Arbeit 
die Du ins Umprogrammieren steckst kostet Dich einige Zeit!

von Kijan (Gast)


Lesenswert?

Master Snowman schrieb:
> nur mal eine zwischenfrage: hast du auch mal den blick zu den PIC24er
>
> gewagt? die gibt's auch ganz schön klein und sind oft preislich
>
> attraktiver als die 18er, jedoch 3.3V ..ist nur so eine idee ;-)

Naja die Hardware ist im Moment auf 5V ausgelegt daher würd ich gern 
dabei bleiben :)

Stephan_ schrieb:
> Warum willst Du den von PIC18 zu PIC16 wechseln? Platzgründe: die 18er
>
> gibt es auch mit 18 und 20 PINs und teuer sind die kleinen 18er auch
>
> nicht. Dafür viel mächtiger und einfacher zu programmieren. Die Arbeit
>
> die Du ins Umprogrammieren steckst kostet Dich einige Zeit!

Der Hauptgrund ist, dass ich in meiner Prüfung wahrscheinlich mit dem 
16F84 konfontriert werde, und somit währe dass dann schon mal als erste 
Schritte dahingehend zu sehen.

von Kijan (Gast)


Lesenswert?

Ich habs mir noch einmal überlegt.
Das mit den kleineren 18F hab ich nicht gewusst...
Ich werd es wohl mal mit dem 18F320 probieren.
Mal schauen in wie weit ich da was ändern muss.

von PIC (Gast)


Lesenswert?

Ich würde auf deiner stelle mit C anfangen. Nur vorteile ;-)
Compiler wie Hi-Tech PIC10/12/16 sind da die richtigen, aber die STD 
version vervenden, die PRO haben vielzuviele BUGs, Wenn du aber erstmal 
lernen willst, dann würde ich dir MikroC Pro vorschlagen.
Später kannst du dir aussuchen :
Hitech,
C18/C30
oder MikroC

von Master S. (snowman)


Lesenswert?

@Kijan: wenn du platz sparen willst und ein exakter takt nicht so 
wichtig ist, nimm einen der nach dem 'PIC18F' vier stellen hat z.b. 
PIC18F1320, die haben meist/immer(?) einen internen 8MHz-oszillator.
hier eine übersicht:
http://www.microchip.com/ParamChartSearch/chart.aspx?mid=10&lang=en&branchID=1004

von Jens (Gast)


Lesenswert?

@ Kijan (Gast)

Mit GOTO kannst du die Sprungweite von BRA auf jeden Fall abdecken. 
Allerdings würde ich nicht mehr downgraden wollen. Es sind zuviele Ecken 
und Kanten zu umschiffen. Register sind anders belegt und werden anders 
angesteuert (Stichwort Banking), etc.

Ansonsten viel Erfolg beim downgraden. Das "viel Spaß" verkneife ich mir 
mal, denn Spaß macht es bestimmt keinen.

von stepp64 (Gast)


Lesenswert?

Und dann noch auf den 16F84 den Großvater der PICs. Der bietet so 
ziemlich gar nichts und es wird wohl sehr schwer werden ein 18F Programm 
auf diesen zu portieren. Du wirst ja bei den 16F nicht nur mit dem 
Pageing konfrontiert sondern auch noch mit dem Banking. Weiterhin fehlen 
dir ca. 40 Befehle, da die 16F nur ca. 35 Befehle kennen und die 18F 
knapp 80. Du hast weniger Timer zur Verfügung, Speicher (sowohl RAM als 
auch Flash) sind ebenfalls wesentlich weniger. Und es gibt Fallen, 
welche bei den 18F beseitigt wurden (z.Bsp. die Portfalle). Also das 
sind schon einige Nachteile.

Wenn du aber üben willst, dann würde ich mir den 16F84 nehmen und damit 
ein paar kleinere Programme schreiben.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.