Remote object callable from many places
Change init_transport to add_remote_objects, so that it can be called many times from different places.
This commit is contained in:
		@@ -27,15 +27,15 @@ SOFTWARE.
 | 
			
		||||
#include "serial_link/protocol/triple_buffered_object.h"
 | 
			
		||||
#include <string.h>
 | 
			
		||||
 | 
			
		||||
static remote_object_t** remote_objects;
 | 
			
		||||
static uint32_t num_remote_objects;
 | 
			
		||||
#define MAX_REMOTE_OBJECTS 16
 | 
			
		||||
static remote_object_t* remote_objects[MAX_REMOTE_OBJECTS];
 | 
			
		||||
static uint32_t num_remote_objects = 0;
 | 
			
		||||
 | 
			
		||||
void init_transport(remote_object_t** _remote_objects, uint32_t _num_remote_objects) {
 | 
			
		||||
    remote_objects = _remote_objects;
 | 
			
		||||
    num_remote_objects = _num_remote_objects;
 | 
			
		||||
void add_remote_objects(remote_object_t** _remote_objects, uint32_t _num_remote_objects) {
 | 
			
		||||
    unsigned int i;
 | 
			
		||||
    for(i=0;i<num_remote_objects;i++) {
 | 
			
		||||
        remote_object_t* obj = remote_objects[i];
 | 
			
		||||
    for(i=0;i<_num_remote_objects;i++) {
 | 
			
		||||
        remote_object_t* obj = _remote_objects[i];
 | 
			
		||||
        remote_objects[num_remote_objects++] = obj;
 | 
			
		||||
        if (obj->object_type == MASTER_TO_ALL_SLAVES) {
 | 
			
		||||
            triple_buffer_object_t* tb = (triple_buffer_object_t*)obj->buffer;
 | 
			
		||||
            triple_buffer_init(tb);
 | 
			
		||||
 
 | 
			
		||||
@@ -144,7 +144,7 @@ typedef struct { \
 | 
			
		||||
 | 
			
		||||
#define REMOTE_OBJECT(name) (remote_object_t*)&remote_object_##name
 | 
			
		||||
 | 
			
		||||
void init_transport(remote_object_t** remote_objects, uint32_t num_remote_objects);
 | 
			
		||||
void add_remote_objects(remote_object_t** remote_objects, uint32_t num_remote_objects);
 | 
			
		||||
void transport_recv_frame(uint8_t from, uint8_t* data, uint16_t size);
 | 
			
		||||
void update_transport(void);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -120,7 +120,7 @@ static matrix_object_t last_matrix = {};
 | 
			
		||||
SLAVE_TO_MASTER_OBJECT(keyboard_matrix, matrix_object_t);
 | 
			
		||||
MASTER_TO_ALL_SLAVES_OBJECT(serial_link_connected, bool);
 | 
			
		||||
 | 
			
		||||
remote_object_t* test_remote_objects[] = {
 | 
			
		||||
static remote_object_t* remote_objects[] = {
 | 
			
		||||
    REMOTE_OBJECT(serial_link_connected),
 | 
			
		||||
    REMOTE_OBJECT(keyboard_matrix),
 | 
			
		||||
};
 | 
			
		||||
@@ -128,7 +128,7 @@ remote_object_t* test_remote_objects[] = {
 | 
			
		||||
void init_serial_link(void) {
 | 
			
		||||
    serial_link_connected = false;
 | 
			
		||||
    init_serial_link_hal();
 | 
			
		||||
    init_transport(test_remote_objects, sizeof(test_remote_objects)/sizeof(remote_object_t*));
 | 
			
		||||
    add_remote_objects(remote_objects, sizeof(remote_objects)/sizeof(remote_object_t*));
 | 
			
		||||
    init_byte_stuffer();
 | 
			
		||||
    sdStart(&SD1, &config);
 | 
			
		||||
    sdStart(&SD2, &config);
 | 
			
		||||
 
 | 
			
		||||
@@ -53,7 +53,7 @@ MASTER_TO_ALL_SLAVES_OBJECT(master_to_slave, test_object1_t);
 | 
			
		||||
MASTER_TO_SINGLE_SLAVE_OBJECT(master_to_single_slave, test_object1_t);
 | 
			
		||||
SLAVE_TO_MASTER_OBJECT(slave_to_master, test_object1_t);
 | 
			
		||||
 | 
			
		||||
remote_object_t* test_remote_objects[] = {
 | 
			
		||||
static remote_object_t* test_remote_objects[] = {
 | 
			
		||||
    REMOTE_OBJECT(master_to_slave),
 | 
			
		||||
    REMOTE_OBJECT(master_to_single_slave),
 | 
			
		||||
    REMOTE_OBJECT(slave_to_master),
 | 
			
		||||
@@ -61,7 +61,7 @@ remote_object_t* test_remote_objects[] = {
 | 
			
		||||
 | 
			
		||||
Describe(Transport);
 | 
			
		||||
BeforeEach(Transport) {
 | 
			
		||||
    init_transport(test_remote_objects, sizeof(test_remote_objects) / sizeof(remote_object_t*));
 | 
			
		||||
    add_remote_objects(test_remote_objects, sizeof(test_remote_objects) / sizeof(remote_object_t*));
 | 
			
		||||
    sent_data_size = 0;
 | 
			
		||||
}
 | 
			
		||||
AfterEach(Transport) {}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user