mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-11-03 23:02:34 +01:00 
			
		
		
		
	Add out of bound check for Leader Key sequence array (#5840)
* Add out of bound check for Leader Key sequence array * A shot at advanced C stuff for Leader Key optimization * Revert most changes * Change default back * Include string.h if compiling for ARM * Use sizeof instead of a number
This commit is contained in:
		
							parent
							
								
									ed6a872911
								
							
						
					
					
						commit
						09f5767072
					
				@ -17,6 +17,9 @@
 | 
				
			|||||||
#ifdef LEADER_ENABLE
 | 
					#ifdef LEADER_ENABLE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "process_leader.h"
 | 
					#include "process_leader.h"
 | 
				
			||||||
 | 
					#ifdef __arm__
 | 
				
			||||||
 | 
					#   include <string.h>
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef LEADER_TIMEOUT
 | 
					#ifndef LEADER_TIMEOUT
 | 
				
			||||||
  #define LEADER_TIMEOUT 300
 | 
					  #define LEADER_TIMEOUT 300
 | 
				
			||||||
@ -41,11 +44,7 @@ void qk_leader_start(void) {
 | 
				
			|||||||
  leading = true;
 | 
					  leading = true;
 | 
				
			||||||
  leader_time = timer_read();
 | 
					  leader_time = timer_read();
 | 
				
			||||||
  leader_sequence_size = 0;
 | 
					  leader_sequence_size = 0;
 | 
				
			||||||
  leader_sequence[0] = 0;
 | 
					  memset(leader_sequence, 0, sizeof(leader_sequence));
 | 
				
			||||||
  leader_sequence[1] = 0;
 | 
					 | 
				
			||||||
  leader_sequence[2] = 0;
 | 
					 | 
				
			||||||
  leader_sequence[3] = 0;
 | 
					 | 
				
			||||||
  leader_sequence[4] = 0;
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
bool process_leader(uint16_t keycode, keyrecord_t *record) {
 | 
					bool process_leader(uint16_t keycode, keyrecord_t *record) {
 | 
				
			||||||
@ -58,8 +57,13 @@ bool process_leader(uint16_t keycode, keyrecord_t *record) {
 | 
				
			|||||||
          keycode = keycode & 0xFF;
 | 
					          keycode = keycode & 0xFF;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
#endif // LEADER_KEY_STRICT_KEY_PROCESSING
 | 
					#endif // LEADER_KEY_STRICT_KEY_PROCESSING
 | 
				
			||||||
        leader_sequence[leader_sequence_size] = keycode;
 | 
					        if ( leader_sequence_size < ( sizeof(leader_sequence) / sizeof(leader_sequence[0]) ) ) {
 | 
				
			||||||
        leader_sequence_size++;
 | 
					          leader_sequence[leader_sequence_size] = keycode;
 | 
				
			||||||
 | 
					          leader_sequence_size++;
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          leading = false;
 | 
				
			||||||
 | 
					          leader_end();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
#ifdef LEADER_PER_KEY_TIMING
 | 
					#ifdef LEADER_PER_KEY_TIMING
 | 
				
			||||||
        leader_time = timer_read();
 | 
					        leader_time = timer_read();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user