Skip to content

Commit f320c6c

Browse files
committed
"generate the folder skeleton"
1 parent 300825f commit f320c6c

20 files changed

+2286
-57
lines changed

.clang-format

+14
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
---
2+
Language: Cpp
3+
BasedOnStyle: LLVM
4+
IndentWidth: 4
5+
AlignAfterOpenBracket: Align
6+
AllowShortBlocksOnASingleLine: false
7+
AllowShortCaseLabelsOnASingleLine: false
8+
AllowShortFunctionsOnASingleLine: false
9+
IndentCaseLabels: true
10+
SpacesBeforeTrailingComments: 2
11+
PointerAlignment: Left
12+
AlignEscapedNewlines: Left
13+
ForEachMacros: ['TEST_GROUP', 'TEST']
14+
...

.gitignore

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
/scd30_i2c_example_usage
2+
/tests/scd30_test_hw_i2c
3+
/tests/scd30_test_sw_i2c

.gitlab-ci.yml

+36
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
stages:
2+
- validate
3+
- build
4+
5+
syntax_check:
6+
stage: validate
7+
image:
8+
name: registry.gitlab.sensirion.lokal/mso-sw/drivers/docker-driver-generator:0.2.0
9+
tags: [linux, docker]
10+
script:
11+
- find . -type f -iregex ".*\.\(c\|h\|cpp\|ino\)" -exec clang-format-6.0 -i -style=file {} \; && git diff --exit-code
12+
13+
14+
cppcheck:
15+
stage: validate
16+
image:
17+
name: registry.gitlab.sensirion.lokal/mso-sw/drivers/docker-driver-generator:0.2.0
18+
tags: [linux, docker]
19+
script:
20+
- cppcheck --std=c89 --language=c --error-exitcode=1 --enable=warning,style,performance,portability -i sample-implementations/ .
21+
22+
build:
23+
stage: build
24+
image:
25+
name: sensirion/embedded-ci:2.4.0
26+
tags: [linux, docker]
27+
script:
28+
- make
29+
30+
TODO_check:
31+
stage: validate
32+
image:
33+
name: registry.gitlab.sensirion.lokal/mso-sw/drivers/docker-driver-generator:0.2.0
34+
tags: [linux, docker]
35+
script:
36+
- '! grep -rnw --exclude=.gitlab-ci.yml --exclude-dir=.git . -e "TODO"'

CHANGELOG.md

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
# Changelog
2+
All notable changes to this project will be documented in this file.
3+
4+
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
5+
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
6+
7+
8+
## [Unreleased]
9+
10+
## [0.1.0] - 2022-04-07
11+
12+
Initial release
13+

LICENSE

+29
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
BSD 3-Clause License
2+
3+
Copyright (c) 2022, Sensirion AG
4+
All rights reserved.
5+
6+
Redistribution and use in source and binary forms, with or without
7+
modification, are permitted provided that the following conditions are met:
8+
9+
1. Redistributions of source code must retain the above copyright notice, this
10+
list of conditions and the following disclaimer.
11+
12+
2. Redistributions in binary form must reproduce the above copyright notice,
13+
this list of conditions and the following disclaimer in the documentation
14+
and/or other materials provided with the distribution.
15+
16+
3. Neither the name of the copyright holder nor the names of its
17+
contributors may be used to endorse or promote products derived from
18+
this software without specific prior written permission.
19+
20+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21+
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22+
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23+
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
24+
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25+
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26+
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27+
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28+
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29+
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Makefile

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
common_sources = sensirion_config.h sensirion_common.h sensirion_common.c
2+
i2c_sources = sensirion_i2c_hal.h sensirion_i2c.h sensirion_i2c.c
3+
driver_sources = scd30_i2c.h scd30_i2c.c
4+
5+
i2c_implementation ?= sensirion_i2c_hal.c
6+
7+
CFLAGS = -Os -Wall -fstrict-aliasing -Wstrict-aliasing=1 -Wsign-conversion -fPIC -I.
8+
9+
ifdef CI
10+
CFLAGS += -Werror
11+
endif
12+
13+
.PHONY: all clean
14+
15+
all: scd30_i2c_example_usage
16+
17+
scd30_i2c_example_usage: clean
18+
$(CC) $(CFLAGS) -o $@ ${driver_sources} ${i2c_sources} \
19+
${i2c_implementation} ${common_sources} scd30_i2c_example_usage.c
20+
21+
clean:
22+
$(RM) scd30_i2c_example_usage

README.md

+138-57
Original file line numberDiff line numberDiff line change
@@ -1,92 +1,173 @@
1-
# raspberry-pi-i2c-scd30
1+
# Sensirion Raspberry Pi I2C SCD30 Driver
22

3+
This document explains how to set up a SCD30 sensor to run on a Raspberry Pi
4+
using the provided code.
35

6+
<center><img src="images/sensor_scd30_image.jpg" width="300px"></center>
47

5-
## Getting started
8+
Click [here](https://sensirion.com/products/catalog/SCD30/) to learn more about the Sensirion SCD30 sensor.
69

7-
To make it easy for you to get started with GitLab, here's a list of recommended next steps.
810

9-
Already a pro? Just edit this README.md and make it your own. Want to make it easy? [Use the template at the bottom](#editing-this-readme)!
1011

11-
## Add your files
12+
The default I²C address of [SCD30](https://sensirion.com/products/catalog/SCD30/) is **0x61**.
1213

13-
- [ ] [Create](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#create-a-file) or [upload](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#upload-a-file) files
14-
- [ ] [Add files using the command line](https://docs.gitlab.com/ee/gitlab-basics/add-file.html#add-a-file-using-the-command-line) or push an existing Git repository with the following command:
1514

16-
```
17-
cd existing_repo
18-
git remote add origin https://gitlab.sensirion.lokal/MSO-SW/drivers/raspberry-pi/raspberry-pi-i2c-scd30.git
19-
git branch -M master
20-
git push -uf origin master
21-
```
2215

23-
## Integrate with your tools
16+
## Setup Guide
17+
18+
### Connecting the Sensor
19+
20+
Your sensor has the 7 different connectors: VDD, GND, SCL, SDA, RDY, PWM, SEL.
21+
Use the following pins to connect your SCD30:
22+
23+
| *SCD30* | *Cable Color* | *Raspberry Pi* |
24+
| :----------------: | -------------- | ------------------ |
25+
| VDD | | Pin 1
26+
| GND | | Pin 6
27+
| SCL | | Pin 5
28+
| SDA | | Pin 3
29+
| RDY | | Pin
30+
| PWM | | Pin
31+
| SEL | | Pin 9
32+
33+
34+
<img src="images/raspi-i2c-pinout-3.3V-SEL.png" width="400px">
35+
2436

25-
- [ ] [Set up project integrations](https://gitlab.sensirion.lokal/MSO-SW/drivers/raspberry-pi/raspberry-pi-i2c-scd30/-/settings/integrations)
37+
#### Detaild sensor pinout
2638

27-
## Collaborate with your team
39+
<img src="images/scd30_pinout.jpg" width="300px">
2840

29-
- [ ] [Invite team members and collaborators](https://docs.gitlab.com/ee/user/project/members/)
30-
- [ ] [Create a new merge request](https://docs.gitlab.com/ee/user/project/merge_requests/creating_merge_requests.html)
31-
- [ ] [Automatically close issues from merge requests](https://docs.gitlab.com/ee/user/project/issues/managing_issues.html#closing-issues-automatically)
32-
- [ ] [Enable merge request approvals](https://docs.gitlab.com/ee/user/project/merge_requests/approvals/)
33-
- [ ] [Automatically merge when pipeline succeeds](https://docs.gitlab.com/ee/user/project/merge_requests/merge_when_pipeline_succeeds.html)
41+
| *Pin* | *Cable Color* | *Name* | *Description* | *Comments* |
42+
|-------|---------------|:------:|----------------|------------|
43+
| 1 | |VDD | Supply Voltage | 3.3 to 5.5V
44+
| 2 | |GND | Ground |
45+
| 3 | |SCL | I2C: Serial clock input |
46+
| 4 | |SDA | I2C: Serial data input / output |
47+
| 5 | |RDY | | High when data is available
48+
| 6 | |PWM | |
49+
| 7 | |SEL | Interface select | Interface select; Pull to ground or floating for I2c
50+
### Raspberry Pi
3451

35-
## Test and Deploy
52+
- [Install the Raspberry Pi OS on to your Raspberry Pi](https://projects.raspberrypi.org/en/projects/raspberry-pi-setting-up)
53+
- [Enable the I²C interface in the raspi-config](https://www.raspberrypi.org/documentation/configuration/raspi-config.md)
54+
- Download the SCD30 driver from [Github](https://github.com/Sensirion/raspberry-pi-i2c-scd30) and extract the `.zip` on your Raspberry Pi
3655

37-
Use the built-in continuous integration in GitLab.
56+
- Compile the driver
57+
1. Open a [terminal](https://www.raspberrypi.com/documentation/computers/using_linux.html#terminal)
58+
2. Navigate to the driver directory. E.g. `cd ~/raspberry-pi-i2c-scd30`
59+
3. Run the `make` command to compile the driver
3860

39-
- [ ] [Get started with GitLab CI/CD](https://docs.gitlab.com/ee/ci/quick_start/index.html)
40-
- [ ] [Analyze your code for known vulnerabilities with Static Application Security Testing(SAST)](https://docs.gitlab.com/ee/user/application_security/sast/)
41-
- [ ] [Deploy to Kubernetes, Amazon EC2, or Amazon ECS using Auto Deploy](https://docs.gitlab.com/ee/topics/autodevops/requirements.html)
42-
- [ ] [Use pull-based deployments for improved Kubernetes management](https://docs.gitlab.com/ee/user/clusters/agent/)
43-
- [ ] [Set up protected environments](https://docs.gitlab.com/ee/ci/environments/protected_environments.html)
61+
Output:
62+
```
63+
rm -f scd30_i2c_example_usage
64+
cc -Os -Wall -fstrict-aliasing -Wstrict-aliasing=1 -Wsign-conversion -fPIC -I. -o scd30_i2c_example_usage scd30_i2c.h scd30_i2c.c sensirion_i2c_hal.h sensirion_i2c.h sensirion_i2c.c \
65+
sensirion_i2c_hal.c sensirion_config.h sensirion_common.h sensirion_common.c scd30_i2c_example_usage.c
66+
```
67+
- Test your connected sensor
68+
- Run `./scd30_i2c_example_usage` in the same directory you used to
69+
compile the driver. You should see the measurement values in the console.
70+
71+
## Troubleshooting
72+
73+
### Building driver failed
74+
75+
If the execution of `make` in the compilation step 3 fails with something like
76+
77+
```bash
78+
make: command not found
79+
```
80+
81+
your RaspberryPi likely does not have the build tools installed. Proceed as follows:
82+
83+
```
84+
$ sudo apt-get update
85+
$ sudo apt-get upgrade
86+
$ sudo apt-get install build-essential
87+
```
4488

45-
***
4689

47-
# Editing this README
90+
### Initialization failed
4891

49-
When you're ready to make this README your own, just edit this file and use the handy template below (or feel free to structure it however you want - this is just a starting point!). Thank you to [makeareadme.com](https://www.makeareadme.com/) for this template.
92+
If you run `./scd30_i2c_example_usage` but do not get sensor readings but something like this instead
5093

51-
## Suggestions for a good README
52-
Every project is different, so consider which of these sections apply to yours. The sections used in the template are suggestions for most open source projects. Also keep in mind that while a README can be too long and detailed, too long is better than too short. If you think your README is too long, consider utilizing another form of documentation rather than cutting out information.
94+
```
95+
Error executing soft_reset(): -1
96+
Error executing read_firmware_version(): -1
97+
Error executing start_periodic_measurement(): -1
98+
...
99+
```
100+
then go through the below troubleshooting steps.
53101

54-
## Name
55-
Choose a self-explaining name for your project.
56102

57-
## Description
58-
Let people know what your project can do specifically. Provide context and add a link to any reference visitors might be unfamiliar with. A list of Features or a Background subsection can also be added here. If there are alternatives to your project, this is a good place to list differentiating factors.
103+
- Ensure that you connected the sensor correctly: All cables are fully
104+
plugged in and connected to the correct pin.
105+
- Ensure that I²C is enabled on the Raspberry Pi. For this redo the steps on
106+
"Enable the I²C interface in the raspi-config" in the guide above.
107+
- Ensure that your user account has read and write access to the I²C device.
108+
If it only works with user root (`sudo ./scd30_i2c_example_usage`), it's
109+
typically due to wrong permission settings. See the next chapter how to solve this.
59110

60-
## Badges
61-
On some READMEs, you may see small images that convey metadata, such as whether or not all the tests are passing for the project. You can use Shields to add some to your README. Many services also have instructions for adding a badge.
111+
### Missing I²C permissions
62112

63-
## Visuals
64-
Depending on what you are making, it can be a good idea to include screenshots or even a video (you'll frequently see GIFs rather than actual videos). Tools like ttygif can help, but check out Asciinema for a more sophisticated method.
113+
If your user is missing access to the I²C interface you should first verfiy
114+
the user belongs to the `i2c` group.
65115

66-
## Installation
67-
Within a particular ecosystem, there may be a common way of installing things, such as using Yarn, NuGet, or Homebrew. However, consider the possibility that whoever is reading your README is a novice and would like more guidance. Listing specific steps helps remove ambiguity and gets people to using your project as quickly as possible. If it only runs in a specific context like a particular programming language version or operating system or has dependencies that have to be installed manually, also add a Requirements subsection.
116+
```
117+
$ groups
118+
users input some other groups etc
119+
```
120+
If `i2c` is missing in the list add the user and restart the Raspberry Pi.
68121

69-
## Usage
70-
Use examples liberally, and show the expected output if you can. It's helpful to have inline the smallest example of usage that you can demonstrate, while providing links to more sophisticated examples if they are too long to reasonably include in the README.
122+
```
123+
$ sudo adduser your-user i2c
124+
Adding user `your-user' to group `i2c' ...
125+
Adding user your-user to group i2c
126+
Done.
127+
$ sudo reboot
128+
```
71129

72-
## Support
73-
Tell people where they can go to for help. It can be any combination of an issue tracker, a chat room, an email address, etc.
130+
If that did not help you can make globally accessible hardware interfaces
131+
with a udev rule. Only do this if everything else failed and you are
132+
reasoably confident you are the only one having access to your Pi.
74133

75-
## Roadmap
76-
If you have ideas for releases in the future, it is a good idea to list them in the README.
134+
Go into the `/etc/udev/rules.d` folder and add a new file named
135+
`local.rules`.
136+
```
137+
$ cd /etc/udev/rules.d/
138+
$ sudo touch local.rules
139+
```
140+
Then add a single line `ACTION=="add", KERNEL=="i2c-[0-1]*", MODE="0666"`
141+
to the file with your favorite editor.
142+
```
143+
$ sudo vi local.rules
144+
```
77145

78146
## Contributing
79-
State if you are open to contributions and what your requirements are for accepting them.
80147

81-
For people who want to make changes to your project, it's helpful to have some documentation on how to get started. Perhaps there is a script that they should run or some environment variables that they need to set. Make these steps explicit. These instructions could also be useful to your future self.
148+
**Contributions are welcome!**
149+
150+
We develop and test this driver using our company internal tools (version
151+
control, continuous integration, code review etc.) and automatically
152+
synchronize the master branch with GitHub. But this doesn't mean that we don't
153+
respond to issues or don't accept pull requests on GitHub. In fact, you're very
154+
welcome to open issues or create pull requests :)
155+
156+
This Sensirion library uses
157+
[`clang-format`](https://releases.llvm.org/download.html) to standardize the
158+
formatting of all our `.c` and `.h` files. Make sure your contributions are
159+
formatted accordingly:
160+
161+
The `-i` flag will apply the format changes to the files listed.
162+
163+
```bash
164+
clang-format -i *.c *.h
165+
```
82166

83-
You can also document commands to lint the code or run tests. These steps help to ensure high code quality and reduce the likelihood that the changes inadvertently break something. Having instructions for running tests is especially helpful if it requires external setup, such as starting a Selenium server for testing in a browser.
167+
Note that differences from this formatting will result in a failed build until
168+
they are fixed.
84169

85-
## Authors and acknowledgment
86-
Show your appreciation to those who have contributed to the project.
87170

88171
## License
89-
For open source projects, say how it is licensed.
90172

91-
## Project status
92-
If you have run out of energy or time for your project, put a note at the top of the README saying that development has slowed down or stopped completely. Someone may choose to fork your project or volunteer to step in as a maintainer or owner, allowing your project to keep going. You can also make an explicit request for maintainers.
173+
See [LICENSE](LICENSE).

images/raspi-i2c-pinout-3.3V-SEL.png

210 KB
Loading

images/scd30_pinout.jpg

23.6 KB
Loading

images/sensor_scd30_image.jpg

13.1 KB
Loading

0 commit comments

Comments
 (0)