mirror of
https://github.com/eried/portapack-mayhem.git
synced 2024-10-01 01:26:06 -04:00
Generalize FIFO to specify FIFO size as 2^K.
Configure baseband queue to be larger (4K) than application queue (2K).
This commit is contained in:
parent
4126f1ab1f
commit
52e8093618
@ -20,33 +20,3 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "message_queue.hpp"
|
#include "message_queue.hpp"
|
||||||
|
|
||||||
#include "ch.h"
|
|
||||||
#include "lpc43xx_cpp.hpp"
|
|
||||||
|
|
||||||
using namespace lpc43xx;
|
|
||||||
|
|
||||||
bool MessageQueue::push(const void* const buf, const size_t len) {
|
|
||||||
const auto result = fifo.in_r(buf, len);
|
|
||||||
const bool success = (result == len);
|
|
||||||
if( success ) {
|
|
||||||
signal();
|
|
||||||
}
|
|
||||||
return success;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t MessageQueue::pop(void* const buf, const size_t len) {
|
|
||||||
return fifo.out_r(buf, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(LPC43XX_M0)
|
|
||||||
void MessageQueue::signal() {
|
|
||||||
creg::m0apptxevent::assert();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LPC43XX_M4)
|
|
||||||
void MessageQueue::signal() {
|
|
||||||
creg::m4txevent::assert();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
@ -27,6 +27,10 @@
|
|||||||
#include "message.hpp"
|
#include "message.hpp"
|
||||||
#include "fifo.hpp"
|
#include "fifo.hpp"
|
||||||
|
|
||||||
|
#include "lpc43xx_cpp.hpp"
|
||||||
|
using namespace lpc43xx;
|
||||||
|
|
||||||
|
template<size_t K>
|
||||||
class MessageQueue {
|
class MessageQueue {
|
||||||
public:
|
public:
|
||||||
template<typename T>
|
template<typename T>
|
||||||
@ -37,7 +41,9 @@ public:
|
|||||||
return push(&message, sizeof(message));
|
return push(&message, sizeof(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t pop(void* const buf, const size_t len);
|
size_t pop(void* const buf, const size_t len) {
|
||||||
|
return fifo.out_r(buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
size_t len() const {
|
size_t len() const {
|
||||||
return fifo.len();
|
return fifo.len();
|
||||||
@ -48,11 +54,29 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
FIFO<uint8_t, 11> fifo;
|
FIFO<uint8_t, K> fifo;
|
||||||
|
|
||||||
bool push(const void* const buf, const size_t len);
|
bool push(const void* const buf, const size_t len) {
|
||||||
|
const auto result = fifo.in_r(buf, len);
|
||||||
|
const bool success = (result == len);
|
||||||
|
if( success ) {
|
||||||
|
signal();
|
||||||
|
}
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
|
||||||
void signal();
|
|
||||||
|
#if defined(LPC43XX_M0)
|
||||||
|
void signal() {
|
||||||
|
creg::m0apptxevent::assert();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(LPC43XX_M4)
|
||||||
|
void signal() {
|
||||||
|
creg::m4txevent::assert();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif/*__MESSAGE_QUEUE_H__*/
|
#endif/*__MESSAGE_QUEUE_H__*/
|
||||||
|
@ -32,8 +32,8 @@ struct TouchADCFrame {
|
|||||||
|
|
||||||
/* NOTE: These structures must be located in the same location in both M4 and M0 binaries */
|
/* NOTE: These structures must be located in the same location in both M4 and M0 binaries */
|
||||||
struct SharedMemory {
|
struct SharedMemory {
|
||||||
MessageQueue baseband_queue;
|
MessageQueue<12> baseband_queue;
|
||||||
MessageQueue application_queue;
|
MessageQueue<11> application_queue;
|
||||||
|
|
||||||
// TODO: M0 should directly configure and control DMA channel that is
|
// TODO: M0 should directly configure and control DMA channel that is
|
||||||
// acquiring ADC samples.
|
// acquiring ADC samples.
|
||||||
@ -44,8 +44,8 @@ extern SharedMemory& shared_memory;
|
|||||||
|
|
||||||
#if defined(LPC43XX_M0)
|
#if defined(LPC43XX_M0)
|
||||||
inline void init_message_queues() {
|
inline void init_message_queues() {
|
||||||
new (&shared_memory.baseband_queue) MessageQueue();
|
new (&shared_memory.baseband_queue) MessageQueue<12>();
|
||||||
new (&shared_memory.application_queue) MessageQueue();
|
new (&shared_memory.application_queue) MessageQueue<11>();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user