71381457fa
d5c5ac6 Merge branch 'develop' 5957682 Merge branch 'hotfix-mediakey' a478c62 Merge branch 'hotfix-vusb' cccebfe Merge branch 'njbair-docfix' 0aaab57 Clean up wording in keymap example dc8bbc3 Clarify layer precedence 9e0b4c1 clarify layer documentation 915eb48 core: Fix media/consumer keys 88f90f3 Fix for VUSB configuration 3e290cd Fix including board.mk in chibios.mk 32c69e0 Merge branch 'newapi' into develop c9a56f9 Merge remote-tracking branch 'flabbergast/chibios' into develop 01e33ea Fix chibios and mbed common.mk for hook.c bea79d9 hook: Change func name of usb events 3e97536 hook: Change file and func names(*_hook -> hook_*) c286d8c Merge pull request #10 from fredizzimo/chibios-contrib2 062d74e Update ChibiOS instructions d47150f Add support for new version of ChibiOS and Contrib 62b5401 Chibios: disable LTO (link-time optimisation). c64e9aa hooks: Fix for LUFA 54e68b0 hooks: Remove led_restore_hook 325c09d Chibios: make the default bootloader_jump redefinable (weak). 078c722 Chibios: fix STM32_BOOTLOADER_ADDRESS name. e73cfe5 hooks: Fix for keyboard LED update e6120c5 Implement basic hooks. 7c370e9 Chibios: Update the main chibios README. 7f0198d Chibios: implement sleep LED for STM32. afef9b4 Fix hard-coded path of CHIBIOS 95c5b19 Merge pull request #7 from fredizzimo/sysvsize 27128a8 Sysv format for ChibiOS arm-none-eabi-size d4b8e68 core: Fix chibios user compile options b85d462 Merge branch 'chibios' of https://github.com/flabbergast/tmk_keyboard into flabbergast_chibios de41aa1 core: Fix ps2_mouse.c debug print d79d925 Removed duplicate debug message code and surrounded it with IFDEF as needed 8f28589 Chibios: Revert common.mk change (fix AVR linking problem). ec9eff2 Chibios: cleanup usb_main code. 28c4665 Chibios: Fix a HardFault bug (wait after start). git-subtree-dir: tmk_core git-subtree-split: d5c5ac63e60dfc6da6661a21bd968b4d577a27d5
101 lines
2.5 KiB
C
101 lines
2.5 KiB
C
/* Name: main.c
|
|
* Project: hid-mouse, a very simple HID example
|
|
* Author: Christian Starkjohann
|
|
* Creation Date: 2008-04-07
|
|
* Tabsize: 4
|
|
* Copyright: (c) 2008 by OBJECTIVE DEVELOPMENT Software GmbH
|
|
* License: GNU GPL v2 (see License.txt), GNU GPL v3 or proprietary (CommercialLicense.txt)
|
|
* This Revision: $Id: main.c 790 2010-05-30 21:00:26Z cs $
|
|
*/
|
|
#include <stdint.h>
|
|
#include <avr/interrupt.h>
|
|
#include <avr/wdt.h>
|
|
#include <avr/sleep.h>
|
|
#include <util/delay.h>
|
|
#include "usbdrv.h"
|
|
#include "oddebug.h"
|
|
#include "vusb.h"
|
|
#include "keyboard.h"
|
|
#include "host.h"
|
|
#include "timer.h"
|
|
#include "uart.h"
|
|
#include "debug.h"
|
|
|
|
|
|
#define UART_BAUD_RATE 115200
|
|
|
|
|
|
/* This is from main.c of USBaspLoader */
|
|
static void initForUsbConnectivity(void)
|
|
{
|
|
uint8_t i = 0;
|
|
|
|
usbInit();
|
|
/* enforce USB re-enumerate: */
|
|
usbDeviceDisconnect(); /* do this while interrupts are disabled */
|
|
while(--i){ /* fake USB disconnect for > 250 ms */
|
|
wdt_reset();
|
|
_delay_ms(1);
|
|
}
|
|
usbDeviceConnect();
|
|
sei();
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
bool suspended = false;
|
|
#if USB_COUNT_SOF
|
|
uint16_t last_timer = timer_read();
|
|
#endif
|
|
|
|
CLKPR = 0x80, CLKPR = 0;
|
|
#ifndef NO_UART
|
|
uart_init(UART_BAUD_RATE);
|
|
#endif
|
|
|
|
keyboard_init();
|
|
host_set_driver(vusb_driver());
|
|
|
|
debug("initForUsbConnectivity()\n");
|
|
initForUsbConnectivity();
|
|
|
|
debug("main loop\n");
|
|
while (1) {
|
|
#if USB_COUNT_SOF
|
|
if (usbSofCount != 0) {
|
|
suspended = false;
|
|
usbSofCount = 0;
|
|
last_timer = timer_read();
|
|
} else {
|
|
// Suspend when no SOF in 3ms-10ms(7.1.7.4 Suspending of USB1.1)
|
|
if (timer_elapsed(last_timer) > 5) {
|
|
suspended = true;
|
|
/*
|
|
uart_putchar('S');
|
|
_delay_ms(1);
|
|
cli();
|
|
set_sleep_mode(SLEEP_MODE_PWR_DOWN);
|
|
sleep_enable();
|
|
sleep_bod_disable();
|
|
sei();
|
|
sleep_cpu();
|
|
sleep_disable();
|
|
_delay_ms(10);
|
|
uart_putchar('W');
|
|
*/
|
|
}
|
|
}
|
|
#endif
|
|
if (!suspended) {
|
|
usbPoll();
|
|
|
|
// TODO: configuration process is incosistent. it sometime fails.
|
|
// To prevent failing to configure NOT scan keyboard during configuration
|
|
if (usbConfiguration && usbInterruptIsReady()) {
|
|
keyboard_task();
|
|
}
|
|
vusb_transfer_keyboard();
|
|
}
|
|
}
|
|
}
|