Datum: 13.05.2008 13:55
Hallo! Habe in meinen FPGA einen Lattice Mico32 Soft Core mit einer GPIO (1 Bit) namens "INT" und einer GPIO (8 Bit) namens "LED". Beim Konfigurieren der GPIO INT habe ich "Interrupt INT0 bei positiver Flanke auslösen" gewählt. Ich habe nun Probleme, die ISR zu programmieren. Ich möchte zuerst einmal alle Interrupts zulassen -> MicoEnableInterrupts(0xFFFF) und dann mit MicoRegisterISR die ISR_INT0(){} mit der GPIO INT verbinden... kennt sich jemand damit aus? Leider findet man nirgendwo ein Beispielprogramm....
Datum: 14.05.2008 20:43
Schau mal bei soc-lm32 rein. Da gibt es in spike_hw.h ein Beispiel für eine Timer-ISR, die bei mir funktioniert. Rick
Datum: 15.05.2008 09:23
wo / was ist soc - lm32? Das soc Verzeichnis ist in jedem SoftCore Projektordner... oder meinst du ein Verzeichnis im MSB Installationsordner? Ein Beispiel für den Timer Interrupt habe ich, ein Übertragen des Codes auf einen GPIO Interrupt hat jedoch nicht funktioniert. Deswegen bräuchte ich ein Beispiel speziell für eine GPIO...
Datum: 15.05.2008 10:20
Hallo! Habe die Lösung gerade vom Lattice Support bekommen
#include "DDStructs.h"
#include "LookupServices.h"
#include "stdio.h"
#include "MicoUtils.h"
#include "MicoGPIO.h"
static void myISR( int intrLevel, void * data )
{
static int capValue ;
MicoGPIOCtx_t * my_buttons = (MicoGPIOCtx_t *) data ;
MICO_GPIO_READ_EDGE_CAPTURE(my_buttons,capValue) ;
//printf("printed by ISR, capValue=%x\r\n",capValue);
MICO_GPIO_WRITE_IRQ_MASK(my_buttons,0x00000000);
// ------------------
MICO_GPIO_WRITE_IRQ_MASK(my_buttons,0xffffffff);
return ;
}
int main(void)
{
unsigned int iValue = 0x1, iKeyStatus;
MicoGPIOCtx_t *leds = (MicoGPIOCtx_t *)MicoGetDevice("LED");
MicoGPIOCtx_t *buttons = (MicoGPIOCtx_t *)MicoGetDevice("Button");
MicoRegisterISR(buttons->intrLevel, buttons, myISR);
MICO_GPIO_WRITE_IRQ_MASK(buttons,0xffffffff);
while(1){
*((volatile unsigned int *)(leds->base)) = ~iValue;
MicoSleepMilliSecs(200);
iValue = iValue << 1;
if(iValue == 0x100){
iValue = 0x1;
}
MICO_GPIO_READ_DATA(buttons,iKeyStatus) ;
//printf("printed by main look-up service,
iKeyStatus=%x\r\n",iKeyStatus);
}
return(0);
}
Antwort schreiben
Die Angabe einer Email-Adresse ist freiwillig. Wenn Sie automatisch per Email über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.
Wichtige Regeln - erst lesen, dann posten!
- Suchfunktion und Betreffsuche benutzen - vielleicht gibt es schon einen ähnlichen Beitrag
- Aussagekräftigen Betreff wählen
- Im Betreff angeben um welchen Controllertyp es geht (AVR, PIC, ...)
- Groß- und Kleinschreibung verwenden
- Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang
- JPEG-Dateien (.jpg) nur für Fotos und Scans verwenden
- Schaltpläne, Screenshots usw. als PNG oder GIF anhängen
Formatierung (mehr Informationen...)
- [c]C-Code[/c]
- [avrasm]AVR-Assembler-Code[/avrasm]
- [vhdl]VHDL-Code[/vhdl]
- [pre]vorformatierter Text (z.B. Code in anderen Sprachen)[/pre]
- [math]Formel in LaTeX-Syntax[/math]
- [[Titel]] - Link zu Artikel