We have prepared a new version of BSP featuring following changes and upgrades:
- Compiler upgraded from version 4.8.1-arduino5 to 4.9.2-atmel3.5.3-arduino2
- Avrdude upgraded from version 6.0.1-arduino5 to 6.3.0-arduino8
- Arduino Core library upgraded to the latest version (contained in Arduino IDE 1.8.3)
- Root folder for BSP no longer contains spaces (fixed issue while compiling from command line)
If you will face some compilation errors after the update, please check your
c:\Users\UserName\AppData\Local\Arduino15\packages\CONTROLLINO_Boards\hardware\avr
folder and remove all previous obsolete versions (e.g. 2.0.0).
This GitHub repository contains all you need to start with CONTROLLINO devices programming in Arduino IDE.
- Arduino IDE extension package for Boards Manager
- See our Installation guide
- CONTROLLINO library for Library Manager
- See our Installation guide
- See our Reference manual
- Examples how to use special features of the CONTROLLINOs
- When the library is installed in the Arduino IDE, you can find them i the File->Examples menu
- Customized bootloaders for all CONTROLLINO variants
- See Bootloaders folder and follow the provided guides
- Frequently Asked Questions
- See our FAQ
Please note that CONTROLLINO exists in 4 different variants.
- Microcontroller: ATmega328
- Atmel Clock Speed: 16 MHz
- RTC
- 1x serial Interface
- 1x SPI Interface
- 1x I2C Interface
- Input current Max. 8A
- 6x Relays Outputs – 230V / 6A
- 8x Analog/Digital Inputs
- 8x Digital Outputs – 2A @12V or 24V
- Microcontroller: ATmega2560
- Clock Speed: 16 MHz
- RTC
- Ethernet Connector
- 2x serial Interface
- 1x RS485 Interface
- 1x I2C Interface
- 1x SPI Interface
- Input current Max. 20A
- 10x Relays Outputs – 230V / 6A
- 12x Analog/Digital Inputs
- 12x Digital Outputs – 2A @12V or 24V
- Microcontroller: ATmega2560
- Clock Speed: 16 MHz
- RTC
- Ethernet Connector
- 2x serial Interface
- 1x I2C Interface
- 1x SPI Interface
- Input current Max. 20A
- Input voltage 24V
- 10x Relays Outputs – 230V / 6A
- 12x Analog Inputs
- 6x Digital Inputs (2x Interrupt)
- 8x Digital Outputs – 2A @ 24V
- 2x 0-10V Inputs
- 2x 0-10V/0-20mA Outputs
- Microcontroller: ATmega2560
- Clock Speed: 16 MHz
- RTC
- Ethernet Connector
- 2x serial Interface
- 1x RS485 Interface
- 1x I2C Interface
- 1x SPI Interface
- Input current Max. 30A
- 16x Relays Outputs – 230V / 6A
- 21x Analog/Digital Inputs
- 12x Digital Outputs – High Side Switch – 2A @12V or 24V
- 12x Digital Outputs – Half-Bridge - 2A @12V or 24V
Please, make sure that you have included the CONTROLLINO library in your sketch.
So, you can see #include <Controllino.h>
at the top of your sketch.
Of course, you can use Arduino native aliases for the pin numbers like A0, or 2, but CONTROLLINO library provides you its own set of aliases. It is always combination of CONTROLLINO_ and the text description of the screw terminal you can see on the device.
For example, for MINI we have defined following aliases:
CONTROLLINO_D0
CONTROLLINO_D1
CONTROLLINO_D2
CONTROLLINO_D3
CONTROLLINO_D4
CONTROLLINO_D5
CONTROLLINO_D6
CONTROLLINO_D7
CONTROLLINO_A0
CONTROLLINO_A1
CONTROLLINO_A2
CONTROLLINO_A3
CONTROLLINO_A4
CONTROLLINO_A5
CONTROLLINO_IN0
CONTROLLINO_IN1
Please, make sure that you have included also the SPI library in your sketch.
So, you can see #include <SPI.h>
at the top of your sketch.
It should be added automatically with the #include <Controllino.h>
.
Do not forget to properly setup the mechanical switch at your MINI!
- @param aChipSelect is ignored. Kept for backwards compatibility only.
- @return Always returns 0
char Controllino_RTC_init(unsigned char aChipSelect)
- See RTC chip manual for more information.
- @param aDay day 01 - 31
- @param aWeekDay weekday 00 - 06
- @param aMonth month 01 - 12
- @param aYear year 00 - 99
- @param aHour hours 01 - 12, or 00 - 23 (depending of 12H/24H mode)
- @param aMinute minutes 00 - 59
- @param aSecond seconds 00 - 59
- @return Returns 0 when succeeded, or -1 if the RTC library was not initialized before
char Controllino_SetTimeDate(unsigned char aDay, unsigned char aWeekDay,unsigned char aMonth, unsigned char aYear, unsigned char aHour, unsigned char aMinute, unsigned char aSecond);
- See RTC chip manual for more information.
- @param aDay pointer to day 01 - 31
- @param aWeekDay pointer to weekday 00 - 06
- @param aMonth pointer to month 01 - 12
- @param aYear pointer to year 00 - 99
- @param aHour pointer to hours 01 - 12, or 00 - 23 (depending of 12H/24H mode)
- @param aMinute pointer to minutes 00 - 59
- @param aSecond pointer to seconds 00 - 59
- @return Returns 0 when succeeded, or -1 if the RTC library was not initialized before
char Controllino_ReadTimeDate(unsigned char *aDay, unsigned char *aWeekDay, unsigned char *aMonth, unsigned char *aYear, unsigned char *aHour, unsigned char *aMinute, unsigned char *aSecond)
- @return Returns day 01 - 31, or -1 if the RTC library was not initialized before
char Controllino_GetDay( void )
- @return Returns weekday 00 - 06, or -1 if the RTC library was not initialized before
char Controllino_GetWeekDay( void )
- @return Returns month 01 - 12, or -1 if the RTC library was not initialized before
char Controllino_GetMonth( void )
- @return Returns year 00 - 99, or -1 if the RTC library was not initialized before
char Controllino_GetYear( void )
- @return Returns hours 01 - 12, or 00 - 23 (depending of 12H/24H mode), or -1 if the RTC library was not initialized before
char Controllino_GetHour( void )
- @return Returns minutes 00 - 59, or -1 if the RTC library was not initialized before
char Controllino_GetMinute( void )
- @return Returns seconds 00 - 59, or -1 if the RTC library was not initialized before
char Controllino_GetSecond( void )
- This function expects that the Serial was initialized before calling it.
- Format is DD/MM/YY HH:MM:SS
- @return Returns seconds 0, or -1 if the RTC library was not initialized before
char Controllino_PrintTimeAndDate( void )
Please note that RS485 interface is present only in MAXI and MEGA variants.
- Serial3 still needs to be initialized separately. This only inits RE and DE pins.
- @return Always returns 0
char Controllino_RS485Init( void )
- @param mode 0 for RS485 Receive Enable Active, 1 for Receive Enable Inactive
- @return Returns 0 when succeeded, -1 for unsupported mode
char Controllino_SwitchRS485RE(char mode)
- @param mode 0 for RS485 Data Transmission Enable Inactive, 1 for Data Transmission Enable Active
- @return Returns 0 when succeeded, -1 for unsupported mode
char Controllino_SwitchRS485DE(char mode)
- General requirements
- PC with Arduino IDE (1.6.4 or newer) (Windows, Linux, MAC)
- Internet connection
- CONTROLLINO library
- Start Arduino IDE, navigate to Sketch–>Include Library–>Manage Libraries
- In the Library Manager type CONTROLLINO into the filter text box and search for CONTROLLINO library
- When found, select the latest version and install it. The installation process should be fully automated
- When finished - check in Sketch–>Include Library menu that you can see the CONTROLLINO library there
- You can also check if you can see the set of CONTROLLINO examples in File->Examples->CONTROLLINO
- CONTROLLINO boards hardware definition
- Navigate to File–>Preferences
- Copy-paste the following link to the Additional Boards Manager URLs: https://raw.githubusercontent.com/CONTROLLINO-PLC/CONTROLLINO_Library/master/Boards/package_ControllinoHardware_index.json
- Press OK button
- Then navigate to Tools–>Board: “Foo“–>Boards Manager
- In the Boards Manager type CONTROLLINO into the filter text box and search for CONTROLLINO boards
- When found, select the latest version and install it. The installation process should be fully automated
- When finished - check in Tools–>Board: “Foo“–> menu that you can see the CONTROLLINO boards there
1. Automated installation through Arduino Board Manager gets 403 Forbidden in Arduino IDE for OSX
Answer: This issue was reported for Arduino IDE 1.6.11. In older versions - e.g. 1.6.8 it worked fine. With the latest Arduino IDE version (1.8.1) it also works fine.
2. AnalogRead always returns 806 instead of 1023
Question: A0 should read 0 and 1023 (its connected to D0 pin), but instead it reads 0 and 806. Is there anything wrong with the voltage reference or am I missing something? Btw, power supply is 24 volts.
Answer: This is caused by the fact that CONTROLLINO actually doesn't have maximum of 24V. The maximum for 24V setting is close to 30V. So, value 1023 will be returned when you would get close to 30V power supply. See our example AnalogInputs.
3. Digital 20 - Digital 23 mapping
Question: Pins Digital 20 - Digital 23 seem not to be implemented to use with digitalWrite, from Arduino lib. Is it possible to use those pins with your library? I understand, that these pins don't have an according alias on arduino, but still. I would really like to somehow circumvent using this syntax in order to set Digital 20.
PORTD = B11110111
Answer: It is correct. Our library does not support these digital outputs as we have tried to do not touch Arduino Core functionality. But it may be a point for further releases... I am afraid that you have to use this "PORTD" way to control these pins. Please check example sketch PortManipulation in the Arduino IDE for more details.
4. CONTROLLINO boards not showing with arduino IDE 1.6.12
Question: Loading the Controllino Library into the Arduino 1.6.12 IDE does not show up the Controllino boards on the board types list.
Answer: You also need to install the "CONTROLLINO Hardware" by the Boards Manager.
5. How to burn bootloader
Question: Is it possible to burn bootloader in Controllino? I want to add possibility for OTA updates by Ethernet.
Answer: Yes, it is possible. We are fully compatible with Arduino! All ICSP signals are available at the X1 pinheader connector of your CONTROLLINO. See https://controllino.biz/downloads/ for more details. You just need ICSP programmer and six wires to handle that.
6. Unable to locate (obsolete) hardware description files on GitHub
Question: My Arduino IDE gives me following error message: "Error downloading ....githubusercontent.com/Controllino/ControllinoHardware/master/package_ControllinoHardware_index.json". Is it unable to locate hardware description files?
Answer: Our GitHub repository has been moved to a new location, therefore this path is no longer valid. Please, follow our new Installation guide.
7. Pin header SPI bus communication is not working properly (MAXI, MEGA)
Question: I am not using RTC and/or Ethernet built in CONTROLLINO MAXI/MEGA. I am trying to use SPI bus available at pinheader, but it sometimes work and sometimes not. Is there any conflict with RTC chip and Etherent chip connected to the same SPI bus, even if I am not using them?
Answer: When SS pins PJ2 (RTC) and PJ3 (Wiznet) are not properly handled, it may happen that the floating pin is recognized as a valid chip select signal and the RTC chip or Wiznet chip is accidentally connected to SPI bus - MISO signal. The solution is quite easy - if a user wants to use the SPI bus signals as GPIOs at the pin header, s/he must properly setup the Slave Select signals for the RTC and Wiznet. This may cause confusion of the SPI communication at the pinheader and also strange voltages at MISO (pin header X1) when using it as GPIO.
These three lines in your sketch setup function should do the job:
DDRJ | = B00001100;
PORTJ &= B11111011;
PORTJ | = B00001000;
8. CONTROLLINO MINI A6, A7 inputs
Question: It is not possible to read digital value of the A6 and A7 inputs on CONTROLLINO MINI.
Answer: These pins are analogue inputs only and it is not possible to read their digital status, because of the microprocessor architecture. The only chance is to read out their analogue value and distinguish by some threshold value.