Spi stands for "Serial to Peripheral Interface", and it is a hardware and firmware communications protocol developed by Motorola and later adopted by everybody. The Spi Bus is used only on the Pcb. I am positive some of you will ask: "Why is the Spi Bus used only on the Pcb? What prevents us from using it exterior the Pcb area?" The Spi Bus was specially designed to transfer data in the middle of various Ic chips, at very high speeds; say, at 180 Mhz or even more. Due to this high-speed aspect, the Bus lines cannot be too long, because their reactance increases too much, and the Bus becomes unusable. However, if you want, you could use the Spi Bus exterior the Pcb at low speeds, but this is not quite practical--the Spi Bus requires 3 or 4 communications lines, which are a bit too many, when compared to 1 or 2 lines ordinarily needed to communicate, efficiently, with field devices settled exterior the Pcb.
Anyway, on the Pcb the Spi Bus is very good, because we can almost attach to the Bus as many Ics (or devices) as we want. Please excuse me for not providing a picture of the Spi Bus, but rest assured you do not need one: the Spi Bus is so simple that you will understand all things in words.
The next question is: "Why is this Spi Bus particularly useful?" besides from exchanging data in the middle of various Ic chips, the Spi Bus is a recipe of multiplying microcontroller's pins. In other words, if you have a tiny 8 pins microcontroller, you could control with that minuscule monster few hundreds of digital Inputs and Outputs. This is impressive, and I am positive many doubt my words. Let's by comparison this.
The Spi Bus contains three lines, and they can be on any normal I/O controller pins. These Bus lines are: Clock, Data-In, and Data-Out. In addition, each Ic associated to the Spi Bus needs an private Enable line. Things work like this: suppose we have four devices, A, B, C, and D; all of them are wired to the Spi Bus lines, and the Bus itself is wired to seven controller pins--this is 3 Bus lines plus the 4 Enable ones. When we want to send a message to expedient C, we enable its Enable line first, then we send the message serially, one bit at a time. In the same time devices A, B, and D do exactly nothing, because they are not enabled.
The beauty with the Spi Bus is, it is Synchronous, meaning, when the controller sends the message to one Ic, it is also able to receive data from that Ic, in the same time. This particular aspect of the Spi protocol is particularly well superior for microcontroller-to-microcontroller communications.
Now, we have seen a small 8 pins microcontroller can control 4 devices (Ics) using 7 pins. Taking into list one expedient of type A, B, C, or D could have eight or even sixteen I/O ports, this is still far from the hundreds Inputs and Outputs I promised to you. The next gorgeous thing about the Spi Bus is: one expedient Ic can be serialized with many more of the same type! For example, we could have B1, B2, B3, B4, B5, and so on. All Ics of type B# are serialized together, and they require only 4 microcontroller pins to make them work; the Enable line is coarse to all of them. Next, we can use each expedient of type A, B, C, and D as a group of tens similar Ics.
The enabling speed of each I/O port on the Spi Bus it is slower, when multiplying microcontroller's pins, but always take into list I/O field devices don't necessarily need speeds of, say 1000 On/Off activations per second each, simply because most of them cannot handle that speed. However, there are few, very smart firmware techniques like the "barrel-shift" type of functions, which allows us to pronounce high-speed messaging on the Spi Bus, even if we have hundreds of I/Os. In the same time, the "barrel-shift" functions allow for great time supervision inside microcontroller, so that it has more time to execute other tasks--makes sense to me! To conclude, I believe it is clear now we can, indeed, build hundreds of effective I/O lines on a small 8 pins controller.
Further from this normal presentation of the Spi Bus, you should be aware almost all Ics implement the Spi protocol in a particular way. For detailed and practical applications I suggest you visit my home site at supervene Theorems. There you are going to contemplate a good tutorial book about working with hardware, firmware--including the "barrel-shift" type of functions--and software design, in general, and about few nice and practical implementations of the Spi Bus in particular.
Many microcontrollers have built-in Spi Bus hardware modules, but I was never concerned too much about using them. What I do, I always design--on the Pcb and for one microcontroller--one, two or more practice Spi Busses, because my practice implementations are far more flexible. Besides, practical implementation of a practice Spi Bus, both in hardware and in firmware, is legitimately simple--trust me with this one!
ไม่มีความคิดเห็น:
แสดงความคิดเห็น