Keyboard: Add new keyboard Zinc (#4245)
* Add Zinc keyboard * Fix photo * Fix readme.md * Fix RGB LED init of monks/keymap.c * Fix default keymap and readme.jp * Fix change DEFS of RGB ANIMATIONS to LED_ANIMATIONS * Add EOL * Use serial_config_simpleapi.h * Fix comment char * Fix error handling in split_scomm.c : mtei works * Fix keymaps * Remove DISABLE_LEADER definition * Remove pro_micro.h * Add 2 spaces after Hardware name * Fix keymaps - remove audio codes - change LAYOUT to LAYOUT_ortho_4X12 - change "persistent_default_layer_set" to core function * Use the Community Layouts feature - with some clean up
This commit is contained in:
		
							parent
							
								
									73e92ef0c0
								
							
						
					
					
						commit
						23cd9f4dee
					
				
					 42 changed files with 3671 additions and 0 deletions
				
			
		
							
								
								
									
										95
									
								
								keyboards/zinc/rev1/split_scomm.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								keyboards/zinc/rev1/split_scomm.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,95 @@
 | 
			
		|||
#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 SERIAL_DEBUG_MODE
 | 
			
		||||
#include <avr/io.h>
 | 
			
		||||
#endif
 | 
			
		||||
#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 */
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue