DYNAMICALLY CONFIGURABLE SERIAL DATA COMMUNICATION INTERFACE
A serial peripheral interface (SPI) controller can be configured in response to data received via the interface. The SPI controller can perform read and write operations upon registers of a register bank in response to signals received via one or more of a data signal line, a clock signal line, and a select signal line. By detecting combinations of signals on one or more of the data signal line, clock signal line and select signal line, the SPI controller can detect the initiation of data read and write operations that may be in accordance with any of several different SPI protocols.
Latest SKYWORKS SOLUTIONS, INC. Patents:
- Baluns with integrated matching networks
- Secondary phase compensation assist for PLL IO delay
- Power management systems and methods related to a plurality of converters for providing dual integrated multi-mode power management
- Secondary phase compensation assist for PLL IO delay aligning sync signal to system clock signal
- Switch circuitry for satellite-navigation-band filters
A serial data communication interface comprises a data bus operating in accordance with a data communication protocol to transfer data serially, i.e., one bit at a time, from one device to another. A well known family of serial data communication interfaces, sometimes referred to as Serial Peripheral Interface or SPI, includes at least three signal lines: Data, Clock and Select. Although these signal lines are commonly referred to as Data, Clock and Select, alternative names, such as Enable instead of Select, are also used. Various types of serial data communication interfaces having so-called “4-wire,” “3-wire,” “2-wire” and even “1-wire” data buses are known, where the term “wire” is a colloquial reference to a signal line. In actuality, the signal line may be a wire, a printed circuit board trace, an optical fiber, or other such single-channel signal-carrying medium. The term “Serial Peripheral Interface” or “SPI” is commonly used to refer to a 3-wire interface having a bidirectional Data line along with the Clock and Select lines, although in some instances the term has been used to refer to a 4-wire interface having two unidirectional Data lines along with the Clock and Select lines. Some SPI busses also include a Reset line.
The SPI is commonly used in electronic systems in which a relatively complex digital subsystem, such as one having a microprocessor, controls aspects of the operation of a peripheral device or other subsystem that is more basic or otherwise different from the controlling digital subsystem. For example, some digital subsystems use a SPI to control another subsystem that primarily comprises analog circuitry, such as radio frequency (RF) circuitry. As illustrated in
As illustrated in
Several types of well-known SPI protocols are illustrated by means of the timing diagrams of
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As illustrated in
In a system in which, for example, SPI slave controller 32 operates in accordance with a first one of the above-described SPI protocols but SPI slave controller 34 operates in accordance with a second one of the above-described SPI protocols, SPI master controller 26 must be capable of switching between the two protocols, i.e., using the first protocol to communicate data with SPI slave controller 32 and using the second protocol to communicate data with SPI slave controller 34. Providing a master controller 26 that operates in accordance with several different protocols can introduce a number of inefficiencies for system manufacturers. Also, providing an RF subsystem 12 that integrates multiple slave controllers operating in accordance with different protocols can be similarly inefficient. It is possible to signal a SPI slave controller circuitry to operate in accordance with a selected SPI protocol by supplying a protocol mode control signal to a mode select pin or similar input on an integrated circuit chip having such a protocol mode select feature. However, dedicating a pin to a protocol mode control signal is wasteful of input/output resources.
SUMMARYEmbodiments of the present invention relate to a serial peripheral interface (SPI) controller that can be configured in response to data received via the interface. The SPI controller can perform read and write operations upon registers of a register bank in response to signals received via one or more of a data signal line, a clock signal line, and a select signal line. By detecting combinations of signals on one or more of the data signal line, clock signal line and select signal line, the SPI controller can detect the initiation of data read and write operations. Different combinations of signals can indicate to the SPI controller the type of SPI protocol with which the data read or data write operation is in accordance, thereby allowing the SPI controller to respond to the initiation of the data read and write operations regardless of which of the two or more SPI protocols is used. Accordingly, when the SPI controller detects the initiation of a data read or data write operation, the SPI controller controls the performance of a corresponding data read or data write operation upon a register identified by the address bits that are received serially on the data signal line.
Other systems, methods, features, and advantages of the invention will be or become apparent to one with skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features, and advantages be included within this description, be within the scope of the invention, and be protected by the accompanying claims.
The components within the figures are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the invention. Moreover, in the figures, like reference numerals designate corresponding parts throughout the different views.
As illustrated in
To control the RF circuitry of IC chip 36, an SPI master controller 44 can initiate a write operation in which SPI master controller 44 transmits data via SPI bus 45 to SPI slave controller 38, which writes the data to a register of a register bank 46. The data that has been written to or latched into the registers is provided to logic blocks 40, 42, etc., in the form of a parallel or multiple-bit data word. For example, a 16-bit data word, REGj[15:0], is provided to the jth logic block 40. A signal name notation that is used throughout the drawing figures to refer to such parallel data words has the form: “X[A:B],” where X is the signal name, A is the index of the most-significant bit, and B is the index of the least-significant bit. SPI master controller 44 can also initiate a read operation, to which SPI slave controller 38 responds by reading data from a register of register bank 46 and transmitting the data to SPI master controller 44 via SPI bus 45.
The SPI bus 45 between SPI master controller 44 and SPI slave controller 38 includes a data signal line 48 (SPI_DATA) that is connectable to a first pin 50 of integrated circuit chip 36, a select signal line 52 (SPI_SEL) that is connectable to a second pin 54 of integrated circuit chip 36, and a clock signal line 56 (SPI_CLK) that is connectable to a third pin 58 of IC chip 36. SPI slave controller 38 also includes SPI control logic 60, a clock signal generator 62, and a reset generator 64. SPI control logic 60 can receive a serial data signal SDAT_IN from first pin 50 and send serial data signal SDAT_OUT to first pin 50. SPI control logic 60 generates a serial output enable signal SOE that controls the direction of data flow through first pin 50. The SPI control logic 60 also receives the select signal SSEL via second pin 54. SPI control logic 60 provides a number of signals to register bank 46: an address Addr[14:0], write data WrData[15:0], and an address length LenAdr[3:0]. SPI control logic 60 also receives signals from register bank 46: the data word stored in a register having an index “0” or REG0[14:0], and read data RdData[15:0]. SPI control logic 60 is described in further detail below.
Register bank 46 also receives a device identifier 68 (DEV_ID[11:0]) that uniquely identifies IC chip 36. That is, in a system having two or more IC chips (not shown), the device identifier (“device ID”) of each chip is different from the device ID of all other chips in the system. SPI master controller 44 can thus use the device ID as part of an address in read or write operations directed to that chip, as described in further detail below. The device ID can be, for example, hard-wired into the logic of IC chip 36. Although in the exemplary embodiment the device ID is 12 bits in length, in other embodiments a device ID can be any other suitable length.
Clock signal generator 62 receives a clock signal SCLK via third pin 58, receives a write enable signal WrEn from SPI control logic 60, and receives the two least-significant bits of the contents of REG0 or REG0[1:0]. As described in further detail below, REG0 is used as an interface configuration register to store information that indicates various modes of SPI operation. Clock signal generator 62 generates a clock register signal ClkReg that it provides to register bank 46 and a clock SPI signal ClkSPI that it provides to SPI control logic 60. Clock signal generator 62 is described in further detail below.
Reset generator 64 receives an active-low hard reset signal RESET_B from a power-on reset (POR) signal generator 66. In the exemplary embodiment, POR signal generator 66 is not part of SPI slave controller 38 but rather is the part of IC chip 36 that provides a reset signal to other circuitry in IC chip 36 when power is first applied to IC chip 36, such as when a mobile telephone handset (not shown) in which IC chip 36 is included is turned on by a user. Reset generator 64 also receives the clock signal SCLK and one bit (REG0[15]) of the configuration word stored in the interface configuration register. Reset generator 64 generates a register reset signal RstReg that it provides to register bank 46 and a SPI reset signal RstSPI that it provides to SPI control logic 60. Reset generator 64 is described in further detail below.
SPI slave controller 38 can operate in accordance with the exemplary flow diagram of
As illustrated in
As indicated by block 74, SPI master controller 44 can configure or set a soft device
ID in any of one or more SPI slave controllers that can be used instead of, i.e., as an alias for, the above-referenced device identifier 68 (DEV_ID[11:0]). For example, a 4-bit soft device identifier (ID) can be assigned to integrated circuit chip 36 that can be used instead of the 12-bit device identifier 68, thus economizing on the number of address bits that SPI master controller 44 needs to send in subsequent read and write operations. To set the soft device ID, SPI master controller 44 initiates a write operation upon a device ID configuration register. The device ID configuration register can be, for example, a register having an index of “1” (REG1) in register bank 46 of SPI slave controller 38. A diagram or map illustrating the bit assignments of the device ID configuration register (REG1) in register bank 46 is shown in
As indicated by block 76, SPI slave controller 38 responds to the write operation to the device ID configuration register by setting the soft device ID. The timing diagram of
In the write operation illustrated in
With reference to
Once the respective soft device IDs of the first and second devices have been configured or set in the manner described above with regard to
With reference to
Returning to
It is contemplated that performing a read operation or write operation upon one of registers REG2-REGj be performed after performing a write operation upon one or both of the device configuration register REG1 (e.g., as indicated by block 82) and the device ID configuration register REG0 (e.g., as indicated by blocks 74-76). That is, it is contemplated that normal read and write operations intended to affect logic blocks 40, 42, etc. (
SPI slave controller 38 can detect whether a data write or data read operation is initiated in accordance with the active-high select SPI protocol, the active-low select SPI protocol, or the I2C SPI protocol by monitoring the SPI_SEL, SPI_DATA and SPI_CLK signals. As described in further detail below, SPI control logic 60 of SPI slave controller 38 can detect the transitions, i.e., rising and falling edges, of SPI_SEL, SPI_DATA and SPI_CLK. By detecting combinations of signal levels and transitions, SPI control logic 60 can detect the initiation of a data write or data read operation, regardless of whether the SPI protocol is active-high select, active-low select, or I2C. SPI slave controller 38 begins operation in the reset state 70 (
As illustrated in
The transition of RESET_B from an active state to an inactive state at the rising edge 202 indicates to SPI slave controller that another data write or data read operation may follow the above-described data write operation. In response to the transition of RESET_B to an active state, reset generator 64 transitions RstSPI (not shown in
The transition of RESET_B from an active state to an inactive state at the rising edge 214 indicates to SPI slave controller 38 that yet another data write or data read operation may follow the above-described data write operations. In response to the transition of RESET_B to an active state, reset generator 64 transitions RstSPI (not shown in
In a data write or read operation, SPI slave controller 38 of the exemplary embodiment can also detect the polarity of the Write/Read bit. That is, SPI slave controller 38 senses one of two modes: a first mode in which a low Write/Read bit indicates a write operation and a high Write-Read bit indicates a read operation, and a second mode in which a high Write/Read bit indicates a read operation and a low Write/Read bit indicates a write operation. Although it is conventional for a low Write/Read bit to indicate a write operation and a high Write/Read bit to indicate a read operation (i.e., the first mode), the polarity detection feature of the exemplary embodiment accommodates a contemplated instance in which a SPI master controller may initiate a write or read operation in which the Write/Read bit polarity is the opposite (i.e., the second mode). Also, although in the exemplary embodiment SPI slave controller 38 only detects the Write/Read bit polarity when a write operation or read operation immediately follows the reset state (block 70) and not every time a write operation or read operation follows the idle state (block 78), in other embodiments a SPI slave controller can detect the Write/Read bit polarity at any other time.
In the exemplary embodiment, in responding to a write operation, SPI slave controller 38 can not only detect which of several SPI protocols is being used, but SPI slave controller 38 can also detect whether the write operation involves a compressed data mode. The term “compressed” as used herein refers to a mode in which two or more data words are sent during a single write operation. In a compressed mode write operation, SPI slave controller 38 automatically increments the register address each time a data word is received. In the compressed mode write operation illustrated in
Returning to
As indicated by block 84, SPI slave controller 38 can set the latch mode that is to be used or applied in any further data write operation (i.e., following the write operation upon the interface configuration register) that may be performed upon another register. The timing diagrams of
The write operation illustrated in
The write operation illustrated in
Returning to
The write operation illustrated in
The write operation illustrated in
Returning to
The write operation illustrated in
The write operation illustrated in
Returning to
The write operation illustrated in
The write operation illustrated in
Returning to
The write operation illustrated in
The write operation illustrated in
Returning to
Returning to
In
Data mapper 226 either passes the data through unchanged or reorders the bits, in accordance with the above-described bit order mode as indicated by a signal SelBitOrd that represents the contents of REG0[12]. A flip-flop array (i.e., a register) 240 latches the output of data mapper 226 as a write data word WrData[15:0]. Shift controller 224 generates a write data sample signal SmpWrData that controls flip-flop array 240.
Shift controller 224 also generates an address sample signal SmpAddr that controls another flip-flop array (i.e., register) 242, which latches the output of data mapper 226 as an address Addr[14:0]. Shift controller 224 generates a compressed mode detection signal DetCmpr for controlling a multiplexer 244 at the input of flip-flop array 242. If DetCmpr indicates compressed mode, an adder 246 increments Addr[14:0] by one and feeds the result back to the selected input of multiplexer 244.
The serial data output (SDAT_OUT) is selected by a multiplexer 248 either from the shift register output or from a flip-flop 250, response to REG0[8]. Flip-flop 250 is used in an instance in which the least-significant bit of the turnaround length word (CtrlTrn[0]) stored in REG0[10:8] is a “1”, indicating that the turnaround length is not an integer number of clock cycles but rather includes a half cycle. As described above, the turnaround length word can be programmed or set with a resolution of one-half of a clock cycle. For example, a turnaround length of 1½ clock cycles can be set. Accordingly, in an instance in which REG0[8] is set to “1”, an inverter 252 inverts ClkSPI so that flip-flop 250 latches the shift register output on the falling edge of ClkSPI. In an instance in which REG[8] is set to “0”, multiplexer 248 does not select the output of flip-flop 250 but rather selects the shift register output directly.
In
Trigger signal circuitry, comprising two multiplexers 280 and 282, two flip-flops 285 and 287, and two AND gates 289 and 291, is controlled by SEL_PROT and outputs the start trigger signal TrgStrt and stop trigger TrgStp signals, respectively. Multiplexer 280 selects the start trigger event associated with the detected SPI protocol. If active-high select SPI protocol has been detected, multiplexer 280 selects the rising edge of SPI_SEL as a start trigger. If active-low select SPI protocol has been detected, multiplexer 280 selects the falling edge of SPI_SEL as a start trigger. If I2C SPI protocol has been detected, multiplexer 280 selects the combination (via an AND gate 284 and inverter 288) of a falling edge of SPI_DATA occurring while SPI_CLK is high as a start trigger. If no SPI protocol has been detected yet, multiplexer 280 selects DET is used as an initial start trigger. Multiplexer 282 selects the stop trigger event associated with the detected SPI protocol. If active-high select SPI protocol has been detected yet, multiplexer 282 selects the falling edge of SPI_SEL (via an inverter 290) as a stop trigger. If active-low select SPI protocol has been detected, multiplexer 282 selects the rising edge of SPI_SEL as a stop trigger. If I2C SPI protocol has been detected, multiplexer 282 select the combination (via an AND gate 286) of a rising edge of SPI_DATA occurring while SPI_CLK is high as a stop trigger. If no SPI protocol has been detected yet, multiplexer 282 selects an input that is tied low (e.g., connected to a fixed voltage such as VSS or ground), because no stop trigger is needed yet.
In
In
Also, during the first or initial data transfer operation that occurs following a reset, circuitry that includes an exclusive-OR gate 257, a flip-flop 259 and an AND gate 261 senses the polarity of the Write/Read bit, i.e., the first bit of the serial data input (SDAT_IN) that occurs when TrgStrt is high. That is, this circuitry senses one of two modes: a first mode in which a low Write/Read bit indicates a write operation and a high Write-Read bit indicates a read operation, and a second mode in which a high Write/Read bit indicates a read operation and a low Write/Read bit indicates a write operation. As the initial data transfer operation following a reset is presumed to be a write operation to a configuration register or other register, flip-flop 259 stores the state of the first bit of the serial data input (SDAT_IN) that occurs when TrgStrt is high.
The inverted output of flip-flop 256 (WrCmd) remains high throughout the entirety of each data transfer. The write enable signal WrEn is a pulse that is generated via AND gate 254 when either the trigger stop signal TrgStp is generated at the end of the data transfer or when the shift count times out. The timeout of the shift count is indicated by the sample write data signal SmpWrData. The latch select signal SelLtch, which represents the contents of REG0[1], controls whether multiplexer 258 selects the trigger stop signal TrgStp or the sample write data signal SmpWrData as the basis for generating the write enable signal WrEn.
Another one of the functions of shift controller 224 is to determine the number of address bits, i.e., the address length, DetLenAddr, and data bits, i.e., the data length DetLenData. A flip-flop array (i.e., register) 296 maintains the shift count (“CntShft[5:0]”). An adder 298 increments the count on each cycle of the clock signal ClkSPI. A multiplexer 300 selects a value of zero for loading into flip-flop array 296 when TrgStrt is in a high state. When TrgStrt is in a low state, multiplexer 300 selects the output of another multiplexer 302, which selects the address length when the shift count reaches the sum of the address length and data length. Logic elements that include two multiplexers 304 and 306 and two comparators 308 and 310 determine whether the number of data bits, i.e., the data length, DetLenData, is 8, 16 or 28. As described above, when a value of “0” is stored in REG0[3:2], a dynamic or on-the-fly selection of DetLenData is made in response to CntShft. Multiplexers 304 and 306 and comparators 308 and 310 produce an output of 28 if CntShft is greater than 32, an output of 16 if CntShft is greater than 20 but less than 32, and an output of eight if CntShft is less than 20. This output, DetLenData, is clocked into a flip-flop array (i.e., register) 312. The data length mode, as indicated by the signal CtrlData[1:0] that represents the contents of REG0[3:2] controls a multiplexer 314. If CtrlData[1:0] is “0,” indicating that the data length is to be determined dynamically, multiplexer 314 selects DetLenData stored in flip-flop array 312. However, if CtrlData[1:0] is “1,” indicating that the data length is to be set to a value of eight, multiplexer 314 selects and outputs a value of eight. Likewise, if CtrlData[1:0] is “2,” indicating that the data length is to be set to a value of 16, multiplexer 314 selects and outputs a value of 16. Similarly, if CtrlData[1:0] is “3,” indicating that the data length is to be set to a value of 28, multiplexer 314 selects and outputs a value of 28. The output of multiplexer 314 is provided to logic circuitry that includes four comparators 316, 318 and 320, an adder 322, and two multiplexers 324 and 326, which generates the sample write data signal SmpWrData and sample read data signal SmpRdData. This logic also receives as inputs, via an AND gate 328, the write command signal WrCmd and the word order mode as indicated by SelWrdOrd that represents the contents of REG0[11]. The sample read data signal SmpRdData is generated by an AND gate 331 that receives RdEn and the output of another comparator 332. An adder 334 sums the address length LenAddr[3:0] with the turnaround length, which is indicated by the signal CtrlTrn[2:1] that represents the contents of REG0[10:9]. Comparator 332 compares this sum with CntShft. If CntShft equals this sum while RdCmd is in a high state, then AND gate 331 asserts the SmpRdData signal.
A multiplexer 336 selects and outputs the address length LenAddr[3:0] in response to the address length mode, which is indicated by the signal CtrlAddr[3:0] that represents the contents of REG0[7:4]. If CtrlAddr[3:0] has a non-zero value as determined by a comparator 338, then multiplexer 336 selects and outputs the contents of REG0[7:4]. If CtrlAddr[3:0] has a value of zero, then multiplexer 336 selects and outputs the contents of the flip-flop array (i.e., register) 320 in which DetLenAddr is stored. DetLenAddr is formed by two subtractors 342 and 344 that compute the quantity ShftCnt−DetLenData−1. An AND gate 346 and a comparator 348 ensure that flip-flop arrays 320 and 312 are disabled after DetLenAddr is sampled after the first data transfer.
A set-reset flip-flop 350 outputs a DetCmpr signal when a compressed mode write operation is detected. Flip-flop 350 is set when the shift count reaches the sum of LenAddr and LenData, as indicated by the output of comparator 318. Flip-flop 350 is reset before every data transfer, as indicated by the start trigger signal TrgStrt.
Still another one of the functions of shift controller 224 is to generate the serial output enable SOE signal. Circuitry for generating the SOE signal includes a comparator 357 and an AND gate 353. The AND gate 353 receives SOE signal is generated by an AND gate 331 that receives RdCmd and the output of comparator 357. As described above, adder 334 sums the address length LenAddr[3:0] and the turnaround length. Comparator 351 compares this sum with CntShft. If CntShft is greater than this sum while RdCmd is in a high state, then AND gate 353 asserts SOE.
In
Register bank 46 also includes an address decoder 352, which decodes ADDR[14:0] and outputs signals that are gated through AND gates 354, 356, 358, 360, etc., to the Enable inputs of REG0 through REGj. The output of a comparator 362 is provided to the other input of each of AND gates 354, 358 and 360. Comparator 362 determines if the least-significant four bits of REG1, which represent the soft device ID, match the most-significant four bits of Addr[14:0]. A bit shifter 364 shifts Addr[14:0] by LenAddr bits to obtain the most-significant four bits of Addr[14:0]. Thus, REG0 and REG2 through REGj can only be written to or read from if Addr[14:0] properly addresses integrated circuit chip 36 (the “device” in this embodiment) using the soft device ID that integrated circuit chip 36 has been assigned, i.e., the soft device ID that SPI master controller 44 has caused to be stored in REG1[3:0]. Each of REG0 and REG2 through REGj can latch or store WrData[15:0] in response to a register clock signal ClkReg. Another comparator 366 determines if the hard device ID, DEV_ID[11:0], matches the most-significant bits of WrData[15:0] and, if they match, provide the other input to AND gate 356 that is needed to enable REG1. A multiplexer 368 that outputs RdData[15:0] operates in response to Addr[14:0] to select the output of one of REG0 through REGj.
In
In
Although an exemplary embodiment of the invention is described above for purposes of clarity in terms of configurations or arrangements of gate-level logic elements, it should be understood that embodiments of the invention can be structured in any suitable manner For example, the logic elements can comprise programmable elements of an application-specific integrated circuit (ASIC), field-programmable gate array (FPGA), or other programmable device.
While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that many more embodiments are possible that are within the scope of this invention. Accordingly, the invention is not to be restricted except in light of the following claims.
Claims
1. A method for controlling a serial peripheral interface, comprising:
- monitoring serial peripheral interface signal lines including a data signal line, a clock signal line, and a select signal line;
- detecting a plurality of clock signal transitions on the clock signal line;
- detecting a plurality of data signal transitions on the data signal line in synchronism with clock signal transitions;
- detecting initiation of one of a data read and data write operation in accordance with a first protocol in response to a first combination of one or more signals on one or more of the data signal line, the clock signal line, and the select signal line; and
- detecting initiation of one of a data read and data write operation in accordance with a second protocol in response to a second combination of one or more signals on one or more of the data signal line, the clock signal line, and the select signal line;
- performing a data read operation upon a register identified by address bits received serially on the data signal line following detection of the initiation of a data read operation; and
- performing a data write operation upon a register identified by address bits received serially on the data signal line following detection of the initiation of a data write operation.
2. The method claimed in claim 1, wherein detecting initiation of one of a data read and data write operation in accordance with a first protocol comprises:
- detecting a transition of a select signal on the select signal line from a low state to a high state; and
- detecting a plurality of clock signal transitions while the select signal is in the high state immediately following detection of the transition of the select signal from a low state to a high state.
3. The method claimed in claim 1, wherein detecting initiation of one of a data read and data write operation in accordance with a first protocol comprises:
- detecting a transition of a select signal on the select signal line from a high state to a low state; and
- detecting a plurality of clock signal transitions while the select signal is in the low state immediately following detection of the transition of the select signal from a high state to a low state.
4. The method claimed in claim 1, wherein detecting initiation of one of a data read and data write operation in accordance with a first protocol comprises:
- detecting a transition of a data signal on the data signal line from a high state to a low state while substantially simultaneously detecting a clock signal on the clock signal line in a high state.
5. The method claimed in claim 1, wherein:
- detecting initiation of one of a data read and data write operation in accordance with a first protocol comprises: detecting a transition of a select signal on the select signal line; and detecting a plurality of clock signal transitions immediately following detection of the transition of the select signal; and
- detecting initiation of one of a data read and data write operation in accordance with a second protocol comprises detecting a transition of a data signal on the data signal line from a high state to a low state while substantially simultaneously detecting a clock signal on the clock signal line in a high state.
6. The method claimed in claim 1, further comprising:
- in response to detecting initiation of a data write operation, counting a number of clock cycles occurring during the data write operation;
- determining a number A of address bits in response to a count C of the number of clock cycles occurring during the data write operation;
- determining a difference C-A between the count of the number of clock cycles occurring during the data write operation and the number A of address bits;
- determining a number D of data bits in response to the difference C-A; and
- wherein performing a data write operation includes storing in the register D data bits received serially on the data signal line following A address bits received serially on the data signal line.
7. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is an address length mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation, the further data write operation including storing in a register data bits received serially on the data signal line following a first number of address bits received serially on the data signal line if the address length mode bit stored in the configuration register is a first binary value, and storing in the register data bits received serially on the data signal line following a second number of address bits received serially on the data signal line if the address length mode bit stored in the configuration register is a second binary value.
8. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a data length mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation, the further data write operation including storing in a register a first number of data bits received serially on the data signal line if the data length mode bit stored in the configuration register is a first binary value, and storing in the register a second number of data bits received serially on the data signal line if the address length mode bit stored in the configuration register is a second binary value.
9. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a clock edge mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation, the further data write operation including shifting each of a plurality of data bits received serially on the data signal line into a shift register on a rising clock signal edge if the clock edge mode bit stored in the configuration register is a first binary value, and shifting each of the plurality of data bits received serially on the data signal line into the shift register on a falling clock signal edge if the clock edge mode bit stored in the configuration register is a second binary value.
10. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a latch mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation upon a register, the further data write operation including: shifting each of a plurality of data bits received serially on the data signal line into a shift register; latching contents of the shift register into the register in response to a transition of the select signal if the sampling latch mode bit stored in the configuration register is a first binary value, and latching contents of the shift register into the register in response to a count of the number of data bits shifted into the shift register if the sampling latch mode bit stored in the configuration register is a second binary value.
11. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a bit order mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation upon a register, the further data write operation including: shifting each of a plurality of data bits received serially on the data signal line into a shift register; latching contents of the shift register into the register in an order from most-significant bit to least-significant bit if the bit order mode bit stored in the configuration register is a first binary value, and latching contents of the shift register into the register in an order from least-significant bit to most-significant bit if the bit order mode bit stored in the configuration register is a second binary value.
12. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a word order mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data write operation, the further data write operation including storing in a register data bits received serially on the data signal line following address bits received serially on the data signal line if the word order mode bit stored in the configuration register is a first binary value, and storing in the register data bits received serially on the data signal line preceding address bits received serially on the data signal line if the word order mode bit stored in the configuration register is a second binary value.
13. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a turnaround length mode bit; and
- the method further comprises, after performing the data write operation on the configuration register, performing a further data read operation upon a register, the further data read operation including: receiving address bits serially on the data signal line; reading data from a register identified by the address bits; and if the turnaround length mode bit stored in the configuration register is a first binary value then beginning to serially transmit data bits read from the register on the data signal line after a delay of a first number of clock cycles after the last address bit received, and if the turnaround length mode bit stored in the configuration register is a second binary value then beginning to serially transmit data bits read from the register on the data signal line after a delay of a second number of clock cycles after the last address bit received.
14. The method claimed in claim 1, wherein:
- performing a data write operation comprises performing a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a soft reset bit; and
- applying a reset signal to a plurality of logic elements if the soft reset mode bit stored in the configuration register is a first binary value, and not applying the reset signal to the plurality of logic elements if the soft reset bit stored in the configuration register is a second binary value.
15. The method claimed in claim 1, wherein performing a data write operation comprises:
- detecting an indication of termination of the data write operation upon the register identified by the address bits in accordance with one of the first protocol and the second protocol in response to one or more signals on one or more of the data signal line, the clock signal line, and the select signal line; and
- if no indication of termination of the data write operation is detected after a number D of data bits associated with the data write operation and received serially on the data signal line have been written to the register identified by the address bits, then performing a further data write operation upon a next register identified by a next address following an address corresponding to the address bits, the further data write operation including storing in the next register a next group of D data bits received serially on the data signal line immediately following a previous group of D data bits received serially on the data signal line.
16. The method claimed in claim 1, further comprising:
- entering a reset state in response to a detection of a reset condition;
- before performing a data read operation and after entering the reset state, detecting whether a Write/Read bit received on the data signal line in an initial data write operation is high or low;
- if the Write/Read bit received in the initial write operation is high, performing a further data write operation only if a Write/Read bit detected in a data transfer operation subsequent to the initial write operation is high, and performing a data read operation only if a Write/Read bit detected in the data transfer operation is low; and
- if the Write/Read bit received in the initial write operation is high, performing a further data write operation only if a Write/Read bit detected in a data transfer operation subsequent to the initial write operation is low, and performing a data read operation only if a Write/Read bit detected in the data transfer operation is high.
17. A serial peripheral interface controller connectable to a data signal line, a clock signal line, and a select signal line, comprising:
- a register bank, the register bank having a plurality of data storage registers; and
- control logic programmed or configured to: detect a plurality of bit transitions on the data signal line in synchronism with clock signal transitions; detect initiation of one of a data read and data write operation in accordance with a first protocol in response to a first combination of one or more signals on one or more of the data signal line, the clock signal line, and the select signal line; and detect initiation of one of a data read and data write operation in accordance with a second protocol in response to a second combination of one or more signals on one or more of the data signal line, the clock signal line, and the select signal line; perform a data read operation upon a register of the register bank identified by address bits received serially on the data signal line following detection of the beginning of a data read operation; and perform a data write operation upon a register of the register bank identified by address bits received serially on the data signal line following detection of the beginning of a data write operation.
18. The serial peripheral interface controller claimed in claim 17, wherein the control logic is programmed or configured to detect initiation of one of a data read and data write operation in accordance with a first protocol by being programmed or configured to:
- detect a transition of a select signal on the select signal line from a low state to a high state; and
- detect a plurality of clock signal transitions while the select signal is in the high state immediately following detection of the transition of the select signal from a low state to a high state.
19. The serial peripheral interface controller claimed in claim 17, wherein the control logic is programmed or configured to detect initiation of one of a data read and data write operation in accordance with a first protocol by being programmed or configured to:
- detect a transition of a select signal on the select signal line from a high state to a low state; and
- detect a plurality of clock signal transitions while the select signal is in the low state immediately following detection of the transition of the select signal from a high state to a low state.
20. The serial peripheral interface controller claimed in claim 17, wherein the control logic is programmed or configured to detect initiation of one of a data read and data write operation in accordance with a first protocol by being programmed or configured to:
- detect a transition of a data signal on the data signal line from a high state to a low state while substantially simultaneously detecting a clock signal on the clock signal line in a high state.
21. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to detect initiation of one of a data read and data write operation in accordance with a first protocol by being programmed or configured to: detect a transition of a select signal on the select signal line; and detect a plurality of clock signal transitions immediately following detection of the transition of the select signal; and
- the control logic is programmed or configured to detect initiation of one of a data read and data write operation in accordance with a second protocol by being programmed or configured to detect a transition of a data signal on the data signal line from a high state to a low state while substantially simultaneously detecting a clock signal on the clock signal line in a high state.
22. The serial peripheral interface controller claimed in claim 17, wherein the control logic is further programmed or configured to:
- in response to detecting initiation of a data write operation, count a number of clock cycles occurring during the data write operation;
- determine a number A of address bits in response to a count C of the number of clock cycles occurring during the data write operation;
- determine a difference C-A between the count of the number of clock cycles occurring during the data write operation and the number A of address bits; determine a number D of data bits in response to the difference C-A; and
- wherein the control logic is programmed or configured to perform a data write operation by storing in the register D data bits received serially on the data signal line following A address bits received serially on the data signal line.
23. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is an address length mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data write operation, the further data write operation including storing in a register data bits received serially on the data signal line following a first number of address bits received serially on the data signal line if the address length mode bit stored in the configuration register is a first binary value, and storing in the register data bits received serially on the data signal line following a second number of address bits received serially on the data signal line if the address length mode bit stored in the configuration register is a second binary value.
24. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a data length mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data write operation, the further data write operation including storing in a register a first number of data bits received serially on the data signal line if the data length mode bit stored in the configuration register is a first binary value, and storing in the register a second number of data bits received serially on the data signal line if the address length mode bit stored in the configuration register is a second binary value.
25. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a clock edge mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data write operation, the further data write operation including shifting each of a plurality of data bits received serially on the data signal line into a shift register on a rising clock signal edge if the clock edge mode bit stored in the configuration register is a first binary value, and shifting each of the plurality of data bits received serially on the data signal line into the shift register on a falling clock signal edge if the clock edge mode bit stored in the configuration register is a second binary value.
26. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to performing a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a latch mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, performing a further data write operation upon a register, the further data write operation including: shifting each of a plurality of data bits received serially on the data signal line into a shift register; latching contents of the shift register into the register in response to a transition of the select signal if the sampling latch mode bit stored in the configuration register is a first binary value, and latching contents of the shift register into the register in response to a count of the number of data bits shifted into the shift register if the sampling latch mode bit stored in the configuration register is a second binary value.
27. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to performing a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- one of the data bits stored in the configuration register is a bit order mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data write operation upon a register, the further data write operation including: shifting each of a plurality of data bits received serially on the data signal line into a shift register; latching contents of the shift register into the register in an order from most-significant bit to least-significant bit if the bit order mode bit stored in the configuration register is a first binary value, and latching contents of the shift register into the register in an order from least-significant bit to most-significant bit if the bit order mode bit stored in the configuration register is a second binary value.
28. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a word order mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data write operation, the further data write operation including storing in a register data bits received serially on the data signal line following address bits received serially on the data signal line if the word order mode bit stored in the configuration register is a first binary value, and storing in the register data bits received serially on the data signal line preceding address bits received serially on the data signal line if the word order mode bit stored in the configuration register is a second binary value.
29. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a turnaround length mode bit; and
- the control logic is further programmed or configured to, after the data write operation is performed on the configuration register, perform a further data read operation upon a register, the further data read operation including: receiving address bits serially on the data signal line; reading data from a register identified by the address bits; and if the turnaround length mode bit stored in the configuration register is a first binary value then beginning to serially transmit data bits read from the register on the data signal line after a delay of a first number of clock cycles after the last address bit received, and if the turnaround length mode bit stored in the configuration register is a second binary value then beginning to serially transmit data bits read from the register on the data signal line after a delay of a second number of clock cycles after the last address bit received.
30. The serial peripheral interface controller claimed in claim 17, wherein:
- the control logic is programmed or configured to perform a data write operation by being programmed or configured to perform a data write operation on a configuration register identified by the address bits, the data write operation including storing in the configuration register data bits received serially on the data signal line following address bits received serially on the data signal line;
- at least one of the data bits stored in the configuration register is a soft reset bit; and
- the control logic is further programmed or configured to apply a reset signal to a plurality of logic elements if the soft reset mode bit stored in the configuration register is a first binary value, and not apply the reset signal to the plurality of logic elements if the soft reset bit stored in the configuration register is a second binary value.
31. The serial peripheral interface controller claimed in claim 17, wherein the control logic is programmed or configured to perform a data write operation by being programmed or configured to:
- detect an indication of termination of the data write operation upon the register identified by the address bits in accordance with one of the first protocol and the second protocol in response to one or more signals on one or more of the data signal line, the clock signal line, and the select signal line; and
- if no indication of termination of the data write operation is detected after a number D of data bits associated with the data write operation and received serially on the data signal line have been written to the register identified by the address bits, then perform a further data write operation upon a next register identified by a next address following an address corresponding to the address bits, the further data write operation including storing in the next register a next group of D data bits received serially on the data signal line immediately following a previous group of D data bits received serially on the data signal line.
32. The serial peripheral interface controller claimed in claim 17, wherein the control logic is further programmed or configured to:
- apply a reset signal to a plurality of logic elements in response to a detection of a reset condition;
- before a data read operation is performed after the reset signal is applied, detect whether a Write/Read bit received on the data signal line in an initial data write operation is high or low;
- if the Write/Read bit received in the initial write operation is high, perform a further data write operation only if a Write/Read bit detected in a data transfer operation subsequent to the initial write operation is high, and perform a data read operation only if a Write/Read bit detected in the data transfer operation is low; and
- if the Write/Read bit received in the initial write operation is high, perform a further data write operation only if a Write/Read bit detected in a data transfer operation subsequent to the initial write operation is low, and perform a data read operation only if a Write/Read bit detected in the data transfer operation is high.
Type: Application
Filed: Sep 27, 2010
Publication Date: Mar 29, 2012
Applicant: SKYWORKS SOLUTIONS, INC. (Woburn, MA)
Inventor: Thomas Obkircher (Tustin, CA)
Application Number: 12/891,513
International Classification: G06F 3/00 (20060101);