diff --git a/config/generic-printrboard.cfg b/config/generic-printrboard.cfg index 5fd99e1e..8a667370 100644 --- a/config/generic-printrboard.cfg +++ b/config/generic-printrboard.cfg @@ -66,7 +66,7 @@ max_temp: 130 pin: PC6 [mcu] -serial: /dev/ttyACM0 +serial: /dev/serial/by-id/usb-Klipper_Klipper_firmware_12345-if00 [printer] kinematics: cartesian diff --git a/src/avr/Makefile b/src/avr/Makefile index 9f814a44..c3f3ab34 100644 --- a/src/avr/Makefile +++ b/src/avr/Makefile @@ -3,14 +3,14 @@ # Use the avr toolchain CROSS_PREFIX=avr- -dirs-y += src/avr src/generic lib/pjrc_usb_serial +dirs-y += src/avr src/generic CFLAGS += -mmcu=$(CONFIG_MCU) # Add avr source files src-y += avr/main.c avr/timer.c avr/gpio.c src-$(CONFIG_AVR_WATCHDOG) += avr/watchdog.c -src-$(CONFIG_AVR_USBSERIAL) += avr/usbserial.c ../lib/pjrc_usb_serial/usb_serial.c +src-$(CONFIG_AVR_USBSERIAL) += avr/usbserial.c generic/usb_cdc.c src-$(CONFIG_AVR_SERIAL) += avr/serial.c generic/serial_irq.c # Suppress broken "misspelled signal handler" warnings on gcc 4.8.1 diff --git a/src/avr/usbserial.c b/src/avr/usbserial.c index 2a16160d..188a1b14 100644 --- a/src/avr/usbserial.c +++ b/src/avr/usbserial.c @@ -1,71 +1,250 @@ -// Wrappers for AVR usb serial. +// Hardware interface to USB on AVR at90usb // -// Copyright (C) 2016,2017 Kevin O'Connor +// Copyright (C) 2018 Kevin O'Connor // // This file may be distributed under the terms of the GNU GPLv3 license. -#include // memmove -#include "../lib/pjrc_usb_serial/usb_serial.h" -#include "board/misc.h" // console_sendf -#include "command.h" // command_find_and_dispatch +#include // USB_COM_vect +#include // NULL +#include "autoconf.h" // CONFIG_MACH_at90usb1286 +#include "board/usb_cdc.h" // usb_notify_ep0 +#include "board/usb_cdc_ep.h" // USB_CDC_EP_BULK_IN +#include "pgm.h" // READP #include "sched.h" // DECL_INIT -static uint8_t receive_buf[MESSAGE_MAX], receive_pos; +// EPCFG0X definitions +#define EP_TYPE_CONTROL 0x00 +#define EP_TYPE_BULK_IN 0x81 +#define EP_TYPE_BULK_OUT 0x80 +#define EP_TYPE_INTERRUPT_IN 0xC1 + +// EPCFG1X definitions +#define EP_SINGLE_BUFFER 0x02 +#define EP_DOUBLE_BUFFER 0x06 +#define EP_SIZE(s) ((s)==64 ? 0x30 : ((s)==32 ? 0x20 : ((s)==16 ? 0x10 : 0x00))) + +static void +usb_write_packet(const uint8_t *data, uint8_t len) +{ + while (len--) + UEDATX = *data++; +} + +static void +usb_write_packet_progmem(const uint8_t *data, uint8_t len) +{ + while (len--) + UEDATX = READP(*data++); +} + +static void +usb_read_packet(uint8_t *data, uint8_t len) +{ + while (len--) + *data++ = UEDATX; +} + +int_fast8_t +usb_read_bulk_out(void *data, uint_fast8_t max_len) +{ + UENUM = USB_CDC_EP_BULK_OUT; + if (!(UEINTX & (1<= sizeof(receive_buf)) - break; - int16_t ret = usb_serial_getchar(); - if (ret == -1) - break; - receive_buf[receive_pos++] = ret; + uint8_t udint = UDINT; + UDINT = 0; + if (udint & (1<