Ich habe zwei Mikrocontroller miteinander verbunden.
Mit dem Master schreibe ich Daten, CLock und ein CS heraus. Funktioniert
auch. Leider springt mein Slave (Atmega88) nicht in den Interrupt. Dies
müßte er doch tun wenn er Daten am Miso, CLock am SCK und ein CS (von
high nach Low) bekommt?
Hat jemand eine Idee, was ich falsch mache?
Hier der Quellcode für meinen Slave:
//CPU: ATMega88
//Clock: 8MHz
#include <avr/io.h>
#include <avr/interrupt.h>
#include <avr/wdt.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <avr/eeprom.h>
#include <avr/delay.h>
#define F_CPU 8000000 //CPU-Frequenz
#define USART_BAUD_RATE 9600 //gewählte Baudrate
volatile unsigned char RECEIVE_u8[10]; //SPI-Empfangsarray
//****Portinitialisierung***********************************************
*****
void init_ports(void)
{
//Eingänge SPI
DDRB &= ~ (1<<PB2) | (1 <<PB4) | (1<<PB5); //SPI SS Miso und SCK
als Input
//Ausgänge SPI
DDRB |= (1<<PB3);
}
//************ENDE
Portinitialisierung****************************************
void SPI_Slave_INIT(void)
{
SPCR |= (1<<SPE) | (1<<SPIE);
}
Signal(SIG_SPI) //SPI-Interrupt wenn etwas empfangen wird. Empfangene
Daten in RECEIVE_u8[1]
{
while(!SPSR & (1<<SPIF));
RECEIVE_u8[1] = SPDR;
}
int main (void)
{
init_ports(); //Portinitialisierung
sei(); //Globale Interrupts aktiviert
void SPI_Slave_INIT(); //INIT SPI
while(1)
{
//warten bis etwas empfangen wird
}
}
im code vom slave ist MISO aber kein eingang
>>DDRB &= ~ (1<<PB2) | (1 <<PB4) | (1<<PB5); //SPI SS Miso und SCK
M aster
I n
S lave
O ut
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.