-
Notifications
You must be signed in to change notification settings - Fork 940
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into tft-gui-work
- Loading branch information
Showing
135 changed files
with
3,068 additions
and
960 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
name: Test Simulator | ||
|
||
on: | ||
schedule: | ||
- cron: "0 0 * * *" # Run every day at midnight | ||
workflow_dispatch: {} | ||
|
||
jobs: | ||
test-simulator: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Install libbluetooth | ||
shell: bash | ||
run: | | ||
sudo apt-get update --fix-missing | ||
sudo apt-get install -y libbluetooth-dev libgpiod-dev libyaml-cpp-dev openssl libssl-dev libulfius-dev liborcania-dev | ||
- name: Checkout code | ||
uses: actions/checkout@v4 | ||
with: | ||
submodules: recursive | ||
|
||
- name: Upgrade python tools | ||
shell: bash | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install -U platformio adafruit-nrfutil | ||
pip install -U meshtastic --pre | ||
- name: Upgrade platformio | ||
shell: bash | ||
run: | | ||
pio upgrade | ||
- name: Build Native | ||
run: bin/build-native.sh | ||
|
||
# We now run integration test before other build steps (to quickly see runtime failures) | ||
- name: Build for native | ||
run: platformio run -e native | ||
|
||
- name: Integration test | ||
run: | | ||
.pio/build/native/program & sleep 10 # 5 seconds was not enough | ||
echo "Simulator started, launching python test..." | ||
python3 -c 'from meshtastic.test import testSimulator; testSimulator()' | ||
- name: PlatformIO Tests | ||
run: platformio test -e native --junit-output-path testreport.xml | ||
|
||
- name: Test Report | ||
uses: dorny/[email protected] | ||
if: success() || failure() # run this step even if previous step failed | ||
with: | ||
name: PlatformIO Tests | ||
path: testreport.xml | ||
reporter: java-junit |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,208 @@ | ||
/* | ||
* lfs utility functions | ||
* | ||
* Copyright (c) 2017, Arm Limited. All rights reserved. | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
|
||
// MESHTASTIC/@geeksville note: This file is copied from the Adafruit nrf52 arduino lib. And we use a special -include in | ||
// nrf52.ini to load it before EVERY file we do this hack because the default definitions for LFS_ASSERT are quite poor and we | ||
// don't want to fork the adafruit lib (again) and send in a PR that they probably won't merge anyways. This file might break if | ||
// they ever update lfs.util on their side, in which case we'll need to update this file to match their new version. The version | ||
// this is a copy from is almost exactly | ||
// https://github.com/adafruit/Adafruit_nRF52_Arduino/blob/c25d93268a3b9c23e9a1ccfcaf9b208beca624ca/libraries/Adafruit_LittleFS/src/littlefs/lfs_util.h | ||
|
||
#ifndef LFS_UTIL_H | ||
#define LFS_UTIL_H | ||
|
||
// Users can override lfs_util.h with their own configuration by defining | ||
// LFS_CONFIG as a header file to include (-DLFS_CONFIG=lfs_config.h). | ||
// | ||
// If LFS_CONFIG is used, none of the default utils will be emitted and must be | ||
// provided by the config file. To start I would suggest copying lfs_util.h and | ||
// modifying as needed. | ||
#ifdef LFS_CONFIG | ||
#define LFS_STRINGIZE(x) LFS_STRINGIZE2(x) | ||
#define LFS_STRINGIZE2(x) #x | ||
#include LFS_STRINGIZE(LFS_CONFIG) | ||
#else | ||
|
||
// System includes | ||
#include <stdbool.h> | ||
#include <stdint.h> | ||
#include <string.h> | ||
|
||
#ifndef LFS_NO_MALLOC | ||
#include <stdlib.h> | ||
#endif | ||
#ifndef LFS_NO_ASSERT | ||
#include <assert.h> | ||
#endif | ||
|
||
#if !defined(LFS_NO_DEBUG) || !defined(LFS_NO_WARN) || !defined(LFS_NO_ERROR) | ||
#include <stdio.h> | ||
#endif | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
// Macros, may be replaced by system specific wrappers. Arguments to these | ||
// macros must not have side-effects as the macros can be removed for a smaller | ||
// code footprint | ||
|
||
// Logging functions | ||
#ifndef LFS_NO_DEBUG | ||
|
||
void logLegacy(const char *level, const char *fmt, ...); | ||
#define LFS_DEBUG(fmt, ...) logLegacy("DEBUG", "lfs debug:%d: " fmt "\n", __LINE__, __VA_ARGS__) | ||
#else | ||
#define LFS_DEBUG(fmt, ...) | ||
#endif | ||
|
||
#ifndef LFS_NO_WARN | ||
#define LFS_WARN(fmt, ...) logLegacy("WARN", "lfs warn:%d: " fmt "\n", __LINE__, __VA_ARGS__) | ||
#else | ||
#define LFS_WARN(fmt, ...) | ||
#endif | ||
|
||
#ifndef LFS_NO_ERROR | ||
#define LFS_ERROR(fmt, ...) logLegacy("ERROR", "lfs error:%d: " fmt "\n", __LINE__, __VA_ARGS__) | ||
#else | ||
#define LFS_ERROR(fmt, ...) | ||
#endif | ||
|
||
// Runtime assertions | ||
#ifndef LFS_NO_ASSERT | ||
#define LFS_ASSERT(test) assert(test) | ||
#else | ||
extern void lfs_assert(const char *reason); | ||
#define LFS_ASSERT(test) \ | ||
if (!(test)) \ | ||
lfs_assert(#test) | ||
#endif | ||
|
||
// Builtin functions, these may be replaced by more efficient | ||
// toolchain-specific implementations. LFS_NO_INTRINSICS falls back to a more | ||
// expensive basic C implementation for debugging purposes | ||
|
||
// Min/max functions for unsigned 32-bit numbers | ||
static inline uint32_t lfs_max(uint32_t a, uint32_t b) | ||
{ | ||
return (a > b) ? a : b; | ||
} | ||
|
||
static inline uint32_t lfs_min(uint32_t a, uint32_t b) | ||
{ | ||
return (a < b) ? a : b; | ||
} | ||
|
||
// Find the next smallest power of 2 less than or equal to a | ||
static inline uint32_t lfs_npw2(uint32_t a) | ||
{ | ||
#if !defined(LFS_NO_INTRINSICS) && (defined(__GNUC__) || defined(__CC_ARM)) | ||
return 32 - __builtin_clz(a - 1); | ||
#else | ||
uint32_t r = 0; | ||
uint32_t s; | ||
a -= 1; | ||
s = (a > 0xffff) << 4; | ||
a >>= s; | ||
r |= s; | ||
s = (a > 0xff) << 3; | ||
a >>= s; | ||
r |= s; | ||
s = (a > 0xf) << 2; | ||
a >>= s; | ||
r |= s; | ||
s = (a > 0x3) << 1; | ||
a >>= s; | ||
r |= s; | ||
return (r | (a >> 1)) + 1; | ||
#endif | ||
} | ||
|
||
// Count the number of trailing binary zeros in a | ||
// lfs_ctz(0) may be undefined | ||
static inline uint32_t lfs_ctz(uint32_t a) | ||
{ | ||
#if !defined(LFS_NO_INTRINSICS) && defined(__GNUC__) | ||
return __builtin_ctz(a); | ||
#else | ||
return lfs_npw2((a & -a) + 1) - 1; | ||
#endif | ||
} | ||
|
||
// Count the number of binary ones in a | ||
static inline uint32_t lfs_popc(uint32_t a) | ||
{ | ||
#if !defined(LFS_NO_INTRINSICS) && (defined(__GNUC__) || defined(__CC_ARM)) | ||
return __builtin_popcount(a); | ||
#else | ||
a = a - ((a >> 1) & 0x55555555); | ||
a = (a & 0x33333333) + ((a >> 2) & 0x33333333); | ||
return (((a + (a >> 4)) & 0xf0f0f0f) * 0x1010101) >> 24; | ||
#endif | ||
} | ||
|
||
// Find the sequence comparison of a and b, this is the distance | ||
// between a and b ignoring overflow | ||
static inline int lfs_scmp(uint32_t a, uint32_t b) | ||
{ | ||
return (int)(unsigned)(a - b); | ||
} | ||
|
||
// Convert from 32-bit little-endian to native order | ||
static inline uint32_t lfs_fromle32(uint32_t a) | ||
{ | ||
#if !defined(LFS_NO_INTRINSICS) && ((defined(BYTE_ORDER) && BYTE_ORDER == ORDER_LITTLE_ENDIAN) || \ | ||
(defined(__BYTE_ORDER) && __BYTE_ORDER == __ORDER_LITTLE_ENDIAN) || \ | ||
(defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__)) | ||
return a; | ||
#elif !defined(LFS_NO_INTRINSICS) && \ | ||
((defined(BYTE_ORDER) && BYTE_ORDER == ORDER_BIG_ENDIAN) || (defined(__BYTE_ORDER) && __BYTE_ORDER == __ORDER_BIG_ENDIAN) || \ | ||
(defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__)) | ||
return __builtin_bswap32(a); | ||
#else | ||
return (((uint8_t *)&a)[0] << 0) | (((uint8_t *)&a)[1] << 8) | (((uint8_t *)&a)[2] << 16) | (((uint8_t *)&a)[3] << 24); | ||
#endif | ||
} | ||
|
||
// Convert to 32-bit little-endian from native order | ||
static inline uint32_t lfs_tole32(uint32_t a) | ||
{ | ||
return lfs_fromle32(a); | ||
} | ||
|
||
// Calculate CRC-32 with polynomial = 0x04c11db7 | ||
void lfs_crc(uint32_t *crc, const void *buffer, size_t size); | ||
|
||
// Allocate memory, only used if buffers are not provided to littlefs | ||
static inline void *lfs_malloc(size_t size) | ||
{ | ||
#ifndef LFS_NO_MALLOC | ||
extern void *pvPortMalloc(size_t xWantedSize); | ||
return pvPortMalloc(size); | ||
#else | ||
(void)size; | ||
return NULL; | ||
#endif | ||
} | ||
|
||
// Deallocate memory, only used if buffers are not provided to littlefs | ||
static inline void lfs_free(void *p) | ||
{ | ||
#ifndef LFS_NO_MALLOC | ||
extern void vPortFree(void *pv); | ||
vPortFree(p); | ||
#else | ||
(void)p; | ||
#endif | ||
} | ||
|
||
#ifdef __cplusplus | ||
} /* extern "C" */ | ||
#endif | ||
|
||
#endif | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,37 +1,42 @@ | ||
|
||
|
||
import subprocess | ||
import configparser | ||
import traceback | ||
import sys | ||
import subprocess | ||
|
||
|
||
def readProps(prefsLoc): | ||
"""Read the version of our project as a string""" | ||
|
||
config = configparser.RawConfigParser() | ||
config.read(prefsLoc) | ||
version = dict(config.items('VERSION')) | ||
verObj = dict(short = "{}.{}.{}".format(version["major"], version["minor"], version["build"]), | ||
long = "unset") | ||
version = dict(config.items("VERSION")) | ||
verObj = dict( | ||
short="{}.{}.{}".format(version["major"], version["minor"], version["build"]), | ||
long="unset", | ||
) | ||
|
||
# Try to find current build SHA if if the workspace is clean. This could fail if git is not installed | ||
try: | ||
sha = subprocess.check_output( | ||
['git', 'rev-parse', '--short', 'HEAD']).decode("utf-8").strip() | ||
isDirty = subprocess.check_output( | ||
['git', 'diff', 'HEAD']).decode("utf-8").strip() | ||
sha = ( | ||
subprocess.check_output(["git", "rev-parse", "--short", "HEAD"]) | ||
.decode("utf-8") | ||
.strip() | ||
) | ||
isDirty = ( | ||
subprocess.check_output(["git", "diff", "HEAD"]).decode("utf-8").strip() | ||
) | ||
suffix = sha | ||
# if isDirty: | ||
# # short for 'dirty', we want to keep our verstrings source for protobuf reasons | ||
# suffix = sha + "-d" | ||
verObj['long'] = "{}.{}.{}.{}".format( | ||
version["major"], version["minor"], version["build"], suffix) | ||
verObj["long"] = "{}.{}.{}.{}".format( | ||
version["major"], version["minor"], version["build"], suffix | ||
) | ||
except: | ||
# print("Unexpected error:", sys.exc_info()[0]) | ||
# traceback.print_exc() | ||
verObj['long'] = verObj['short'] | ||
verObj["long"] = verObj["short"] | ||
|
||
# print("firmware version " + verStr) | ||
return verObj | ||
|
||
|
||
# print("path is" + ','.join(sys.path)) |
Oops, something went wrong.