update to own SPI lib

This commit is contained in:
Mats van Reenen 2020-05-22 16:49:09 +02:00
parent 305aacc83f
commit 977c26b2ca
2 changed files with 30 additions and 48 deletions

View File

@ -5,10 +5,12 @@
Lightly modified by Frank Milburn
Lightly modified by Roy Bakker C++ --> C
Released into the public domain
Lightly modified by Mats van Reenen: use other SPI interface
*/
#include <Mfrc522.h>
#include <SPI.h>
//#include <SPI2.h>
void RC522_init(int chipSelectPin, int NRSTPD)
{
@ -46,12 +48,20 @@ void RC522_init(int chipSelectPin, int NRSTPD)
*/
void RC522_writeReg(unsigned char addr, unsigned char val)
{
P1OUT &= ~(_chipSelectPin);
SPIInitSend(_chipSelectPin, SPI_Mode0, SPI_Clock_4MHz);
SPI_transfer((addr<<1)&0x7E);
SPI_transfer(val);
SPI_packet[3] = (addr<<1)&0x7E;
SPI_packet[4] = val;
SPI_packetC = 3;
P1OUT |= _chipSelectPin;
SPISend();
// P1OUT &= ~(_chipSelectPin);
// SPI_transfer((addr<<1)&0x7E);
// SPI_transfer(val);
// P1OUT |= _chipSelectPin;
}
/*
@ -62,15 +72,25 @@ void RC522_writeReg(unsigned char addr, unsigned char val)
*/
unsigned char RC522_readReg(unsigned char addr)
{
unsigned char val;
P1OUT &= ~(_chipSelectPin);
SPIInitSend(_chipSelectPin, SPI_Mode0, SPI_Clock_4MHz);
SPI_transfer(((addr<<1)&0x7E) | 0x80);
val = SPI_transfer(0x00);
SPI_packet[3] = ((addr<<1)&0x7E) | 0x80;
SPI_packet[4] = 0;
SPI_packetC = 3;
P1OUT |= _chipSelectPin;
SPISend();
return val;
return SPI_packet[4];
// unsigned char val;
// P1OUT &= ~(_chipSelectPin);
// SPI_transfer(((addr<<1)&0x7E) | 0x80);
// val = SPI_transfer(0x00);
// P1OUT |= _chipSelectPin;
// return val;
}
/*

38
SPI2.h
View File

@ -1,38 +0,0 @@
#ifndef _SPI_H_INCLUDED
#define _SPI_H_INCLUDED
#include <msp430.h>
#include <inttypes.h>
inline static void SPI_begin();
inline static uint8_t SPI_transfer(uint8_t data);
inline static void SPI_end();
void SPI_begin(void) {
/* Configure P1.5, 1.6, 1.7 for SPI. */
P1SEL |= (BIT5 | BIT6 | BIT7);
P1SEL2 |= (BIT5 | BIT6 | BIT7);
/* Setup SPI on USCI B */
UCB0CTL1 = (UCSSEL_2 | UCSWRST); // SMCLK + Reset
UCB0CTL0 = (UCCKPL | UCMSB | UCMST | UCSYNC); // 3-pin, 8-bit SPI master
UCB0BR0 = 8; // /8
UCB0BR1 = 0; //
UCB0CTL1 &= ~UCSWRST; // release USCI for operation
}
uint8_t SPI_transfer(uint8_t data) {
UCB0TXBUF = data; // Setting TXBUF clears the TXIFG
while(UCB0STAT & UCBUSY); // wait for SPI TX/RX to finish
return UCB0RXBUF; // Reading clears RXIFG
}
void SPI_end()
{
UCB0CTL1 |= UCSWRST; // Put USCI in reset mode
}
#endif