Skip to content
This repository has been archived by the owner on Jun 27, 2019. It is now read-only.

Ideas for Google Summer of Code 2016

Bruno Dilly edited this page Feb 25, 2016 · 49 revisions

GSoC Ideas

Templates

Idea Template (title)

Mentors: Bruno Dilly, Gustavo Lima (who you talked to, if anybody)

Description

Idea Devs Template (title)

Mentors: Bruno Dilly, Gustavo Lima ...

Difficulty: [Easy|Medium|Hard]

Short description of the idea (1-3 paragraphs)

Requirements:

  • Language
  • Protocol
  • Technology
  • [Basic|Heavy] understanding of something

Long description (optional)

Ideas

Port Soletta to Brillo

Mentors: Bruno Dilly

Difficulty: Medium

Soletta supports many OSes:

  • Linux
  • Zephyr
  • RIOT
  • Contiki

Idea here is to do the same on top of Brillo, making sure Soletta subsystems are properly coupled with Brillo stacks. For example, Soletta provides an API to trigger and report updates, that would need a specific implementation for Brillo update core system.

The first step on this task would be to go through Soletta components and evaluate which requires specific implementations for Brillo and which can go with regular Linux implementations.

Please get familiarized with Soletta's porting guide before writing a proposal for this idea.

Requirements:

  • Knowing C is mandatory

Implement Python bindings for Soletta

Mentors: Bruno Dilly, Gustavo Barbieri, Rodrigo Chiossi

Difficulty: Medium

Create Python bindings for Soletta.

Soletta provide C API covering many aspects required by an IoT product. It has API to deal with mainloops, I/O, network, crypto, some parsers, and sure, to deal with flows (see flow-based-programming).

But many of these areas are covered by well established Python modules. So first thing to do is identify which Soletta modules should be provided. Maybe making it possible to deal with flows and I/O is enough.

Some tools can be used to help on this task, like SWIG. But a common pitfall when writing language bindings is to end up with a C API written on other language. So Python types and idioms must be taken on consideration. Soletta's Python API need to properly feel like a Python API, so Python coders will feel comfortable writing code on it.

Requirements:

  • Previously knowledge about Python is highly recommended. Don't need to be an expert, but should be comfortable with Python programming idioms.

Long description (optional)

Implement Python metatype for Soletta

Mentors: Flavio Ceolin

Difficulty: Medium

Allows Soletta node's type development using python. Soletta already supports the development of metatypes using javascript.

Requirements:

  • Previously knowledge about Python is highly recommended. Don't need to be an expert, but should be comfortable with Python programming idioms. Also would be nice a general knowledge about mainloop.

Long description (optional)

Implement Go bindings for Soletta

Mentors: Bruno Dilly

Difficulty: Medium

Write Go bindings for Soletta. Please see Python bindings idea, it's pretty much the same thing and I don't want to repeat myself.

Requirements:

  • Previously knowledge about Go is highly recommended. Don't need to be an expert, but should be comfortable with Go programming idioms. We don't want to end up with a C API on Go.

Long description (optional)

Implement Go metatype for Soletta

Mentors: Flavio Ceolin

Difficulty: Medium

Allows Soletta node's type development using Go. Soletta already supports the development of metatypes using javascript.

Requirements:

  • Previously knowledge about Go is highly recommended. Don't need to be an expert, but should be comfortable with Go programming idioms. Also would be nice a general knowledge about mainloop.

Long description (optional)

Port to ESP8266

Mentors: Leandro Pereira

Difficulty: Medium

Port Soletta to run on cheap ESP8266 modules. It's already possible to run a Lua runtime on them, so it must be possible to run Soletta as well. Modules can be obtained from online stores for about $3 with S&H included, which makes it a very desirable target.

Requirements:

  • Language: Good knowledge of C.
  • Cross compilation experience not required but desirable.

Implement auto-complete in Soletta Dev-App

Mentors: Bruno Bottazzini

Difficulty: Easy

Auto-complete the code in the Soletta Development Application editor while the FBP is being programmed.

It's possible to get what nodetypes Soletta has. Now it will have to get these nodetypes, processing it and make auto-completion tips for the users when they are programming with Soletta Dev-App. We can also auto-complete the syntax to make the FBP development easier and faster.

The auto-complete should have the same behavior as the majority IDE. It will open a box allowing the user of Soletta Dev-App to choose what code to be completed.

Requirements:

  • Language: Knowledge in Javascript. Experience with NodeJS, AngularJS or Jquery would be good

Implement missing features on Contiki's port

Mentors: Flavio Ceolin, Ivan Briano

Difficulty: Medium

Soletta already has a basic port for Contiki, it means build integration, mainloop and basic IO (only GPIO). It's missing network support and others IO, such as, I2C and SPI.

Requirements:

  • Language: Good knowledge of C.
  • Cross compilation experience not required but desirable.

sol-gatt: Implement GATT profile in Soletta

Mentors: Vinicius Gomes, Andre Guedes

Difficulty: Medium

In Bluetooth Smart (also known as Bluetooth Low Energy) the most interoperable way of communicating with devices is using the GATT protocol. GATT provides a low overhead protocol, with high level concepts (services, characteristics, decriptors) ideal for low power devices, which may be coin cell battery operated.

The Bluetooth Special Interest Group (SIG) already defines many protocols implemented on top of GATT for many common applications[2].

sol-gatt will provide a high-level API (initially for Zephyr[3] and Linux) for registering and manipulating local and remote services and characteristics.

Requirements:

  • C programming language experience;
  • Knowledge of networking programming, Bluetooth technology has many analogs with TCP/IP/Ethernet;

[1] https://learn.adafruit.com/introduction-to-bluetooth-low-energy/gatt

[2] https://www.bluetooth.com/specifications/adopted-specifications

[3] https://www.zephyrproject.org/

sol-fbp-runner: Implement remote inspection

Mentors: Murilo Belluzzo

Difficulty: Easy

Add the capability to attach to sol-fbp-runner remotely (ip:port) and receive the inspection output for the flow being executed as well the logging messages.

Requirements:

  • C programming language experience;
  • Knowledge of networking programming;

sol-joyn: Soletta API for AllJoyn

Mentors: Vinicius Gomes

Difficulty: Medium

AllSeen[1] is a notable protocol in the IoT market, AllJoyn is the implementation of the protocol, providing a unified way for discovering devices and services over multiple transports.

Requirements:

  • C programming language experience;
  • Knowledge of networking programming;

[1] https://allseenalliance.org/

sol-lwm2m: Implement missing features.

Mentors: Guilherme Iscaro

Difficulty: Medium

Soletta has its own implementation of the lightweight machine to machine (LWM2M) [1] protocol. The LWM2M protocol is used to remotely control IoT devices, these include: Firmware updates, status reporting and etc. Although Soletta already implements the LMWM2M server and the LWM2M client, Soletta implementation is lacking some main features, that are: a bootstrap server, message encryption and data access control.

Expected Deliveries:

  • A LWM2M bootstrap server.
  • CoAP message encryption.
  • Data access control.

Requirements:

  • C programming language experience.
  • LWM2M knowledge is desirable.

[1] http://technical.openmobilealliance.org/Technical/technical-information/release-program/current-releases/oma-lightweightm2m-v1-0

Firmata protocol node types

Mentor: Leandro Pereira

Difficulty: Easy

Firmata is a protocol for communicating with microcontrollers from software on a computer (or smartphone/tablet, etc). The protocol can be implemented in firmware on any microcontroller architecture as well as software on any computer software package (see list of client libraries below).

This task would make it possible to have Firmata node types available to Soletta's Flow Based Programming engine, both to allow Soletta to control other devices, and to be controlled by other devices. Full documentation and links to implementations are available here.

Requirements:

  • Ability to program in C
  • Have an Arduino or other device which is compatible with Firmata to test the implementation

Soletta bare metal: Soletta port to QMSI

Mentors: Vinicius Gomes, Andre Guedes

Difficulty: Extra hard

Soletta is a library to offer developers a framework for making IoT products with which they can easily write software for diverse devices, providing a high level API which users can use to target many different platforms, among these: PID1 processes on barebones Linux kernel (known as micro-Linux), Riot-OS, Contiki and Zephyr. But what if we don’t even need the services provided by the OS?

For the Intel Quark Microcontrollers family, Intel has open-sourced QMSI[1] (Quark Microcontroller Software Interface), which provides a consistent API for interfacing with peripherals and such, giving total control of the platform to developers. All this control implies extra care when writing softwares, that should be employed in every software written.

Soletta aim is clear, it's a framework for building devices. What's a better way than to build devices using a consistent and high level interface and have the generated code run comfortably on the smallest Quark Microcontroller? The increased growth of the IoT market is putting even more pressure in development time, so that extra care when development applications with full control of the hardware is better employed when it can be re-used, Soletta fills this niche nicely.

Requirements:

  • C programming language experience;
  • Low level programming experience;

[1] http://github.com/01org/qmsi

Clone this wiki locally