summaryrefslogtreecommitdiffstats
path: root/keyboards/honeycomb/honeycomb.c
blob: add4af1536527d01df3b360ead659196e975a901 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include "honeycomb.h"
#include "pointing_device.h"
#include "report.h"

void uart_init(void) {
	SERIAL_UART_INIT();
}

void pointing_device_task(void){
	/*report_mouse_t currentReport = {};
    SERIAL_UART_INIT();
    uint32_t timeout = 0;

    //the m character requests the RF slave to send the mouse report
    SERIAL_UART_DATA = 'm';

    //trust the external inputs completely, erase old data
    uint8_t uart_data[5] = {0};

    //there are 10 bytes corresponding to 10 columns, and an end byte
    for (uint8_t i = 0; i < 5; i++) {
        //wait for the serial data, timeout if it's been too long
        //this only happened in testing with a loose wire, but does no
        //harm to leave it in here
        while(!SERIAL_UART_RXD_PRESENT){
            timeout++;
            if (timeout > 10000){
		xprintf("\r\nTIMED OUT");
                break;
            }
        }
	xprintf("\r\nGOT DATA for %d",i);
        uart_data[i] = SERIAL_UART_DATA;
    }

    //check for the end packet, bytes 1-4 are movement and scroll
    //but byte 5 has bits 0-3 for the scroll button state
	//(1000 if pressed, 0000 if not) and bits 4-7 are always 1
	//We can use this to verify the report sent properly.
    if (uart_data[4] == 0x0F || uart_data[4] == 0x8F)
    {
	xprintf("\r\nREQUESTED MOUSE, RECEIVED %i, %i, %i, %i, %i",uart_data[0],uart_data[1],uart_data[2],uart_data[3],uart_data[4]);
		currentReport = pointing_device_get_report();
        //shifting and transferring the info to the mouse report varaible
        //mouseReport.x = 127 max -127 min
		currentReport.x = (int8_t) uart_data[0];
        //mouseReport.y = 127 max -127 min
		currentReport.y = (int8_t) uart_data[1];
        //mouseReport.v = 127 max -127 min (scroll vertical)
		currentReport.v = (int8_t) uart_data[2];
        //mouseReport.h = 127 max -127 min (scroll horizontal)
		currentReport.h = (int8_t) uart_data[3];
        //mouseReport.buttons = 0x31 max (bitmask for mouse buttons 1-5) 0x00 min
		//mouse buttons 1 and 2 are handled by the keymap, but not 3
		if (uart_data[4] == 0x0F) { //then 3 is not pressed
			currentReport.buttons &= ~MOUSE_BTN3; //MOUSE_BTN3 is def in report.h
		} else { //3 must be pressed
			currentReport.buttons |= MOUSE_BTN3;
		}
		pointing_device_set_report(currentReport);
    } else {
	xprintf("\r\nRequested packet, data 4 was %d",uart_data[4]);
    }*/
    pointing_device_send();
}

void led_init(void) {
  setPinOutput(D1);
  writePinHigh(D1);
  setPinOutput(F4);
  writePinHigh(F4);
  setPinOutput(F5);
  writePinHigh(F5);
}

void matrix_init_kb(void) {
	// put your keyboard start-up code here
	// runs once when the firmware starts up
	matrix_init_user();
	uart_init();
	led_init();
}

void matrix_scan_kb(void) {
	// put your looping keyboard code here
	// runs every cycle (a lot)
	matrix_scan_user();
}

void led_set_kb(uint8_t usb_led) {

}