This disclosure is in the field of configuring software programmable identifications of slave components in a circuit.
In most conventional serial bus standards, such as MIPI (a circuitry standards organization) RFFE (RF Front-End), several slave components can exist on the bus. Each slave has a unique Slave ID (USID). To minimize bus overhead, there are only a finite number of bits used to assign the USID. This leads to the potential of multiple slaves having the same USID, and therefore these multiple slaves having the same USID cannot be uniquely addressed.
To alleviate this problem, some standards allow a software programmable USID. This software programmable ID is generally in addition to a hard-wired default ID. Upon reset, the slave generally (although not always) reverts back to the hard-wired default ID.
In the MIPI RFFE standard, the product_id and manufacturer_id are used in the programming sequence to derive a potentially unique Slave ID for each slave. This works well if each chip has a unique Slave ID (due to a unique product_id, or a unique manufacturer_id, or a unique combination of product_id and manufacter_id).
In the case where the MIPI RFFE standard Slave ID is not unique (e.g. several identical chips on the same bus), software programming of the Slave ID (slave_ids) is not possible using conventional standards such as MIPI RFFE. A second conventional method is to use pins to tie high or low, with bond wires or the PCB (printed circuit board) tied high or low. In other words, the Slave ID is “mechanically” individually hardwired for each slave. However, this method has high costs associated with adding IO pins and placement on the PCB (printed circuit board). Additional pins also mean more ESD (electro-static discharge) hazards. Additional pins can also cause difficulties with the RF operation of the IC. Further, each pin can only increase the number of slaves by 2×. For example, for 4 slaves we need 2 pins (set at 00, 01, 10, and 11), and for 8 slaves need 3 pins (000 though 111). This hard wiring method does have the advantage of eliminating the need for the bus master to have several GPIO pins that are used as slave selects. GPIO stands for General Purpose Input/Output.
A third conventional method uses eFuses to configure slaves during production. This requires more programming (setting the eFuses) during production, and requires the customers and suppliers to inventory and track the slaves individually and uniquely as they are organized into larger circuits.
The main problem is that identical components generally cannot be easily uniquely identified in a circuit, and therefore it is difficult to use software to assign unique identifications to each of the identical components.
In other words, if you have a group of children all named Sam, how do you instruct just one of the Sams (the first Sam) that you are changing his name (and only his name) to Fred? And then, how do you instruct just one of the remaining Sams (the second Sam) that you are changing his name (and only his name) to Bill? And so forth.
The present disclosure relates to a method in which the slaves are cascaded on a bus, and cascading slave-to-slave communication is used to prioritize (or sequence) the software slave ID programming. In one embodiment, the first slave in the cascade stalls the programming of other slaves until the first slave's programming is complete. Once completed, the first slave then enables programming of the second slave, and so on. The present disclosure is compatible with (does not conflict with) the MIPI RFFE standard. This embodiment allows multiple placements of identical slaves on the bus, and still provides a method to uniquely identify and control each slave by using cascading software slave ID programming.
As a first example, a group of three children have the same name (Sam). The first Sam holds his hands over the ears of the second Sam, and the second Sam hold his hands over the ears of the third Sam, and so forth. This organization may be called a serial disablement (the first disables the second, and the second disables the third), or a cascading disablement. Only the first Sam has uncovered ears, so only the first Sam can hear commands. Parenthetically, a structure with a similar effect may be created by lack of enablement (instead of disablement), wherein initially only the first Sam is enabled, and the other Sams are initially not enabled.
Returning to the example of cascading disablement, a teacher (or master) commands, “Sam, your new name is Fred, and put your hands in your pockets.” Only the first Sam (now Fred) hears and obeys the teacher by accepting his new name (Fred) and removing his hands from the ears of the second Sam, thus removing the disablement of Sam. Alternatively, this command may be in two parts, “Sam, your new name is Fred. Fred, put your hands in your pockets.” Now the second Sam can hear future commands from the teacher. The third Sam still cannot hear commands, because his ears are still covered by the hands of the second Sam.
The teacher then says, “Sam, your new name is Bill, and put your hands in your pockets.” The first Sam (now Fred), hears and ignores the teacher because the commands are directed towards Sam. The second Sam hears and obeys. Again alternatively, this command may be in two parts, “Sam, your new name is Bill. Bill, put your hands in your pockets.”
Thus, the first Sam is now named Fred, the second Sam is now named Bill, and the third Sam can hear the next command for the next new name. In this fashion, a large number of Sams can be sequentially renamed, because only one Sam can hear the teacher at any time.
Interestingly, it is not essential to rename the last Sam, because if all of the other Sams are renamed then the last Sam is the only Sam. However, preferably the last Sam is renamed according to some sequential list of names.
Additionally, the last Sam may be “renamed” as Sam. For example the last Sam is hard-wired with a default/initial name of Sam, and he may be “renamed” as Sam in a programmable USID which is stored in a register, and which may take priority over the hard-wired default name under most circumstances.
Further, in the above example, the first child initially disabled the second child (by placing hands over the ears of the second child), and then later stopped disabling the second child (by removing the hands). This is the case of the children having a default condition of enablement, and needing a signal (hands over the ears) to be disabled.
Alternatively, the first child might initially not enable the second child, and then later actively enable the second child. In this case, the results are the same, but the exact logic is slightly technically different (stopping disablement, in contrast to granting enablement).
In one embodiment, a method for uniquely configuring a first slave having an initial USID (Unique Slave ID) comprises: providing the first slave; performing a first name change (including receiving, by the first slave, a first reference voltage having a first start up value, and receiving, by the first slave, a first new USID which is different from the initial USID); and performing a first transition (including sending, by the first slave after receiving the first new USID, a first output reference voltage having a second start up value). The first new USID is also known as a programmable USID.
Those skilled in the art will appreciate the scope of the present disclosure and realize additional aspects thereof after reading the following detailed description of the preferred embodiments in association with the accompanying drawings.
The accompanying drawings incorporated in and forming a part of this specification illustrate several aspects of the disclosure, and together with the description serve to explain the principles of the disclosure.
The embodiments set forth below represent the necessary information to enable those skilled in the art to practice the embodiments and illustrate the best mode of practicing the embodiments. Upon reading the following description in light of the accompanying drawing figures, those skilled in the art will understand the concepts of the disclosure and will recognize applications of these concepts not particularly addressed herein. It should be understood that these concepts and applications fall within the scope of the disclosure and the accompanying claims.
As a preliminary matter, slaves placed on a bus are cascaded by one of several methods. Because of the cascade, only the first slave on the bus is active immediately after power up and before system configuration is complete. The first slave is programmed to have a new slave ID. Programming a new slave ID in the first slave activates a trigger to program the second slave. The second slave is programmed, which in turn triggers the third slave. This cascading/triggering process continues until all slaves are programmed with new unique (and preferably sequential) slave IDs. At this point all devices are active on the bus and can be accessed (through their new unique slave IDs) without interference with each other.
A MIPI RFFE standard slave interface has a VIO pin that can be used to put the slave into a shutdown (or sleep or reset) mode. If VIO is low (low voltage, or shut down value), the slave is in a shutdown mode. In this shutdown mode, the slave registers are in reset, which generally sets (resets) the USID (Unique Slave ID) to its hardwired “power on” default value. Since all the slaves in
It is possible, although perhaps contrary to the present MIPI RFFE, to have a reset which retains the software USID in some of the slave registers, and thus does not reset/revert back to the hardwired USID during reset (VIO low).
In MIPI RFFE, version 1.10, Jul. 26, 2011, VIO is described as an “input/output supply/reference voltage,” and is rather complex. VIO generally only powers the level shifters in the 10 pads, whereas the rest of the slave may have power (from Vbatt, not shown) even if VIO is low. Less commonly, in some products the entire digital block is powered from VIO. However, when VIO goes low, generally the slave does not operate, but will be in a standby state and the serial interface is turned off. In the standby state, the USID does not matter.
So for either case (whether VIO powers the entire slave or just the level shifters), when VIO goes low, then the USID is a “don't care” (because the serial interface is inactive).
Thus, as discussed above, the programmable USID is stored in a register, and resetting the slave resets the registers and reverts the slave back to the hard wired USID. With respect to MIPI RFFE, the embodiment of
The VIO2 output pin 1D of the first slave (slave 1) is connected to input VIO pin 2C of the second slave (slave 2) through signal S1-2, and the output pin 2D of the second slave is connected to input VIO pin 3C of the third slave (slave 3) through signal S2-3.
This figure may be expanded by inserting additional slaves between slave 2 and slave 3, as indicated by the ellipsis in
Initially, VIO signal S1 is low, which sets (resets) the USID (Unique Slave ID) of slave 1 to its “power on” hardwired default value. For example, the default value may be 15 (or 1111 in binary). Also, initially VIO2 output pin 1D of slave 1 is low, and is connected to VIO input pin 2C of slave 2 such that slave 2 similarly sets (resets) the USID (Unique Slave ID) of slave B to its “power on” default value. In this fashion, the VIO input of every slave is low initially.
Introducing some convenient terminology, the first slave (slave 1) has a first reset input (VIO signal S1) connected to a first reset input pin 1C, and a first reset output (VIO2 signal S1-2) which is connected to the VIO input pin 2C of the second slave (slave 2).
Referring to
It is not essential to rename the last slave, because it is acceptable for the last slave to be the only slave with the initial USID. However, it is preferable to rename the last slave for the sake of symmetry (for example, renaming the slaves in a sequential decreasing order), and in order to place a name in the registers of the last slave.
Further, note that this cascade method is limited by the number of bits in the USID. For example, in the case of 4 bits, the slaves may be renamed from 14 down to 1 (for 14 slaves in MIPI RFFE, because 0 is reserved for other purposes), and a fifteenth slave (last slave) may optionally be “renamed” in its registers as 15 (the same as its hardwired default name in this example). The renaming may occur sequentially, or may occur randomly (but without repetition). The last or final slave does not have to be renamed, because its initial name becomes unique after all previous slaves have been renamed.
Preferably, the first slave sends a signal to the master confirming that its name has been changed, and then, after receiving this confirmation, the master names the second slave. Alternatively, the master may wait a safe period of time (perhaps double the expected period of time that it should take for the first slave to change its name and to send the VIO2 high signal to the second slave), and then assume that the first name change was successful, and then name the second slave. The VIO2 output pin 3D of the last slave is not used for cascading renaming purposes, but may be used to signal to a master (not shown) that the renaming of all of the slaves has been completed.
After all of the names are changed, changes in the VIO signal S1 should quickly propagate (be re-sent) from slave 1 to slave 2, and so on downstream, so that all slaves effectively receive the VIO signal S1 at almost the same time. In theory, a very long chain (perhaps 516 slaves) may have timing problems (in ordinary operations after the renaming is completed) due to delays in passing/repeating the VIO signal from slave to slave. This should not be a problem in small chains such as 16 slaves. Further, generally devices are programmed when the VIO stays high (enabled). At the end of a burst or phone call, VIO will go low. Thus, the above discussed propagation delays are generally not critical.
This embodiment avoids the timing difficulties discussed above in
The slaves (slave 4, slave 5, and slave 6) use GPO output pins (4F, 5F, and 6F respectively) to stall the programming of downstream slaves. The first slave has the GPI 4E tied high to enable it. Thus, slave 1 is always enabled with respect to GPI.
Initially, slave 1 holds its output GPO low to disable slave 2 via signal S4-5. Similarly, slave 2 initially holds its GPO output low to disable the downstream slave via signal S5-6. The GPO output pin 6F of the last slave (slave 6 in
The programming procedure for
Additionally, the configuration of
These signal pins may be used to signal and control downstream slaves, similar to the control mechanisms of
In cases where identical slaves appear on the same bus, these slaves may perform the same function. For instance, adding more slaves can increase the order of a filter. In this case, the slaves may use AC pins that are multiplexed until configuration of the slaves is complete.
The VIO signal S1, SCLK signal S2, SDATA signal S3, and the associated slave input pins are the same as in
A signal S5 branches at a node and inputs to slave 7 as signal 7-IN, and inputs into associated parallel circuit 10 as 10-IN. The output signal of slave 7 is 7-OUT. During renaming, the parallel circuits 10, 11, and 12 are inactive, and
In
In contrast to
For example, slave 13 may control an associated circuit 16 to enable it, such as with an existing enablement pin in circuit 16. If an enablement pin in circuit 16 is disabled, then downstream slave 14 is stalled (disabled) from receiving an RFFE renaming command from a master (not shown). After being renamed, then slave 1 enables associated circuit 16 to enable Slave 2.
In the following claims, the term “reset” is defined broadly as placing a slave into a state where it cannot receive a new USID, and the term “start up” is defined broadly as placing the slave in a state where it can receive a new USID. In other words, reset is defined broadly as comprising at least one of the following functions: sleep, off, disabled, not enabled, and shut down. Similarly, the term “start up” is defined broadly as comprising at least one of the following functions: start up, enabled, not disabled, and active.
Those skilled in the art will recognize improvements and modifications to the preferred embodiments of the present disclosure. All such improvements and modifications are considered within the scope of the concepts disclosed herein and the claims that follow.
This application claims the benefit of provisional patent application Ser. No. 61/489,025, filed May 23, 2011, the disclosure of which is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61489025 | May 2011 | US |