commit | 1896e2f22ad414cf802cea5d24a626539a898511 | [log] [tgz] |
---|---|---|
author | Wyatt Hepler <hepler@google.com> | Wed Mar 04 08:36:04 2020 -0800 |
committer | CQ Bot Account <commit-bot@chromium.org> | Wed Mar 04 20:03:04 2020 +0000 |
tree | 72cfcf55ee74921644610879c48d9a1bcde12d75 | |
parent | 9d35e0227acb71d17a5e596518dcb76aaa2d3645 [diff] |
pw_presubmit: Change step banner style No longer attempt to form boxes for each step, which does not work well when there are log messages during a step. Example: ═══════════════════════════════════════════════════════════════════════════════╗ Presubmit checks for pigweed ║ ═══════════════════════════════════════════════════════════════════════════════╝ 20200304 10:28:05 INF Running 17 of 17 checks on 521 files in /home/hepler/pw/pigweed ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓ 1/17 init_cipd 521 files PASSED init_cipd 0:00.8 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓ 2/17 init_virtualenv 521 files PASSED init_virtualenv 0:00.0 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓ 3/17 copyright_notice 453 files 20200304 10:28:06 WRN 1 file with a missing or incorrect copyright notice: /home/hepler/pw/pigweed/pw_presubmit/py/pw_presubmit/format_code.py FAILED copyright_notice 0:00.0 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛ ════════╦══════════════════════════════════════════════════════════╦═══════════╗ FAILED ║ 17 checks: 2 passed, 1 failed, 14 did not run ║ 0:00.8 ║ ════════╩══════════════════════════════════════════════════════════╩═══════════╝ Change-Id: Ib9bb1049b61e7b7962c22dd814f9295e1c551b8b
Pigweed is a collection of embedded-focused libraries, called “modules”. These modules are designed for small-footprint MMU-less microcontrollers like the ST Micro STM32L452 or the Nordic NRF82832. The modules are designed to facilitate easy integration into existing codebases.
Pigweed is in the early stages of development, and should be considered experimental. We’re continuing to evolve the platform and add new modules. We value developer feedback along the way.
Pigweed is an open source project with a code of conduct that we expect everyone who interacts with the project to respect.
$ git clone sso://pigweed.googlesource.com/pigweed/pigweed ~/pigweed $ cd ~/pigweed # Only need to run auth-login once per machine. $ pw_env_setup/py/pw_env_setup/cipd_setup/wrapper.py auth-login $ . pw_env_setup/bootstrap.sh
You can use . pw_env_setup/setup.sh
in place of . pw_env_setup/bootstrap.sh
. Both should work every time, but bootstrap.sh
tends to remove and reinstall things at the expense of time whereas setup.sh
assumes things have already been installed and only sets environment variables.
If you‘re using Homebrew and you get an error saying module 'http.client' has no attribute 'HTTPSConnection'
then your Homebrew Python was not set up to support SSL. Ensure it’s installed with brew install openssl
and then run brew uninstall python && brew install python
. After that things should work.
The environment setup script will pull down the versions of tools necessary to build Pigweed and add them to your environment. You can then build with GN, CMake, or Bazel. You can also confirm you're getting the right versions of tools—they should be installed under .cipd/
.
Build for the host with GN
$ which gn ~/pigweed/.cipd/pigweed.ensure/gn $ gn gen out/host $ ninja -C out/host
Build for the host with CMake
$ which cmake ~/pigweed/.cipd/pigweed.ensure/bin/cmake $ cmake -B out/cmake-host -S . -G Ninja $ ninja -C out/cmake-host
Build for the host with Bazel
$ which bazel ~/pigweed/.cipd/pigweed.ensure/bazel $ bazel test //...
Build for the STM32F429 Discovery board
$ gn gen --args='pw_target_config = "//targets/stm32f429i-disc1/target_config.gni"' out/disco $ ninja -C out/disco $ pw test --root out/disco/ --runner stm32f429i_disc1_unit_test_runner
Build upstream Pigweed documentation
$ gn gen --args='pw_target_config = "//targets/docs/target_config.gni"' out/docs $ ninja -C out/docs $ google-chrome out/docs/gen/docs/html/index.html
The CMake and Bazel builds do not yet support building for hardware.
To flash firmware to an STM32 Discovery development board (and run pw test
) from macOS, you need to install OpenOCD. Install Homebrew using the latest instructions at https://brew.sh/, then install OpenOCD with brew install openocd
.
If any of this doesn't work please file a bug.