Spi stands for "Serial to Peripheral Interface", and it is a hardware and firmware communications protocol advanced by Motorola and later adopted by everybody. The Spi Bus is used only on the Pcb. I am inescapable 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 exchange data in the middle of varied 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 commonly needed to communicate, efficiently, with field devices placed exterior the Pcb.
Anyway, on the Pcb the Spi Bus is very good, because we can roughly attach to the Bus as many Ics (or devices) as we want. Please excuse me for not providing a photo of the Spi Bus, but rest assured you do not need one: the Spi Bus is so simple that you will understand everything in words.
Router D Handle
The next demand is: "Why is this Spi Bus particularly useful?" also from exchanging data in the middle of varied Ic chips, the Spi Bus is a method of multiplying microcontroller's pins. In other words, if you have a tiny 8 pins microcontroller, you could operate with that tiny monster few hundreds of digital Inputs and Outputs. This is impressive, and I am inescapable many doubt my words. Let's construe 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 related to the Spi Bus needs an personel 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 device 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 charm 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 singular aspect of the Spi protocol is particularly well superior for microcontroller-to-microcontroller communications.
Now, we have seen a small 8 pins microcontroller can operate 4 devices (Ics) using 7 pins. Taking into account one device 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 beautiful thing about the Spi Bus is: one device 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 tasteless to all of them. Next, we can use each device 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 account I/O field devices don't necessarily need speeds of, say 1000 On/Off activations per second each, naturally 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 declare 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 administration 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 roughly all Ics implement the Spi protocol in a singular way. For detailed and practical applications I recommend you visit my home site at follow Theorems. There you are going to inspect 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 curious 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 no ifs ands or buts simple--trust me with this one!
Spi Bus: theory and Implementation