The present disclosure relates generally to processors, and more particularly, to a serial peripheral interface that provides slave support for accessing memory-mapped resources of a processor.
An electronic system can combine different processors (including microprocessors, microcontrollers, digital signal processors, central processing units, or other type of processor) with circuitry to achieve specific applications. One processor, typically referred to as a host processor, may control operations of another processor, typically referred to as a slave processor. For example, a general purpose processor may control general operations of the electronic system, along with operations of an application-specific processor that performs application-specific operations (such as a digital signal processor performing specific signal processing operations under control of the general purpose processor). A host interface may be implemented to connect the host processor and the slave processor, which allows communication between the host processor and the slave processor. Processors today demand lightweight, low expense, low performance host interfaces that enable the host processor to access resources of the slave processor. Although existing host interfaces, such as parallel host port interfaces, have been generally adequate for their intended purposes, they have not been entirely satisfactory in all respects.
The present disclosure is best understood from the following detailed description when read with the accompanying figures. It is emphasized that, in accordance with the standard practice in the industry, various features are not drawn to scale and are used for illustration purposes only. In fact, the dimension of the various features may be arbitrarily increased or reduced for clarity of discussion.
A serial peripheral interface (SPI) host port is disclosed that enables a host external to a processor to access the processor's memory-mapped resources using SPI memory command protocol. The SPI host port enables the processor to operate as a slave and the host to operate as a master that controls data transfer between the processor and the host.
An exemplary processor can include a SPI host port connected to a system interconnect, which is connected to memory-mapped resources. The SPI host port is configured to use an SPI memory command protocol, such as a SPI SRAM/Flash style protocol, to access memory-mapped resources of the processor for a host external to the processor. In various implementations, the SPI host port can interpret a payload of an SPI communication packet received from the host as an access instruction and perform an access operation based on the access instruction, wherein the SPI communication packet is based on the SPI memory command protocol. The SPI host port can include a system master interface connected to the system interconnect that is configured to access the memory-mapped resources across the system interconnect based on the access instruction. In some implementations, the system master interface can interpret the SPI communication packet based on the SPI memory command protocol into the access instruction.
The SPI host port can include a SPI host port ready line for asserting an SPI host port ready signal to the host when the SPI host port is ready to perform an access operation. A SPI host port status register can include a SPI host port status ready bit that indicates when the SPI host port is ready to perform an access operation. In some implementations, the SPI host port status register includes an error condition bit that indicates an error condition.
The SPI host port can include a SPI host port interrupt request line for asserting a SPI host port interrupt request signal when the SPI host port detects an error condition, and/or a SPI host port trigger out line for asserting a SPI host port trigger out signal when the SPI host port is ready to perform an access operation. In some implementations, the SPI host port interrupt request line is connected to a system event controller of the processor. A SPI host port control register can include an error condition mask bit for controlling assertion of the SPI host port interrupt request signal. In some implementations, the SPI host port trigger out line is connected to a trigger routing unit of the processor. A SPI host port control register that includes a trigger mode bit for controlling a source for asserting the SPI host port trigger out signal.
A serial peripheral interface is disclosed that can be implemented by a processor to provide a lightweight, low cost, low performance interface for providing a host external to a processor control and access of the processor's memory-mapped resources.
Processing system 10 includes a processor 15 and a memory 20. Processor 15 may be referred to as a core processor, which may be implemented as a central processing unit (CPU), a microcontroller, a microprocessor, a digital signal processor, or other processor. Memory 20 can include a flash memory, a random access memory (RAM), a read only memory (ROM), a dynamic RAM (DRAM), a static RAM (SRAM), a synchronous DRAM (SDRAM), a double data rate SDRAM (DDR SDRAM), a graphic DDR memory, a magnetoresistive RAM (MRAM), other type of memory, or combination thereof.
A system interconnect 25 interconnects various components of processing system 10. For example, in the depicted embodiment, processor 15 and memory 20 are coupled to system interconnect 30, such that processor 15 and memory 20 can communicate with one another via the system interconnect 25. Memory-mapped resources (which includes memory 20) are connected to system interconnect 25, where each memory-mapped resource has a defined, unique address (a memory-mapped address). Memory-mapped resources can include memory, internal and/or external to processing system 10, and memory-mapped registers, such as control registers and data registers associated with various components of processing system 10. System interconnect 25 can include a single bus, multiple buses, a crossbar network, a single-stage network, a multistage network, other type of interconnection network, or combination thereof. In various implementations, system interconnect 25 can implement system crossbars (SCB) that form a switch-fabric style for system bus interconnection.
A serial peripheral interface (SPI) 30 connected to system interconnect 25 enables communication between processing system 10 and SPI-compatible devices external to processing system 10. In
Typically, SPI 30 simply transfers data between processing system 10 and host 40 (for example, by moving data in/out of first-in-first out memory buffers), where host 40 has no control over the data transfer. The present disclosure proposes extending SPI 30 to include a mechanism that allows host 40 to control SPI data transfer between host 40 and processing system 10. Such control can facilitate host 40 directly accessing memory-mapped resources, such as memory and/or memory-mapped registers, of processing system 10. In
SPI host port 50 includes a system master interface 52 and a system slave interface 54 connected to system interconnect 25. System master interface 52 enables processing system 10 to operate as a slave device so that host 40 (operating as a master device), can access resources of processing system 10. For example, system master interface 52 provides a master interface on system interconnect 25 having direct access to memory-mapped resources, such as memory and memory-mapped registers, of processing system 10. In various implementations, based on access commands received from host 40, system master interface 52 reads data from and/or writes data to memory-mapped resources of processing system 10 across system interconnect 25. In various implementations, system master interface 52 can perform prefetch operations. System slave interface 54 enables SPI host port 50 to operate as a slave device so that processing system 10 (operating as a master device) can access resources of SPI host port 50, such as memory and/or registers of SPI host port 50.
A SPI host port receive buffer (SPIHP_RFIFO) 56 can store data received from host 40, and a SPI host port transmit buffer (SPIHP_TFIFO) 58 can store data for transmission to host 40. In various implementations, SPI host port receive buffer 56 and SPI host port transmit buffer 58 are first-in-first-out buffers. SPI host port receive buffer 56 has an associated SPI host port receive shift register (RSR) 60, and SPI host port transmit buffer 58 has an associated SPI host port transmit shift register (TSR) 62.
A SPI interface 64 provides a full-duplex, synchronous serial host interface for facilitating communication with host 40. SPI interface 64 has four data pins: a MOSI (master output, slave input) data pin, a MISO (master input, slave output), a SPIQ2 data pin and a SPIQ3 data pin. The four data pins enable SPI host port 50 to provide full-duplex operation and quad SPI operation.
SPI ready signal enables host 40 to control data transfer between processing system 10 and host 40 in a hardware manner, providing hardware flow control for host 40. SPI ready signal can indicate a need for host 40 to stall, such that host 40 can use SPI ready signal to perform access (read/write) operations on memory-mapped resources of processing system 10. For example, host 40 waits for SPI host port 50 to assert SPI ready signal to latch data during a read operation or send data during a write operation. SPI host port 50 can assert SPI ready signal when ready for an access operation, such as a read, a write, or a pre-fetch operation. SPI ready signal assertion can be controlled by a SPI host port control 68. SPI host port 50 can stall host 40 from performing an access operation by deasserting SPI ready signal, for example, when SPI host port receive buffer 56 is almost full during a write operation, SPI host port transmit buffer 58 is almost empty during a read operation, when SPI host port 50 detects an error condition, and/or when SPI host port 50 detects some other occurrence that warrants stalling host 40. Host 40 can thus use SPI ready signal as a throttle to delay subsequent data transfer and/or instructions as necessary until the slave device (processing system 10) is ready.
SPI host port 50 further supports a SPI host port interrupt request (SPIHPIRQ) signal and a SPI host port trigger out (SPIHPTO) signal from SPI host port 50 to components of processing system 10. In the depicted embodiment, SPI host port interrupt request signal is connected to a system event controller (SEC) 70 of processing system 10, which manages configuration of system event sources as well as propagation of system events and system interrupts in processing system 10. In various implementations, system event controller 70 manages system interrupt and/or system fault sources, including control features such as enable/disable, prioritization, and active/pending source status. In the depicted embodiment, SPI host port 50 provides SPI host port trigger out signal to system event controller 70 when an error condition is detected. SPI host port interrupt request signal can be controlled by SPI host port control 68, as described below.
SPI host port 50 further supports a SPI host port trigger out (SPIHPTO) signal from SPI host port 50 to components of processing system 10. In the depicted embodiment, SPI host port trigger out signal is connected to a trigger routing unit (TRU) 72 of processing system 10. Trigger routing unit 72 provide system-level sequence control for processing system without core intervention, for example, from processor 15. Trigger routing unit 72 can receive trigger inputs from master trigger inputs, and generate trigger outputs that initiate slave operations in processor 15 and peripherals of processing system 10 based on the trigger inputs. In the depicted embodiment, SPI host port 50 provides SPI host port trigger out signal as a master trigger input of trigger routing unit 72. SPI host port trigger out signal can be controlled by SPI host port control 68, as described below.
Returning to
Table 1 provides SPI memory instructions/commands that can be supported by SPI host port 50, in various implementations. Each instruction has an associated SPI communication packet that includes an instruction/opcode byte (such as Byte 0) and various information bytes (such as Byte 1, Byte 2, Byte 3, Byte 4, and Byte 5). The instruction/opcode byte specifies a type of access operation, and the information bytes can be address bytes or data bytes depending on the access operation. In Table 1, “A” stands for address, “D” stands for data input to SPI host port 50, “(D)” stands for data output from SPI host port 50, “R” stands for a SPI host port register address, “S” stands for stride, and “Dummy” stands for an unused/discarded byte.
SPI host port 50 can support host 40 accessing memory-mapped resources, such as memory and/or memory-mapped registers, of processing system 10. See, for example, Read Data, Fast Read, Fast Read Dual Output, Fast Read Quad Output, Write Data, Write Data Dual Input, and Write Data Quad Input instructions. SPI host port 50 can support host 40 accessing registers local to SPI host port 50 through dedicated register read and register write instructions. See, for example, Read Register, Read Register Dual Output, Read Register Quad Output, and Write Register. In some implementations, register read instructions can return data from least significant byte to most significant byte, and register write instructions can expect data from least significant byte to most significant byte. SPI host port 50 can further support host 40 performing write data stride. See, for example, Write Data Stride, Write Data Dual Input Stride, and Write Data Quad Input Stride. In various implementations, host 40 can write data to memory to discontinuous addresses using write data stride instructions. Such instructions may expect a stride byte value before each data element of the payload. Table 1 is not an exhaustive list of instructions supported by SPI host port 50, and as noted above, SPI host port 50 can support various instructions/commands/opcodes as applicable to SPI memory architectures, such as SPI flash/SRAM memory.
SPI host port control 68 governs operations of SPI host port 50, such that SPI host port 50 can achieve functionality as described herein. SPI host port control 68 can include SPI host port logic and various SPI host port registers. In various implementations, SPI host port logic and SPI host port registers determine transactions issued to system master interface 52. For example, based on instructions received from host 40, SPI host port control 68 can generate instructions to system master interface 52 for accessing memory-mapped resources.
In
SPI host port status register 100 further includes a SPI host port status ready (SPIHP_STAT.RDY) bit that indicates when SPI host port 50 is ready for an access operation, such as a read data, a write data, or a prefetch instructions operation. Host 40 cannot perform an access operation when SPI host port status ready bit reflects an inactive state. SPI host port status ready bit may be transitioned to an inactive state (deasserted) under various conditions, including but not limited to, when SPI host port receive buffer 56 is almost full during a write data instruction, when SPI host port transmit buffer 58 is almost empty during a read data instruction, or when any error condition bit is triggered. In various implementations, SPI host port status register 100 can further includes a SPI host port status ready sticky (SPIHP_STAT.RDYSTKY) bit that indicates when SPI host port 50 is ready for an access operation, which can be triggered when SPI host port 50 asserts SPI host port status ready bit. In some implementations, SPI host port status ready bit can be implemented as a not write-through bit (NW), and SPI host port status ready sticky bit can be implemented as W1C (write-1-to-clear) bits. Accordingly, as described above, host 40 may wait for SPI host port 50 to assert SPI host port status ready bit (or SPI host port status ready sticky bit, depending on how SPI host port 50 is configured) before performing an access operation.
SPI host port status register 100 enable host 40 to control data transfer between processing system 10 and host 40 in a software manner, providing software flow control for host 40. Software flow control is managed by checking a status of SPI host port 50 before read/write operations and using prefetch operations to perform reads from SPI slave memory space. In various implementations, host 40 can place a limit on a data transfer size and check SPI host port status register 100 after each instruction completion (read data, write data, or prefetch operation) to confirm a previous operation and before performing a next operation. For example, for write data operations, host 40 can limit write data instruction payloads to a depth of SPI host port receive buffer 56. After each write data instruction, host 40 can check SPI host port status ready bit to confirm that SPI host port 50 is ready for a next operation.
In
SPI host port control register 110 can further include various bits for enabling SPI host port interrupt request signal and SPI host port trigger out signal from SPI host port 50 to resources of processing system 10. In the depicted embodiment, SPI host port control register 110 includes various masks that control assertion of SPI host port interrupt signal (for example, from SPI host port 50 to system event controller 70):
In
In
In various implementations, processing system 10, components of processing system 10 (such as processor 15, memory 20, SPI host port 50), and/or the various circuits and/or components of the FIGURES can be implemented on a board of an associated electronic device. The board can be a general circuit board that can hold various components of an internal electronic system of the electronic device and, further, provide connectors for other peripherals. The board can provide the electrical connections by which the other components of the system can communicate electrically. Any suitable processors (inclusive of digital signal processors, microprocessors, supporting chipsets, etc.), memory elements, etc. can be suitably coupled to the board based on particular configuration needs, processing demands, computer designs, other considerations, or a combination thereof. Other components, such as external storage, sensors, controllers for audio/video display, and peripheral devices may be attached to the board as plug-in cards, via cables, or integrated into the board itself. In various implementations, processing system 10, components of processing system 10, and/or the various the circuits and/or components of the FIGURES can be implemented as stand-alone modules (for example, a device with associated components and circuitry configured to perform a specific application or function) or implemented as plug-in modules into application specific hardware of electronic devices. Note that particular embodiments of the present disclosure may be readily included in a system-on-chip (SOC) package, either in part, or in whole. An SOC represents an integrated circuit that integrates components of a computer or other electronic system into a single chip. It may contain digital, analog, mixed-signal, and often radio frequency functions: all of which may be provided on a single chip substrate. Other embodiments may include a multi-chip-module (MCM), with a plurality of separate ICs located within a single electronic package and configured to interact closely with each other through the electronic package. In various other embodiments, the various functions described herein may be implemented in one or more semiconductor cores (such as silicon cores) in application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), other semiconductor chips, or combinations thereof.
The various functions outlined herein may be implemented by logic encoded in one or more non-transitory and/or tangible media (for example, embedded logic provided in an application specific integrated circuit (ASIC), as digital signal processor (DSP) instructions, software (potentially inclusive of object code and source code) to be executed by a processor, or other similar machine, etc.). In some of these instances, a memory element can store data used for the operations described herein. This includes the memory element being able to store logic (for example, software, code, processor instructions) that is executed by a processor to carry out the activities described herein. The processor can execute any type of instructions associated with the data to achieve the operations detailed herein. In various implementations, the processor can transform an element or an article (such as data) from one state or thing to another state or thing. In another example, the activities outlined herein may be implemented with fixed logic or programmable logic (such as software/computer instructions executed by the processor) and the elements identified herein can be some type of a programmable processor (such as a DSP), programmable digital logic (e.g., a FPGA, an erasable programmable read only memory (EPROM), an electrically erasable programmable ROM (EEPROM)), or an ASIC that includes digital logic, software, code, electronic instructions, or any suitable combination thereof.
Note that the activities discussed above with reference to the FIGURES are applicable to any integrated circuits that involve signal processing, particularly those that can execute specialized software programs or algorithms, some of which may be associated with processing digitized real-time data. Certain embodiments can relate to multi-DSP signal processing, floating point processing, signal/control processing, fixed-function processing, microcontroller applications, etc. In certain contexts, the features discussed herein can be applicable to medical systems, scientific instrumentation, wireless and wired communications, radar, industrial process control, audio and video equipment, current sensing, instrumentation (which can be highly precise), and other digital-processing-based systems. Moreover, certain embodiments discussed above can be provisioned in digital signal processing technologies for medical imaging, patient monitoring, medical instrumentation, and home healthcare. This could include pulmonary monitors, accelerometers, heart rate monitors, pacemakers, etc. Other applications can involve automotive technologies for safety systems (e.g., stability control systems, driver assistance systems, braking systems, infotainment and interior applications of any kind) Furthermore, powertrain systems (for example, in hybrid and electric vehicles) can use high-precision data conversion products in battery monitoring, control systems, reporting controls, maintenance activities, etc. In yet other example scenarios, the teachings of the present disclosure can be applicable in the industrial markets that include process control systems that help drive productivity, energy efficiency, and reliability. In consumer applications, the teachings of the signal processing circuits discussed above can be used for image processing, auto focus, and image stabilization (e.g., for digital still cameras, camcorders, etc.). Other consumer applications can include audio and video processors for home theater systems, DVD recorders, and high-definition televisions. Yet other consumer applications can involve advanced touch screen controllers (e.g., for any type of portable media device). Hence, such technologies could readily be a part of smartphones, tablets, security systems, PCs, gaming technologies, virtual reality, simulation training, etc.
The specifications, dimensions, and relationships outlined herein have only been offered for purposes of example and teaching only. Each of these may be varied considerably without departing from the spirit of the present disclosure, or the scope of the appended claims. The specifications apply only to non-limiting examples and, accordingly, they should be construed as such. In the foregoing description, example embodiments have been described with reference to particular processor and/or component arrangements. Various modifications and changes may be made to such embodiments without departing from the scope of the appended claims. The description and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Note that with the numerous examples provided herein, interaction may be described in terms of two, three, four, or more processing components. However, this has been done for purposes of clarity and example only. It should be appreciated that the system can be consolidated in any suitable manner. Along similar design alternatives, any of the illustrated components, modules, circuits, and elements of the FIGURES may be combined in various possible configurations, all of which are clearly within the broad scope of this Specification. In certain cases, it may be easier to describe one or more of the functionalities of a given set of flows by only referencing a limited number of processing components. It should be appreciated that the processing components of the FIGURES and its teachings are readily scalable and can accommodate a large number of components, as well as more complicated/sophisticated arrangements and configurations. Accordingly, the examples provided should not limit the scope or inhibit the broad teachings of the processing system and/or components as potentially applied to a myriad of other architectures.
Further, note that references to various features (e.g., elements, structures, modules, components, steps, operations, characteristics, etc.) included in “one embodiment”, “example embodiment”, “an embodiment”, “another embodiment”, “some embodiments”, “various embodiments”, “other embodiments”, “alternative embodiment”, and the like are intended to mean that any such features are included in one or more embodiments of the present disclosure, but may or may not necessarily be combined in the same embodiments. It is further noted that “coupled to” and “coupled with” are used interchangeably herein, and that references to a feature “coupled to” or “coupled with” another feature include any communicative coupling means, electrical coupling means, mechanical coupling means, other coupling means, or a combination thereof that facilitates the feature functionalities and operations, such as the security check mechanisms, described herein.
Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims. In order to assist the United States Patent and Trademark Office (USPTO) and, additionally, any readers of any patent issued on this application in interpreting the claims appended hereto, Applicant wishes to note that the Applicant: (a) does not intend any of the appended claims to invoke paragraph six (6) of 35 U.S.C. section 112 as it exists on the date of the filing hereof unless the words “means for” or “steps for” are specifically used in the particular claims; and (b) does not intend, by any statement in the specification, to limit this disclosure in any way that is not otherwise reflected in the appended claims.
In various implementations, a system is provided. The system can include means for receiving a SPI communication packet based on a SPI memory command protocol from a host external to a processor; interpreting a payload of the SPI communication packet as an access instruction; and performing an access operation based on the access instruction. The ‘means for’ in these instances can include (but is not limited to) using any suitable component discussed herein, along with any suitable software, circuitry, hub, computer code, logic, algorithms, hardware, controller, interface, link, bus, communication pathway, etc. In various implementations, the system includes memory that includes instructions that when executed cause the system to perform any of the activities discussed herein.