* checksum offload

* ethernet console

* guard flag

* flags

* reserve pins

* f4

* ip and link options

* chibios

* conditional build lwip

Co-authored-by: Matthew Kennedy <makenne@microsoft.com>
This commit is contained in:
Matthew Kennedy 2021-10-09 22:15:49 -07:00 committed by GitHub
parent 98775ef12b
commit 208497e6ed
12 changed files with 190 additions and 4 deletions

@ -1 +1 @@
Subproject commit c62811da8c73aef9960d59560c56ca663986d8f4 Subproject commit 45965706d04b640c2dd7d267afc63e82aac56a32

View File

@ -166,6 +166,11 @@ include $(CHIBIOS)/os/ex/devices/ST/lis302dl.mk
endif endif
include $(CHIBIOS)/os/hal/lib/streams/streams.mk include $(CHIBIOS)/os/hal/lib/streams/streams.mk
include $(CHIBIOS)/os/various/cpp_wrappers/chcpp.mk include $(CHIBIOS)/os/various/cpp_wrappers/chcpp.mk
ifeq ($(LWIP),yes)
include $(CHIBIOS)/os/various/lwip_bindings/lwip.mk
endif
include $(CHIBIOS)/os/hal/lib/complex/mfs/hal_mfs.mk include $(CHIBIOS)/os/hal/lib/complex/mfs/hal_mfs.mk
ifeq ($(USE_FATFS),yes) ifeq ($(USE_FATFS),yes)
@ -209,6 +214,7 @@ $(info LDSCRIPT: $(LDSCRIPT))
CSRC = $(ALLCSRC) \ CSRC = $(ALLCSRC) \
$(CHIBIOS)/os/various/syscalls.c \ $(CHIBIOS)/os/various/syscalls.c \
$(CHIBIOS_CONTRIB)/os/various/ramdisk.c \ $(CHIBIOS_CONTRIB)/os/various/ramdisk.c \
$(CHIBIOS)/os/various/evtimer.c \
$(TRIGGER_SRC) \ $(TRIGGER_SRC) \
$(TRIGGER_DECODERS_SRC) \ $(TRIGGER_DECODERS_SRC) \
$(DEV_SRC) \ $(DEV_SRC) \

View File

@ -9,6 +9,7 @@ CONSOLE_SRC_CPP = $(PROJECT_DIR)/console/status_loop.cpp \
$(PROJECT_DIR)/console/binary_log/log_field.cpp \ $(PROJECT_DIR)/console/binary_log/log_field.cpp \
$(PROJECT_DIR)/console/binary_log/binary_logging.cpp \ $(PROJECT_DIR)/console/binary_log/binary_logging.cpp \
$(PROJECT_DIR)/console/binary_log/usb_console.cpp \ $(PROJECT_DIR)/console/binary_log/usb_console.cpp \
$(PROJECT_DIR)/console/binary_log/ethernet_console.cpp \
CONSOLE_INC=\ CONSOLE_INC=\

View File

@ -10,3 +10,4 @@
void initializeConsole(); void initializeConsole();
void startUsbConsole(); void startUsbConsole();
void startEthernetConsole();

View File

@ -0,0 +1,98 @@
#include "pch.h"
#if EFI_ETHERNET
#include "lwipthread.h"
#include "lwip/sockets.h"
#include "thread_controller.h"
#include "tunerstudio.h"
static int listenerSocket = -1;
static int connectionSocket = -1;
static void do_connection() {
if (connectionSocket != -1) {
auto localCopy = connectionSocket;
connectionSocket = -1;
lwip_close(localCopy);
}
sockaddr_in remote;
socklen_t size = sizeof(remote);
connectionSocket = lwip_accept(listenerSocket, (sockaddr*)&remote, &size);
}
class EthernetChannel : public TsChannelBase {
public:
EthernetChannel()
: TsChannelBase("Ethernet")
{
}
bool isReady() const override {
return connectionSocket != -1;
}
void write(const uint8_t* buffer, size_t size) override {
lwip_send(connectionSocket, buffer, size, 0);
}
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override {
auto result = lwip_recv(connectionSocket, buffer, size, 0);
if (result == -1) {
do_connection();
return 0;
}
return result;
}
};
static EthernetChannel ethChannel;
struct EthernetThread : public TunerstudioThread {
EthernetThread() : TunerstudioThread("Ethernet Console") { }
TsChannelBase* setupChannel() override {
lwipInit(nullptr);
sockaddr_in address;
address.sin_family = AF_INET;
address.sin_port = htons(29000);
address.sin_addr.s_addr = INADDR_ANY;
listenerSocket = lwip_socket(AF_INET, SOCK_STREAM, 0);
lwip_bind(listenerSocket, (sockaddr*)&address, sizeof(address));
lwip_listen(listenerSocket, 1);
do_connection();
return &ethChannel;
}
};
static EthernetThread ethernetConsole;
void startEthernetConsole() {
efiSetPadMode("ethernet", GPIOA_1, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOA_2, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOA_7, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOC_1, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOC_4, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOC_5, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOD_5, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOG_11, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOG_13, PAL_MODE_ALTERNATE(0xb));
efiSetPadMode("ethernet", GPIOG_14, PAL_MODE_ALTERNATE(0xb));
ethernetConsole.Start();
}
#endif // EFI_ETHERNET

View File

@ -0,0 +1,63 @@
/*
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
* OF SUCH DAMAGE.
*
* This file is part of the lwIP TCP/IP stack.
*
* Author: Simon Goldschmidt
*
*/
#ifndef LWIP_HDR_LWIPOPTS_H__
#define LWIP_HDR_LWIPOPTS_H__
/* Fixed settings mandated by the ChibiOS integration.*/
#include "static_lwipopts.h"
#define DEFAULT_TCP_RECVMBOX_SIZE 40
#define DEFAULT_ACCEPTMBOX_SIZE 4
/* Optional, application-specific settings.*/
#if !defined(TCPIP_MBOX_SIZE)
#define TCPIP_MBOX_SIZE MEMP_NUM_PBUF
#endif
#if !defined(TCPIP_THREAD_STACKSIZE)
#define TCPIP_THREAD_STACKSIZE 1024
#endif
/* Use ChibiOS specific priorities. */
#if !defined(TCPIP_THREAD_PRIO)
#define TCPIP_THREAD_PRIO (NORMALPRIO + 5)
#endif
#if !defined(LWIP_THREAD_PRIORITY)
#define LWIP_THREAD_PRIORITY (NORMALPRIO + 4)
#endif
#define LWIP_LINK_POLL_INTERVAL TIME_S2I(1)
#define LWIP_IPADDR(p) IP4_ADDR(p, 192, 168, 10, 14)
#define LWIP_GATEWAY(p) IP4_ADDR(p, 192, 168, 10, 1)
#define LWIP_COMPAT_SOCKETS 0
#endif /* LWIP_HDR_LWIPOPTS_H__ */

View File

@ -37,6 +37,9 @@
// only the MSD driver requires USB_USE_WAIT // only the MSD driver requires USB_USE_WAIT
#define USB_USE_WAIT (EFI_FILE_LOGGING && EFI_USB_SERIAL) #define USB_USE_WAIT (EFI_FILE_LOGGING && EFI_USB_SERIAL)
// Ethernet
#define HAL_USE_MAC EFI_ETHERNET
/*===========================================================================*/ /*===========================================================================*/
/* Required rusEFI settings */ /* Required rusEFI settings */
/*===========================================================================*/ /*===========================================================================*/
@ -86,3 +89,7 @@
// Extra field in the UART driver's struct to store a reference to the DMA receive buffer object // Extra field in the UART driver's struct to store a reference to the DMA receive buffer object
#define UART_DRIVER_EXT_FIELDS void* dmaAdapterInstance; #define UART_DRIVER_EXT_FIELDS void* dmaAdapterInstance;
// Ethernet MAC
#define MAC_USE_ZERO_COPY FALSE
#define MAC_USE_EVENTS TRUE

View File

@ -175,7 +175,7 @@
#define STM32_MAC_PHY_TIMEOUT 100 #define STM32_MAC_PHY_TIMEOUT 100
#define STM32_MAC_ETH1_CHANGE_PHY_STATE TRUE #define STM32_MAC_ETH1_CHANGE_PHY_STATE TRUE
#define STM32_MAC_ETH1_IRQ_PRIORITY 13 #define STM32_MAC_ETH1_IRQ_PRIORITY 13
#define STM32_MAC_IP_CHECKSUM_OFFLOAD 0 #define STM32_MAC_IP_CHECKSUM_OFFLOAD 3
/* /*
* PWM driver system settings. * PWM driver system settings.

View File

@ -33,6 +33,12 @@
// Ignore USB VBUS pin (we're never a host, only a device) // Ignore USB VBUS pin (we're never a host, only a device)
#define BOARD_OTG_NOVBUSSENS TRUE #define BOARD_OTG_NOVBUSSENS TRUE
/*
* Ethernet PHY type.
*/
#define BOARD_PHY_ID MII_LAN8742A_ID
#define BOARD_PHY_RMII
/* /*
* Default to input mode, with internal pulldown resistor enabled. * Default to input mode, with internal pulldown resistor enabled.
*/ */

View File

@ -324,7 +324,7 @@
* @note Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. * @note Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS.
*/ */
#if !defined(CH_CFG_USE_DYNAMIC) #if !defined(CH_CFG_USE_DYNAMIC)
#define CH_CFG_USE_DYNAMIC FALSE #define CH_CFG_USE_DYNAMIC TRUE
#endif #endif
/** @} */ /** @} */

View File

@ -324,7 +324,7 @@
* @note Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. * @note Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS.
*/ */
#if !defined(CH_CFG_USE_DYNAMIC) #if !defined(CH_CFG_USE_DYNAMIC)
#define CH_CFG_USE_DYNAMIC FALSE #define CH_CFG_USE_DYNAMIC TRUE
#endif #endif
/** @} */ /** @} */

View File

@ -188,6 +188,10 @@ void runRusEfi(void) {
// Perform hardware initialization that doesn't need configuration // Perform hardware initialization that doesn't need configuration
initHardwareNoConfig(); initHardwareNoConfig();
#if EFI_ETHERNET
startEthernetConsole();
#endif
#if EFI_USB_SERIAL #if EFI_USB_SERIAL
startUsbConsole(); startUsbConsole();
#endif #endif