瀏覽代碼

FTDI transmit, improve performance for fast output

main
PaulStoffregen 7 年之前
父節點
當前提交
9840e82db8
共有 3 個文件被更改,包括 44 次插入6 次删除
  1. +2
    -1
      USBHost_t36.h
  2. +1
    -1
      ehci.cpp
  3. +41
    -4
      serial.cpp

+ 2
- 1
USBHost_t36.h 查看文件

@@ -747,7 +747,8 @@ private:

class USBSerial: public USBDriver, public Stream {
public:
enum { BUFFER_SIZE = 390 }; // must hold at least 6 max size packets, plus 2 extra bytes
// FIXME: need different USBSerial, with bigger buffers for 480 Mbit & faster speed
enum { BUFFER_SIZE = 648 }; // must hold at least 6 max size packets, plus 2 extra bytes
USBSerial(USBHost &host) : txtimer(this) { init(); }
void begin(uint32_t baud, uint32_t format=0);
void end(void);

+ 1
- 1
ehci.cpp 查看文件

@@ -393,7 +393,7 @@ void USBHost::isr()

void USBDriverTimer::start(uint32_t microseconds)
{
#ifdef USBHOST_PRINT_DEBUG
#if defined(USBHOST_PRINT_DEBUG) && 0
Serial.print("start_timer, us = ");
Serial.print(microseconds);
Serial.print(", driver = ");

+ 41
- 4
serial.cpp 查看文件

@@ -287,13 +287,50 @@ void USBSerial::rx_queue_packets(uint32_t head, uint32_t tail)

void USBSerial::tx_data(const Transfer_t *transfer)
{
if (transfer->buffer == tx1) {
uint32_t mask;
uint8_t *p = (uint8_t *)transfer->buffer;
if (p == tx1) {
println("tx1:");
txstate &= 0xFE;
} else if (transfer->buffer == tx2) {
mask = 1;
//txstate &= 0xFE;
} else if (p == tx2) {
println("tx2:");
txstate &= 0xFD;
mask = 2;
//txstate &= 0xFD;
} else {
return; // should never happen
}
// check how much more data remains in the transmit buffer
uint32_t head = txhead;
uint32_t tail = txtail;
uint32_t count;
if (head >= tail) {
count = head - tail;
} else {
count = txsize + head - tail;
}
uint32_t packetsize = tx2 - tx1;
if (count < packetsize) {
// not enough data in buffer to fill a full packet
txstate &= ~mask;
return;
}
// immediately transmit another full packet, if we have enough data
println("TX:moar data!!!!");
if (++tail >= txsize) tail = 0;
uint32_t n = txsize - tail;
if (n > packetsize) n = packetsize;
memcpy(p, txbuf + tail, n);
if (n >= packetsize) {
tail += n - 1;
if (tail >= txsize) tail = 0;
} else {
uint32_t len = packetsize - n;
memcpy(p + n, txbuf, len);
tail = len - 1;
}
txtail = tail;
queue_Data_Transfer(txpipe, p, packetsize, this);
}



Loading…
取消
儲存