|
|
@ -55,7 +55,8 @@ void matrix_init(void) {
|
|
|
|
right_hand = palReadPad(GPIOC, 13);
|
|
|
|
right_hand = palReadPad(GPIOC, 13);
|
|
|
|
|
|
|
|
|
|
|
|
// if USB is active, this is the master
|
|
|
|
// if USB is active, this is the master
|
|
|
|
master = (USB_DRIVER.state == USB_ACTIVE);
|
|
|
|
// master = usbGetDriverStateI(&USB_DRIVER) == USB_ACTIVE;
|
|
|
|
|
|
|
|
master = right_hand;
|
|
|
|
|
|
|
|
|
|
|
|
if (master) {
|
|
|
|
if (master) {
|
|
|
|
twi2c_master_init();
|
|
|
|
twi2c_master_init();
|
|
|
@ -127,15 +128,16 @@ matrix_row_t matrix_scan_common(uint8_t row) {
|
|
|
|
return data;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void matrix_scan_master(void) {
|
|
|
|
const uint8_t command[2] = { 0x01, 0x00 };
|
|
|
|
|
|
|
|
uint8_t other_matrix[MATRIX_ROWS] = { 0 };
|
|
|
|
|
|
|
|
|
|
|
|
const uint8_t command[2] = { 0x01, 0x00 };
|
|
|
|
void matrix_scan_master(void) {
|
|
|
|
uint8_t other_matrix[MATRIX_ROWS];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
msg_t resp;
|
|
|
|
msg_t resp;
|
|
|
|
resp = twi2c_master_send(slaveI2Caddress/2, command, other_matrix, TIME_INFINITE);
|
|
|
|
resp = twi2c_master_send(slaveI2Caddress/2, command, other_matrix, TIME_IMMEDIATE);
|
|
|
|
printf("%x\n", resp);
|
|
|
|
// printf("%x\n", resp);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (resp == MSG_OK) {
|
|
|
|
uint8_t * matrix_pointer;
|
|
|
|
uint8_t * matrix_pointer;
|
|
|
|
if (right_hand) {
|
|
|
|
if (right_hand) {
|
|
|
|
matrix_pointer = matrix;
|
|
|
|
matrix_pointer = matrix;
|
|
|
@ -144,6 +146,7 @@ void matrix_scan_master(void) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
memcpy(matrix_pointer, other_matrix, MATRIX_ROWS / 2);
|
|
|
|
memcpy(matrix_pointer, other_matrix, MATRIX_ROWS / 2);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
uint8_t matrix_scan(void) {
|
|
|
|
uint8_t matrix_scan(void) {
|
|
|
|