Skip to content

C library for extending and redirecting the HAL IO drivers, and provides arduino like serial functions for printing and reading.

License

Notifications You must be signed in to change notification settings

AddioElectronics/CeriHAL

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CeriHAL

V0.1.3

C library for extending and redirecting the HAL IO drivers, and provides arduino like serial functions for printing and reading.

Usage (Atmel Start)

  • Run git clone https://github.com/AddioElectronics/CeriHAL.git
  • Run git submodule update --init --recursive
  • Create a project with Atmel Start.
    • Add the Middleware/Utilities/STDIO Redirect component.
    • USB
      • Add the Middleware/USB Stack/USB Device CDC ACM component.
      • Configure proper clock settings for USB.
    • USART
      • Add the Drivers/USART component, or use the "Target_IO" from "STDIO Redirect".
      • Under Component Settings, change Driver: to "HAL:Driver:USART_Async" or "HAL:Driver:USART_Sync"
    • Generate your project
  • Move/Copy the CeriHAL folder to your project. *1
  • In your Atmel Studio project properties, include each CeriHAL\submodules* path in "ARM/GNU C Compiler->Directories."
  • (Optional) Edit the multiple "_config" files.
  • _(Optional)_In atmel_start.c, comment out stdio_redirect_init();
  • Include headers
    • #include "Addio/Embedded/IO/Serial/serial.h"
    • #include "Addio/GeNETiCC/Embedded/IO/Serial/serial_geneticc.h"
    • #include "Addio/Embedded/Time/System_Timer/system_timer.h"
    • USB
      • #include "Addio/Embedded/IO/Atmel Start/cdc_stdio_redirect/usb_cdc_stdio.h"
    • USART
      • #include "Addio/Embedded/IO/hal_io_extension/usart_async/addio_hal_usart_async_extension.h"
  • Initialization
    • Call system_timer_init() *2 *3
  • USB
    • Call cdc_stdio_init()
    • Register your desired callbacks using usb_cdc_stdio_register_callback
    • Initialize Serial IO descriptor using Serial_Init()
  • USART
    • Call addio_usart_async_extend() *4
    • Register your desired callbacks using usart_async_register_callback
    • Initialize Serial IO descriptor using Serial_Init()
  • You can now use printf, stdio_io_write, stdio_io_read, Print, Println, and much more.

1 : If you wish to use the original "hal_io.h" and "stdio_io.h" delete the "hal" and "stdio_redirect" folders before copying into your project. Some Serial functions/macros will not be able to be used with the original drivers.

2 : If the system timer is not available. You will need to write your own millis() function, which returns how many milliseconds have elapsed since program start. Create a source file and include "Addio/Embedded/Time/System_Timer/system_timer.h", which contains the millis() prototype.`

3 : If you are using a new MCU or Core, it may not be supported yet. You can issue a bug report and I will add it asap. If you wish to add support for an MCU or Core, there are short tutorials here.

4 : You do not have to use the extended IO descriptors, although some Serial functions will not work. More info coming soon.

Example

Example located in main.c

Data will be echoed back, unless certain commands are sent.

Commands

Commands are not apart of CeriHAL, they are specific to the example and simply used to display the CeriHAL functions.

  • %TXCOUNT : Returns the amount of tranfers received from the host.
  • %HEX : Starts waiting for a sequence of commands.
HEX Command

Collects a sequence of parameters sent from the host, and calls a function when all parameters have been received. The function prints memory in the format of a HEX editor.

Data Expected (In order)
Step # Name Command/Format Description
1. Start %HEX Start the state machine, will begin looking for address.
2. Address 0x00000000 The starting location to display./td>
3. Length 8-infinity How many bytes to display./td>
4. Line Length 8, 16, 32, 64 How many bytes per line to display. *Must be less than or equal to length./td>
5. Labels 0, 1 Display column labels?/td>
6. Text Column 0, 1 Display a text representation in the right most column./td>

Included Repos

SubModules
  1. Only compatible with Atmel Start

License

CeriHAL is released under the MIT License.

Author

  • Author : Addio from Addio Electronics (Canada)
  • Website : www.Addio.io

About

C library for extending and redirecting the HAL IO drivers, and provides arduino like serial functions for printing and reading.

Topics

Resources

License

Stars

Watchers

Forks

Languages