The invention relates to a software defined device interface system, a software defined device interface, gateway and a method of defining an interface for a device which uses a specific communication protocol for communication purposes.
The “Internet of Things” (IoT) is a technical term in the IT industry, where billions of devices are going to be connected to various Internet servers/Cloud Services. Although a portion of devices are sufficiently intelligent (for example IP based), and can be directly connected to the cloud, there are a lot of legacy or potential new low cost devices that can be connected (“digitised”) onto an IP based platform, via an edge gateway.
Currently it is believed by the Inventor that IoT could be implemented in the following markets:
Depending on the purpose of the controller (or “Edge Gateway”) and the types of external devices that were catered for by the hardware designer, the groupings of processor pins are usually routed on printed circuit boards (PCB's) to a set of fixed number of exposed physical industry standard connectors, such as:
The following communication protocols are currently used in the industry to connect to devices or sensors:
Currently, all of the above can be accomplished by utilizing various different dedicated ports on existing controllers, such as PLCs, industrial embedded computers, Arduino, Raspberry Pi or commercial/industrial “Edge Gateways”.
The standard way of connecting non-IP based devices to the cloud, are with what is termed “Edge Gateways”. These Gateway devices usually can connect devices with some level of intelligence via dedicated hardware ports (e.g. RS232, RS485, USB, CAN bus, I2C). Some companies (for example Cisco, Dell & Samsung) are selling “Edge Gateways” that sits on premise (“at the edge”) close to the sensors/devices. These gateways then communicate via various standards (GSM/Ethernet/WiFi/Long Range Wireless) to a cloud solution which usually consist of a combination of “Big Data”, “Analytics”, Machine Learning and mobile devices (such as smart phones or tablet) to analyse the data after the event and to generate alerts.
The main purpose of these IoT/Edge Gateways, are to connect to various non-IP based devices and sensors, filter/aggregate sensor values and to then push this data to the cloud, instead of having sensors that are directly connected to the cloud. Examples are temperature/humidity sensors and accelerometers, vibration sensor, etc. Some of these non-IP-based devices typically include 1-wire, 2-wire, I2C, SPI and CAN bus interfaces that cannot be connected to a IP-based network switch or router directly and requires a specific physical layer protocol to interrogate and control these devices. Cisco Systems has also coined the term “Fog Computing” for their edge routers (as opposed to “Cloud Computing”) meaning intelligence has moved closer to the edge.
To date, all the industrial Edge Gateways that are sold, usually imply a device that has a Linux or Windows operating system, which can then be programmed to accumulate various sensors/device data via dedicated ports or detect simple inputs or emit simple outputs. Proprietary firmware/embedded devices also exist, with limited number of dedicated connectors for devices or sensors to plug into.
The cost-factor plays a major role in deciding the functionality of a dedicated edge gateway design. There is a trade-off between low-cost controllers with a very limited number of interfaces vs over-engineered controllers which are very expensive and are not guaranteed to be future proof in terms of new connectors or protocols.
The inventor wishes to address at least some of the problems identified above.
In accordance with a first aspect of the invention there is provided a software-defined device interface system, or a device interface system, which includes:
“Communication”, in this instance, should be interpreted to also refer to communication flowing only in one direction (e.g. from the device through the virtual port to the processing unit). In other words, communication refers to communication in one direction as well as in both directions.
The term “virtual port” refers to a communication port which is formed by assigning/selecting, in runtime, one or more communication pins of the microprocessor/processing unit and using it together with appropriate/suitable software/firmware in order to allow a specific communication protocol to be implemented, wherein the assigned/selected communication pin(s) forms a physical connection for the device to be connected to the system.
The communication pins may be general purpose input/output (GPIO) pins.
The microprocessor may be, or forms part of, a central processing unit (microprocessor).
The software/firmware is typically run/executed on the microprocessor.
The software/firmware may be configured to utilise interrupt logic in order to receive information via the virtual port.
The software/firmware may be configured to utilise a signal generator(s) in order to transmit information through the virtual port.
The software/firmware may be configured to, in runtime, group/assign a collection of GPIO pins to form part of the virtual port, and implement the specific communication protocol by utilising the collection of GPIO pins. The software/firmware may be configured to, in runtime, implement two or more communication protocols in order to form two or more virtual ports to which devices, which utilise the specific communication protocols, can be connected. Using the available exposed GPIO pins the user can decide how many device interfaces may be needed and therefore created. The software/firmware may be configured to, in runtime, implement a number of communication protocols in order to create a number of virtual ports to which devices, which utilise the specific communication protocols, can be connected, when receiving input from a user (e.g. via a user interface) to create the said number of virtual ports.
The system may include one or more dedicated native microprocessor communication ports (e.g. USB, Ethernet, etc.). The dedicated communication ports may have dedicated pins for communication purposes (for example a TX (transmit) pin and RX (receive) pin in a serial port configuration). The dedicated communication ports may be implemented in hardware. The dedicated port(s) may include a universal asynchronous receiver/transmitter (UART) port.
The firmware/software may be configured to, in runtime, use the microprocessor's software-configurable timer counter/clock as a variable signal generator. The firmware/software may be configured to implement a rising/falling-edge interrupt on one or more of the GPIO pins which form the virtual port, in order to start/initiate a sampling process by which the pin is sampled/read at a frequency set by a software-configurable timer counter of the microprocessor.
The microprocessor may be configured to receive communication protocol information programmatically for implementing a specific communication protocol for a particular device from a remote computing device/server via a communication network. The system may include a programmable voltage switching circuit which is, in use, connected between the communication pins and the device, and which is configured to adjust/switch/change voltages between the communication pins on the one hand and an interface of the device on the other hand, depending on specific voltage requirements for the communication pins and the device, respectively. The programmable voltage switching circuit may be the programmable voltage switching circuit in accordance with the eight aspect of the invention described further below.
The microprocessor, software/firmware and programmable voltage switching circuit may form part of an edge gateway.
The system may include at least one library, preferably multiple libraries, which defines various communication protocols, which can be applied to a specific virtual port(s) which was created by the user. These communication protocols can then be used to effectively replace dedicated hardware ports, by merely assigning specific GPIO pins for a specific protocol on a specific virtual port, preferably in conjunction with a programmable voltage switching circuit/circuit arrangement. (see for example
In accordance with a second aspect of the invention there is provided a method of defining/establishing an interface for a device which uses a specific communication protocol for communication purposes, wherein the method includes:
The communication pins may be general purpose input/output (GPIO) pins of the microprocessor. The communication pins may also include tri-state capable pins.
The assigning/selecting step may include grouping/assigning a collection of GPIO pins to form part of the virtual port, and implementing the specific communication protocol by utilising the collection of GPIO pins.
The method may include utilising a programmable voltage switching circuit in order to regulate voltage levels between the collection of GPIO pins which forms the virtual port and the device.
The method may include sending programming instructions to the programmable voltage switching circuit to specify pin voltages of the microprocessor, on the one hand, and voltages of the device, on the other hand, wherein the programming instructions are sent from the microprocessor or any other remote computing device via a network.
In accordance with a third aspect of the invention there is provided a software-defined device interface which includes:
A “module”, in the context of the specification, includes an identifiable portion of code, computational or executable instructions, or a computational object to achieve a particular function, operation, processing, or procedure. A module may be implemented in software or a combination of software and hardware.
In accordance with a fourth aspect of the invention there is provided a software-defined device interface which includes:
In accordance with a fifth aspect of the invention there is provided a gateway/edge gateway which includes a protocol module/library which is configured, based on a communication protocol which is used by a particular device, to, in runtime:
In accordance with a sixth aspect of the invention there is provided a software defined device interface system which is configured to utilizes native capabilities of a microprocessor in order to define one or more virtual communication port(s) to which a device(s) can be connected by assigning one or more communication pins of the microprocessor to form the virtual port and execute software/firmware which is configured to, in runtime, implement a communication protocol by utilising the pin(s) which forms the virtual port, to thereby communicate with the device, when connected to the port, by utilising the communication protocol.
In accordance with a seventh aspect of the invention there is provided a software defined device interface system (proposed to be used in an Edge Gateway, although not limited to), said system including:
The system effectively includes software code programmed onto the system to permit assigning any one, or a collection of, the microprocessor's native capabilities (as listed below) to define a device interface, or virtual port that can implement a specific protocol that is normally associated with this type of port.
The microprocessor, as mentioned in any of the above-mentioned aspects of the invention, may include/provide the following native processor capabilities:
Since the system is effectively implemented in runtime, the system does not need to restart and no hardware needs to be redesigned if a new communication port or protocol is required.
The system need not have specific hardware ports or device interfaces that are hard wired in the microprocessor's dedicated circuitry.
The device interface or port configuration can, in runtime, be configured by a user to implement the protocol required for a specific device that is connected to the virtual port.
The system does not need an operating system and may use an open source implementation of the Microsoft™ .NET Micro framework or any other custom firmware.
The software configurable ports may be expanded on via I2C or other means to daisy-chain multiple input or output ports.
The system/gateway may be remotely configured via an embedded web server or other means, to define and configure a new device interface.
The gateway may include some standard configurations which simplifies the grouping of GPIO's for a number of desired or often used configurations and protocols such as UART.
The gateway may have an embedded web server to enable installers to do initial diagnostics and configuration, which is stored on the gateway for its entire lifetime.
The gateway may include storage for persisting data in a constrained storage space. The storage may be a record storage file system, without the need of an operating system.
A software defined device interface may combine software logic and native microprocessor pin capabilities to overcome the limitations of having a dedicated hardware port in the microprocessor or electronic circuit design that is dedicated for a specific device or protocol such as a dedicated UART.
Thus, the software defined device interface of the invention may permit firmware to incorporate the features of modern day microprocessor native GPIO pin capabilities to reinterpret existing device interfaces. The combination of high speed clock cycles, signal generators and pin configurations (input, output, tristate) allows for said interface to implement communication protocols without the need of dedicated processor embedded circuitry, for example UART, I2C, CAN bus or SPI. Any protocol data transmit and receive logic may be controlled precisely using interrupt logic for receive and signal generators for transmit.
The interface of the invention thus may allow for general purpose pins to emulate special functions to expand interfaces even if not supported by the underlying microprocessor hardware architecture.
The invention thus provides for the use of the GPIO pins on a microprocessor via software or firmware to simulate or enhance or extend hardwired ports or connections.
The system of the invention extends to a method of defining an interface, said method including:
In accordance with an eighth aspect of the invention there is provided a programmable voltage switching circuit which includes:
In accordance with a ninth aspect of the invention there is provided a software-defined device interface which includes:
The invention will now be described, by way of example, with reference to the accompanying diagrammatic drawings. In the drawings:
The invention relates to a software defined device interface system which can be deployed remotely by a user (or programmatically as batches), and configured in runtime, without hardware circuitry changes being required and which allows a user to configure device interfaces remotely, as and when required. This allows configuration in runtime, via software configuration, to define a device interface (virtual port), using GPIO pins on a microprocessor. In addition, the user can configure the device interface via software, to implement any current or even future communication protocol on the device interface. This virtual, software defined “port” eliminates the requirement to have dedicated electronic circuitry for different “ports” which are used to connect and communicate with devices. The differences between native microprocessor and device/sensor voltages are solved using a programmable voltage switching circuit.
In
As mentioned, non-IP based devices can generally not be connected directly to the Internet/a cloud-based computing system. The communication protocols for different non-IP based devices also generally differ from each other. Some of these communication protocols include TTL (transistor-transistor logic) serial, RS-232, RS-485, USB, SPI, I2C, CAN bus, etc. They may need to utilise only one pin or a number of pins for communication purposes. Some device interfaces require different voltage levels for communication which requires different hardware designs for the different communication interfaces or hardware ports.
The invention uses a programmable voltage switching circuit 52 that allows any processor voltage level to be connected to any device interface voltage level(s). It allows the configuration of these levels (including whether or not the levels are inverted) to be done via a programmable interface.
The current system 10, however, includes appropriate software/firmware which, when executed (e.g. by the microprocessor 12), assigns or designates one or more GPIO pins 14 which can be used for a specific type of communication protocol, depending on the type of device which should be connected to the microprocessor 12. More specifically, the system 10 typically includes a database 22 on which a library of a plurality of different communication protocols are stored. This database 22 may be stored on a database near the microprocessor 12 or at a remote storage/library facility (e.g. stored in a cloud-based system 17). A user 100 may then use a computer 200 to download and/or configure a specific microprocessor 12, via the Internet, to implement a certain communication protocol for a specific device 30.1-30.4 (collectively referred to as 30) which should be connected to the microprocessor 12 via the programmable voltage switching circuit 52. The communication protocol is typically implemented in software/firmware which, when executed (using the data shifting mechanism 25 as described further down in the specification), utilises the GPIO pins 14 as physical connection/communication points with the device 30.
More specifically, when the microprocessor 12 executes the software/firmware, it, in runtime, designates/assigns one or more of the GPIO pins 14 for implementing the specified communication protocol for communicating with the device 30 via the programmable voltage switching circuit 52. The GPIO pins 14, voltage switching circuit 52, together with the software/firmware and protocol libraries, therefore creates or defines a device interface for allowing communication with the particular device 30. Certain protocols may only require one pin, while other protocols may require a plurality of GPIO pins 14, which will result in the software/firmware grouping/clustering a plurality of the GPIO pins 14 together in order to implement the communication protocol. It is important to note from the above that GPIO pins 14 typically have no special function when the software/firmware is not executed. However, the moment the software/firmware is executed, one or more of the GPIO pins 14 are effectively transformed into a virtual port for connecting to the device 30 and for allowing communication between the device 30 and microprocessor 12. In other words, the virtual ports are created in runtime. It should be appreciated that more than one “virtual port” can be created in runtime by the microprocessor 12.
As shown in
Reference is now made to
In the example shown in
An example of how the UART protocol is implemented will now be described. This implementation may also be referred to as the “data shifting mechanism” for UART communication without the use of a dedicated TTL to RS-232 IC.
A user 100 can, for example, now use a software interface such as
It should however be appreciated that the invention is not only limited to just the UART protocol, but can implement a large variety of communication protocols as described in examples to follow.
This example illustrates how the system 10 can be used to implement a Wiegand communication protocol (see
In a similar fashion as described above, devices 30 and communication protocols that do not exist currently, may be connected and implemented in future, by upgrading the software to add protocols and device-specific communication logic, and by adding software configurable parameters. It should also be noted that the term “device” also refers to certain types of sensors, such as temperature sensors, vibration sensors, etc. (see
This example illustrates how the system 10 can be used to configure a microprocessor in runtime for use with a particular device 30, by implementing a specific communication protocol.
The system 10 can include a multitude of existing software, protocol/device libraries. Reference is in this regard made to an example of a user interface of the system 10 shown in
In
In one example, the GPIO pins 14 of the microprocessor 12 may be configured, by means of the software/firmware, to be grouped together in order to configure the following interfaces/virtual ports:
Any number of GPIO pins 14 may be grouped to configure the following interfaces/ports (not limited to these):
It should however be appreciated that the system 10 is not limited to the “virtual port” examples listed above.
Data Shifting Mechanism
The following communication techniques can be used in various different communication protocols and typically relies on the native processing capabilities of the microprocessor 12. This technique is described as follows:
Programmable Voltage Switching Circuit
It should be noted that the system 10 can include a generic hardware circuit with fast switching two-way DC-to-DC Volt shifting capabilities (with isolation protection) to convert the microprocessor GPIO Voltage to/from the device interface-specific voltage requirements. The voltage level shifting circuitry is software configurable depending on the type of device interface that is created. Reference is in this regard specifically made to
From the above, it should be clear that the system 10 has considerable advantages over current hard-wired device interfaces, since the interfaces can be implemented in software, in combination with GPIO pins 14 and the programmable voltage switching circuit 52. The parameters of the communication protocols can also be configured remotely via a communication network on software programmable user interfaces. In other words, a person does not need to physically be at the system 10 in order to update any communication protocols thereon.
Number | Date | Country | Kind |
---|---|---|---|
2016/06120 | Sep 2016 | ZA | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IB2017/055324 | 9/5/2017 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2018/042402 | 3/8/2018 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7185138 | Galicki | Feb 2007 | B1 |
8117587 | Testardi | Feb 2012 | B1 |
20080058964 | Nickerson | Mar 2008 | A1 |
20090088885 | Yuan et al. | Apr 2009 | A1 |
20090138732 | Chang | May 2009 | A1 |
20100238003 | Chan | Sep 2010 | A1 |
20130080677 | Simmons | Mar 2013 | A1 |
20140292531 | Whitson, Jr. | Oct 2014 | A1 |
20140292532 | Whitson, Jr. | Oct 2014 | A1 |
20150131485 | Brandt et al. | May 2015 | A1 |
20150187209 | Brandt | Jul 2015 | A1 |
20150277778 | Adams et al. | Oct 2015 | A1 |
20150363012 | Sundara-Rajan et al. | Dec 2015 | A1 |
20160224489 | Mishra et al. | Aug 2016 | A1 |
20160275034 | Chang | Sep 2016 | A1 |
20170039162 | Mishra | Feb 2017 | A1 |
20170116103 | Cencini | Apr 2017 | A1 |
20170220502 | Kessler | Aug 2017 | A1 |
20170228327 | Mishra | Aug 2017 | A1 |
20180096971 | Pappu | Apr 2018 | A1 |
20180096979 | Pappu | Apr 2018 | A1 |
20180225230 | Litichever | Aug 2018 | A1 |
20190103914 | Junk | Apr 2019 | A1 |
20190213152 | Jacobs | Jul 2019 | A1 |
20200106743 | Park | Apr 2020 | A1 |
Number | Date | Country |
---|---|---|
WO-8810028 | Dec 1988 | WO |
Entry |
---|
International Search Report and Written Opinion for International Application No. PCT/IB2017/055324, dated Jan. 4, 2018. |
Extended European Search Report for EP Application No. 1784561.3 dated Feb. 5, 2020. |
Number | Date | Country | |
---|---|---|---|
20190213152 A1 | Jul 2019 | US |