enable ethernet on atlas (#3348)
* enable h7 ethernet * some ethernet settings while we're here * mac address * misc * extra spaces Co-authored-by: Matthew Kennedy <makenne@microsoft.com>
This commit is contained in:
parent
b4a9d7b1fc
commit
1a0bce808a
|
@ -67,6 +67,22 @@
|
||||||
"isDefault": true
|
"isDefault": true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"label": "Build Firmware (Atlas H7)",
|
||||||
|
"type": "shell",
|
||||||
|
"command": "make -j16 PROJECT_BOARD=atlas PROJECT_CPU=ARCH_STM32H7",
|
||||||
|
"windows": {
|
||||||
|
"command": "wsl bash -lc 'make -j12 PROJECT_BOARD=atlas PROJECT_CPU=ARCH_STM32H7'"
|
||||||
|
},
|
||||||
|
"options": {
|
||||||
|
"cwd": "${workspaceRoot}/firmware"
|
||||||
|
},
|
||||||
|
"problemMatcher": [],
|
||||||
|
"group": {
|
||||||
|
"kind": "build",
|
||||||
|
"isDefault": true
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"label": "Build Firmware (hellen72)",
|
"label": "Build Firmware (hellen72)",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 45965706d04b640c2dd7d267afc63e82aac56a32
|
Subproject commit 8bae576fdde4e2220bfdc577ca71920bcf1043b2
|
|
@ -11,11 +11,15 @@ DDEFS += -DFIRMWARE_ID=\"atlas\" -DDEFAULT_ENGINE_TYPE=MINIMAL_PINS
|
||||||
# DEFS += -DEFI_SOFTWARE_KNOCK=TRUE
|
# DEFS += -DEFI_SOFTWARE_KNOCK=TRUE
|
||||||
|
|
||||||
# disable hardware serial ports on H7
|
# disable hardware serial ports on H7
|
||||||
DDEFS += -DTS_NO_PRIMARY -DTS_NO_SECONDARY
|
# DDEFS += -DTS_NO_PRIMARY -DTS_NO_SECONDARY
|
||||||
|
|
||||||
# We are running on Proteus hardware!
|
# We are running on Atlas hardware!
|
||||||
DDEFS += -DHW_ATLAS=1
|
DDEFS += -DHW_ATLAS=1
|
||||||
|
|
||||||
|
# Atlas needs networking library
|
||||||
|
LWIP = yes
|
||||||
|
DDEFS += -DEFI_ETHERNET=TRUE
|
||||||
|
|
||||||
# Shared variables
|
# Shared variables
|
||||||
ALLCPPSRC += $(BOARDCPPSRC)
|
ALLCPPSRC += $(BOARDCPPSRC)
|
||||||
ALLINC += $(BOARDINC)
|
ALLINC += $(BOARDINC)
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
export PROJECT_BOARD=atlas
|
export PROJECT_BOARD=atlas
|
||||||
export PROJECT_CPU = ARCH_STM32H7
|
export PROJECT_CPU=ARCH_STM32H7
|
||||||
|
|
||||||
bash ../common_make.sh
|
bash ../common_make.sh
|
||||||
|
|
|
@ -37,11 +37,11 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
void write(const uint8_t* buffer, size_t size) override {
|
void write(const uint8_t* buffer, size_t size) override {
|
||||||
lwip_send(connectionSocket, buffer, size, 0);
|
lwip_send(connectionSocket, buffer, size, /*flags =*/ 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override {
|
size_t readTimeout(uint8_t* buffer, size_t size, int /*timeout*/) override {
|
||||||
auto result = lwip_recv(connectionSocket, buffer, size, 0);
|
auto result = lwip_recv(connectionSocket, buffer, size, /*flags =*/ 0);
|
||||||
|
|
||||||
if (result == -1) {
|
if (result == -1) {
|
||||||
do_connection();
|
do_connection();
|
||||||
|
@ -78,6 +78,8 @@ struct EthernetThread : public TunerstudioThread {
|
||||||
static EthernetThread ethernetConsole;
|
static EthernetThread ethernetConsole;
|
||||||
|
|
||||||
void startEthernetConsole() {
|
void startEthernetConsole() {
|
||||||
|
#ifndef STM32H7
|
||||||
|
// TODO: why does this break H7? I thought the pins were the same?
|
||||||
efiSetPadMode("ethernet", GPIOA_1, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOA_1, PAL_MODE_ALTERNATE(0xb));
|
||||||
efiSetPadMode("ethernet", GPIOA_2, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOA_2, PAL_MODE_ALTERNATE(0xb));
|
||||||
efiSetPadMode("ethernet", GPIOA_7, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOA_7, PAL_MODE_ALTERNATE(0xb));
|
||||||
|
@ -91,6 +93,7 @@ void startEthernetConsole() {
|
||||||
efiSetPadMode("ethernet", GPIOG_11, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOG_11, PAL_MODE_ALTERNATE(0xb));
|
||||||
efiSetPadMode("ethernet", GPIOG_13, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOG_13, PAL_MODE_ALTERNATE(0xb));
|
||||||
efiSetPadMode("ethernet", GPIOG_14, PAL_MODE_ALTERNATE(0xb));
|
efiSetPadMode("ethernet", GPIOG_14, PAL_MODE_ALTERNATE(0xb));
|
||||||
|
#endif // STM32H7
|
||||||
|
|
||||||
ethernetConsole.Start();
|
ethernetConsole.Start();
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,4 +60,20 @@
|
||||||
|
|
||||||
#define LWIP_COMPAT_SOCKETS 0
|
#define LWIP_COMPAT_SOCKETS 0
|
||||||
|
|
||||||
|
#define LWIP_RAW 0
|
||||||
|
#define LWIP_TCP 1
|
||||||
|
#define LWIP_UDP 0
|
||||||
|
#define LWIP_STATS 0
|
||||||
|
|
||||||
|
// In theory we're only talking to a single PC, so we don't need a big ARP table
|
||||||
|
#define ARP_TABLE_SIZE 4
|
||||||
|
|
||||||
|
// ascii `rus`
|
||||||
|
#define LWIP_ETHADDR_0 0x72
|
||||||
|
#define LWIP_ETHADDR_1 0x75
|
||||||
|
#define LWIP_ETHADDR_2 0x73
|
||||||
|
#define LWIP_ETHADDR_3 0x12
|
||||||
|
#define LWIP_ETHADDR_4 0x34
|
||||||
|
#define LWIP_ETHADDR_5 0x56
|
||||||
|
|
||||||
#endif /* LWIP_HDR_LWIPOPTS_H__ */
|
#endif /* LWIP_HDR_LWIPOPTS_H__ */
|
||||||
|
|
Loading…
Reference in New Issue