The present invention relates to a method used in an inter-integrated circuit (I2C) system, and more particularly, to a control method for an I2C device of an I2C system and the related I2C device.
With advancements in technology, the size of an electronic system becomes larger and larger, where more and more elements are required in the electronic system. Inter-integrated circuit (I2C) is a typical two-wire interface for connecting peripheral devices with a processor or a microcontroller unit (MCU) in the electronic system, allowing the processor or MCU to communicate with these peripheral devices.
According to the specification of the I2C system, the devices in the I2C system include a master device and several slave devices. A master device should poll a slave device to obtain information from the slave device. More specifically, the master device needs to poll the slave device and checks if a status of the slave device changes, and then performs a specific operation accordingly. The polling operation consumes a lot of time and causes the master device to be busy if a large number of slave devices in the I2C system need to be polled. The I2C bus is also busy, resulting in higher electromagnetic interferences in the electronic system. Another method allows the master device to obtain information from a slave device via another line, which requires additional lines and I/O pins, and thereby increases circuit costs, especially when the I2C system includes a large number of slave devices. Thus, there is a need for improvement over the prior art.
It is therefore an objective of the present invention to provide a control method for a device of an inter-integrated circuit (I2C) system, to reduce or simplify the polling operations, in order to improve the efficiency of the I2C system.
The present invention discloses a control method for a first device of an I2C system comprising a microcontroller unit (MCU). The control method comprises receiving a first indication from the MCU of the I2C system, wherein the first indication configures the first device from a slave mode to a master mode; polling the first device itself for status information of the first device when the first device is in the master mode; determining whether the status information of the first device matches a target status after polling; and determining to perform a parameter adjustment on a second device of the I2C system when determining that the status information of the first device matches the target status.
The present invention further discloses a device of an I2C system. The device supports a master mode and a slave mode, and comprises a register module, a register control module and an I2C controller. The register module is used for storing status information and mode information of the device. The register control module, coupled to the register module, is used for performing the following steps: polling the register module for the status information of the device when the device is in the master mode; determining whether the status information of the device matches a target status after polling; and determining to perform a parameter adjustment on an I2C device of the I2C system when determining that the status information of the device matches the target status. The I2C controller, coupled to the register module and the register control module, is used for receiving a first indication from the MCU, wherein the first indication configures the device from the slave mode to the master mode.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
Please refer to
Please refer to
A general I2C system includes a serial clock line (SCL) for transmitting clock signals and a serial data line (SDA) for transmitting data. Conventionally, the polling operations of the master device in the I2C system mean that the master device transmits a message on the SDA to a slave device, where the message indicates that the master device needs to read data in a register of a specific slave device. This message may be forwarded to every slave device on the I2C bus, but only the specific slave device reacts in response to this message. This slave device replies a response message to the master device, and the response message indicates the register data or the status queried by the master device. After receiving the register data or the status of the slave device, the master device may determine whether the status of the slave device matches the target status. The determination result may lead to a specific operation or configuration performed by the master device, e.g., a parameter adjustment of a slave device.
As can be seen in
Please refer to
Step 300: Start.
Step 302: Receive a first indication from the MCU 100 of the I2C system 10, wherein the first indication configures the I2C device 104 from a slave mode to a master mode.
Step 304: Poll the I2C device 104 itself for status information of the I2C device 104 when the I2C device 104 is in the master mode.
Step 306: Determine whether the status information of the I2C device 104 matches a target status after polling.
Step 308: Determine to perform a parameter adjustment on another I2C device 102 of the I2C system 10 when determining that the status information of the I2C device 104 matches the target status.
Step 310: End.
According to the process 30, the I2C device 104 supports a master mode and a slave mode. The I2C device 104 receives a first indication from the MCU 100, where the first indication configures the I2C device 104 from the slave mode to the master mode. In other words, by transmitting the first indication, the MCU 100 configures the I2C device 104 to the master mode. The MCU 100 also configures itself to the slave mode accordingly. Therefore, the I2C device 104 may act as a master device and start the polling operations for itself. The I2C device 104 may poll itself for status information of the I2C device 104, and determine whether the status information of the I2C device 104 matches a target status after polling. After determining that the status information matches the target status, the I2C device 104 determines to perform a parameter adjustment on the I2C device 102.
Please refer to
In detail, the I2C device 104 may include a mode switch register indicating to operate in the master mode or the slave mode. The first indication I1 may include but is not limited to an address of the I2C device 104, a write signal, an address of the mode switch register of the I2C device 104, and a value indicating the master mode to be set in the mode switch register of the I2C device 104. After the I2C device 104 receives the first indication I1 and determines that the first indication I1 is configured to the I2C device 104 according to the address, the I2C device 104 may write the value indicating the master mode into the mode switch register according to the information carried by the first indication I1, allowing the I2C device 104 to enter the master mode.
Subsequently, the I2C device 104 keeps polling itself to obtain the status information when it is in the master mode; that is, the I2C device 104 keeps polling itself to check if a status of the I2C device 104 changes and matches a target status. If the detected status information does not match the target status, the I2C device 104 then polls itself again. After the I2C device 104 determines that the status information matches the target status, the I2C device 104 may determine to perform the parameter adjustment on the I2C device 102.
In response to determining that the status information of the I2C device 104 matches the target status, the I2C device 104 may transmit a second indication I2 to the MCU 100, to instruct the MCU 100 to perform the parameter adjustment on the I2C device 102. The second indication I2 may include but is not limited to an address of the MCU 100, a write signal, an address of a designated register of the MCU 100 or a flag of the MCU 100, and a value to be set in the designated register or the flag, wherein the designated register or the flag indicates that a parameter register of the I2C device 102 is to be adjusted. Therefore, after receiving the second indication I2, the MCU 100 may know that the second indication I2 is configured to the MCU 100 according to the address. The MCU 100 may also know which parameter register of the I2C device 102 needs to be adjusted according to the address and the setting value of the register or the flag. Note that the value to be set in the designated register of the MCU 100 may be a parameter value to be set in the parameter register of the I2C device 102. Alternatively, if the value to be set in the designated register or the flag of the MCU 100 is a simple value such as 0 or 1 instructing to perform the parameter adjustment, the second indication may further include a parameter value to be set in the parameter register of the I2C device 102. For example, the parameter register of the I2C device 102 may be associated with brightness control, contrast control, or saturation control on images displayed in the I2C device 102, and the parameter value may indicate the brightness, contrast, or saturation to be applied.
In addition, the I2C device 104 may further transmit a third indication I3 to the MCU 100, where the third indication I3 configures the MCU 100 from the slave mode to the master mode. After switched to the master mode, the MCU 100 is allowed to perform the parameter adjustment on the I2C device 102. Accordingly, the I2C device 104 also configures itself to the slave mode. In detail, the MCU 100 may also include a mode switch register indicating to operate in the master mode or the slave mode. The third indication I3 may include but is not limited to an address of the MCU 100, a write signal, an address of the mode switch register of the MCU 100, and a value indicating the master mode to be set in the mode switch register of the MCU 100. After the MCU 100 receives the third indication I3 and determines that the third indication I3 is configured to the MCU 100 according to the address, the MCU 100 may write the value indicating the master mode into the mode switch register according to the information carried by the third indication I3, allowing the MCU 100 to enter the master mode. Note that the second indication I2 and the third indication I3 transmitted by the I2C device 104 may be transmitted separately as shown in
As shown in
Please note that the embodiment of message flows shown in FIG. 4 is one of various embodiments of the present invention. For example, the parameter adjustment of the I2C device 102 may be performed by the I2C device 104 instead of the MCU 100. Please refer to
After the parameter adjustment of the I2C device 102 is completed, if it is necessary, the I2C device 104 may transmit another indication I5 to the MCU 100, to configure the MCU 100 to the master mode. The content of the indication I5 is similar to the content of the indication I3, and will not be narrated herein. The I2C device 104 may transmit the indication I5 to configure the MCU 100 to the master mode at any time according to a predefined configuration, and the I2C device 104 configures itself to the slave mode accordingly. The I2C device 104 may be configured to return to the slave mode at any time. Alternatively, the MCU 100 is capable of automatically configuring itself to the master mode. Since the I2C system cannot have two master devices simultaneously according to its specification, the I2C device 104 should return to the slave mode when the MCU 100 automatically changes to the master mode.
Please note that the above self-polling operations of the I2C device 104 are performed periodically; that is, the I2C device 104 may poll itself for the status information of the I2C device 104 periodically. The period of polling may be configured arbitrarily.
As can be seen in the message flows shown in
Please refer to
Initially, the register control module 604 may provide a default value for the mode switch register and status register(s) in the register module 602, to control the I2C device to be in the master mode or the slave mode. Alternatively, the I2C controller 606 may receive a control signal from an external I2C device or an MCU via the I2C bus, and the control signal controls the I2C device to enter the master mode or the slave mode. When the I2C device is in the slave mode, the I2C controller 606 may receive the first indication from the MCU, which may include a write signal, an address of the mode switch register of the I2C device 104, and a value indicating the master mode. After receiving the first indication, the I2C controller 606 writes the value indicating the master mode into the mode switch register in the register module 602. The register module 602 thereby transmits a control signal to the multiplexer 608, to switch the operation mode of the I2C device from the slave mode to the master mode. When the I2C device is in the master mode, the register control module 604 then polls the register module 602 for the status information of the I2C device. In detail, the register control module 604 may transmit a polling request to the register module 602, and in response to the polling request, the register module 602 may transmit the status information stored in the status register to the register control module 604. Note that the polling operation is performed periodically, and the counter 610 may configure the period of polling the register module 602 for the status information such that the register control module 604 performs self-polling operation periodically.
Subsequently, the register control module 604 determines whether the status information of the I2C device matches the target status after receiving the status information. When determining that the status information of the I2C device matches the target status, the register control module 604 may determine to perform parameter adjustment on another I2C device of the I2C system which is to be adjusted. Therefore, the I2C controller 606 may perform the parameter adjustment on the adjusted I2C device according to instructions from the register control module 604. More specifically, the I2C controller 606 may transmit an indication, such as I4 in
In an embodiment, the I2C system is used for data transmission in a monitoring system. Please refer to
In an embodiment, the MCU 702 may transmit an indication, such as the first indication I1 in
It should be noted that whether the modulator 706 receives the control signal CTRL or not yet, the modulator 706 keeps polling itself periodically. After receiving the control signal CTRL which triggers the status register to change its value, the modulator 706 may determine, based on the polled status information, that the status information corresponding to the brightness matches the target status. Therefore, the modulator 706 may configure the MCU 702 to enter the master mode via the I2C bus, allowing the MCU 702 to adjust the brightness which is set in the corresponding parameter register in the image sensor 704 according to the target brightness value obtained from the control center device 710. Alternatively, the modulator 706 may directly adjust the brightness which is set in the corresponding parameter register in the image sensor 704 via the I2C bus according to the target brightness value obtained from the control center device 710.
The above monitoring system may be applied to monitor the real-time image in any places required by the user. In an embodiment, the camera of the monitoring system may be a rear-view camera installed on a vehicle. In another embodiment, the camera of the monitoring system may be implemented with a doorbell to capture an image outside the door. In addition, the camera of the monitoring system may be integrated with a temperature sensor; hence, the self-polling operation of the present invention allows the MCU to reserve more resources for dealing with temperature sensing operations. In a further embodiment, the camera of the monitoring system is utilized for a video conference and integrated with an audio device; hence, the self-polling operation of the present invention allows the MCU to reserve more resources for managing the audio functions.
Please note that the present invention aims at providing a self-polling operation for an I2C system, allowing an I2C device to poll itself for status information of the I2C device. Those skilled in the art can make modifications and alternations accordingly. For example, in the above embodiments, the MCU is in the master mode and the I2C devices are in the slave mode in an initial condition. In another embodiment, an I2C device other than the MCU may be configured to the master mode when the I2C system is powered on. This configuration may be predefined in the I2C system and stored in registers of the I2C devices. In addition, the MCU refers to a processing unit of an electronic system, and may be replaced by a central processing unit (CPU) or another type of processor. Note that a general polling operation of an I2C system should follow the specification of the I2C system, where the polling request and response have predefined formats, allowing the master device and the slave devices to communicate with each other. On the other hand, in the embodiments of the present invention, the self-polling operation refers to an I2C device polling itself, so the formats of the polling request and response do not need to follow the I2C specification, as long as the formats of the polling request and response are recognizable by the register control module, the register module and/or other related devices in the I2C device. Furthermore, in the above embodiments, the status information refers to a value in a status register. In another embodiment, the status information may be a combination of values in multiple status registers indicating any possible statuses of the I2C device; this is not limited herein.
To sum up, the present invention provides a control method for an I2C device of an I2C system, where the I2C device is allowed to poll itself for status information of the I2C device. This reduces data transmissions for polling operation in the I2C system, and thereby improves the efficiency of the I2C system. With the self-polling operation of the present invention, the loading of the MCU is significantly reduced, so that the MCU may reserve more resources for other operations. In addition, signal transmissions on the I2C bus are reduced; this reduces electromagnetic interference problems generated from the I2C bus.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.
This application claims the benefit of U.S. Provisional Application No. 62/353,050, filed on Jun. 22, 2016, the contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
8719476 | Tokuda | May 2014 | B2 |
20150074305 | Sengoku | Mar 2015 | A1 |
20150095537 | Sengoku | Apr 2015 | A1 |
20160034417 | Chavez | Feb 2016 | A1 |
Number | Date | Country | |
---|---|---|---|
20170371819 A1 | Dec 2017 | US |
Number | Date | Country | |
---|---|---|---|
62353050 | Jun 2016 | US |