-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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 use_mei_in_more_templates
- Loading branch information
Showing
47 changed files
with
1,816 additions
and
100 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
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,62 @@ | ||
#!/usr/bin/env python | ||
# Copyright (c) 2023 Project CHIP Authors | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
import argparse | ||
import os | ||
from datetime import datetime, timezone | ||
|
||
|
||
def utc_time_in_matter_epoch_s(): | ||
""" Returns the time in matter epoch in s. """ | ||
# Matter epoch is 0 hours, 0 minutes, 0 seconds on Jan 1, 2000 UTC | ||
utc_matter = datetime.now(tz=timezone.utc) - datetime(2000, 1, 1, 0, 0, 0, 0, timezone.utc) | ||
return int(utc_matter.total_seconds()) | ||
|
||
|
||
class Options: | ||
def __init__(self, output, define_name, define_val): | ||
self.output = output | ||
self.define_name = define_name | ||
self.define_val = define_val | ||
|
||
|
||
def GetOptions(): | ||
parser = argparse.ArgumentParser() | ||
parser.add_argument('--output', help="Output header name (inside gen dir)") | ||
parser.add_argument('--gen-dir', | ||
help="Path to root of generated file directory tree.") | ||
cmdline_options = parser.parse_args() | ||
|
||
# The actual output file is inside the gen dir. | ||
output = os.path.join(cmdline_options.gen_dir, cmdline_options.output) | ||
|
||
define_name = 'CHIP_DEVICE_CONFIG_FIRMWARE_BUILD_TIME_MATTER_EPOCH_S' | ||
build_time = utc_time_in_matter_epoch_s() | ||
|
||
return Options(output=output, | ||
define_name=define_name, | ||
define_val=str(build_time)) | ||
|
||
|
||
def WriteHeader(options): | ||
with open(options.output, "w") as output_file: | ||
output_file.write("// Generated by write_build_time_header.py\n") | ||
output_file.write('#pragma once\n\n') | ||
|
||
output_file.write(f'#define {options.define_name} {options.define_val}\n') | ||
|
||
|
||
options = GetOptions() | ||
WriteHeader(options) |
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,71 @@ | ||
# Visual Studio Code Development | ||
|
||
[Visual Studio Code](https://code.visualstudio.com/) is a great and simple IDE | ||
that can be used to build & develop with for Matter. | ||
|
||
Matter supports the docker / remote container workflow in Visual Studio Code, | ||
and has a container environment setup automatically. You can read more about | ||
this workflow [here](https://code.visualstudio.com/docs/remote/containers). | ||
|
||
Tested on: | ||
|
||
- Windows 11 Pro + WSL 2 + Ubuntu 22.04 LTS | ||
- Ubuntu 22.04 LTS | ||
|
||
## Setup Steps | ||
|
||
Follow | ||
[these](https://github.com/project-chip/connectedhomeip/edit/master/docs/VSCODE_DEVELOPMENT.md) | ||
steps to set up Visual Studio Code for Matter development. | ||
|
||
### Linux <a name="linux"> | ||
|
||
For Espressif esp32 devices: | ||
|
||
1. Connect your device to the system before running the container. | ||
|
||
1. Add `"--device=/dev/ttyUSB0",` inside runArgs in | ||
[devcontainer.json](../../../.devcontainer/devcontainer.json). Confirm the | ||
port of the device and change the parameter accordingly. | ||
|
||
1. On opening connectedhomeip in Visual Studio code, At the bottom right of your | ||
window you should have a new box prompting you to re-open the window as a | ||
container. Hit yes. | ||
|
||
1. The container will be built. | ||
|
||
1. Install esp-idf : `cd /opt/espressif/esp-idf && ./install.sh` | ||
|
||
1. Source esp-idf : `source /opt/espressif/esp-idf/export.sh` | ||
|
||
1. Activate matter : | ||
`cd /workspaces/connectedhomeip && source scripts/bootstrap.sh && source scripts/activate.sh` | ||
|
||
1. Confirm that the device is accessible : `ls -l /dev/ttyUSB*` | ||
|
||
1. Go to lighting_example : `cd examples/lighting-app/esp32` | ||
|
||
1. Set-target: `idf.py set-target esp32c3` | ||
|
||
1. Build the project: `idf.py build` | ||
|
||
1. Flash: `idf.py -p /dev/ttyUSB0 flash` | ||
|
||
1. Monitor: `idf.py -p /dev/ttyUSB0 monitor` | ||
|
||
### Windows | ||
|
||
1. Connect to WSL Distro from VS Code. | ||
|
||
1. Git clone inside WSL from Matter repository here: | ||
<https://github.com/project-chip/connectedhomeip> | ||
|
||
1. Follow [these](https://github.com/dorssel/usbipd-win) steps on Windows and | ||
[these](https://github.com/espressif/vscode-esp-idf-extension/blob/master/docs/WSL.md#usbipd) | ||
steps in WSL to have serial port access inside WSL. | ||
|
||
1. Confirm that the device is accessible inside WSL : `ls -l /dev/ttyUSB*`. | ||
|
||
1. Open connectedhomeip within WSL on Visual Studio Code. | ||
|
||
1. Perform step 2 onwards from [Linux](#linux) guide. |
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
Oops, something went wrong.