Port SPLIT_USB_DETECT to helix/rev2 (#7385)
* Port SPLIT_USB_DETECT to helix/rev2 * Remove debug toggles. * Rename is_keyboard_master to has_usb in split_util
This commit is contained in:
		
							parent
							
								
									e8efc46e74
								
							
						
					
					
						commit
						36a6e269bf
					
				
					 2 changed files with 60 additions and 25 deletions
				
			
		|  | @ -95,9 +95,8 @@ uint8_t matrix_cols(void) | ||||||
| 
 | 
 | ||||||
| void matrix_init(void) | void matrix_init(void) | ||||||
| { | { | ||||||
|     debug_enable = true; |     split_keyboard_setup(); | ||||||
|     debug_matrix = true; | 
 | ||||||
|     debug_mouse = true; |  | ||||||
|     // initialize row and col
 |     // initialize row and col
 | ||||||
|     unselect_rows(); |     unselect_rows(); | ||||||
|     init_cols(); |     init_cols(); | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ | ||||||
| #include "split_util.h" | #include "split_util.h" | ||||||
| #include "matrix.h" | #include "matrix.h" | ||||||
| #include "keyboard.h" | #include "keyboard.h" | ||||||
|  | #include "wait.h" | ||||||
| 
 | 
 | ||||||
| #ifdef USE_MATRIX_I2C | #ifdef USE_MATRIX_I2C | ||||||
| #  include "i2c.h" | #  include "i2c.h" | ||||||
|  | @ -14,21 +15,66 @@ | ||||||
| #  include "split_scomm.h" | #  include "split_scomm.h" | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | #ifdef EE_HANDS | ||||||
|  | #    include "eeconfig.h" | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifndef SPLIT_USB_TIMEOUT | ||||||
|  |   #define SPLIT_USB_TIMEOUT 2500 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| volatile bool isLeftHand = true; | volatile bool isLeftHand = true; | ||||||
| 
 | 
 | ||||||
| static void setup_handedness(void) { | bool waitForUsb(void) { | ||||||
|   #ifdef EE_HANDS |     for (uint8_t i = 0; i < (SPLIT_USB_TIMEOUT / 100); i++) { | ||||||
|     isLeftHand = eeprom_read_byte(EECONFIG_HANDEDNESS); |         // This will return true of a USB connection has been established
 | ||||||
|   #else |         if (UDADDR & _BV(ADDEN)) { | ||||||
|     // I2C_MASTER_RIGHT is deprecated, use MASTER_RIGHT instead, since this works for both serial and i2c
 |             return true; | ||||||
|     #if defined(I2C_MASTER_RIGHT) || defined(MASTER_RIGHT) |         } | ||||||
|       isLeftHand = !has_usb(); |         wait_ms(100); | ||||||
|     #else |     } | ||||||
|       isLeftHand = has_usb(); | 
 | ||||||
|  |     // Avoid NO_USB_STARTUP_CHECK - Disable USB as the previous checks seem to enable it somehow
 | ||||||
|  |     (USBCON &= ~(_BV(USBE) | _BV(OTGPADE))); | ||||||
|  | 
 | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | __attribute__((weak)) bool is_keyboard_left(void) { | ||||||
|  | #if defined(SPLIT_HAND_PIN) | ||||||
|  |     // Test pin SPLIT_HAND_PIN for High/Low, if low it's right hand
 | ||||||
|  |     setPinInput(SPLIT_HAND_PIN); | ||||||
|  |     return readPin(SPLIT_HAND_PIN); | ||||||
|  | #elif defined(EE_HANDS) | ||||||
|  |     return eeconfig_read_handedness(); | ||||||
|  | #elif defined(MASTER_RIGHT) | ||||||
|  |     return !has_usb(); | ||||||
| #endif | #endif | ||||||
|  | 
 | ||||||
|  |     return has_usb(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | __attribute__((weak)) bool has_usb(void) { | ||||||
|  |     static enum { UNKNOWN, MASTER, SLAVE } usbstate = UNKNOWN; | ||||||
|  | 
 | ||||||
|  |     // only check once, as this is called often
 | ||||||
|  |     if (usbstate == UNKNOWN) { | ||||||
|  | #if defined(SPLIT_USB_DETECT) | ||||||
|  |         usbstate = waitForUsb() ? MASTER : SLAVE; | ||||||
|  | #elif defined(__AVR__) | ||||||
|  |         USBCON |= (1 << OTGPADE);  // enables VBUS pad
 | ||||||
|  |         wait_us(5); | ||||||
|  | 
 | ||||||
|  |         usbstate = (USBSTA & (1 << VBUS)) ? MASTER : SLAVE;  // checks state of VBUS
 | ||||||
|  | #else | ||||||
|  |         usbstate = MASTER; | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     return (usbstate == MASTER); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static void keyboard_master_setup(void) { | static void keyboard_master_setup(void) { | ||||||
| 
 | 
 | ||||||
| #ifdef USE_MATRIX_I2C | #ifdef USE_MATRIX_I2C | ||||||
|  | @ -47,14 +93,8 @@ static void keyboard_slave_setup(void) { | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool has_usb(void) { |  | ||||||
|    USBCON |= (1 << OTGPADE); //enables VBUS pad
 |  | ||||||
|    _delay_us(5); |  | ||||||
|    return (USBSTA & (1<<VBUS));  //checks state of VBUS
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void split_keyboard_setup(void) { | void split_keyboard_setup(void) { | ||||||
|    setup_handedness(); |    isLeftHand = is_keyboard_left(); | ||||||
| 
 | 
 | ||||||
|    if (has_usb()) { |    if (has_usb()) { | ||||||
|       keyboard_master_setup(); |       keyboard_master_setup(); | ||||||
|  | @ -64,7 +104,3 @@ void split_keyboard_setup(void) { | ||||||
|    sei(); |    sei(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // this code runs before the usb and keyboard is initialized
 |  | ||||||
| void matrix_setup(void) { |  | ||||||
|     split_keyboard_setup(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Eric Bunton
						Eric Bunton