diff options
author | Salicylic-acid3 <46864619+Salicylic-acid3@users.noreply.github.com> | 2019-10-17 02:26:43 +0900 |
---|---|---|
committer | Drashna Jaelre <drashna@live.com> | 2019-10-16 10:26:43 -0700 |
commit | f360c27f9302b1f916985dc32f68657ec22b3b9c (patch) | |
tree | b3c3210e6c0c450b5d27d643c6d6817309ac83fc /keyboards/naked60/rev1/split_scomm.c | |
parent | 2fc3494fd967bb2d8ffba3dcd33fa4a7ef1066ed (diff) | |
download | firmware-f360c27f9302b1f916985dc32f68657ec22b3b9c.tar.gz firmware-f360c27f9302b1f916985dc32f68657ec22b3b9c.tar.bz2 firmware-f360c27f9302b1f916985dc32f68657ec22b3b9c.zip |
[Keyboard] Add keyboard Naked60 (#6527)
* Add Naked60
* readme Update
* Update keyboards/naked60/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Updated keymaps
Changed the alias.
* updated rule.mk
Unnecessary part was deleted and explanation was added to the boot loader.
* Update keyboards/naked60/rules.mk
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/rules.mk
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/rev1/rev1.h
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/rev1/rev1.h
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/rev1/config.h
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/rev1/config.h
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Updated keymaps rules.mk.
Cleaned up declarations in rules.mk.
* Updated keymap
Changed remaining aliases.
* Update rev1.c
Cleaned up declarations in rev1.c.
* Update readme
The appearance has been adjusted.
* Update keyboards/naked60/keymaps/default/readme.md
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_nafuda/readme.md
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_nafuda/readme.md
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic/readme.md
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic_with_nafuda/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic_with_nafuda/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic_with_setta21/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic_with_setta21/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/rev1/rev1.c
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_nafuda/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/salicylic/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_nafuda/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_setta21/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Update keyboards/naked60/keymaps/default_with_setta21/rules.mk
Co-Authored-By: noroadsleft <18669334+noroadsleft@users.noreply.github.com>
* Updated keymaps
The appearance has been adjusted.
Unnecessary rules.mk was deleted.
* Update keyboards/naked60/readme.md
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update readme
Changed to markdown format.
* Update keyboards/naked60/keymaps/default/readme.md
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/keymaps/salicylic/readme.md
Co-Authored-By: fauxpark <fauxpark@gmail.com>
* Update keyboards/naked60/keymaps/salicylic/readme.md
Co-Authored-By: fauxpark <fauxpark@gmail.com>
Diffstat (limited to 'keyboards/naked60/rev1/split_scomm.c')
-rw-r--r-- | keyboards/naked60/rev1/split_scomm.c | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/keyboards/naked60/rev1/split_scomm.c b/keyboards/naked60/rev1/split_scomm.c new file mode 100644 index 000000000..ada786796 --- /dev/null +++ b/keyboards/naked60/rev1/split_scomm.c @@ -0,0 +1,92 @@ +#ifdef USE_SERIAL +#ifdef SERIAL_USE_MULTI_TRANSACTION +/* --- USE flexible API (using multi-type transaction function) --- */ + +#include <stdbool.h> +#include <stdint.h> +#include <stddef.h> +#include <split_scomm.h> +#include "serial.h" +#ifdef CONSOLE_ENABLE + #include <print.h> +#endif + +uint8_t volatile serial_slave_buffer[SERIAL_SLAVE_BUFFER_LENGTH] = {0}; +uint8_t volatile serial_master_buffer[SERIAL_MASTER_BUFFER_LENGTH] = {0}; +uint8_t volatile status_com = 0; +uint8_t volatile status1 = 0; +uint8_t slave_buffer_change_count = 0; +uint8_t s_change_old = 0xff; +uint8_t s_change_new = 0xff; + +SSTD_t transactions[] = { +#define GET_SLAVE_STATUS 0 + /* master buffer not changed, only recive slave_buffer_change_count */ + { (uint8_t *)&status_com, + 0, NULL, + sizeof(slave_buffer_change_count), &slave_buffer_change_count, + }, +#define PUT_MASTER_GET_SLAVE_STATUS 1 + /* master buffer changed need send, and recive slave_buffer_change_count */ + { (uint8_t *)&status_com, + sizeof(serial_master_buffer), (uint8_t *)serial_master_buffer, + sizeof(slave_buffer_change_count), &slave_buffer_change_count, + }, +#define GET_SLAVE_BUFFER 2 + /* recive serial_slave_buffer */ + { (uint8_t *)&status1, + 0, NULL, + sizeof(serial_slave_buffer), (uint8_t *)serial_slave_buffer + } +}; + +void serial_master_init(void) +{ + soft_serial_initiator_init(transactions, TID_LIMIT(transactions)); +} + +void serial_slave_init(void) +{ + soft_serial_target_init(transactions, TID_LIMIT(transactions)); +} + +// 0 => no error +// 1 => slave did not respond +// 2 => checksum error +int serial_update_buffers(int master_update) +{ + int status, smatstatus; + static int need_retry = 0; + + if( s_change_old != s_change_new ) { + smatstatus = soft_serial_transaction(GET_SLAVE_BUFFER); + if( smatstatus == TRANSACTION_END ) { + s_change_old = s_change_new; +#ifdef CONSOLE_ENABLE + uprintf("slave matrix = %b %b %b %b %b\n", + serial_slave_buffer[0], serial_slave_buffer[1], + serial_slave_buffer[2], serial_slave_buffer[3], + serial_slave_buffer[4] ); +#endif + } + } else { + // serial_slave_buffer dosen't change + smatstatus = TRANSACTION_END; // dummy status + } + + if( !master_update && !need_retry) { + status = soft_serial_transaction(GET_SLAVE_STATUS); + } else { + status = soft_serial_transaction(PUT_MASTER_GET_SLAVE_STATUS); + } + if( status == TRANSACTION_END ) { + s_change_new = slave_buffer_change_count; + need_retry = 0; + } else { + need_retry = 1; + } + return smatstatus; +} + +#endif // SERIAL_USE_MULTI_TRANSACTION +#endif /* USE_SERIAL */ |