Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial restructure to support multiple target architectures #1675

Merged
merged 22 commits into from
May 1, 2019
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
baa4f00
Initial restructure to support multiple platforms
mikee47 Apr 25, 2019
5d7ad1d
Makefile fixes and remove `apptest` directory
mikee47 Apr 27, 2019
cd9919a
Use `Arch` directory instead of `Platform`
mikee47 Apr 27, 2019
f4f9b61
Add makefile rule to run stack trace and update instructions
mikee47 Apr 28, 2019
6c58abb
Move `Services/libb64` into `Components`
mikee47 Apr 28, 2019
1149ba8
Move `Services/WebHelpers` into `SmingCore/Network`
mikee47 Apr 28, 2019
e120909
Rename `SmingCore` to `Core`
mikee47 Apr 28, 2019
acf29f3
Add help documenation to makefiles
mikee47 Apr 29, 2019
78b419c
WebHelpers now subject to coding style
mikee47 Apr 29, 2019
a98ba2e
Add `make help` and `make list-config` to travis/appveyor, update cod…
mikee47 Apr 29, 2019
7a1d8c1
Update `Doxyfile`
mikee47 Apr 29, 2019
3e68e58
Fix esptool2 submodule dependency
mikee47 Apr 29, 2019
100c6c9
Add individual .submodule dependencies for user libraries, make them …
mikee47 Apr 30, 2019
85a5ea7
Add optional `TRACE` variable for `decode-tracktrace` target
mikee47 Apr 30, 2019
bc3367e
Add `SmingCore/SmingCore.h` legacy file with warnings and link to Wik…
mikee47 Apr 30, 2019
e849638
In `decode-stacktrace.py`, use `sys.stdin.readline()` instead of `raw…
mikee47 Apr 30, 2019
b207eed
Remove sorting from `PrintHelp` make function to improve compatibilit…
mikee47 Apr 30, 2019
a8e25f6
Replace `#include` guards with `#pragma once`
mikee47 Apr 30, 2019
9fb2b9a
Minor change to `building.md`
mikee47 Apr 30, 2019
4498378
Fix coding style
mikee47 Apr 30, 2019
f0ad288
Fix line endings by running everything through dos2unix
mikee47 Apr 30, 2019
c929c93
Merge SmingCore warning #pragmas
mikee47 Apr 30, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
110 changes: 58 additions & 52 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -1,94 +1,100 @@
[submodule "Sming/third-party/rboot"]
path = Sming/third-party/rboot
url = https://github.com/raburton/rboot.git
ignore = dirty
[submodule "Sming.wiki"]
path = docs/wiki
url = https://github.com/SmingHub/Sming.wiki.git
ignore = dirty
[submodule "Sming/third-party/pwm"]
path = Sming/third-party/pwm
[submodule "spiffs"]
path = Sming/Components/spiffs
url = https://github.com/pellepl/spiffs.git
ignore = dirty
[submodule "http-parser"]
path = Sming/Components/http-parser
url = https://github.com/nodejs/http-parser.git
ignore = dirty
[submodule "ws_parser"]
path = Sming/Components/ws_parser
url = https://github.com/charliesome/ws_parser.git
ignore = dirty
[submodule "mqtt-codec"]
path = Sming/Components/mqtt-codec
url = https://github.com/slaff/mqtt-codec.git
ignore = dirty
[submodule "libyuarel"]
path = Sming/Components/libyuarel
url = https://github.com/jacketizer/libyuarel.git
ignore = dirty

[submodule "ESP8266.rboot"]
path = Sming/Arch/Esp8266/Components/rboot/rboot
url = https://github.com/raburton/rboot.git
ignore = dirty
[submodule "ESP8266.new-pwm"]
path = Sming/Arch/Esp8266/Components/pwm/new-pwm
url = https://github.com/StefanBruens/ESP8266_new_pwm.git
ignore = dirty
[submodule "Sming/third-party/axtls-8266"]
path = Sming/third-party/axtls-8266
ignore = dirty
[submodule "ESP8266.axtls-8266"]
path = Sming/Arch/Esp8266/Components/axtls-8266/axtls-8266
url = https://github.com/igrr/axtls-8266.git
ignore = dirty
[submodule "Sming/third-party/spiffs"]
path = Sming/third-party/spiffs
url = https://github.com/pellepl/spiffs.git
[submodule "Sming/third-party/umm_malloc"]
path = Sming/third-party/umm_malloc
ignore = dirty
[submodule "ESP8266.umm_malloc"]
path = Sming/Arch/Esp8266/Components/custom_heap/umm_malloc
url = https://github.com/rhempel/umm_malloc.git
ignore = dirty
[submodule "Sming/third-party/esp-open-lwip"]
path = Sming/third-party/esp-open-lwip
[submodule "ESP8266.esp-open-lwip"]
path = Sming/Arch/Esp8266/Components/esp-open-lwip/esp-open-lwip
url = https://github.com/pfalcon/esp-open-lwip.git
ignore = dirty
[submodule "Sming/third-party/http-parser"]
path = Sming/third-party/http-parser
url = https://github.com/nodejs/http-parser.git
[submodule "ESP8266.lwip2"]
path = Sming/Arch/Esp8266/Components/lwip2/lwip2
url = https://github.com/d-a-v/esp82xx-nonos-linklayer.git
ignore = dirty
[submodule "Sming/third-party/ws_parser"]
path = Sming/third-party/ws_parser
url = https://github.com/charliesome/ws_parser.git

[submodule "ESP8266.Sdk"]
path = Sming/Arch/Esp8266/Components/Sdk/ESP8266_NONOS_SDK
url = https://github.com/espressif/ESP8266_NONOS_SDK.git
ignore = dirty
[submodule "Sming/Libraries/Adafruit_ST7735"]
[submodule "ESP8266.esptool2"]
path = Sming/Arch/Esp8266/Tools/esptool2
url = https://github.com/raburton/esptool2.git
ignore = dirty

[submodule "Libraries.Adafruit_ST7735"]
path = Sming/Libraries/Adafruit_ST7735
url = https://github.com/adafruit/Adafruit-ST7735-Library.git
ignore = dirty
[submodule "Sming/Libraries/Adafruit_SSD1306"]
[submodule "Libraries.Adafruit_SSD1306"]
path = Sming/Libraries/Adafruit_SSD1306
url = https://github.com/adafruit/Adafruit_SSD1306.git
ignore = dirty
[submodule "Sming/Libraries/Adafruit_BME280_Library"]
[submodule "Libraries.Adafruit_BME280_Library"]
path = Sming/Libraries/Adafruit_BME280_Library
url = https://github.com/adafruit/Adafruit_BME280_Library.git
ignore = dirty
[submodule "Sming/Libraries/Adafruit_Sensor"]
[submodule "Libraries.Adafruit_Sensor"]
path = Sming/Libraries/Adafruit_Sensor
url = https://github.com/adafruit/Adafruit_Sensor
ignore = dirty
[submodule "Sming/third-party/lwip2"]
path = Sming/third-party/lwip2
url = https://github.com/d-a-v/esp82xx-nonos-linklayer.git
ignore = dirty
[submodule "Sming/third-party/ESP8266_NONOS_SDK"]
path = Sming/third-party/ESP8266_NONOS_SDK
url = https://github.com/espressif/ESP8266_NONOS_SDK.git
ignore = dirty
[submodule "tools/esptool2"]
path = tools/esptool2
url = https://github.com/raburton/esptool2.git
ignore = dirty
[submodule "Sming/Libraries/RingBufCPP"]
[submodule "Libraries.RingBufCPP"]
path = Sming/Libraries/RingBufCPP
url = https://github.com/wizard97/Embedded_RingBuf_CPP.git
ignore = dirty
[submodule "Sming/Libraries/IR"]
[submodule "Libraries.IR"]
path = Sming/Libraries/IR
url = https://github.com/markszabo/IRremoteESP8266.git
ignore = dirty
[submodule "Sming/Libraries/DHTesp"]
[submodule "Libraries.DHTesp"]
path = Sming/Libraries/DHTesp
url = https://github.com/beegee-tokyo/DHTesp.git
ignore = dirty
[submodule "Sming/third-party/ITEADLIB_Arduino_Nextion"]
[submodule "Libraries.ITEADLIB_Arduino_Nextion"]
path = Sming/Libraries/ITEADLIB_Arduino_Nextion
url = https://github.com/itead/ITEADLIB_Arduino_Nextion.git
ignore = dirty
[submodule "Sming/Libraries/DFRobotDFPlayerMini"]
[submodule "Libraries.DFRobotDFPlayerMini"]
path = Sming/Libraries/DFRobotDFPlayerMini
url = https://github.com/DFRobot/DFRobotDFPlayerMini.git
ignore = dirty
[submodule "Sming/Libraries/TM1637"]
[submodule "Libraries.TM1637"]
path = Sming/Libraries/TM1637
url = https://github.com/avishorp/TM1637.git
ignore = dirty
[submodule "Sming/third-party/mqtt-codec"]
path = Sming/third-party/mqtt-codec
url = https://github.com/slaff/mqtt-codec.git
ignore = dirty
[submodule "Sming/third-party/libyuarel"]
path = Sming/third-party/libyuarel
url = https://github.com/jacketizer/libyuarel.git

2 changes: 2 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,8 @@ script:
- cd $SMING_HOME
- if [ "$SDK_VERSION" == "2.0.0" ]; then ../.travis/tools/clang/format-pr.sh; fi
- cd $SMING_HOME
- make help
- make list-config
- make STRICT=1
- make samples
- make clean samples-clean
Expand Down
2 changes: 1 addition & 1 deletion .travis/tools/clang/format-pr.sh
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ $CLANG_FORMAT --version
cd $SMING_HOME/..

# Get list of modified files
files_to_lint="$(git diff --name-only --diff-filter=ACMRTUXB $TRAVIS_COMMIT_RANGE | grep '^[^.]*[.]\(c\|cpp\|h\)$' | grep -e Sming/SmingCore -e samples || true)"
files_to_lint="$(git diff --name-only --diff-filter=ACMRTUXB $TRAVIS_COMMIT_RANGE | grep '^[^.]*[.]\(c\|cpp\|h\)$' | grep -e Sming/Core -e Sming/Platform -e Sming/Arch/.+/Core -e Sming/Arch/.+/Platform -e samples || true)"

for f in $files_to_lint; do

Expand Down
File renamed without changes.
1 change: 1 addition & 0 deletions Sming/Arch/Esp8266/Components/Sdk/ESP8266_NONOS_SDK
Submodule ESP8266_NONOS_SDK added at e4434a
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,7 @@
* Note: uart_detach_all() should be called at startup, i.e. from user_init().
*/

#ifndef ESP_UART_H
#define ESP_UART_H
#pragma once

#if defined (__cplusplus)
extern "C" {
Expand Down Expand Up @@ -427,5 +426,3 @@ void uart_restore_interrupts();
#if defined (__cplusplus)
} // extern "C"
#endif

#endif // ESP_UART_H
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@
#include "Clock.h"
#include "Digital.h"

#include "espinc/uart.h"
#include "driver/uart.h"
slaff marked this conversation as resolved.
Show resolved Hide resolved
#include "espinc/peri.h"

#include "Data/Buffer/SerialBuffer.h"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
*/

#include <user_config.h>
#include "gdb_hooks.h"
#include "gdb/gdb_hooks.h"

extern void __real_system_restart_local();

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#include "../include/user_config.h"
#include "../include/esp_cplusplus.h"
#include <user_config.h>
#include "include/esp_cplusplus.h"
#include <stdlib.h>

////////////////////////////////////////////////////////////////////////
Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,7 @@
*
****/

#ifndef _SYSTEM_INCLUDE_ESP_CPLUSPLUS_H_
#define _SYSTEM_INCLUDE_ESP_CPLUSPLUS_H_
#pragma once

#ifdef __cplusplus
extern "C" {
Expand All @@ -23,5 +22,3 @@ extern void (*__init_array_start)(void);
extern void (*__init_array_end)(void);

void cpp_core_initialize();

#endif /* _SYSTEM_INCLUDE_ESP_CPLUSPLUS_H_ */
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@
*
****/

#ifndef _SYSTEM_INCLUDE_ESP_SYSTEMAPI_H_
#define _SYSTEM_INCLUDE_ESP_SYSTEMAPI_H_
#pragma once

#include <ets_sys.h>
#include <osapi.h>
Expand Down Expand Up @@ -126,5 +125,3 @@ extern void ets_isr_mask(unsigned intr);
extern void ets_isr_unmask(unsigned intr);

typedef signed short file_t;

#endif /* _SYSTEM_INCLUDE_ESP_SYSTEMAPI_H_ */
Original file line number Diff line number Diff line change
@@ -1,64 +1,61 @@
/*
* esp_promiscuous.h
*
* Internal structures for decoding WiFi in promiscuous mode
*
* See ESP8266 Technical Reference, Chapter 14: Sniffer Introduction
*/

#ifndef _ESP_WIFI_SNIFFER_H_
#define _ESP_WIFI_SNIFFER_H_

#include <user_config.h>

/* ==============================================
Promiscous callback structures, see ESP manual
============================================== */
struct RxControl {
signed rssi : 8;
unsigned rate : 4;
unsigned is_group : 1;
unsigned : 1;
unsigned sig_mode : 2;
unsigned legacy_length : 12;
unsigned damatch0 : 1;
unsigned damatch1 : 1;
unsigned bssidmatch0 : 1;
unsigned bssidmatch1 : 1;
unsigned MCS : 7;
unsigned CWB : 1;
unsigned HT_length : 16;
unsigned Smoothing : 1;
unsigned Not_Sounding : 1;
unsigned : 1;
unsigned Aggregation : 1;
unsigned STBC : 2;
unsigned FEC_CODING : 1;
unsigned SGI : 1;
unsigned rxend_state : 8;
unsigned ampdu_cnt : 8;
unsigned channel : 4;
unsigned : 12;
};

struct LenSeq {
uint16_t length;
uint16_t seq;
uint8_t address3[6];
};

struct sniffer_buf {
struct RxControl rx_ctrl;
uint8_t buf[36];
uint16_t cnt;
struct LenSeq lenseq[1];
};

struct sniffer_buf2 {
struct RxControl rx_ctrl;
uint8_t buf[112];
uint16_t cnt;
uint16_t len;
};

#endif /* _ESP_WIFI_SNIFFER_H_ */
/*
* esp_promiscuous.h
*
* Internal structures for decoding WiFi in promiscuous mode
*
* See ESP8266 Technical Reference, Chapter 14: Sniffer Introduction
*/

#pragma once

#include <user_config.h>

/* ==============================================
Promiscous callback structures, see ESP manual
============================================== */
struct RxControl {
signed rssi : 8;
unsigned rate : 4;
unsigned is_group : 1;
unsigned : 1;
unsigned sig_mode : 2;
unsigned legacy_length : 12;
unsigned damatch0 : 1;
unsigned damatch1 : 1;
unsigned bssidmatch0 : 1;
unsigned bssidmatch1 : 1;
unsigned MCS : 7;
unsigned CWB : 1;
unsigned HT_length : 16;
unsigned Smoothing : 1;
unsigned Not_Sounding : 1;
unsigned : 1;
unsigned Aggregation : 1;
unsigned STBC : 2;
unsigned FEC_CODING : 1;
unsigned SGI : 1;
unsigned rxend_state : 8;
unsigned ampdu_cnt : 8;
unsigned channel : 4;
unsigned : 12;
};

struct LenSeq {
uint16_t length;
uint16_t seq;
uint8_t address3[6];
};

struct sniffer_buf {
struct RxControl rx_ctrl;
uint8_t buf[36];
uint16_t cnt;
struct LenSeq lenseq[1];
};

struct sniffer_buf2 {
struct RxControl rx_ctrl;
uint8_t buf[112];
uint16_t cnt;
uint16_t len;
};
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,7 @@
// Updated, compatible version of c_types.h
// Just removed types declared in <stdint.h>

#ifndef _SYSTEM_INCLUDE_ESPINC_C_TYPES_COMPATIBLE_H_
#define _SYSTEM_INCLUDE_ESPINC_C_TYPES_COMPATIBLE_H_
#pragma once

/*typedef unsigned char uint8_t;
typedef signed char sint8_t;
Expand Down Expand Up @@ -100,5 +99,3 @@ typedef unsigned char bool;


#endif /* !__cplusplus */

#endif /* _SYSTEM_INCLUDE_ESPINC_C_TYPES_COMPATIBLE_H_ */
Loading