mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 18:18:49 -04:00
libraries: rename purple to APM2
This commit is contained in:
parent
e297f0cb23
commit
a9dfc68bc0
@ -52,20 +52,20 @@ extern "C" {
|
|||||||
//{
|
//{
|
||||||
//}
|
//}
|
||||||
|
|
||||||
// the purple hardware needs to check the state of the
|
// the apm2 hardware needs to check the state of the
|
||||||
// chip using a direct IO port
|
// chip using a direct IO port
|
||||||
// On Purple prerelease hw, the data ready port is hooked up to PE7, which
|
// On APM2 prerelease hw, the data ready port is hooked up to PE7, which
|
||||||
// is not available to the arduino digitalRead function.
|
// is not available to the arduino digitalRead function.
|
||||||
#define BMP_DATA_READY() (_purple_hardware?(PINE&0x80):digitalRead(BMP085_EOC))
|
#define BMP_DATA_READY() (_apm2_hardware?(PINE&0x80):digitalRead(BMP085_EOC))
|
||||||
|
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
bool APM_BMP085_Class::Init(int initialiseWireLib, bool purple_hardware)
|
bool APM_BMP085_Class::Init(int initialiseWireLib, bool apm2_hardware)
|
||||||
{
|
{
|
||||||
byte buff[22];
|
byte buff[22];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
_purple_hardware = purple_hardware;
|
_apm2_hardware = apm2_hardware;
|
||||||
|
|
||||||
pinMode(BMP085_EOC, INPUT); // End Of Conversion (PC7) input
|
pinMode(BMP085_EOC, INPUT); // End Of Conversion (PC7) input
|
||||||
|
|
||||||
|
@ -19,10 +19,10 @@ class APM_BMP085_Class
|
|||||||
int32_t Press;
|
int32_t Press;
|
||||||
//int Altitude;
|
//int Altitude;
|
||||||
uint8_t oss;
|
uint8_t oss;
|
||||||
bool _purple_hardware;
|
bool _apm2_hardware;
|
||||||
//int32_t Press0; // Pressure at sea level
|
//int32_t Press0; // Pressure at sea level
|
||||||
|
|
||||||
bool Init(int initialiseWireLib = 1, bool purple_hardware=false);
|
bool Init(int initialiseWireLib = 1, bool apm2_hardware=false);
|
||||||
uint8_t Read();
|
uint8_t Read();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -15,7 +15,7 @@ APM_BMP085_HIL_Class::APM_BMP085_HIL_Class()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
void APM_BMP085_HIL_Class::Init(int initialiseWireLib, bool purple_hardware)
|
void APM_BMP085_HIL_Class::Init(int initialiseWireLib, bool apm2_hardware)
|
||||||
{
|
{
|
||||||
BMP085_State=1;
|
BMP085_State=1;
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,7 @@ class APM_BMP085_HIL_Class
|
|||||||
int32_t Press;
|
int32_t Press;
|
||||||
//int Altitude;
|
//int Altitude;
|
||||||
uint8_t oss;
|
uint8_t oss;
|
||||||
void Init(int initialiseWireLib = 1, bool purple_hardware=false);
|
void Init(int initialiseWireLib = 1, bool apm2_hardware=false);
|
||||||
uint8_t Read();
|
uint8_t Read();
|
||||||
void setHIL(float Temp, float Press);
|
void setHIL(float Temp, float Press);
|
||||||
int32_t _offset_press;
|
int32_t _offset_press;
|
||||||
|
@ -13,10 +13,10 @@ unsigned long timer;
|
|||||||
|
|
||||||
FastSerialPort0(Serial);
|
FastSerialPort0(Serial);
|
||||||
|
|
||||||
#ifdef PURPLE_HARDWARE
|
#ifdef APM2_HARDWARE
|
||||||
static bool purple_hardware = true;
|
static bool apm2_hardware = true;
|
||||||
#else
|
#else
|
||||||
static bool purple_hardware = false;
|
static bool apm2_hardware = false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
@ -24,7 +24,7 @@ void setup()
|
|||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
Serial.println("ArduPilot Mega BMP085 library test");
|
Serial.println("ArduPilot Mega BMP085 library test");
|
||||||
Serial.println("Initialising barometer..."); delay(100);
|
Serial.println("Initialising barometer..."); delay(100);
|
||||||
if (!APM_BMP085.Init(1, purple_hardware)) {
|
if (!APM_BMP085.Init(1, apm2_hardware)) {
|
||||||
Serial.println("Barometer initialisation FAILED\n");
|
Serial.println("Barometer initialisation FAILED\n");
|
||||||
}
|
}
|
||||||
Serial.println("initialisation complete."); delay(100);
|
Serial.println("initialisation complete."); delay(100);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BOARD = mega
|
BOARD = mega
|
||||||
include ../../../AP_Common/Arduino.mk
|
include ../../../AP_Common/Arduino.mk
|
||||||
|
|
||||||
purple:
|
apm2:
|
||||||
make -f Makefile EXTRAFLAGS="-DPURPLE_HARDWARE=1"
|
make -f Makefile EXTRAFLAGS="-DAPM2_HARDWARE=1"
|
||||||
|
@ -46,6 +46,6 @@ class APM_RC_Class
|
|||||||
};
|
};
|
||||||
|
|
||||||
#include "APM_RC_APM1.h"
|
#include "APM_RC_APM1.h"
|
||||||
#include "APM_RC_Purple.h"
|
#include "APM_RC_APM2.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
APM_RC_Purple.cpp - Radio Control Library for Ardupilot Mega 2.0. Arduino
|
APM_RC_APM2.cpp - Radio Control Library for Ardupilot Mega 2.0. Arduino
|
||||||
Code by Jordi Muñoz and Jose Julio. DIYDrones.com
|
Code by Jordi Muñoz and Jose Julio. DIYDrones.com
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
This library is free software; you can redistribute it and/or
|
||||||
@ -18,7 +18,7 @@
|
|||||||
Automatically resets when we call InputCh to read channels
|
Automatically resets when we call InputCh to read channels
|
||||||
|
|
||||||
*/
|
*/
|
||||||
#include "APM_RC_Purple.h"
|
#include "APM_RC_APM2.h"
|
||||||
|
|
||||||
#include "WProgram.h"
|
#include "WProgram.h"
|
||||||
|
|
||||||
@ -27,13 +27,13 @@
|
|||||||
#else
|
#else
|
||||||
|
|
||||||
// Variable definition for Input Capture interrupt
|
// Variable definition for Input Capture interrupt
|
||||||
volatile uint16_t APM_RC_Purple::_PWM_RAW[NUM_CHANNELS] = {2400,2400,2400,2400,2400,2400,2400,2400};
|
volatile uint16_t APM_RC_APM2::_PWM_RAW[NUM_CHANNELS] = {2400,2400,2400,2400,2400,2400,2400,2400};
|
||||||
volatile uint8_t APM_RC_Purple::_radio_status=0;
|
volatile uint8_t APM_RC_APM2::_radio_status=0;
|
||||||
|
|
||||||
/****************************************************
|
/****************************************************
|
||||||
Input Capture Interrupt ICP5 => PPM signal read
|
Input Capture Interrupt ICP5 => PPM signal read
|
||||||
****************************************************/
|
****************************************************/
|
||||||
void APM_RC_Purple::_timer5_capt_cb(void)
|
void APM_RC_APM2::_timer5_capt_cb(void)
|
||||||
{
|
{
|
||||||
static uint16_t prev_icr;
|
static uint16_t prev_icr;
|
||||||
static uint8_t frame_idx;
|
static uint8_t frame_idx;
|
||||||
@ -68,12 +68,12 @@ void APM_RC_Purple::_timer5_capt_cb(void)
|
|||||||
|
|
||||||
// Constructors ////////////////////////////////////////////////////////////////
|
// Constructors ////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
APM_RC_Purple::APM_RC_Purple()
|
APM_RC_APM2::APM_RC_APM2()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
void APM_RC_Purple::Init( Arduino_Mega_ISR_Registry * isr_reg )
|
void APM_RC_APM2::Init( Arduino_Mega_ISR_Registry * isr_reg )
|
||||||
{
|
{
|
||||||
// --------------------- TIMER1: OUT1 and OUT2 -----------------------
|
// --------------------- TIMER1: OUT1 and OUT2 -----------------------
|
||||||
pinMode(12,OUTPUT); // OUT1 (PB6/OC1B)
|
pinMode(12,OUTPUT); // OUT1 (PB6/OC1B)
|
||||||
@ -147,7 +147,7 @@ void APM_RC_Purple::Init( Arduino_Mega_ISR_Registry * isr_reg )
|
|||||||
TIMSK5 |= (1<<ICIE5);
|
TIMSK5 |= (1<<ICIE5);
|
||||||
}
|
}
|
||||||
|
|
||||||
void APM_RC_Purple::OutputCh(unsigned char ch, uint16_t pwm)
|
void APM_RC_APM2::OutputCh(unsigned char ch, uint16_t pwm)
|
||||||
{
|
{
|
||||||
pwm=constrain(pwm,MIN_PULSEWIDTH,MAX_PULSEWIDTH);
|
pwm=constrain(pwm,MIN_PULSEWIDTH,MAX_PULSEWIDTH);
|
||||||
pwm<<=1; // pwm*2;
|
pwm<<=1; // pwm*2;
|
||||||
@ -165,7 +165,7 @@ void APM_RC_Purple::OutputCh(unsigned char ch, uint16_t pwm)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t APM_RC_Purple::InputCh(unsigned char ch)
|
uint16_t APM_RC_APM2::InputCh(unsigned char ch)
|
||||||
{
|
{
|
||||||
uint16_t result;
|
uint16_t result;
|
||||||
uint16_t result2;
|
uint16_t result2;
|
||||||
@ -187,24 +187,24 @@ uint16_t APM_RC_Purple::InputCh(unsigned char ch)
|
|||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char APM_RC_Purple::GetState(void)
|
unsigned char APM_RC_APM2::GetState(void)
|
||||||
{
|
{
|
||||||
return(_radio_status);
|
return(_radio_status);
|
||||||
}
|
}
|
||||||
|
|
||||||
// InstantPWM is not implemented!
|
// InstantPWM is not implemented!
|
||||||
|
|
||||||
void APM_RC_Purple::Force_Out(void) { }
|
void APM_RC_APM2::Force_Out(void) { }
|
||||||
void APM_RC_Purple::Force_Out0_Out1(void) { }
|
void APM_RC_APM2::Force_Out0_Out1(void) { }
|
||||||
void APM_RC_Purple::Force_Out2_Out3(void) { }
|
void APM_RC_APM2::Force_Out2_Out3(void) { }
|
||||||
void APM_RC_Purple::Force_Out6_Out7(void) { }
|
void APM_RC_APM2::Force_Out6_Out7(void) { }
|
||||||
|
|
||||||
/* ---------------- OUTPUT SPEED CONTROL ------------------ */
|
/* ---------------- OUTPUT SPEED CONTROL ------------------ */
|
||||||
// Output rate options:
|
// Output rate options:
|
||||||
#define OUTPUT_SPEED_50HZ 0
|
#define OUTPUT_SPEED_50HZ 0
|
||||||
#define OUTPUT_SPEED_200HZ 1
|
#define OUTPUT_SPEED_200HZ 1
|
||||||
|
|
||||||
void APM_RC_Purple::SetFastOutputChannels(uint32_t chmask)
|
void APM_RC_APM2::SetFastOutputChannels(uint32_t chmask)
|
||||||
{
|
{
|
||||||
if ((chmask & ( MSK_CH_1 | MSK_CH_2 )) != 0)
|
if ((chmask & ( MSK_CH_1 | MSK_CH_2 )) != 0)
|
||||||
_set_speed_ch1_ch2(OUTPUT_SPEED_200HZ);
|
_set_speed_ch1_ch2(OUTPUT_SPEED_200HZ);
|
||||||
@ -216,7 +216,7 @@ void APM_RC_Purple::SetFastOutputChannels(uint32_t chmask)
|
|||||||
_set_speed_ch6_ch7_ch8(OUTPUT_SPEED_200HZ);
|
_set_speed_ch6_ch7_ch8(OUTPUT_SPEED_200HZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
void APM_RC_Purple::_set_speed_ch1_ch2(uint8_t speed)
|
void APM_RC_APM2::_set_speed_ch1_ch2(uint8_t speed)
|
||||||
{
|
{
|
||||||
switch(speed) {
|
switch(speed) {
|
||||||
case OUTPUT_SPEED_200HZ:
|
case OUTPUT_SPEED_200HZ:
|
||||||
@ -229,7 +229,7 @@ void APM_RC_Purple::_set_speed_ch1_ch2(uint8_t speed)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void APM_RC_Purple::_set_speed_ch3_ch4_ch5(uint8_t speed)
|
void APM_RC_APM2::_set_speed_ch3_ch4_ch5(uint8_t speed)
|
||||||
{
|
{
|
||||||
switch(speed) {
|
switch(speed) {
|
||||||
case OUTPUT_SPEED_200HZ:
|
case OUTPUT_SPEED_200HZ:
|
||||||
@ -243,7 +243,7 @@ void APM_RC_Purple::_set_speed_ch3_ch4_ch5(uint8_t speed)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void APM_RC_Purple::_set_speed_ch6_ch7_ch8(uint8_t speed)
|
void APM_RC_APM2::_set_speed_ch6_ch7_ch8(uint8_t speed)
|
||||||
{
|
{
|
||||||
switch(speed) {
|
switch(speed) {
|
||||||
case OUTPUT_SPEED_200HZ:
|
case OUTPUT_SPEED_200HZ:
|
||||||
@ -260,7 +260,7 @@ void APM_RC_Purple::_set_speed_ch6_ch7_ch8(uint8_t speed)
|
|||||||
// allow HIL override of RC values
|
// allow HIL override of RC values
|
||||||
// A value of -1 means no change
|
// A value of -1 means no change
|
||||||
// A value of 0 means no override, use the real RC values
|
// A value of 0 means no override, use the real RC values
|
||||||
bool APM_RC_Purple::setHIL(int16_t v[NUM_CHANNELS])
|
bool APM_RC_APM2::setHIL(int16_t v[NUM_CHANNELS])
|
||||||
{
|
{
|
||||||
uint8_t sum = 0;
|
uint8_t sum = 0;
|
||||||
for (unsigned char i=0; i<NUM_CHANNELS; i++) {
|
for (unsigned char i=0; i<NUM_CHANNELS; i++) {
|
||||||
@ -279,7 +279,7 @@ bool APM_RC_Purple::setHIL(int16_t v[NUM_CHANNELS])
|
|||||||
_radio_status = 1;
|
_radio_status = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void APM_RC_Purple::clearOverride(void)
|
void APM_RC_APM2::clearOverride(void)
|
||||||
{
|
{
|
||||||
for (unsigned char i=0; i<NUM_CHANNELS; i++) {
|
for (unsigned char i=0; i<NUM_CHANNELS; i++) {
|
||||||
_HIL_override[i] = 0;
|
_HIL_override[i] = 0;
|
@ -1,5 +1,5 @@
|
|||||||
#ifndef __APM_RC_PURPLE_H__
|
#ifndef __APM_RC_APM2_H__
|
||||||
#define __APM_RC_PURPLE_H__
|
#define __APM_RC_APM2_H__
|
||||||
|
|
||||||
#define NUM_CHANNELS 8
|
#define NUM_CHANNELS 8
|
||||||
#define MIN_PULSEWIDTH 900
|
#define MIN_PULSEWIDTH 900
|
||||||
@ -8,11 +8,11 @@
|
|||||||
#include "APM_RC.h"
|
#include "APM_RC.h"
|
||||||
#include "../Arduino_Mega_ISR_Registry/Arduino_Mega_ISR_Registry.h"
|
#include "../Arduino_Mega_ISR_Registry/Arduino_Mega_ISR_Registry.h"
|
||||||
|
|
||||||
class APM_RC_Purple : public APM_RC_Class
|
class APM_RC_APM2 : public APM_RC_Class
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
public:
|
public:
|
||||||
APM_RC_Purple();
|
APM_RC_APM2();
|
||||||
void Init( Arduino_Mega_ISR_Registry * isr_reg );
|
void Init( Arduino_Mega_ISR_Registry * isr_reg );
|
||||||
void OutputCh(unsigned char ch, uint16_t pwm);
|
void OutputCh(unsigned char ch, uint16_t pwm);
|
||||||
uint16_t InputCh(unsigned char ch);
|
uint16_t InputCh(unsigned char ch);
|
@ -10,7 +10,7 @@
|
|||||||
#include <APM_RC.h> // ArduPilot Mega RC Library
|
#include <APM_RC.h> // ArduPilot Mega RC Library
|
||||||
|
|
||||||
Arduino_Mega_ISR_Registry isr_registry;
|
Arduino_Mega_ISR_Registry isr_registry;
|
||||||
APM_RC_Purple APM_RC;
|
APM_RC_APM2 APM_RC;
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
@ -37,6 +37,6 @@ class DataFlash_Class
|
|||||||
};
|
};
|
||||||
|
|
||||||
#include "DataFlash_APM1.h"
|
#include "DataFlash_APM1.h"
|
||||||
#include "DataFlash_Purple.h"
|
#include "DataFlash_APM2.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
/*
|
/*
|
||||||
DataFlash_Purple.cpp - DataFlash log library for AT45DB321D
|
DataFlash_APM2.cpp - DataFlash log library for AT45DB321D
|
||||||
Code by Jordi Muñoz and Jose Julio. DIYDrones.com
|
Code by Jordi Muñoz and Jose Julio. DIYDrones.com
|
||||||
This code works only on ATMega2560. It uses Serial port 3 in SPI MSPI mdoe.
|
This code works only on ATMega2560. It uses Serial port 3 in SPI MSPI mdoe.
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ extern "C" {
|
|||||||
#include "WConstants.h"
|
#include "WConstants.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "DataFlash_Purple.h"
|
#include "DataFlash_APM2.h"
|
||||||
|
|
||||||
// DataFlash is connected to Serial Port 3 (we will use SPI mode)
|
// DataFlash is connected to Serial Port 3 (we will use SPI mode)
|
||||||
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
|
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
|
||||||
@ -79,7 +79,7 @@ extern "C" {
|
|||||||
#define OVERWRITE_DATA 0 // 0: When reach the end page stop, 1: Start overwritten from page 1
|
#define OVERWRITE_DATA 0 // 0: When reach the end page stop, 1: Start overwritten from page 1
|
||||||
|
|
||||||
// *** INTERNAL FUNCTIONS ***
|
// *** INTERNAL FUNCTIONS ***
|
||||||
unsigned char DataFlash_Purple::SPI_transfer(unsigned char data)
|
unsigned char DataFlash_APM2::SPI_transfer(unsigned char data)
|
||||||
{
|
{
|
||||||
/* Wait for empty transmit buffer */
|
/* Wait for empty transmit buffer */
|
||||||
while ( !( UCSR3A & (1<<UDRE3)) );
|
while ( !( UCSR3A & (1<<UDRE3)) );
|
||||||
@ -91,23 +91,23 @@ unsigned char DataFlash_Purple::SPI_transfer(unsigned char data)
|
|||||||
return UDR3;
|
return UDR3;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::CS_inactive()
|
void DataFlash_APM2::CS_inactive()
|
||||||
{
|
{
|
||||||
digitalWrite(DF_SLAVESELECT,HIGH); //disable device
|
digitalWrite(DF_SLAVESELECT,HIGH); //disable device
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::CS_active()
|
void DataFlash_APM2::CS_active()
|
||||||
{
|
{
|
||||||
digitalWrite(DF_SLAVESELECT,LOW); //enable device
|
digitalWrite(DF_SLAVESELECT,LOW); //enable device
|
||||||
}
|
}
|
||||||
|
|
||||||
// Constructors ////////////////////////////////////////////////////////////////
|
// Constructors ////////////////////////////////////////////////////////////////
|
||||||
DataFlash_Purple::DataFlash_Purple()
|
DataFlash_APM2::DataFlash_APM2()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
void DataFlash_Purple::Init(void)
|
void DataFlash_APM2::Init(void)
|
||||||
{
|
{
|
||||||
pinMode(DF_DATAOUT, OUTPUT);
|
pinMode(DF_DATAOUT, OUTPUT);
|
||||||
pinMode(DF_DATAIN, INPUT);
|
pinMode(DF_DATAIN, INPUT);
|
||||||
@ -139,7 +139,7 @@ void DataFlash_Purple::Init(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This function is mainly to test the device
|
// This function is mainly to test the device
|
||||||
void DataFlash_Purple::ReadManufacturerID()
|
void DataFlash_APM2::ReadManufacturerID()
|
||||||
{
|
{
|
||||||
CS_inactive(); // Reset dataflash command decoder
|
CS_inactive(); // Reset dataflash command decoder
|
||||||
CS_active();
|
CS_active();
|
||||||
@ -154,13 +154,13 @@ void DataFlash_Purple::ReadManufacturerID()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This function return 1 if Card is inserted on SD slot
|
// This function return 1 if Card is inserted on SD slot
|
||||||
bool DataFlash_Purple::CardInserted()
|
bool DataFlash_APM2::CardInserted()
|
||||||
{
|
{
|
||||||
return (digitalRead(DF_CARDDETECT) != 0);
|
return (digitalRead(DF_CARDDETECT) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read the status register
|
// Read the status register
|
||||||
byte DataFlash_Purple::ReadStatusReg()
|
byte DataFlash_APM2::ReadStatusReg()
|
||||||
{
|
{
|
||||||
CS_inactive(); // Reset dataflash command decoder
|
CS_inactive(); // Reset dataflash command decoder
|
||||||
CS_active();
|
CS_active();
|
||||||
@ -172,26 +172,26 @@ byte DataFlash_Purple::ReadStatusReg()
|
|||||||
|
|
||||||
// Read the status of the DataFlash
|
// Read the status of the DataFlash
|
||||||
inline
|
inline
|
||||||
byte DataFlash_Purple::ReadStatus()
|
byte DataFlash_APM2::ReadStatus()
|
||||||
{
|
{
|
||||||
return(ReadStatusReg()&0x80); // We only want to extract the READY/BUSY bit
|
return(ReadStatusReg()&0x80); // We only want to extract the READY/BUSY bit
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline
|
inline
|
||||||
uint16_t DataFlash_Purple::PageSize()
|
uint16_t DataFlash_APM2::PageSize()
|
||||||
{
|
{
|
||||||
return(528-((ReadStatusReg()&0x01)<<4)); // if first bit 1 trhen 512 else 528 bytes
|
return(528-((ReadStatusReg()&0x01)<<4)); // if first bit 1 trhen 512 else 528 bytes
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Wait until DataFlash is in ready state...
|
// Wait until DataFlash is in ready state...
|
||||||
void DataFlash_Purple::WaitReady()
|
void DataFlash_APM2::WaitReady()
|
||||||
{
|
{
|
||||||
while(!ReadStatus());
|
while(!ReadStatus());
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::PageToBuffer(unsigned char BufferNum, uint16_t PageAdr)
|
void DataFlash_APM2::PageToBuffer(unsigned char BufferNum, uint16_t PageAdr)
|
||||||
{
|
{
|
||||||
CS_inactive();
|
CS_inactive();
|
||||||
CS_active();
|
CS_active();
|
||||||
@ -215,7 +215,7 @@ void DataFlash_Purple::PageToBuffer(unsigned char BufferNum, uint16_t PageAdr)
|
|||||||
while(!ReadStatus()); //monitor the status register, wait until busy-flag is high
|
while(!ReadStatus()); //monitor the status register, wait until busy-flag is high
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::BufferToPage (unsigned char BufferNum, uint16_t PageAdr, unsigned char wait)
|
void DataFlash_APM2::BufferToPage (unsigned char BufferNum, uint16_t PageAdr, unsigned char wait)
|
||||||
{
|
{
|
||||||
CS_inactive(); // Reset dataflash command decoder
|
CS_inactive(); // Reset dataflash command decoder
|
||||||
CS_active();
|
CS_active();
|
||||||
@ -242,7 +242,7 @@ void DataFlash_Purple::BufferToPage (unsigned char BufferNum, uint16_t PageAdr,
|
|||||||
while(!ReadStatus()); //monitor the status register, wait until busy-flag is high
|
while(!ReadStatus()); //monitor the status register, wait until busy-flag is high
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::BufferWrite (unsigned char BufferNum, uint16_t IntPageAdr, unsigned char Data)
|
void DataFlash_APM2::BufferWrite (unsigned char BufferNum, uint16_t IntPageAdr, unsigned char Data)
|
||||||
{
|
{
|
||||||
CS_inactive(); // Reset dataflash command decoder
|
CS_inactive(); // Reset dataflash command decoder
|
||||||
CS_active();
|
CS_active();
|
||||||
@ -257,7 +257,7 @@ void DataFlash_Purple::BufferWrite (unsigned char BufferNum, uint16_t IntPageAdr
|
|||||||
SPI_transfer(Data); //write data byte
|
SPI_transfer(Data); //write data byte
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char DataFlash_Purple::BufferRead (unsigned char BufferNum, uint16_t IntPageAdr)
|
unsigned char DataFlash_APM2::BufferRead (unsigned char BufferNum, uint16_t IntPageAdr)
|
||||||
{
|
{
|
||||||
byte tmp;
|
byte tmp;
|
||||||
|
|
||||||
@ -278,7 +278,7 @@ unsigned char DataFlash_Purple::BufferRead (unsigned char BufferNum, uint16_t In
|
|||||||
}
|
}
|
||||||
// *** END OF INTERNAL FUNCTIONS ***
|
// *** END OF INTERNAL FUNCTIONS ***
|
||||||
|
|
||||||
void DataFlash_Purple::PageErase (uint16_t PageAdr)
|
void DataFlash_APM2::PageErase (uint16_t PageAdr)
|
||||||
{
|
{
|
||||||
CS_inactive(); //make sure to toggle CS signal in order
|
CS_inactive(); //make sure to toggle CS signal in order
|
||||||
CS_active(); //to reset Dataflash command decoder
|
CS_active(); //to reset Dataflash command decoder
|
||||||
@ -299,7 +299,7 @@ void DataFlash_Purple::PageErase (uint16_t PageAdr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void DataFlash_Purple::ChipErase ()
|
void DataFlash_APM2::ChipErase ()
|
||||||
{
|
{
|
||||||
CS_inactive(); //make sure to toggle CS signal in order
|
CS_inactive(); //make sure to toggle CS signal in order
|
||||||
CS_active(); //to reset Dataflash command decoder
|
CS_active(); //to reset Dataflash command decoder
|
||||||
@ -315,7 +315,7 @@ void DataFlash_Purple::ChipErase ()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// *** DATAFLASH PUBLIC FUNCTIONS ***
|
// *** DATAFLASH PUBLIC FUNCTIONS ***
|
||||||
void DataFlash_Purple::StartWrite(int16_t PageAdr)
|
void DataFlash_APM2::StartWrite(int16_t PageAdr)
|
||||||
{
|
{
|
||||||
df_BufferNum=1;
|
df_BufferNum=1;
|
||||||
df_BufferIdx=4;
|
df_BufferIdx=4;
|
||||||
@ -330,7 +330,7 @@ void DataFlash_Purple::StartWrite(int16_t PageAdr)
|
|||||||
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::FinishWrite(void)
|
void DataFlash_APM2::FinishWrite(void)
|
||||||
{
|
{
|
||||||
df_BufferIdx=0;
|
df_BufferIdx=0;
|
||||||
BufferToPage(df_BufferNum,df_PageAdr,0); // Write Buffer to memory, NO WAIT
|
BufferToPage(df_BufferNum,df_PageAdr,0); // Write Buffer to memory, NO WAIT
|
||||||
@ -353,7 +353,7 @@ void DataFlash_Purple::FinishWrite(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void DataFlash_Purple::WriteByte(byte data)
|
void DataFlash_APM2::WriteByte(byte data)
|
||||||
{
|
{
|
||||||
if (!df_Stop_Write)
|
if (!df_Stop_Write)
|
||||||
{
|
{
|
||||||
@ -389,13 +389,13 @@ void DataFlash_Purple::WriteByte(byte data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::WriteInt(int16_t data)
|
void DataFlash_APM2::WriteInt(int16_t data)
|
||||||
{
|
{
|
||||||
WriteByte(data>>8); // High byte
|
WriteByte(data>>8); // High byte
|
||||||
WriteByte(data&0xFF); // Low byte
|
WriteByte(data&0xFF); // Low byte
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::WriteLong(int32_t data)
|
void DataFlash_APM2::WriteLong(int32_t data)
|
||||||
{
|
{
|
||||||
WriteByte(data>>24); // First byte
|
WriteByte(data>>24); // First byte
|
||||||
WriteByte(data>>16);
|
WriteByte(data>>16);
|
||||||
@ -404,18 +404,18 @@ void DataFlash_Purple::WriteLong(int32_t data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Get the last page written to
|
// Get the last page written to
|
||||||
int16_t DataFlash_Purple::GetWritePage()
|
int16_t DataFlash_APM2::GetWritePage()
|
||||||
{
|
{
|
||||||
return(df_PageAdr);
|
return(df_PageAdr);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the last page read
|
// Get the last page read
|
||||||
int16_t DataFlash_Purple::GetPage()
|
int16_t DataFlash_APM2::GetPage()
|
||||||
{
|
{
|
||||||
return(df_Read_PageAdr-1);
|
return(df_Read_PageAdr-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::StartRead(int16_t PageAdr)
|
void DataFlash_APM2::StartRead(int16_t PageAdr)
|
||||||
{
|
{
|
||||||
df_Read_BufferNum=1;
|
df_Read_BufferNum=1;
|
||||||
df_Read_BufferIdx=4;
|
df_Read_BufferIdx=4;
|
||||||
@ -431,7 +431,7 @@ void DataFlash_Purple::StartRead(int16_t PageAdr)
|
|||||||
df_FilePage = (df_FilePage<<8) | BufferRead(df_Read_BufferNum,3); // Low byte
|
df_FilePage = (df_FilePage<<8) | BufferRead(df_Read_BufferNum,3); // Low byte
|
||||||
}
|
}
|
||||||
|
|
||||||
byte DataFlash_Purple::ReadByte()
|
byte DataFlash_APM2::ReadByte()
|
||||||
{
|
{
|
||||||
byte result;
|
byte result;
|
||||||
|
|
||||||
@ -458,7 +458,7 @@ byte DataFlash_Purple::ReadByte()
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int16_t DataFlash_Purple::ReadInt()
|
int16_t DataFlash_APM2::ReadInt()
|
||||||
{
|
{
|
||||||
uint16_t result;
|
uint16_t result;
|
||||||
|
|
||||||
@ -467,7 +467,7 @@ int16_t DataFlash_Purple::ReadInt()
|
|||||||
return (int16_t)result;
|
return (int16_t)result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t DataFlash_Purple::ReadLong()
|
int32_t DataFlash_APM2::ReadLong()
|
||||||
{
|
{
|
||||||
uint32_t result;
|
uint32_t result;
|
||||||
|
|
||||||
@ -478,18 +478,18 @@ int32_t DataFlash_Purple::ReadLong()
|
|||||||
return (int32_t)result;
|
return (int32_t)result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DataFlash_Purple::SetFileNumber(uint16_t FileNumber)
|
void DataFlash_APM2::SetFileNumber(uint16_t FileNumber)
|
||||||
{
|
{
|
||||||
df_FileNumber = FileNumber;
|
df_FileNumber = FileNumber;
|
||||||
df_FilePage = 1;
|
df_FilePage = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t DataFlash_Purple::GetFileNumber()
|
uint16_t DataFlash_APM2::GetFileNumber()
|
||||||
{
|
{
|
||||||
return df_FileNumber;
|
return df_FileNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t DataFlash_Purple::GetFilePage()
|
uint16_t DataFlash_APM2::GetFilePage()
|
||||||
{
|
{
|
||||||
return df_FilePage;
|
return df_FilePage;
|
||||||
}
|
}
|
@ -1,12 +1,12 @@
|
|||||||
/* ************************************************************ */
|
/* ************************************************************ */
|
||||||
/* DataFlash_Purple Log library */
|
/* DataFlash_APM2 Log library */
|
||||||
/* ************************************************************ */
|
/* ************************************************************ */
|
||||||
#ifndef __DATAFLASH_PURPLE_H__
|
#ifndef __DATAFLASH_APM2_H__
|
||||||
#define __DATAFLASH_PURPLE_H__
|
#define __DATAFLASH_APM2_H__
|
||||||
|
|
||||||
#include "DataFlash.h"
|
#include "DataFlash.h"
|
||||||
|
|
||||||
class DataFlash_Purple : public DataFlash_Class
|
class DataFlash_APM2 : public DataFlash_Class
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
// DataFlash Log variables...
|
// DataFlash Log variables...
|
||||||
@ -43,7 +43,7 @@ class DataFlash_Purple : public DataFlash_Class
|
|||||||
unsigned char df_device_1;
|
unsigned char df_device_1;
|
||||||
uint16_t df_PageSize;
|
uint16_t df_PageSize;
|
||||||
|
|
||||||
DataFlash_Purple(); // Constructor
|
DataFlash_APM2(); // Constructor
|
||||||
void Init();
|
void Init();
|
||||||
void ReadManufacturerID();
|
void ReadManufacturerID();
|
||||||
bool CardInserted();
|
bool CardInserted();
|
@ -34,7 +34,7 @@ struct RC_ICR4 {
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
ignore rate assignment for now (needed for purple
|
ignore rate assignment for now (needed for apm2
|
||||||
emulation)
|
emulation)
|
||||||
*/
|
*/
|
||||||
RC_ICR4& operator=(uint16_t rate) {
|
RC_ICR4& operator=(uint16_t rate) {
|
||||||
|
Loading…
Reference in New Issue
Block a user