The disclosure relates generally to storage devices, and more particularly to a device to integrate a storage device with a computational storage unit.
With the increase in capacity offered by storage devices, applications may process more and more data. Transferring large amounts of data from the storage device to main memory for an application to process may require significant amounts of time. In addition, having the host processor execute the commands to process that data may impose a burden on the host processor.
A need remains to improve the processing data.
The drawings described below are examples of how embodiments of the disclosure may be implemented, and are not intended to limit embodiments of the disclosure. Individual embodiments of the disclosure may include elements not shown in particular figures and/or may omit elements shown in particular figures. The drawings are intended to provide illustration and may not be to scale.
Embodiments of the disclosure include a multi-function device. The multi-function device may support storage devices and/or computational storage units. The computational storage units may support processing of data on the storage devices. One or more computational storage units may be hidden from the host.
Reference will now be made in detail to embodiments of the disclosure, examples of which are illustrated in the accompanying drawings. In the following detailed description, numerous specific details are set forth to enable a thorough understanding of the disclosure. It should be understood, however, that persons having ordinary skill in the art may practice the disclosure without these specific details. In other instances, well-known methods, procedures, components, circuits, and networks have not been described in detail so as not to unnecessarily obscure aspects of the embodiments.
It will be understood that, although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first module could be termed a second module, and, similarly, a second module could be termed a first module, without departing from the scope of the disclosure.
The terminology used in the description of the disclosure herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. As used in the description of the disclosure and the appended claims, the singular forms “a”, “an”, and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. The components and features of the drawings are not necessarily drawn to scale.
As storage devices increase in capacity, the amount of data to be processed by an application may also increase. The time required to transfer such data between the storage device and main memory may increase, potentially slowing down execution of the application. In addition, having the host processor execute the commands may place a burden on the host processor, which may reduce the cycles available for the host processor to execute other commands.
Embodiments of the disclosure address these problems with a multi-function device. The multi-function device may support one or more storage devices and one or more computational storage units. One or more of the computational storage units may be hidden from the host processor, and used internally by the storage devices and/or the other computational storage units. The multi-function device may expose to the host processor the storage devices and/or computational storage units that are not hidden from the host processor in a manner that makes it appear as though the host processor is directly accessing the storage devices and/or computational storage units.
Computational storage units may be connected to the multi-function device via a connector, or they may be integrated into the multi-function device. If the storage units or the computational storage units are connected to the multi-function device, they may be replaceable.
Storage devices and computational storage units may share data using a buffer. By using the buffer, data may be shared without host management or involvement. The buffer may act like a shared memory, supporting multiple storage devices and/or computational storage units accessing the data sequentially or in parallel.
Processor 110 may be coupled to memory 115. Memory 115 may be any variety of memory, such as flash memory, Dynamic Random Access Memory (DRAM), Static Random Access Memory (SRAM), Persistent Random Access Memory, Ferroelectric Random Access Memory (FRAM), or Non-Volatile Random Access Memory (NVRAM), such as Magnetoresistive Random Access Memory (MRAM) etc. Memory 115 may be a volatile or non-volatile memory, as desired. Memory 115 may also be any desired combination of different memory types, and may be managed by memory controller 125. Memory 115 may be used to store data that may be termed “short-term”: that is, data not expected to be stored for extended periods of time. Examples of short-term data may include temporary files, data being used locally by applications (which may have been copied from other storage locations), and the like.
Processor 110 and memory 115 may also support an operating system under which various applications may be running. These applications may issue requests (which may also be termed commands) to read data from or write data to either memory 115. When storage device 120 is used to support applications reading or writing data via some sort of file system, storage device 120 may be accessed using device driver 130. While
While
Machine 105 may also include multi-function device 135 (which may also be termed an accelerator or a device). As discussed below, multi-function device 135 may support connections to storage device 120 and computational storage unit 140, but present to processor 110 as though storage device 120 and computational storage unit 140 were a single device. Multi-function device 135 may enable modularity in storage device 120 and/or computational storage unit 140, in that storage device 120 and/or computational storage unit 140 may be added or replaced without necessarily having to replace other components connected to multi-function device 135.
Multi-function device 135 may be implemented using any desired hardware. For example, multi-function device 135, or components thereof, may be implemented using a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a central processing unit (CPU), a System-on-a-Chip (SoC), a graphics processing unit (GPU), a general purpose GPU (GPGPU), a data processing unit (DPU), a neural processing unit (NPU), a Network Interface Card (NIC), or a tensor processing unit (TPU), to name a few possibilities. Multi-function device 135 may also use a combination of these elements to implement multi-function device 135.
Computational storage unit 140 may take any desired form. Like multi-function device 135, computational storage unit 140 may be implemented using an FPGA, an ASIC, a CPU, an SoC, a GPU, a GPGPU, a DPU, an NPU, an NIC, or a TPU, to name a few possibilities. Computational storage unit 140 may implement any desired function or functions. For example, computational storage unit 140 may implement a specific-purpose accelerator, designed to perform near-data processing. Computational storage unit 140 may also be a general-purpose accelerator, designed to receive a program from machine 140 to perform near-data processing. Computational storage unit 140 may also implement other functions, such as encryption and/or decryption, compression and/or decompression, or network interfacing, among other possibilities.
A particular example of encryption and/or decryption that may be performed using computational storage unit 140 may be Fully Homomorphic Encryption (FHE). FHE may support analyzing encrypted data without decrypting it. FHE may thus protect the privacy and confidentiality of customer data. When computational storage unit 140 includes a circuit to implement FHE, machine 105 may download instructions into the engine of the FHE circuit to implement the desired processing, which may then be performed near to the data, without transferring the data into memory 115.
While
In some embodiments of the disclosure, device driver 130 (and other device drivers, such as to support computational storage unit 140) may provide application programming interfaces (APIs) to access storage device 120 and/or computational storage unit 140. By supporting existing device drivers, existing applications may be executed by processor 110 without change to the applications (although embodiments of the disclosure may involve modifications to other elements in a software stack). For example, a TPU may have a TPU device driver, or a GPU may have a GPU device driver: applications that access functions of the TPU or the GPU may continue to use the existing TPU device driver or GPU device driver. In addition, by supporting existing device drivers, computational storage unit 140 may be any computational storage unit, even if manufactured by a different manufacturer from storage device 120 and/or multi-function device 135. Further, in some embodiments of the disclosure, device driver 130 (or other device drivers) may be proprietary.
Embodiments of the disclosure may include any desired mechanism to communicate with storage device 120 and/or computational device 140. For example, storage device 120 and/or computational device 140 may connect to a bus, such as a Peripheral Component Interconnect Express (PCIe) bus, or storage device 120 and/or computational device 140 may include Ethernet interfaces or some other network interface. Other potential interfaces and/or protocols to storage device 120 and/or computational device 140 may include NVMe, NVMe over Fabrics (NVMe-oF), CXL, Remote Direct Memory Access (RDMA), Transmission Control Protocol/Internet Protocol (TCP/IP), Universal Flash Storage (UFS), embedded MultiMediaCard (eMMC), InfiniBand, Serial Attached Small Computer System Interface (SCSI) (SAS), Internet SCSI (iSCSI), and Serial AT Attachment (SATA), among other possibilities.
Machine 105 may include a range of addresses in memory 115 that are addressable by processor 110, storage device 120, and/or computational storage unit 140. In some embodiments of the disclosure, processor 110 may allocate subsets of this address range that may be associated with commands to be sent to storage device 120 and/or computational storage unit 140. In addition, processor 110 may allocate a subset of this address range that may be associated with commands for peer-to-peer communication between storage device 120 and computational storage unit 140. That is, by associating a command with a particular address in memory 115, it may be possible to determine whether the command is intended for storage device 120, computational storage unit 140, or for transferring data between storage device 120 and computational storage unit 140. Note that memory 115 might not include enough memory to include such a physical address, but memory 115 is not necessarily required to actually enough memory to include such an address. For example, memory 115 might include 2 gigabytes (GB) of memory, but might support addressing up to 4 GB of memory. A subset of addresses, such as those between 2 GB and 3 GB, might be used to identify commands for peer-to-peer communication, even though memory 115 might not be able to process a request for those particular addresses. Multi-function device 135 may identify such commands based on the address assigned to the command, and may intercept such commands for processing.
Processor 110, memory 115, storage device 120, memory controller 125, multi-function device 135, and computational storage unit 140 may be connected in any desired manner, using any desired links and any desired protocols. For example, multi-function device 135 may connect to processor 110, memory 115, and memory controller 125 using a PCIe bus and using the NVMe protocol, but other busses or links and other protocols may be used. Storage device 120 and computational storage unit 140 may similarly connect to multi-function device 135 using a PCIe bus and using the NVMe protocol, but other busses or links (for example, Small Computer System Interface (SCSI), Parallel AT Attachment (known as IDE), HyperTransport, Infiniband, or others) and other protocols may be used. Nor is it required that the same busses, links, or protocols be used: storage device 120 and computational storage unit 140 might connect to multi-function device 135 using other busses, links, or protocols (and may each use different busses, links, or protocols). Embodiments of the disclosure are intended to include any and all variations regarding how the components of
Endpoint 310 may be connected to (or implemented as part of) connector 305. Endpoint 310 may function as an endpoint for queries from processor 110 of
Asynchronous buffer 325 may be connected to endpoint 310 and/or connector 305. Asynchronous buffer 325 may act as a landing point for requests, messages, and/or data to be exchanged between host processor 110 of
Note that in some embodiments of the disclosure, multi-function device 135 may operate using the same clock cycle as processor 110 of
Multiplexer/demultiplexer 330 may be connected to asynchronous buffer 325. Multiplexer/demultiplexer 330 may access requests, messages, and/or data from asynchronous buffer 325. Multiplexer/demultiplexer 330 may then determine which device connected to multi-function device 135 the request, message, or data is intended, and may route the request, message, or data accordingly. To accomplish this function, multiplexer/demultiplexer 330 may also be connected to bridges 335 and 340, each of which may ultimately deliver a request, message, or data to a particular device connected to multi-function device 135. In another embodiment of the disclosure, multiplexer/demultiplexer 330 may communicate with more than two bridges. How multiplexer/demultiplexer 330 may determines to which bridge a particular request should be delivered is discussed further below.
Bridges 335 and 340 may be connected to asynchronous buffers 345 and 350, respectively. Asynchronous buffers 345 and 350, like asynchronous buffer 325, may enable multi-function device 135 to operate at a different clock cycle than the various devices connected to connectors 315 and 320. In addition, like asynchronous buffer 325, in some embodiments of the disclosure multi-function device 135 may operate using the same clock cycle as the device(s) connected to connectors 315 and/or 320. In such embodiments of the disclosure, asynchronous buffer 345 and/or 350 may be omitted entirely, or replaced with synchronous buffers (to permit temporary storage of requests, messages, and/or data received from or to be transmitted to the devices connected to connectors 315 and/or 320).
Root ports 355 and 360 may be connected to asynchronous buffers 345 and 350 respectively (and may be implemented as part of connectors 315 and 320, respectively). Root ports 355 and 360 may communicate with devices connected to connectors 315 and 320, respectively. For example, storage device 120 of
Root ports 355 and 360 may interrogate devices connected to connectors 315 and 320 for information about those devices. For example, devices connected to connectors 315 or 320 may expose various functions identifying requests that may be made of the devices.
In some embodiments of the disclosure, these functions may include one or more physical functions (PFs) and/or one or more virtual functions (VFs). Each PF may represent a resource, such as a function offered by the device. Each VF may represent a function that is associated with a PF, but is “virtualized”: that is, for a given PF there may be one more VFs. PFs and VFs may be discovered by when the devices are enumerated: this enumeration may be performed by root ports 355 and 360 rather than by processor 110 of
Once the PFs and VFs are enumerated, this information may be provided to bridges 335 and 340, and eventually be provided back to multiplexer/demultiplexer 330 and/or endpoint 310. In this manner, endpoint 310 may be capable of exposing the functions (PFs, VFs, or both) of the various devices connected to connectors 315 and 320. If there are any conflicts between the functions exposed by the devices connected to connectors 315 and 320 (for example, identical function identifiers), multiplexer/demultiplexer 330 and/or endpoint 310 may change the enumerations to avoid such conflicts. For example, devices may enumerate the functions starting at zero: if the devices connected to connectors 315 and 320 were both assigned the function number starting at zero, multiplexer/demultiplexer 330 might not be able to determine for which device a particular request associated with function number zero is intended. Thus, for example, if the device connected to connector 315 has three PFs and the device connected to connector 320 has two PFs, multiplexer/demultiplexer 330 may assign the PFs to the device connected to connector 315 using numbers 0, 1, and 2, and may assign the PFs to the device connected to connector 320 using numbers 3 and 4. As long as no two PFs are assigned the same number, multiplexer/demultiplexer 330 may map functions in any desired manner. In addition, VFs exposed by the devices connected to connectors 315 and/or 320 may be exposed as VFs or PFs (that is, VFs of the devices may map to PFs exposed by multi-function device 135).
With this understanding the operation of multiplexer/demultiplexer 330 may now be understood. Upon receiving a request, message, or data from processor 110 of
Endpoint 310 and root ports 355 and 360 may be examples of PCIe ports, and may be used with embodiments of the disclosure with multi-function device 135 connecting to PCIe busses. In embodiments connecting multi-function device 135 connecting to other busses, endpoint 310 and root ports 355 and 360 may be replaced with other equivalent components, or may be omitted if not needed in that architecture.
While
As discussed above, in some embodiments of the disclosure, the devices connected to connectors 315 and 320 may be PCIe devices. In such embodiments of the disclosure, multiplexer/demultiplexer 365 may expect to process transaction layer packets (TLP).
In embodiments of the disclosure that support more than two devices connected to multi-function device 135, there may be a multiplexer/demultiplexer like multiplexer/demultiplexer 365 associated with devices attached to multi-function device 135. In some embodiments of the disclosure, such a multiplexer/demultiplexer may be interposed between a bridge like bridge 340 and an asynchronous buffer like asynchronous buffer 350 for all devices; in other embodiments of the disclosure, such a multiplexer/demultiplexer may be interposed between a bridge and an asynchronous buffer for computational storage units like computational storage unit 140 of
Note that multiplexer/demultiplexer 365 may receive requests, messages, and/or data from a device attached to connector 315, and from processor 110 of
There are several ways in which such a conflict might be avoided. One solution may be to process requests from only one source at a time, and the other source might wait until no requests from the first source are active. But this solution might not offer the best performance. Another solution may be to permit only requests with unique tags to be active at any time. Thus, so long as each request has a different tag from any other active requests, the request may be processed; if the request replicates a tag that is associated with another active request, the new request may be buffered until the active request with that tag is complete. This solution offers better performance. Yet another solution may be for multiplexer/demultiplexer 365 to provide tags that may be used by the various sources: so long as each source may be provided a set of tags that does not intersect with the set of tags assigned to another source, tag conflict may be avoided. Yet another solution may be for multiplexer/demultiplexer 365 to introduce a level of indirection, mapping tags from each source to new tags (used internally to multiplexer/demultiplexer 365). When a request is received, the tag may be mapped and the mapping from the original tag to the new tag may be stored in a table in multiplexer/demultiplexer 365. When the request is completed, multiplexer/demultiplexer 365 may determine the original tag from the new tag received with the response.
To support such operations, bridge 335 may also be capable of directing requests, messages, or data (whether received from processor 110 of
While having either storage device 120 of
In addition, if DMA is used, then the devices may need to handle the data as stored, without processing. If the data may need processing before it is used, DMA might not be an option. For example, consider computational storage unit 140 of
If storage device 120 of
Buffer 370 may be used to store data being transferred between the devices connected to connectors 315 and 320. Once the data is stored in buffer 370, data processor 375 may then process the data as appropriate before transfer to the destination device. Once the data in buffer 370 has been processed by data processor 375, the processed data may be transferred to the destination device. In some embodiments of the disclosure, DMA may be used by the devices to write data to or read data from buffer 370. Buffer 370 may use any desired form of storage: for example, DRAM, SRAM, or the like, and may be on-chip or off-chip.
Buffer 370 may have an associated address range, which may be used by storage device 120 of
Bridges 335 and 340 may use the address range of buffer 370 to determine whether a particular request to access an address involves memory 115 of
Data processor 375 may perform any desired processing on data in buffer 370. Data processor 375 may include a circuit and/or software to perform some expected processing. But data processor 375 may also be general enough to support processing as instructed by processor 110 of
As discussed above, in some embodiments of the disclosure data processing may be performed to put the data in a format appropriate for the device designated to receive the data. But in some embodiments of the disclosure, data processing may be performed even if the device designated to receive the data may be able to process the data. For example, the data might already be in a format that may be acceptable to the destination device, but there might be a more optimal format. In such embodiments of the disclosure, data processor 375 may process the data even though the data is already in a format that may be acceptable to the destination device.
In some embodiments of the disclosure, processor 110 of
In other embodiments of the disclosure, data processor 375 may act as a scheduler for the data transfer. Data processor 375 may send a request to the source device, asking that the data be transferred to buffer 370. Note that bridges 335 and 340 may access buffer 370, to effect writing data to (and reading data from) buffer 370. Once the transfer is complete, the source device may signal data processor 375 that the transfer is complete. Data processor 375 may then transform the data as appropriate. Once data processor 375 has finished transforming the data in buffer 370, data processor 375 may signal the destination device that the data is ready for retrieval, and the destination device may then read the data from buffer 370. Data processor 375 may receive such instructions regarding scheduling from processor 110 of
When computational storage unit 140 of
As discussed above, multi-function device 135 may include more than two connectors 315 and 320, and therefore may include more than two attached devices. In some embodiments of the disclosure, some or all attached devices may have access to buffer 370, and may read data from or write data to buffer 370. In other embodiments of the disclosure, there may be any number (one or more) of buffers 370 (and possibly more than one data processor 375 as well). For example, there may a buffer 370 associated with each computational storage unit 140 of
In some embodiments of the disclosure, peer-to-peer communication may use a PCIe protocol for communication. That is, bridges 335 and/or 340 may use the PCIe protocol for transmission of requests, messages, and/or data to and/or from the devices connected to connectors 315 and 320. In other embodiments of the disclosure, peer-to-peer communication may use other protocols. In some embodiments of the disclosure, the devices connected to connectors 315 and 320 may use different protocols for communication (although in such embodiments of the disclosure some mapping of requests, messages, or data formats and/or protocols between or among the protocols may be needed).
As noted above, computational storage unit 140 of
While
Host interface layer 405 may manage an interface across only a single port, or it may manage interfaces across multiple ports. Alternatively, storage device 120 may include multiple ports, each of which may have a separate host interface layer 405 to manage interfaces across that port. Embodiments of the inventive concept may also mix the possibilities (for example, an SSD with three ports might have one host interface layer to manage one port and a second host interface layer to manage the other two ports).
Controller 410 may manage the read and write operations, along with garbage collection and other operations, on flash memory chips 415-1 through 415-8 using flash memory controller 425. SSD controller 410 may also include flash translation layer 430, memory 435, and/or DMA controller 440. Flash translation layer 430 may manage the mapping of logical block addresses (LBAs) (as used by host 105 of
Memory 435 may be a local memory, such as a DRAM, used by storage controller 410. Memory 435 may be a volatile or non-volatile memory. Memory 435 may also be accessible via DMA from devices other than storage device 120: for example, computational storage unit 140 of
DMA 440 may be a circuit that enables storage device 120 to execute DMA commands in a memory outside storage device 120. For example, DMA 440 may enable storage device 120 to read data from or write data to memory 115 of
While
While
Computational device 510-1 may be paired with storage device 505. Computational device 510-1 may include any number (one or more) processors 530, which may offer one or more services 535-1 and 535-2. To be clearer, each processor 530 may offer any number (one or more) services 535-1 and 535-2 (although embodiments of the disclosure may include computational device 510-1 including exactly two services 535-1 and 535-2). Each processor 530 may be a single core processor or a multi-core processor. Computational device 510-1 may be reachable across a host protocol interface, such as host interface 540, which may be used for both management of computational device 510-1 and/or to control I/O of computational device 510-1. As with host interface 525, host interface 540 may include queue pairs for submission and completion, but other host interfaces 540 are also possible, using any native host protocol supported by computational device 510-1. Examples of such host protocols may include Ethernet, RDMA, TCP/IP, InfiniBand, iSCSI, PCIe, SAS, and SATA, among other possibilities. In addition, host interface 540 may support communications with other components of system 105 of
Processor(s) 530 may be thought of as near-storage processing: that is, processing that is closer to storage device 505 than processor 110 of
Computational storage unit 410-1 may also include DMA 550. DMA 550 may be used similarly to DMA 440 of
Depending on the implementation, memory 545 and/or DMA 550 may be omitted, as shown by the dashed lines.
While
Services 535-1 and 535-2 may offer a number of different functions that may be executed on data stored in storage device 505. For example, services 535-1 and 535-2 may offer pre-defined functions, such as encryption, decryption, compression, and/or decompression of data, erasure coding, and/or applying regular expressions. Or, services 535-1 and 535-2 may offer more general functions, such as data searching and/or SQL functions. Services 535-1 and 535-2 may also support running application-specific code. That is, the application using services 535-1 and 535-2 may provide custom code to be executed using data on storage device 505. Services 535-1 and 535-2 may also any combination of such functions. Table 1 lists some examples of services that may be offered by processor(s) 530.
Processor(s) 530 (and, indeed, computational device 510-1) may be implemented in any desired manner. Example implementations may include a local processor, such as a CPU or some other processor (such as an FPGA, an ASIC, or a SoC), a GPU, a GPGPU, a DPU, an NPU, an NIC, or a TPU, among other possibilities. Processor(s) 530 may also be implemented using an FPGA or an ASIC, among other possibilities. If computational device 510-1 includes more than one processor 530, each processor may be implemented as described above. For example, computational device 510-1 might have one each of CPU, TPU, and FPGA, or computational device 510-1 might have two FPGAs, or computational device 510-1 might have two CPUs and one ASIC, etc.
Depending on the desired interpretation, either computational device 510-1 or processor(s) 530 may be thought of as a computational storage unit.
Some embodiments of the disclosure may include other mechanisms to communicate with storage device 505 and/or computational device 510-1. For example, storage device 505 and/or computational device 510-1 may include network interface 560, which may support communication with other devices using Ethernet, RDMA, TCP/IP, InfiniBand, SAS, iSCSI, or SATA, among other possibilities. Network interface 560 may provide another interface for communicating with storage device 505 and/or computational device 510-1. While
Whereas
In yet another variation shown in
In addition, processor(s) 530 may have proxied storage access 565 to storage 520-1. Thus, instead of routing access requests through controller 515, processor(s) 530 may be able to directly access the data from storage 520-1.
In
Finally,
Because computational device 510-4 may include more than one storage element 520-1 through 520-4, computational device 510-4 may include array controller 570. Array controller 570 may manage how data is stored on and retrieved from storage elements 520-1 through 520-4. For example, if storage elements 520-1 through 520-4 are implemented as some level of a Redundant Array of Independent Disks (RAID), array controller 570 may be a RAID controller. If storage elements 520-1 through 520-4 are implemented using some form of Erasure Coding, then array controller 570 may be an Erasure Coding controller.
At block 810, at some later time, multiplexer/demultiplexer 330 of
At block 820, at some later time, root port 355 of
Alternatively, at block 1115 (
As discussed above with reference to
In
In embodiments of the disclosure where multi-function device 135 supports only two devices, which may be storage device 120 of
As a particular example, consider a situation where storage device 120 of
There are some other points worth noting about this example, which generalize to embodiments of the disclosure. First, as noted above, rather than being used as a transit buffer, buffer 370 may be used as a shared memory, with storage device 120 of
Second, note that in the example host processor 110 of
Third, host processor 110 of
An advantage of having one controller issue requests to another controller, and that host processor 110 of
To achieve this result, multi-function device 135 may enumerate the various devices attached to multi-function device 135 and determine how the devices are configured. Each device's configuration may specify what functions the device offers, and which devices/controllers are to be exposed to host processor 110 of
In some embodiments of the disclosure, multi-function device 135 may notify storage device 120 of
While
Each function 1315 listed in entries 1325 may represent a different capability offered by the identified device. For example, consider storage device 120 of
As shown in list of device configurations 1305, different devices may offer different numbers of functions. For example, entries 1325-1 and 1325-2 show devices with two functions expose, whereas entry 1325-3 shows a device with only one function exposed. Embodiments of the disclosure may include any number (one or more) of devices, each with any number (one or more) of functions exposed by the device.
In referring to physical and virtual functions in column 1315, list of device configurations 1305 implies that the devices are PCIe devices. In some embodiments of the disclosure, PCIe busses and functions may be used. But embodiments of the disclosure may also use architectures other than PCIe, and may use other mechanisms to enable host processor 110 of
In
It may be noted that functions 1315 shows three different functions identified as physical function 0: one for each device 1310. In some embodiments of the disclosure, each device may list its functions starting at function 0. When devices are directly accessed by host processor 110 of
To resolve this concern, multi-function device 135 of
Thus, when multi-function device 135 of
Note that since device 2 is not exposed to host processor 110 of
In some embodiments of the disclosure, the mapping of Table 2 may be used with requests received at multi-function device 135 from any source, be it a device “above” multi-function device 135 (such as host processor 110 of
Storage 1215 may be any variety of storage. For example, storage 1215 may be a volatile storage, such as DRAM, or a non-volatile storage, such as flash memory. Some embodiments of the disclosure may use list of device configurations 1305 of
The fact that a particular device/controller might be hidden from host processor 110 of
While
But in some situations, while source 1505 might send request 1510 to target 1515, multi-function device 135 (or bridges 335 or 340 of
In some embodiments of the disclosure, target 1515, buffer 370, or data processor 375 might send reply 1520 back to source 1505. In such situations, reply 1520 may be delivered back to source 1520 by multi-function device 135.
Note that target 1515 might send reply 1520 even if target 1515 is integrated into multi-function device 135 of
At block 1620, multi-function device 135 of
While
At block 1915, multi-function device 135 of
While request 1510 of
At block 2415, multi-function device 135 of
In
Embodiments of the disclosure may have a multi-function device that may support connections to storage devices and computational storage units. The multi-function device may present to the host processor a single device supporting all the functions of the individual storage devices and computational storage units. In addition, some devices may be hidden from the host processor, and used solely by other devices connected to the multi-function device. Embodiments of the disclosure offer a technical advantage by enabling customers to mix and match which storage devices and which computational storage units to combine as though they were a single device. Embodiments of the disclosure also offer a technical advantage by enabling one device to access functions of another device attached to the multi-function device.
Embodiments of the disclosure may also include a buffer in the multi-function device. The buffer may act as a shared memory accessible by some or all of the attached storage devices and/or computational storage units. Embodiments of the disclosure offer a technical advantage by avoiding the need to use the main memory to move data between storage devices and/or computational storage units, or to process data in the main memory.
Various embodiments of the present disclosure include systems and methods for integrating a storage device such as solid-state drive (SSD) and compute device in an integrated storage device. In some embodiments of the disclosure, a Non-Volatile Memory Express (NVMe) controller and Compute may be exposed to a host independently using separate Peripheral Component Interconnect Express (PCIe) functions including physical functions (PFs)/Virtual Functions (VFs). A peer-to-peer data path may be provided between a storage device and a compute device. The compute device and SSD may be connected using connectors to provide flexibility to change various compute types such as graphics processing units (GPUs), Tensor Processing Units (TPUs), network interface controllers (NICs), Field Programmable Gate Arrays (FPGAs), Application-Specific Integrated Circuits (ASIC), System-on-a-Chips (SoC).
In some embodiments of the disclosure, applications may include those such as social networks, Artificial Intelligence/Machine Learning (AI/ML), Internet-of-things (JOT), and autonomous vehicles etc. which may generate large amounts of data. In some embodiments of the disclosure, such large datasets may require processing to generate monetarization from the datasets. In some embodiments, such processing may be expensive in terms of CPU cycles, memory bandwidth, energy spent. As such, some embodiments of the disclosure may process data near or inside a storage device to provide lower response latencies to the applications. Such near processing may also reduce energy consumption to move large data sets to and from a processor. Additionally, such near processing may enable distributed computing. As such, some embodiments of the disclosure may offload such application functions to a storage device and may minimize the compute resources needed, and hence may lower the cost of the database infrastructure including one or more of compute cycles, memory, network bandwidth, and energy consumed.
In some embodiments of the disclosure, one or more SSD Controllers and/or one or more Compute devices may be plugged/connected in the integrated storage device.
In some embodiments of the disclosure, the SSDs Controllers and/or Compute devices may be exposed to host in full or in part.
In some embodiments of the disclosure, subsets of SSD Controllers and/or Compute devices may not be exposed to the host and may be only internally.
In some embodiments of the disclosure, SSD Controllers and Compute devices may exposed using PCIe PF and/or VF.
In some embodiments of the disclosure, an FPGA performs a PCIe-PCIe bridging function, and host protocol pass-through.
In some embodiments of the disclosure, the SSD controllers and Compute devices may have their own device drivers and host software stack on the host that may access these device functions natively.
In some embodiments of the disclosure, SSD controllers and/or Compute devices may share peer-to-peer data buffer to exchange data being processed.
In some embodiments of the disclosure, one or more fixed compute devices such as a processor core may be used for certain pre-processing steps in FPGA.
In some embodiments of the disclosure, integrated devices may perform intelligent hosting directed device/function management such that those actions do not interfere with other SSD controllers and/or compute devices.
In some embodiments of the disclosure, SSD controllers and Compute devices may be pre-installed and configured in a flexible storage device.
In some embodiments of the disclosure, a flexible, integrated storage device may support a plug-and-play method of installing new computes into an existing flexible storage device.
Some embodiments of the disclosure may support integrating many different kinds of computes, such as TPU/GPU/FPGA/ASIC/SoC with SSD, for optimal data processing.
In some embodiments of the disclosure, different applications and use cases may benefit from cost and performance optimal computational storage solution.
Some embodiments of the disclosure may enable a broader set of applications customers.
Some embodiments of the disclosure may enable fewer product skews by having a base platform and different computes from partners.
Embodiments of the disclosure may include a proposed architecture for a flexible, integrated storage device that combines persistent storage and compute for optimal data processing. By processing data inside the storage device system, resource costs savings such as host bus bandwidth, host memory bandwidth, CPU cycles, energy spent in moving data may be achieved. Some embodiments of the disclosure may enable lower latencies as data processing may start sooner.
In some embodiments of the disclosure, a flexible and integrated storage device may be a processing element such as FPGA (or ASIC, SoC, etc.) and may be used to connect one or more SSD Controllers and/or one or more Compute resources to the host. In some embodiments of the disclosure, the SSD controllers and compute resources might be connected to such FPGA using connector so that different flavors could be connected as needed. In some embodiments of the disclosure, some of the SSD controllers and/or compute resources may be connected in a fixed manner if desirable.
One or more SSD controllers and one or more Compute resources may be exposed to the host through PCIe End Point (EP) Physical Functions (PF) or Virtual Functions (VF) in a transparent manner. The SSD controllers and compute resources may be connected to the FPGA using PCIe Root Port (RP). The FPGA logic may perform PCIe pass-through of the host and device interactions and host protocols. That is to say that a host system software stack such as SSD device drivers, compute drivers, and application frameworks may directly talk to the SSD controller and compute devices through the FPGA. In some embodiments, this facilitates easy integration of the proposed flexible storage device integration into existing application software stack.
In some embodiments of the disclosure, the number of PFs/VFs may match with the number of SSD Controllers and/or Computes exposed to the host. In some embodiments of the disclosure, the connected SSDs and Computes may be exposed or advertised to the host. In other embodiments of the disclosure, a subset of SSD controllers and/or computes may not be exposed to the host and may be used internally to the proposed storage device flexible storage device.
In some embodiments of the disclosure, a proposed flexible storage device may have other host interfaces such as one or more of Ethernet, TCP/IP, RDMA, NVMe-oF, UFS, eMMC, SAS, SATA, and so on in addition to or as an alternative to PCIe interfaces. Similarly, in some embodiments of the disclosure, the FPGA interface to the SSD Controller and Compute may have other protocols such as Ethernet, TCP/IP, RDMA, NVMe-oF, UFS, eMMC, SAS, SATA, and so on in addition to or as an alternative to PCIe interfaces. Although this disclosure uses examples with PCIe and NVMe as transport and host protocols for communication between host and flexible storage device, some embodiments of the disclosure may use other transports and host protocols to achieve optimal data processing operations in the proposed storage device.
In some embodiments of the disclosure, a PCIe bridge such as Light Weight Bridge (LWB) may forward the host PCIe packets and traffic to the SSD Controller and Compute resources attached to it with appropriate transactions if necessary. Similarly, in some embodiments of the disclosure, a PCIe bridge may forward the PCIe packets and traffic originating from SSD Controller and Compute device attached going to the host with appropriate translations if necessary.
In some embodiments of the disclosure, a flexible storage device may provide a peer-to-peer (P2P) data buffer that may be used to transfer data between SSD controller and compute device directly without sending it to the host memory. Such P2P data transfer may reduce the energy consumed, as well as the CPU cycles, the host memory bandwidth, and host bus bandwidth. Some embodiments of the disclosure may also enable a lower latency of data processing. In some embodiments of the disclosure, the P2P buffer may use on-chip SRAM, off-chip DRAM, or any other memory or combination of multiple memory elements.
In some embodiments of the disclosure, a flexible storage device may intercept any DMA transactions coming from an SSD controller and Compute device that fall in the P2P address range. The intercepted data transfer transactions may be re-directed to the P2P buffer instead of host memory. That is to say that SSD controller and/or Computes may be agnostic to the fact that some of their DMA transactions are automatically routed to the P2P buffer located in the storage device itself. From SSD Controller and Compute DMA point of view, they may just perform DMA operation using the memory addresses provided by their own device drivers. In some embodiments of the disclosure, no specific change or knowledge may be required by the SSD Controller and Compute device to participate in a P2P data transfer. As such, some embodiments of the disclosure may be very useful to enable usage of off-the-shelf SSD controllers and Compute devices into a flexible storage device to provide integrated solution with higher value.
In some embodiments of the disclosure, the P2P buffer may be accessed by SSD controllers using higher level protocols such as File Read or Write, and NVMe. In some embodiments of the disclosure, the P2P buffer may be accessed by the Compute devices using their own DMA engines under their own host device driver and software stack using any higher-level host protocols.
In some embodiments of the disclosure, a P2P buffer may be exposed to the host using a PCIe BAR mechanism. In some embodiments, the P2P buffer address range may be programmed or provided by the host into the flexible storage device. The method may be used by non PCIe host interfaces. In some embodiments of the disclosure, the P2P buffer address range available through BAR, or programming by host, or any other method may then be used by the FPGA to intercept the DMA transactions coming from the attached SSD Controllers and/or Compute resources.
In some embodiments of the disclosure, the P2P buffer may be shared between any number of devices connected to the FPGA including SSD controllers and Computes. That is to say that data may be exchanged between an SSD Controller and a compute device, a compute device and another compute device, an SSD controller and another SSD Controller, and/or any such combinations. In some embodiments of the disclosure, data may be shared or exchanged by one or more SSD Controllers or Computes to one or more SSD Controllers and/or compute devices. In another words, data exchange may be done in 1-to-1, many-to-1, or many-to-many manner. These forms of data exchange may be further described as unicast, or multicast, or broadcast type of data exchange.
In some embodiments of the disclosure, one or more SSD controllers may deposit data into the P2P buffer and then one or more Compute devices may operate or process that data by reading that data into their own local memory buffers.
In some embodiments of the disclosure, the FPGA may contain one or more processor cores or logic elements attached to the P2P buffer, to perform certain pre-processing data operations on the data contained in the P2P buffer itself. In some embodiments of the disclosure, such fixed, FPGA based pre-processing steps may be performed under device direction without host getting involved. In some embodiments of the disclosure, the FPGA based pro-processing steps may be performed under host direction. In some embodiments of the disclosure, the host may provide such instructions and orchestration using host bus interface to one or more PCIe functions.
In some embodiments of the disclosure, since multiple Compute functions and SSD controller functions may be exposed to the host, an integrated device may perform intelligent host directed device/function management such that those actions do not interfere with other SSD controllers and/or compute devices. Some examples of such device management functions are power management, reset, or interrupt settings.
In some embodiments of the disclosure, the flexible storage device, SSD controllers and Computes may be pre-installed and configured. In some embodiments of the disclosure, the flexible storage device supports plug-and-play method of installing new Computes and SSD controllers into an existing flexible storage device. In some embodiments of the disclosure, a FPGA uses local persistent memory to store configuration and capabilities of the SSD Controller and/or compute devices attached to it and may use local persistent memory to advertise devices attached to the FPGA to the host.
In some embodiments of the disclosure, after power-on, the logic in the FPGA may detect a newly connected device (SSD controller, and/or compute device) by checking the attached device identification information with its list of known device configurations stored in local persistent memory. If the device information does not match, the FPGA may read the host interface configuration and capabilities of the attached device and may store the read configuration and capability information in persistent memory. In other words, the FPGA may update its list of attached devices stored in local persistent memory. Then, on subsequent power-on events, the FPGA may use the host configuration and capability information stored in its local persistent memory to advertise configuration and capabilities matching a newly connected device. In this manner, a new compute device or SSD controller may be plugged into the flexible storage device base platform, and the storage device would automatically make it visible to the host.
Various embodiments of the disclosure include systems and methods for integrating a storage device such as Solid-State Drives (SSD) and Fully Homomorphic Encryption (FHE) acceleration engine in an integrated storage device. A Non-Volatile Memory Express (NVMe) controller and FHE acceleration engine may be exposed to the host independently using separate Peripheral Component Interconnect Express (PCIe) functions including physical functions (PFs)/Virtual Functions (VFs). A peer-to-peer data path may be provided between storage and FHE compute.
In some embodiments of the disclosure, applications may include those such as social networks, Artificial Intelligence/Machine Learning (AI/ML), Internet-of-things (IOT), and autonomous vehicles etc. which may generate large amounts of data. In some embodiments of the disclosure, such large datasets may require processing to generate monetarization from the datasets. In some embodiments of the disclosure, such processing may be expensive in terms of CPU cycles, memory bandwidth, energy spent. As such, some embodiments of the disclosure may process data near or inside a storage device to provide lower response latencies to the applications. Such near processing may also reduce energy consumption to move large data sets to and from a processor. Additionally, such near processing may enable distributed computing. As such, some embodiments of the disclosure may offload such application functions to a storage device and may minimize the compute resources needed, and hence may lower the cost of the database infrastructure including one or more of compute cycles, memory, network bandwidth, and energy consumed.
In some embodiments of the disclosure, one or more SSD Controllers and/or one or more FHE acceleration engines may be integrated in a storage device.
In some embodiments of the disclosure, off-the-shelf SSD controllers may be used to provide integrated solution.
In some embodiments of the disclosure, SSD controllers and FHE acceleration engine may have their own device drivers and host software stack on the host that may access these device functions natively.
In some embodiments of the disclosure, SSD controllers and/or FHE acceleration engines may share peer-to-peer data buffer to exchange data being processed.
In some embodiments of the disclosure, part of the P2P buffer may be reserved for FHE instructions as cache, or pre-fetch buffer.
In some embodiments of the disclosure, part of the P2P buffer may be reserved for input dataset as cache, or prefetch buffer.
In some embodiments of the disclosure, part of the P2P buffer may be reserved for intermediate results as cache or prefetch buffer.
In some embodiments of the disclosure, FHE processing may be performed on data stored in SSD efficiently, without moving it to the host memory.
In some embodiments of the disclosure, FHE processing instructions may be downloaded into the FHE engine quickly, resulting in lower latency.
In some embodiments of the disclosure, an off-the-shelf SSD may be used without re-spinning SSD controller.
In some embodiments of the disclosure, FHE acceleration may integrate into FHE framework and device driver smooth.
In embodiments of the disclosure, Fully Homomorphic Encryption (FHE) technology may be used to store sensitive data in encrypted form and then may process it for analytics without decrypting it. In some embodiments of the disclosure, this technology may enable secure data storage and processing without compromising confidentiality or misuse. A flexible, integrated storage device may combine persistent storage and an FHE acceleration engine. In some embodiments of the disclosure, by processing data inside the storage device system resource costs such as host bus bandwidth, host memory bandwidth, CPU cycles, energy spent in moving data may be achieved. In some embodiments of the disclosure, it also may enable lower latencies as data processing starts sooner.
In some embodiments of the disclosure, a flexible and integrated storage device may have a processing element such as a Field Programmable Gate Arrays (FPGA) (or Application-Specific Integrated Circuit (ASIC), or a System-on-a-Chip (SoC), etc.) used to connect one or more SSD Controllers and/or one or more Fully Homomorphic Encryption (FHE) processing engine to the host. The SSD controllers and FHE engine may be connected to FPGA using a connector so that different flavors or number of devices could be connected. In some embodiments of the disclosure, some of the SSD controllers and/or FHE engines may be connected in a fixed manner.
One or more SSD controllers and one or more FHE engines may be exposed to the host through PCIe End Point (EP) Physical Functions (PFs) or Virtual Functions (VFs) in a transparent manner. The FPGA logic may perform PCIe pass-through of the host and device interactions and host protocols. In other words, the FHE application and driver may communicate with FHE acceleration engine directly through the FPGA.
In some embodiments of the disclosure, a proposed flexible storage device with FHE acceleration engine may have other host interfaces such as one or more of Ethernet, TCP/IP, RDMA, NVMe-oF, UFS, eMMC, SAS, SATA, and so on in addition to or as an alternative to PCIe interfaces. Similarly, in some embodiments, the FPGA interface to the SSD Controller and Compute may have other protocols such as one or more of Ethernet, TCP/IP, RDMA, NVMe-oF, UFS, eMMC, SAS, SATA, and so on. Although this disclosure uses examples with PCIe and NVMe as transport and host protocols for communication between host and flexible storage device, some embodiments of the disclosure may use other transports and host protocols to achieve optimal data processing operations in the proposed storage device.
In some embodiments of the disclosure, the proposed flexible storage device FHE storage device may provide a peer-to-peer (P2P) data buffer that may be used to transfer data between SSD controller and FHE engine directly without sending it to the host memory. Such P2P data transfers may greatly reduce energy consumed, as well as CPU cycles, host memory bandwidth, and host bus bandwidth. In some embodiments of the disclosure, use of the P2P buffer may also enable lower latency of data processing. In some embodiments of the disclosure, the P2P buffer may use on-chip SRAM, off-chip DRAM, or any other memory or combination of multiple memory elements.
FHE processing instructions may be first downloaded into the FHE engine. In some embodiments of the disclosure, the FHE engine may receive DMA instructions from the host memory. In some embodiments of the disclosure, the FHE engine may receive DMA instructions from the P2P buffer in the integrated storage device. In some embodiments of the disclosure, the application and driver software may first read the instructions from SSD into the P2P buffer. In some embodiments of the disclosure, the system software may move instructions from host memory into the P2P buffer, and then may direct FHE engine to DMA instructions from P2P buffer.
In some embodiments of the disclosure, instructions kept in the P2P buffer may be kept there for future usage by reserving part of the P2P buffer for this purpose. That is to say that instructions kept in the P2P buffer may be cached there for subsequent usage. This may reduce latency of instruction loading into the FHE engine. In some embodiments of the disclosure, the system software may pre-fetch the desired instruction from SSD or host memory into the P2P buffer reserved for instructions.
In some embodiments of the disclosure, once the instructions are loaded into the FHE engine, input dataset may be provided to the engine for processing. In some embodiments of the disclosure, the input dataset may be present in host memory and FHE engine DMAs it from there through the FPGA in pass-through manner. In other embodiments of the disclosure, the input data set may be stored in the attached SSD and first may load it into the P2P buffer in the storage device. Such data loading may be done using higher level protocol such as File Read and NVMe Read commands to the attached SSD Controller. Once input data is DMA deposited into the P2P buffer by SSD Controller, application and/or system software may instruct the FHE engine to fetch that data for processing. At that point, the FHE engine may transfer data from P2P buffer into its local memory for processing.
In some embodiments of the disclosure, part of the P2P buffer may be reserved to store input data for future usage. In other words, P2P buffer may be used as cache or pre-fetch buffer for some of the processing inputs. Such caching and/or prefetching would reduce latency of data processing.
In some embodiments of the disclosure, once the FHE engine completes data processing, the completion may be conveyed to the application and system software through the FPGA in pass-through manner. At that point, application and/or system software may decide what to do with the FHE processing results. In some embodiments of the disclosure, the results may be transferred to the host memory using FHE engine DMA through the FPGA in pass-through manner. In some embodiments of the disclosure, the FHE processing results may be deposited into the P2P buffer for persistent storage in the attached SSD. Once results are transferred to P2P buffer, application and/or system software may instruct the SSD Controller to persist those results. That orchestration may be achieved using higher level protocol such as File Write and NVMe Write commands.
In some embodiments of the disclosure, part of the processing results may be kept in the P2P buffer for future usage. That is to say that part of the P2P buffer may be used as cache or prefetch buffer for intermediate results.
In some embodiments of the disclosure, a FHE engine may be integrated inside the FPGA instead of, or in addition to, connecting it externally. The other features mentioned earlier may apply to this integration method as well. An additional benefit of this integration method may be a reduced cost and reduction of power of devices. This method may also reduce overall latency of FHE operations as data may not need to cross the FPGA boundary or pass-through logic workbench (LWB) bridge logic.
The following discussion is intended to provide a brief, general description of a suitable machine or machines in which certain aspects of the disclosure may be implemented. The machine or machines may be controlled, at least in part, by input from conventional input devices, such as keyboards, mice, etc., as well as by directives received from another machine, interaction with a virtual reality (VR) environment, biometric feedback, or other input signal. As used herein, the term “machine” is intended to broadly encompass a single machine, a virtual machine, or a system of communicatively coupled machines, virtual machines, or devices operating together. Exemplary machines include computing devices such as personal computers, workstations, servers, portable computers, handheld devices, telephones, tablets, etc., as well as transportation devices, such as private or public transportation, e.g., automobiles, trains, cabs, etc.
The machine or machines may include embedded controllers, such as programmable or non-programmable logic devices or arrays, Application Specific Integrated Circuits (ASICs), embedded computers, smart cards, and the like. The machine or machines may utilize one or more connections to one or more remote machines, such as through a network interface, modem, or other communicative coupling. Machines may be interconnected by way of a physical and/or logical network, such as an intranet, the Internet, local area networks, wide area networks, etc. One skilled in the art will appreciate that network communication may utilize various wired and/or wireless short range or long range carriers and protocols, including radio frequency (RF), satellite, microwave, Institute of Electrical and Electronics Engineers (IEEE) 802.11, Bluetooth®, optical, infrared, cable, laser, etc.
Embodiments of the present disclosure may be described by reference to or in conjunction with associated data including functions, procedures, data structures, application programs, etc. which when accessed by a machine results in the machine performing tasks or defining abstract data types or low-level hardware contexts. Associated data may be stored in, for example, the volatile and/or non-volatile memory, e.g., RAM, ROM, etc., or in other storage devices and their associated storage media, including hard-drives, floppy-disks, optical storage, tapes, flash memory, memory sticks, digital video disks, biological storage, etc. Associated data may be delivered over transmission environments, including the physical and/or logical network, in the form of packets, serial data, parallel data, propagated signals, etc., and may be used in a compressed or encrypted format. Associated data may be used in a distributed environment, and stored locally and/or remotely for machine access.
Embodiments of the disclosure may include a tangible, non-transitory machine-readable medium comprising instructions executable by one or more processors, the instructions comprising instructions to perform the elements of the disclosures as described herein.
The various operations of methods described above may be performed by any suitable means capable of performing the operations, such as various hardware and/or software component(s), circuits, and/or module(s). The software may comprise an ordered listing of executable instructions for implementing logical functions, and may be embodied in any “processor-readable medium” for use by or in connection with an instruction execution system, apparatus, or device, such as a single or multiple-core processor or processor-containing system.
The blocks or steps of a method or algorithm and functions described in connection with the embodiments disclosed herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a tangible, non-transitory computer-readable medium. A software module may reside in Random Access Memory (RAM), flash memory, Read Only Memory (ROM), Electrically Programmable ROM (EPROM), Electrically Erasable Programmable ROM (EEPROM), registers, hard disk, a removable disk, a CD ROM, or any other form of storage medium known in the art.
Having described and illustrated the principles of the disclosure with reference to illustrated embodiments, it will be recognized that the illustrated embodiments may be modified in arrangement and detail without departing from such principles, and may be combined in any desired manner. And, although the foregoing discussion has focused on particular embodiments, other configurations are contemplated. In particular, even though expressions such as “according to an embodiment of the disclosure” or the like are used herein, these phrases are meant to generally reference embodiment possibilities, and are not intended to limit the disclosure to particular embodiment configurations. As used herein, these terms may reference the same or different embodiments that are combinable into other embodiments.
The foregoing illustrative embodiments are not to be construed as limiting the disclosure thereof. Although a few embodiments have been described, those skilled in the art will readily appreciate that many modifications are possible to those embodiments without materially departing from the novel teachings and advantages of the present disclosure. Accordingly, all such modifications are intended to be included within the scope of this disclosure as defined in the claims.
Embodiments of the disclosure may extend to the following statements, without limitation:
Statement 1. An embodiment of the disclosure includes a device, comprising:
a storage device, the storage device including storage for a data and a controller to manage access to the storage;
a network interface device to send the data across a network; and
a host interface, the host interface to receive a request for the storage device or the network interface device.
Statement 2. An embodiment of the disclosure includes the device according to statement 1, wherein:
the storage device includes a Solid State Drive (SSD);
the controller includes an SSD controller; and
the storage includes a not-AND flash storage.
Statement 3. An embodiment of the disclosure includes the device according to statement 1, wherein the host interface includes a Peripheral Component Interconnect Express (PCIe) interface or a cache-coherent interconnect interface.
Statement 4. An embodiment of the disclosure includes the device according to statement 3, wherein the cache-coherent interconnect interface includes a Compute Express Link (CXL) interface.
Statement 5. An embodiment of the disclosure includes the device according to statement 1, wherein the network interface device is configured to access the data from the storage of the storage device.
Statement 6. An embodiment of the disclosure includes the device according to statement 5, wherein the network interface device is further configured to access the data from the storage of the storage device using the controller.
Statement 7. An embodiment of the disclosure includes the device according to statement 1, further comprising a buffer connected to the storage device and the network interface device.
Statement 8. An embodiment of the disclosure includes the device according to statement 7, wherein:
the storage device is configured to store the data in the buffer; and
the network interface device is configured to read the data from the buffer.
Statement 9. An embodiment of the disclosure includes the device according to statement 8, wherein:
the storage device is further configured to store the data in the buffer based at least in part on the request from a host processor; and
the network interface device is further configured to read the data from the buffer based at least in part on the request from the host processor.
Statement 10. An embodiment of the disclosure includes the device according to statement 8, wherein the storage device is further configured to pause storing the data in the buffer based at least in part on the buffer reaching a first threshold.
Statement 11. An embodiment of the disclosure includes the device according to statement 10, wherein the storage device is further configured to store the data in the buffer based at least in part on the buffer reaching a second threshold.
Statement 12. An embodiment of the disclosure includes the device according to statement 10, wherein the storage device is further configured to signal a host processor based at least in part on the data in the buffer reaching the first threshold.
Statement 13. An embodiment of the disclosure includes the device according to statement 8, further comprising a circuit to process the data in the buffer.
Statement 14. An embodiment of the disclosure includes the device according to statement 13, wherein the circuit includes a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Tensor Processing Unit (TPU), a Neural Processing Unit (NPU), or a processor.
Statement 15. An embodiment of the disclosure includes the device according to statement 13, wherein the circuit includes the buffer.
Statement 16. An embodiment of the disclosure includes the device according to statement 13, wherein:
the host interface, is configured to receive the request for the storage device and to receive a second request for the network interface device;
the request is sent from the host interface to the circuit and from the circuit to the storage device; and
the second request is sent from the host interface to the circuit and from the circuit to the network interface device.
Statement 17. An embodiment of the disclosure includes the device according to statement 13, wherein the circuit is configured to transcode the data in the buffer.
Statement 18. An embodiment of the disclosure includes the device according to statement 8, wherein:
the buffer is partitioned into a first region and a second region;
the storage device is further configured to store the data in the first region of the buffer; and
the device further comprises a second storage device, the second storage device including a second storage for a second data and a second controller, the second storage device connected to the buffer, the second storage device configured to store the second data in the second region of the buffer.
Statement 19. An embodiment of the disclosure includes the device according to statement 18, wherein the network interface device is further configured to read the data from the first region of the buffer and the second data from the second region of the buffer.
Statement 20. An embodiment of the disclosure includes the device according to statement 18, wherein:
the network interface device is configured to read the data from the first region of the buffer; and
the device further comprises a second network interface device to send the second data across the network, the second network interface device connected to the buffer, the second network interface device configured to read the second data from the second region of the buffer.
Statement 21. An embodiment of the disclosure includes the device according to statement 8, wherein:
the buffer is partitioned into a first region and a second region;
the storage stores a second data; and
the storage device is further configured to store the data in the first region of the buffer and the second data in the second region of the buffer.
Statement 22. An embodiment of the disclosure includes the device according to statement 21, wherein:
the network interface device is configured to read the data from the first region of the buffer; and
the device further comprises a second network interface device to send the second data across the network, the second network interface device connected to the buffer, the second network interface device configured to read the second data from the second region of the buffer.
Statement 23. An embodiment of the disclosure includes the device according to statement 8, wherein:
the device further comprises a second buffer; and
the device further comprises a second storage device, the second storage device including a second storage for a second data and a second controller, the second storage device connected to the second buffer, the second storage device configured to store the second data in the second buffer.
Statement 24. An embodiment of the disclosure includes the device according to statement 23, wherein:
the network interface device is connected to the second buffer; and
the network interface device is further configured to read the second data from the second buffer.
Statement 25. An embodiment of the disclosure includes the device according to statement 24, further comprising a multiplexer connected to the network interface device, the buffer, and the second buffer.
Statement 26. An embodiment of the disclosure includes the device according to statement 23, further comprising a second network interface device to send the second data across the network, the second network interface device connected to the second buffer, the second network interface device configured to read the second data from the second buffer.
Statement 27. An embodiment of the disclosure includes the device according to statement 8, wherein:
the device further comprises a second buffer;
the storage stores a second data;
the storage device is connected to the second buffer; and
the storage device is further configured to store the second data in the second buffer.
Statement 28. An embodiment of the disclosure includes the device according to statement 27, further comprising a demultiplexer connected to the storage device, the buffer, and the second buffer.
Statement 29. An embodiment of the disclosure includes the device according to statement 27, further comprising a second network interface device to send the second data across the network, the second network interface device connected to the second buffer, the second network interface device configured to read the second data from the second buffer.
Statement 30. An embodiment of the disclosure includes the device according to statement 1, wherein the host interface includes an endpoint exposing a first function to issue a first request to the storage device and a second function to issue a second request to the network interface device.
Statement 31. An embodiment of the disclosure includes the device according to statement 1, further comprising a root port.
Statement 32. An embodiment of the disclosure includes the device according to statement 31, wherein the root port connects to the storage device.
Statement 33. An embodiment of the disclosure includes the device according to statement 32, wherein:
the device further comprises a second storage device; and
the root port further connects to the second storage device.
Statement 34. An embodiment of the disclosure includes the device according to statement 32, further comprising a second root port connected to the network interface device.
Statement 35. An embodiment of the disclosure includes the device according to statement 34, wherein:
the device further comprises a second network interface device; and
the second root port further connects to the second network interface device.
Statement 36. An embodiment of the disclosure includes the device according to statement 31, wherein the root port connects to the network interface device.
Statement 37. An embodiment of the disclosure includes the device according to statement 36, wherein:
the device further comprises a second network interface device; and
the root port further connects to the second network interface device.
Statement 38. An embodiment of the disclosure includes the device according to statement 1, wherein:
the storage device communicates with a host processor using a first protocol; and
the network interface device communicates with the host processor using a second protocol.
Statement 39. An embodiment of the disclosure includes the device according to statement 1, wherein:
the device further comprises a circuit;
the storage device communicates with the circuit using a first protocol; and
the network interface device communicates with the circuit using a second protocol.
Statement 40. An embodiment of the disclosure includes the device according to statement 39, wherein the circuit communicates with a host processor using a third protocol.
Statement 41. An embodiment of the disclosure includes a method, comprising:
receiving a request at a device;
accessing a data from a storage device of the device based at least in part on the request; and
transmitting the data using a network interface device of the device.
Statement 42. An embodiment of the disclosure includes the method according to statement 41, wherein receiving the request at the device includes receiving the request at the device from a host processor.
Statement 43. An embodiment of the disclosure includes the method according to statement 41, wherein receiving the request at the device includes receiving the request at a host interface of the device.
Statement 44. An embodiment of the disclosure includes the method according to statement 43, wherein receiving the request at the host interface of the device includes receiving the request at a function exposed by the host interface of the device.
Statement 45. An embodiment of the disclosure includes the method according to statement 44, wherein receiving the request at the function exposed by the host interface of the device includes receiving the request at the function exposed by an endpoint of the device.
Statement 46. An embodiment of the disclosure includes the method according to statement 43, wherein the host interface includes a Peripheral Component Interconnect Express (PCIe) interface or a cache-coherent interconnect interface.
Statement 47. An embodiment of the disclosure includes the method according to statement 46, wherein the cache-coherent interconnect interface includes a Compute Express Link (CXL) interface.
Statement 48. An embodiment of the disclosure includes the method according to statement 41, wherein accessing the data from the storage device of the device includes accessing the data from a storage of the storage device of the device.
Statement 49. An embodiment of the disclosure includes the method according to statement 48, wherein:
the storage device includes a Solid State Drive (SSD);
the SSD includes an SSD controller; and
the storage includes a not-AND flash storage.
Statement 50. An embodiment of the disclosure includes the method according to statement 41, wherein accessing the data from the storage device of the device includes accessing the data from the storage device of the device by the network interface device of the device.
Statement 51. An embodiment of the disclosure includes the method according to statement 41, wherein:
the method further comprises receiving a second request at the device; and
transmitting the data using a network interface device of the device includes transmitting the data using a network interface device of the device based at least in part on the second request.
Statement 52. An embodiment of the disclosure includes the method according to statement 51, wherein receiving the second request at the device includes receiving the second request at the device from a host processor.
Statement 53. An embodiment of the disclosure includes the method according to statement 51, wherein receiving the second request at the device includes receiving the second request at a host interface of the device.
Statement 54. An embodiment of the disclosure includes the method according to statement 53, wherein receiving the second request at the host interface of the device includes receiving the second request at a function exposed by the host interface of the device.
Statement 55. An embodiment of the disclosure includes the method according to statement 54, wherein receiving the second request at the second function exposed by the host interface of the device includes receiving the second request at the second function exposed by an endpoint of the device.
Statement 56. An embodiment of the disclosure includes the method according to statement 41, wherein:
accessing the data from the storage device of the device based at least in part on the request includes storing the data in a buffer by the storage device based at least in part on the request, the device including the buffer, the buffer connected to the storage device of the device and the network interface of the device; and
transmitting the data using the network interface device of the device includes reading the data from the buffer by the network interface device of the device.
Statement 57. An embodiment of the disclosure includes the method according to statement 56, wherein storing the data in the buffer by the storage device based at least in part on the request includes storing the data in the buffer by a storage controller of the storage device based at least in part on the request.
Statement 58. An embodiment of the disclosure includes the method according to statement 56, wherein storing the data in the buffer by the storage device based at least in part on the request includes prefetching the data by the storage device into the buffer based at least in part on the buffer crossing a threshold.
Statement 59. An embodiment of the disclosure includes the method according to statement 56, wherein storing the data in the buffer by the storage device based at least in part on the request includes pausing a prefetching of the data by the storage device into the buffer based at least in part on the buffer crossing a threshold.
Statement 60. An embodiment of the disclosure includes the method according to statement 56, further comprising processing the data in the buffer using a circuit of the device.
Statement 61. An embodiment of the disclosure includes the method according to statement 60, wherein the circuit of the device includes a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Tensor Processing Unit (TPU), a Neural Processing Unit (NPU), or a processor.
Statement 62. An embodiment of the disclosure includes the method according to statement 60, wherein the circuit of the device includes the buffer.
Statement 63. An embodiment of the disclosure includes the method according to statement 60, wherein receiving the request at the device includes:
receiving the request at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device.
Statement 64. An embodiment of the disclosure includes the method according to statement 63, wherein:
receiving the request at the circuit of the device includes receiving the request using a first protocol at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device includes sending the request using a second protocol from the circuit of the device to the storage device of the device.
Statement 65. An embodiment of the disclosure includes the method according to statement 60, wherein;
the method further comprises receiving a second request at the circuit of the device; and
transmitting the data using a network interface device of the device includes sending the second request from the circuit of the device to the network interface device of the device.
Statement 66. An embodiment of the disclosure includes the method according to statement 65, wherein:
receiving the second request at the circuit of the device includes receiving the second request using a first protocol at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device includes sending the request using a second protocol from the circuit of the device to the network interface device of the device.
Statement 67. An embodiment of the disclosure includes the method according to statement 60, wherein processing the data in the buffer using the circuit of the device includes transcoding the data in the buffer using the circuit of the device.
Statement 68. An embodiment of the disclosure includes the method according to statement 56, wherein:
storing the data in the buffer based at least in part on the request includes storing the data in a first region of the buffer based at least in part on the request; and
the method further comprises storing a second data in a second region of the buffer.
Statement 69. An embodiment of the disclosure includes the method according to statement 68, wherein storing the second data in the second region of the buffer includes accessing the second data from the storage device of the device.
Statement 70. An embodiment of the disclosure includes the method according to statement 68, wherein storing the second data in the second region of the buffer includes accessing the second data from a second storage device of the device, the buffer further connected to the second storage device of the device.
Statement 71. An embodiment of the disclosure includes the method according to statement 68, wherein reading the data from the buffer by the network interface device of the device includes reading the data from the first region of the buffer by the network interface device of the device.
Statement 72. An embodiment of the disclosure includes the method according to statement 71, further comprising:
reading the second data from the second region of the buffer by the network interface device; and
transmitting the second data using the network interface device of the device.
Statement 73. An embodiment of the disclosure includes the method according to statement 71, further comprising:
reading the second data from the second region of the buffer by a second network interface device of the device, the buffer further connected to the second network interface of the device; and
transmitting the second data using the second network interface device of the device.
Statement 74. An embodiment of the disclosure includes the method according to statement 56, further comprising storing a second data in a second buffer, the device including the second buffer, the second buffer connected to the storage device of the device and the network interface of the device.
Statement 75. An embodiment of the disclosure includes the method according to statement 74, wherein storing the second data in the second buffer includes accessing the second data from the storage device of the device.
Statement 76. An embodiment of the disclosure includes the method according to statement 75, wherein storing the second data in the second buffer further includes storing the second data in the second buffer via a demultiplexer.
Statement 77. An embodiment of the disclosure includes the method according to statement 74, wherein storing the second data in the second buffer includes accessing the second data from a second storage device of the device, the second buffer further connected to the second storage device of the device.
Statement 78. An embodiment of the disclosure includes the method according to statement 74, further comprising:
reading the second data from the second buffer by the network interface device; and
transmitting the second data using the network interface device of the device.
Statement 79. An embodiment of the disclosure includes the method according to statement 78, wherein reading the second data from the second buffer by the network interface device includes reading the second data from the second buffer by the network interface device via a multiplexer.
Statement 80. An embodiment of the disclosure includes the method according to statement 78, further comprising:
reading the second data from the second buffer by a second network interface device of the device, the second buffer further connected to the second network interface of the device; and
transmitting the second data using the second network interface device of the device.
Statement 81. An embodiment of the disclosure includes the method according to statement 41, wherein receiving the request at the device includes sending the request to the storage device of the device using a root port of the device.
Statement 82. An embodiment of the disclosure includes the method according to statement 81, wherein the storage device of the device and a second storage device of the device connect to the root port of the device.
Statement 83. An embodiment of the disclosure includes the method according to statement 41, wherein receiving the request at the device includes sending the request to the network interface device of the device using a root port of the device.
Statement 84. An embodiment of the disclosure includes the method according to statement 83, wherein the network interface device of the device and a second network interface device of the device connect to the root port of the device.
Statement 85. An embodiment of the disclosure includes a method, comprising:
sending a first request from a host processor to a storage device of a device, the device including the storage device and a network interface device; and
sending a second request from the host processor to the network interface device of the device,
wherein a data of storage device of the device is transmitted by the network interface device of the device.
Statement 86. An embodiment of the disclosure includes the method according to statement 85, wherein:
the data is read from the storage device of the device based at least in part on the first request; and
the data is transmitted by the network interface device of the device based at least in part on the second request.
Statement 87. An embodiment of the disclosure includes the method according to statement 85, wherein the data of the storage device of the device is transmitted by the network interface device of the device without transferring the data to a main memory associated with the host processor.
Statement 88. An embodiment of the disclosure includes the method according to statement 85, wherein sending the first request from the host processor to the storage device of the device includes sending the second request from the host processor to the network interface device of the device.
Statement 89. An embodiment of the disclosure includes the method according to statement 85, wherein
sending the first request from the host processor to the storage device of the device includes sending the first request using a first protocol from the host processor to the storage device of the device; and
sending the second request from the host processor to the network interface device of the device includes sending the second request using a second protocol from the host processor to the network interface device of the device.
Statement 90. An embodiment of the disclosure includes the method according to statement 85, further comprising sending a third request from the host processor to a circuit of the device.
Statement 91. An embodiment of the disclosure includes the method according to statement 90, wherein the circuit includes a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Tensor Processing Unit (TPU), a Neural Processing Unit (NPU), or a processor.
Statement 92. An embodiment of the disclosure includes the method according to statement 90, wherein the circuit transcodes the data from the storage device of the device for transmission by the network interface device of the device.
Statement 93. An embodiment of the disclosure includes the method according to statement 92, where the circuit transcodes the data from the storage device of the device for transmission by the network interface device of the device based at least in part on the third request.
Statement 94. An embodiment of the disclosure includes the method according to statement 85, further comprising sending a third request from the host processor to the device.
Statement 95. An embodiment of the disclosure includes the method according to statement 94, wherein the device transcodes the data from the storage device of the device for transmission by the network interface device of the device.
Statement 96. An embodiment of the disclosure includes the method according to statement 95, where the device transcodes the data from the storage device of the device for transmission by the network interface device of the device based at least in part on the third request.
Statement 97. An embodiment of the disclosure includes an article, comprising a non-transitory storage medium, the non-transitory storage medium having stored thereon instructions that, when executed by a machine, result in:
receiving a request at a device;
accessing a data from a storage device of the device based at least in part on the request; and
transmitting the data using a network interface device of the device.
Statement 98. An embodiment of the disclosure includes the article according to statement 97, wherein receiving the request at the device includes receiving the request at the device from a host processor.
Statement 99. An embodiment of the disclosure includes the article according to statement 97, wherein receiving the request at the device includes receiving the request at a host interface of the device.
Statement 100. An embodiment of the disclosure includes the article according to statement 99, wherein receiving the request at the host interface of the device includes receiving the request at a function exposed by the host interface of the device.
Statement 101. An embodiment of the disclosure includes the article according to statement 100, wherein receiving the request at the function exposed by the host interface of the device includes receiving the request at the function exposed by an endpoint of the device.
Statement 102. An embodiment of the disclosure includes the article according to statement 99, wherein the host interface includes a Peripheral Component Interconnect Express (PCIe) interface or a cache-coherent interconnect interface.
Statement 103. An embodiment of the disclosure includes the article according to statement 102, wherein the cache-coherent interconnect interface includes a Compute Express Link (CXL) interface.
Statement 104. An embodiment of the disclosure includes the article according to statement 97, wherein accessing the data from the storage device of the device includes accessing the data from a storage of the storage device of the device.
Statement 105. An embodiment of the disclosure includes the article according to statement 104, wherein:
the storage device includes a Solid State Drive (SSD);
the SSD includes an SSD controller; and
the storage includes a not-AND flash storage.
Statement 106. An embodiment of the disclosure includes the article according to statement 97, wherein accessing the data from the storage device of the device includes accessing the data from the storage device of the device by the network interface device of the device.
Statement 107. An embodiment of the disclosure includes the article according to statement 97, wherein:
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in receiving a second request at the device; and
transmitting the data using a network interface device of the device includes transmitting the data using a network interface device of the device based at least in part on the second request.
Statement 108. An embodiment of the disclosure includes the article according to statement 107, wherein receiving the second request at the device includes receiving the second request at the device from a host processor.
Statement 109. An embodiment of the disclosure includes the article according to statement 107, wherein receiving the second request at the device includes receiving the second request at a host interface of the device.
Statement 110. An embodiment of the disclosure includes the article according to statement 109, wherein receiving the second request at the host interface of the device includes receiving the second request at a function exposed by the host interface of the device.
Statement 111. An embodiment of the disclosure includes the article according to statement 110, wherein receiving the second request at the second function exposed by the host interface of the device includes receiving the second request at the second function exposed by an endpoint of the device.
Statement 112. An embodiment of the disclosure includes the article according to statement 97, wherein:
accessing the data from the storage device of the device based at least in part on the request includes storing the data in a buffer by the storage device based at least in part on the request, the device including the buffer, the buffer connected to the storage device of the device and the network interface of the device; and transmitting the data using the network interface device of the device includes reading the data from the buffer by the network interface device of the device.
Statement 113. An embodiment of the disclosure includes the article according to statement 112, wherein storing the data in the buffer by the storage device based at least in part on the request includes storing the data in the buffer by a storage controller of the storage device based at least in part on the request.
Statement 114. An embodiment of the disclosure includes the article according to statement 112, wherein storing the data in the buffer by the storage device based at least in part on the request includes prefetching the data by the storage device into the buffer based at least in part on the buffer crossing a threshold.
Statement 115. An embodiment of the disclosure includes the article according to statement 112, wherein storing the data in the buffer by the storage device based at least in part on the request includes pausing a prefetching of the data by the storage device into the buffer based at least in part on the buffer crossing a threshold.
Statement 116. An embodiment of the disclosure includes the article according to statement 112, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in processing the data in the buffer using a circuit of the device.
Statement 117. An embodiment of the disclosure includes the article according to statement 116, wherein the circuit of the device includes a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Tensor Processing Unit (TPU), a Neural Processing Unit (NPU), or a processor.
Statement 118. An embodiment of the disclosure includes the article according to statement 116, wherein the circuit of the device includes the buffer.
Statement 119. An embodiment of the disclosure includes the article according to statement 116, wherein receiving the request at the device includes:
receiving the request at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device.
Statement 120. An embodiment of the disclosure includes the article according to statement 119, wherein:
receiving the request at the circuit of the device includes receiving the request using a first protocol at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device includes sending the request using a second protocol from the circuit of the device to the storage device of the device.
Statement 121. An embodiment of the disclosure includes the article according to statement 116, wherein;
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in receiving a second request at the circuit of the device; and
transmitting the data using a network interface device of the device includes sending the second request from the circuit of the device to the network interface device of the device.
Statement 122. An embodiment of the disclosure includes the article according to statement 121, wherein:
receiving the second request at the circuit of the device includes receiving the second request using a first protocol at the circuit of the device; and
sending the request from the circuit of the device to the storage device of the device includes sending the request using a second protocol from the circuit of the device to the network interface device of the device.
Statement 123. An embodiment of the disclosure includes the article according to statement 116, wherein processing the data in the buffer using the circuit of the device includes transcoding the data in the buffer using the circuit of the device.
Statement 124. An embodiment of the disclosure includes the article according to statement 112, wherein:
storing the data in the buffer based at least in part on the request includes storing the data in a first region of the buffer based at least in part on the request; and
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in storing a second data in a second region of the buffer.
Statement 125. An embodiment of the disclosure includes the article according to statement 124, wherein storing the second data in the second region of the buffer includes accessing the second data from the storage device of the device.
Statement 126. An embodiment of the disclosure includes the article according to statement 124, wherein storing the second data in the second region of the buffer includes accessing the second data from a second storage device of the device, the buffer further connected to the second storage device of the device.
Statement 127. An embodiment of the disclosure includes the article according to statement 124, wherein reading the data from the buffer by the network interface device of the device includes reading the data from the first region of the buffer by the network interface device of the device.
Statement 128. An embodiment of the disclosure includes the article according to statement 127, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
reading the second data from the second region of the buffer by the network interface device; and
transmitting the second data using the network interface device of the device.
Statement 129. An embodiment of the disclosure includes the article according to statement 127, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
reading the second data from the second region of the buffer by a second network interface device of the device, the buffer further connected to the second network interface of the device; and
transmitting the second data using the second network interface device of the device.
Statement 130. An embodiment of the disclosure includes the article according to statement 112, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in storing a second data in a second buffer, the device including the second buffer, the second buffer connected to the storage device of the device and the network interface of the device.
Statement 131. An embodiment of the disclosure includes the article according to statement 130, wherein storing the second data in the second buffer includes accessing the second data from the storage device of the device.
Statement 132. An embodiment of the disclosure includes the article according to statement 131, wherein storing the second data in the second buffer further includes storing the second data in the second buffer via a demultiplexer.
Statement 133. An embodiment of the disclosure includes the article according to statement 130, wherein storing the second data in the second buffer includes accessing the second data from a second storage device of the device, the second buffer further connected to the second storage device of the device.
Statement 134. An embodiment of the disclosure includes the article according to statement 130, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
reading the second data from the second buffer by the network interface device; and
transmitting the second data using the network interface device of the device.
Statement 135. An embodiment of the disclosure includes the article according to statement 134, wherein reading the second data from the second buffer by the network interface device includes reading the second data from the second buffer by the network interface device via a multiplexer.
Statement 136. An embodiment of the disclosure includes the article according to statement 134, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
reading the second data from the second buffer by a second network interface device of the device, the second buffer further connected to the second network interface of the device; and
transmitting the second data using the second network interface device of the device.
Statement 137. An embodiment of the disclosure includes the article according to statement 97, wherein receiving the request at the device includes sending the request to the storage device of the device using a root port of the device.
Statement 138. An embodiment of the disclosure includes the article according to statement 137, wherein the storage device of the device and a second storage device of the device connect to the root port of the device.
Statement 139. An embodiment of the disclosure includes the article according to statement 97, wherein receiving the request at the device includes sending the request to the network interface device of the device using a root port of the device.
Statement 140. An embodiment of the disclosure includes the article according to statement 139, wherein the network interface device of the device and a second network interface device of the device connect to the root port of the device.
Statement 141. An embodiment of the disclosure includes an article, comprising a non-transitory storage medium, the non-transitory storage medium having stored thereon instructions that, when executed by a machine, result in:
sending a first request from a host processor to a storage device of a device, the device including the storage device and a network interface device; and
sending a second request from the host processor to the network interface device of the device,
wherein a data of storage device of the device is transmitted by the network interface device of the device.
Statement 142. An embodiment of the disclosure includes the article according to statement 141, wherein:
the data is read from the storage device of the device based at least in part on the first request; and
the data is transmitted by the network interface device of the device based at least in part on the second request.
Statement 143. An embodiment of the disclosure includes the article according to statement 141, wherein the data of the storage device of the device is transmitted by the network interface device of the device without transferring the data to a main memory associated with the host processor.
Statement 144. An embodiment of the disclosure includes the article according to statement 141, wherein sending the first request from the host processor to the storage device of the device includes sending the second request from the host processor to the network interface device of the device.
Statement 145. An embodiment of the disclosure includes the article according to statement 141, wherein
sending the first request from the host processor to the storage device of the device includes sending the first request using a first protocol from the host processor to the storage device of the device; and
sending the second request from the host processor to the network interface device of the device includes sending the second request using a second protocol from the host processor to the network interface device of the device.
Statement 146. An embodiment of the disclosure includes the article according to statement 141, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in sending a third request from the host processor to a circuit of the device.
Statement 147. An embodiment of the disclosure includes the article according to statement 146, wherein the circuit includes a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Tensor Processing Unit (TPU), a Neural Processing Unit (NPU), or a processor.
Statement 148. An embodiment of the disclosure includes the article according to statement 146, wherein the circuit transcodes the data from the storage device of the device for transmission by the network interface device of the device.
Statement 149. An embodiment of the disclosure includes the article according to statement 148, where the circuit transcodes the data from the storage device of the device for transmission by the network interface device of the device based at least in part on the third request.
Statement 150. An embodiment of the disclosure includes the article according to statement 141, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in sending a third request from the host processor to the device.
Statement 151. An embodiment of the disclosure includes the article according to statement 150, wherein the device transcodes the data from the storage device of the device for transmission by the network interface device of the device.
Statement 152. An embodiment of the disclosure includes the article according to statement 151, where the device transcodes the data from the storage device of the device for transmission by the network interface device of the device based at least in part on the third request.
Statement 153. An embodiment of the disclosure includes a multi-function device, comprising:
a first connector for communicating with a storage device;
a second connector for communicating with a first computational storage unit;
a third connector for communicating with a second computational storage unit; and
a fourth connector for communicating with a host processor;
wherein the multi-function device is configured to expose the storage device and the first computational storage unit to the host processor via the fourth connector.
Statement 154. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the multi-function device does not expose the second computational storage unit to the host processor.
Statement 155. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 156. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the first computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 157. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the second computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 158. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the storage device includes a Solid State Drive (SSD).
Statement 159. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the first computational storage unit includes an accelerator circuit, a Fully Homomorphic Encryption (FHE) circuit, or a network interface device.
Statement 160. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the second computational storage unit includes an accelerator circuit, an FHE circuit, or a network interface device.
Statement 161. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the storage device is configured to invoke a capability of the first computational storage unit or the second computational storage unit.
Statement 162. An embodiment of the disclosure includes the multi-function device according to statement 161, wherein the multi-function device is configured to receive a request from the storage device and send the request to the first computational storage unit or the second computational storage unit.
Statement 163. An embodiment of the disclosure includes the multi-function device according to statement 162, wherein the multi-function device is configured to receive the request from the storage device and send the request to the first computational storage unit or the second computational storage unit without sending the request to the host processor.
Statement 164. An embodiment of the disclosure includes the multi-function device according to statement 161, wherein the storage device is configured to invoke the capability of the first computational storage unit or the second computational storage unit without management by the host processor.
Statement 165. An embodiment of the disclosure includes the multi-function device according to statement 161, wherein the multi-function device is configured to receive a reply from the first computational storage unit or the second computational storage unit and send the reply to the storage device.
Statement 166. An embodiment of the disclosure includes the multi-function device according to statement 165, wherein the multi-function device is configured to receive the reply from the first computational storage unit or the second computational storage unit and send the reply to the storage device without sending the reply to the host processor.
Statement 167. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the first computational storage unit is configured to invoke a capability of the storage device or the second computational storage unit.
Statement 168. An embodiment of the disclosure includes the multi-function device according to statement 167, wherein the multi-function device is configured to receive a request from the first computational storage unit and send the request to the storage device or the second computational storage unit.
Statement 169. An embodiment of the disclosure includes the multi-function device according to statement 168, wherein the multi-function device is configured to receive the request from the first computational storage unit and send the request to the storage device or the second computational storage unit without sending the request to the host processor.
Statement 170. An embodiment of the disclosure includes the multi-function device according to statement 167, wherein the first computational storage unit is configured to invoke the capability of the storage device or the second computational storage unit without management by the host processor.
Statement 171. An embodiment of the disclosure includes the multi-function device according to statement 167, wherein the multi-function device is configured to receive a reply from the storage device or the second computational storage unit and send the reply to the first computational storage unit.
Statement 172. An embodiment of the disclosure includes the multi-function device according to statement 171, wherein the multi-function device is configured to receive the reply from the storage device or the second computational storage unit and send the reply to the first computational storage unit without sending the reply to the host processor.
Statement 173. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the second computational storage unit is configured to invoke a capability of the storage device or the first computational storage unit.
Statement 174. An embodiment of the disclosure includes the multi-function device according to statement 173, wherein the multi-function device is configured to receive a request from the second computational storage unit and send the request to the storage device or the first computational storage unit.
Statement 175. An embodiment of the disclosure includes the multi-function device according to statement 174, wherein the multi-function device is configured to receive the request from the second computational storage unit and send the request to the storage device or the first computational storage unit without sending the request to the host processor.
Statement 176. An embodiment of the disclosure includes the multi-function device according to statement 173, wherein the second computational storage unit is configured to invoke the capability of the storage device or the first computational storage unit without management by the host processor.
Statement 177. An embodiment of the disclosure includes the multi-function device according to statement 173, wherein the multi-function device is configured to receive a reply from the storage device or the first computational storage unit and send the reply to the second computational storage unit.
Statement 178. An embodiment of the disclosure includes the multi-function device according to statement 177, wherein the multi-function device is configured to receive the reply from the storage device or the first computational storage unit and send the reply to the second computational storage unit without sending the reply to the host processor.
Statement 179. An embodiment of the disclosure includes the multi-function device according to statement 153, further comprising a buffer connected to the storage device, the first computational storage unit, and the second computational storage unit.
Statement 180. An embodiment of the disclosure includes the multi-function device according to statement 179, wherein the storage device, the first computational storage unit, and the second computational storage unit are configured to access a data in the buffer.
Statement 181. An embodiment of the disclosure includes the multi-function device according to statement 179, wherein the buffer includes an address range.
Statement 182. An embodiment of the disclosure includes the multi-function device according to statement 181, wherein the host processor determines the address range of the buffer.
Statement 183. An embodiment of the disclosure includes the multi-function device according to statement 179, wherein the storage device is configured to access the buffer using a protocol.
Statement 184. An embodiment of the disclosure includes the multi-function device according to statement 183, wherein the protocol includes at least one of a File Read protocol, a
File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 185. An embodiment of the disclosure includes the multi-function device according to statement 179, wherein the first computational storage unit is configured to access the buffer using a protocol.
Statement 186. An embodiment of the disclosure includes the multi-function device according to statement 185, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 187. An embodiment of the disclosure includes the multi-function device according to statement 179, wherein the second computational storage unit is configured to access the buffer using a protocol.
Statement 188. An embodiment of the disclosure includes the multi-function device according to statement 187, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 189. An embodiment of the disclosure includes the multi-function device according to statement 179, further comprising a data processor connected to the buffer, the data processor configured to process a data in the buffer.
Statement 190. An embodiment of the disclosure includes the multi-function device according to statement 189, wherein the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 191. An embodiment of the disclosure includes the multi-function device according to statement 190, wherein:
the data processor is configured to expose a function;
the request is from the host processor; and
the request triggers the function of the data processor.
Statement 192. An embodiment of the disclosure includes the multi-function device according to statement 191, wherein the function includes a Peripheral Component Interconnect Express (PCIe) function.
Statement 193. An embodiment of the disclosure includes the multi-function device according to statement 192, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 194. An embodiment of the disclosure includes the multi-function device according to statement 191, wherein:
the multi-function device is configured to expose a second function to the host processor via the fourth connector;
the multi-function device is configured to receive the request from the host processor via the fourth connector; and
the multi-function device triggers the function of the data processor.
Statement 195. An embodiment of the disclosure includes the multi-function device according to statement 194, wherein:
the request includes the second function; and
the multi-function device is configured to map the second function to the function of the data processor.
Statement 196. An embodiment of the disclosure includes the multi-function device according to statement 153, further comprising:
a first bridge connecting the fourth connector and the first connector; and
a second bridge connecting the fourth connector and the second connector.
Statement 197. An embodiment of the disclosure includes the multi-function device according to statement 196, wherein:
the first bridge supports pass-through of a first request between the host processor and the storage device; and
the second bridge supports pass-through of a second request between the host processor and the first computational storage unit.
Statement 198. An embodiment of the disclosure includes the multi-function device according to statement 196, further comprising a third bridge connecting the fourth connector and the third connector.
Statement 199. An embodiment of the disclosure includes the multi-function device according to statement 198, wherein the third bridge supports pass-through of a request between the host processor and the second computational storage unit.
Statement 200. An embodiment of the disclosure includes the multi-function device according to statement 196, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the first computational storage unit is configured to expose a second function to the multi-function device via the second connector;
the second computational storage unit is configured to expose a third function to the multi-function device via the third connector;
the multi-function device is configured to expose a fourth function and a fifth function to the host processor via the fourth connector;
the first bridge is configured to map a first request using the fourth function to a second request using the first function;
the second bridge is configured to map a third request using the fifth function to a fourth request using the second function; and
a third bridge is configured to map a fifth request using a sixth function to a sixth request using the third function.
Statement 201. An embodiment of the disclosure includes the multi-function device according to statement 200, wherein:
the multi-function device is configured to direct the first request to the first bridge;
the multi-function device is configured to direct the third request to the second bridge; and
the multi-function device is configured to direct the fifth request to the third bridge.
Statement 202. An embodiment of the disclosure includes the multi-function device according to statement 201, wherein:
the multi-function device is configured to receive the first request from the host processor, the first computational storage unit, or the second computational storage unit;
the multi-function device is configured to receive the third request from the host processor, the storage device, or the second computational storage unit; and
the multi-function device is configured to receive the fifth request from storage device or the first computational storage unit.
Statement 203. An embodiment of the disclosure includes the multi-function device according to statement 200, wherein:
the multi-function device is configured to expose the fourth function to the first computational storage unit via the second connector and to the second computational storage unit via the third connector;
the multi-function device is configured to expose the fifth function to the storage device via the first connector and to the second computational storage unit via the third connector; and
the multi-function device is configured to expose the sixth function to the storage device via the first connector and to the first computational storage unit via the second connector.
Statement 204. An embodiment of the disclosure includes the multi-function device according to statement 200, wherein the multi-function device is configured not to expose the sixth function to the host processor via the fourth connector.
Statement 205. An embodiment of the disclosure includes the multi-function device according to statement 196, further comprising:
a third bridge connecting the fourth connector and the third connector; and
a buffer connected to the first bridge, the second bridge, and the third bridge.
Statement 206. An embodiment of the disclosure includes the multi-function device according to statement 205, wherein the first bridge is configured to receive a request sent from the storage device and direct the request to the buffer.
Statement 207. An embodiment of the disclosure includes the multi-function device according to statement 206, wherein the request is sent from the storage device to the host processor.
Statement 208. An embodiment of the disclosure includes the multi-function device according to statement 206, wherein the storage device is agnostic to the first bridge redirecting the request to the buffer.
Statement 209. An embodiment of the disclosure includes the multi-function device according to statement 206, wherein the first bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 210. An embodiment of the disclosure includes the multi-function device according to statement 209, wherein the buffer includes an address range including the address.
Statement 211. An embodiment of the disclosure includes the multi-function device according to statement 205, wherein the second bridge is configured to receive a request sent from the first computational storage unit and direct the request to the buffer.
Statement 212. An embodiment of the disclosure includes the multi-function device according to statement 211, wherein the request is sent from the first computational storage unit to the host processor.
Statement 213. An embodiment of the disclosure includes the multi-function device according to statement 211, wherein the first computational storage unit is agnostic to the second bridge redirecting the request to the buffer.
Statement 214. An embodiment of the disclosure includes the multi-function device according to statement 211, wherein the second bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 215. An embodiment of the disclosure includes the multi-function device according to statement 214, wherein the buffer includes an address range including the address.
Statement 216. An embodiment of the disclosure includes the multi-function device according to statement 205, wherein the third bridge is configured to receive a request sent from the second computational storage unit and direct the request to the buffer.
Statement 217. An embodiment of the disclosure includes the multi-function device according to statement 216, wherein the second computational storage unit is agnostic to the third bridge redirecting the request to the buffer.
Statement 218. An embodiment of the disclosure includes the multi-function device according to statement 216, wherein the third bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 219. An embodiment of the disclosure includes the multi-function device according to statement 218, wherein the buffer includes an address range including the address.
Statement 220. An embodiment of the disclosure includes the multi-function device according to statement 153, further comprising a storage for a list of device configurations.
Statement 221. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the list of device configurations includes a first entry for the storage device, a second entry for the first computational storage unit, and a third entry for the second computational storage unit.
Statement 222. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the storage includes a persistent storage.
Statement 223. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the multi-function device is configured to expose the storage device and the first computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 224. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the multi-function device is configured not to expose the second computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 225. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the multi-function device is configured to detect a device connected to at least one of the second connector or the third connector, determine a configuration of the device, and update the list of device configurations based at least in part on the configuration of the device.
Statement 226. An embodiment of the disclosure includes the multi-function device according to statement 225, wherein the device includes a second storage device, a third computational storage unit, a FHE circuit, or a network interface device.
Statement 227. An embodiment of the disclosure includes the multi-function device according to statement 220, wherein the multi-function device is configured to determine the configuration of the device and update the list of device configurations based at least in part on the list of configurations omitting a configuration of the device.
Statement 228. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the storage device is replaceable.
Statement 229. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the first computational storage unit is replaceable.
Statement 230. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the second computational storage unit is replaceable.
Statement 231. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein:
the first connector includes a first PCIe port;
the second connector includes a second PCIe port;
the third connector includes a third PCIe port; and
the fourth connector includes a fourth PCIe port.
Statement 232. An embodiment of the disclosure includes the multi-function device according to statement 231, wherein:
the first PCIe port includes a first root port;
the second PCIe port includes a second root port;
the third PCIe port includes a third root port; and
the fourth PCIe port includes an endpoint.
Statement 233. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein:
the storage device is configured to expose a first PCIe function to the multi-function device via the first connector;
the first computational storage unit is configured to expose a second PCIe function to the multi-function device via the second connector;
the second computational storage unit is configured to expose a third PCIe function to the multi-function device via the third connector; and
the multi-function device is configured to expose a fourth PCIe function to the host processor via the fourth connector.
Statement 234. An embodiment of the disclosure includes the multi-function device according to statement 233, wherein:
the first PCIe function includes a first PF or a first VF;
the second PCIe function includes a second PF or a second VF;
the third PCIe function includes a third PF or a third VF;
the fourth PCIe function includes a fourth PF or a fourth VF.
Statement 235. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the first connector supports at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 236. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the second connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 237. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the third connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 238. An embodiment of the disclosure includes the multi-function device according to statement 153, wherein the fourth connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 239. An embodiment of the disclosure includes a multi-function device, comprising:
a first connector for communicating with a storage device;
a first computational storage unit integrated into the multi-function device;
a second connector for communicating with a second computational storage unit; and
a third connector for communicating with a host processor;
wherein the multi-function device is configured to expose the storage device and at least one of the first computational storage unit or the second computational storage unit to the host processor via the third connector.
Statement 240. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the multi-function device does not expose at least one of the first computational storage unit or the second computational storage unit to the host processor.
Statement 241. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 242. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the second computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 243. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the storage device is configured to invoke a capability of the first computational storage unit or the second computational storage unit.
Statement 244. An embodiment of the disclosure includes the multi-function device according to statement 243, wherein the multi-function device is configured to receive a request from the storage device and send the request to the first computational storage unit or the second computational storage unit.
Statement 245. An embodiment of the disclosure includes the multi-function device according to statement 244, wherein the multi-function device is configured to receive the request from the storage device and send the request to the first computational storage unit or the second computational storage unit without sending the request to the host processor.
Statement 246. An embodiment of the disclosure includes the multi-function device according to statement 243, wherein the storage device is configured to invoke the capability of the first computational storage unit or the second computational storage unit without management by the host processor.
Statement 247. An embodiment of the disclosure includes the multi-function device according to statement 243, wherein the multi-function device is configured to receive a reply from the first computational storage unit or the second computational storage unit and send the reply to the storage device.
Statement 248. An embodiment of the disclosure includes the multi-function device according to statement 247, wherein the multi-function device is configured to receive the reply from the first computational storage unit or the second computational storage unit and send the reply to the storage device without sending the reply to the host processor.
Statement 249. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the first computational storage unit is configured to invoke a capability of the storage device or the second computational storage unit.
Statement 250. An embodiment of the disclosure includes the multi-function device according to statement 249, wherein the multi-function device is configured to receive a request from the first computational storage unit and send the request to the storage device or the second computational storage unit.
Statement 251. An embodiment of the disclosure includes the multi-function device according to statement 250, wherein the multi-function device is configured to receive the request from the first computational storage unit and send the request to the storage device or the second computational storage unit without sending the request to the host processor.
Statement 252. An embodiment of the disclosure includes the multi-function device according to statement 249, wherein the first computational storage unit is configured to invoke the capability of the storage device or the second computational storage unit without management by the host processor.
Statement 253. An embodiment of the disclosure includes the multi-function device according to statement 249, wherein the multi-function device is configured to receive a reply from the storage device or the second computational storage unit and send the reply to the first computational storage unit.
Statement 254. An embodiment of the disclosure includes the multi-function device according to statement 253, wherein the multi-function device is configured to receive the reply from the storage device or the second computational storage unit and send the reply to the first computational storage unit without sending the reply to the host processor.
Statement 255. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the second computational storage unit is configured to invoke a capability of the storage device or the first computational storage unit.
Statement 256. An embodiment of the disclosure includes the multi-function device according to statement 255, wherein the multi-function device is configured to receive a request from the second computational storage unit and send the request to the storage device or the first computational storage unit.
Statement 257. An embodiment of the disclosure includes the multi-function device according to statement 256, wherein the multi-function device is configured to receive the request from the second computational storage unit and send the request to the storage device or the first computational storage unit without sending the request to the host processor.
Statement 258. An embodiment of the disclosure includes the multi-function device according to statement 255, wherein the second computational storage unit is configured to invoke the capability of the storage device or the first computational storage unit without management by the host processor.
Statement 259. An embodiment of the disclosure includes the multi-function device according to statement 255, wherein the multi-function device is configured to receive a reply from the storage device or the first computational storage unit and send the reply to the second computational storage unit.
Statement 260. An embodiment of the disclosure includes the multi-function device according to statement 259, wherein the multi-function device is configured to receive the reply from the storage device or the first computational storage unit and send the reply to the second computational storage unit without sending the reply to the host processor.
Statement 261. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the storage device includes a Solid State Drive (SSD).
Statement 262. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the first computational storage unit includes an accelerator circuit, a Fully Homomorphic Encryption (FHE) circuit, or a network interface device.
Statement 263. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the second computational storage unit includes an accelerator circuit, a Fully Homomorphic Encryption (FHE) circuit, or a network interface device.
Statement 264. An embodiment of the disclosure includes the multi-function device according to statement 239, further comprising a buffer connected to the storage device, the first computational storage unit, and the second computational storage unit.
Statement 265. An embodiment of the disclosure includes the multi-function device according to statement 264, wherein the storage device, the first computational storage unit, and the second computational storage unit are configured to access a data in the buffer.
Statement 266. An embodiment of the disclosure includes the multi-function device according to statement 264, wherein the buffer includes an address range.
Statement 267. An embodiment of the disclosure includes the multi-function device according to statement 266, wherein the host processor determines the address range of the buffer.
Statement 268. An embodiment of the disclosure includes the multi-function device according to statement 264, wherein the storage device is configured to access the buffer using a protocol.
Statement 269. An embodiment of the disclosure includes the multi-function device according to statement 268, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 270. An embodiment of the disclosure includes the multi-function device according to statement 264, wherein the first computational storage unit is configured to access the buffer using a protocol.
Statement 271. An embodiment of the disclosure includes the multi-function device according to statement 270, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 272. An embodiment of the disclosure includes the multi-function device according to statement 264, wherein the second computational storage unit is configured to access the buffer using a protocol.
Statement 273. An embodiment of the disclosure includes the multi-function device according to statement 272, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 274. An embodiment of the disclosure includes the multi-function device according to statement 264, further comprising a data processor connected to the buffer, the data processor configured to process a data in the buffer.
Statement 275. An embodiment of the disclosure includes the multi-function device according to statement 274, wherein the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 276. An embodiment of the disclosure includes the multi-function device according to statement 275, wherein:
the data processor is configured to expose a function;
the request is from the host processor; and
the request triggers the function of the data processor.
Statement 277. An embodiment of the disclosure includes the multi-function device according to statement 276, wherein the function includes a Peripheral Component Interconnect Express (PCIe) function.
Statement 278. An embodiment of the disclosure includes the multi-function device according to statement 277, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 279. An embodiment of the disclosure includes the multi-function device according to statement 276, wherein:
the multi-function device is configured to expose a second function to the host processor via the third connector;
the multi-function device is configured to receive the request from the host processor via the third connector; and
the multi-function device triggers the function of the data processor.
Statement 280. An embodiment of the disclosure includes the multi-function device according to statement 279, wherein:
the request includes the second function; and
the multi-function device is configured to map the second function to the function of the data processor.
Statement 281. An embodiment of the disclosure includes the multi-function device according to statement 239, further comprising:
a first bridge connecting the third connector and the first connector; and
a second bridge connecting the third connector and the second connector.
Statement 282. An embodiment of the disclosure includes the multi-function device according to statement 281, wherein:
the first bridge supports pass-through of a first request between the host processor and the storage device; and
the second bridge supports pass-through of a second request between the host processor and the second computational storage unit.
Statement 283. An embodiment of the disclosure includes the multi-function device according to statement 281, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the first computational storage unit is configured to expose a second function;
the second computational storage unit is configured to expose a third function to the multi-function device via the second connector;
the multi-function device is configured to expose a fourth function to the host processor via the third connector;
the first bridge is configured to map a first request using the fourth function to a second request using the first function;
the second bridge is configured to map a third request using a fifth function to a fourth request using the third function.
Statement 284. An embodiment of the disclosure includes the multi-function device according to statement 283, wherein the multi-function device is configured to expose the fifth function to the host processor via the third connector.
Statement 285. An embodiment of the disclosure includes the multi-function device according to statement 284, wherein the multi-function device does not expose the second function to the host processor via the third connector.
Statement 286. An embodiment of the disclosure includes the multi-function device according to statement 283, wherein the multi-function device is configured to expose the second function to the host processor via the third connector.
Statement 287. An embodiment of the disclosure includes the multi-function device according to statement 286, wherein the multi-function device does not expose the fifth function to the host via the third connector.
Statement 288. An embodiment of the disclosure includes the multi-function device according to statement 283, wherein:
the multi-function device is configured to direct the first request to the first bridge;
the multi-function device is configured to direct the third request to the second bridge; and
the multi-function device is configured to direct a fifth request to the first computational storage unit.
Statement 289. An embodiment of the disclosure includes the multi-function device according to statement 288, wherein the multi-function device is configured to receive the first request from the host processor, the first computational storage unit, or the second computational storage unit.
Statement 290. An embodiment of the disclosure includes the multi-function device according to statement 288, wherein the multi-function device is configured to receive the third request from the host processor, the storage device, or the first computational storage unit.
Statement 291. An embodiment of the disclosure includes the multi-function device according to statement 288, wherein the multi-function device is configured to receive the third request from the storage device or the first computational storage unit.
Statement 292. An embodiment of the disclosure includes the multi-function device according to statement 288, wherein the multi-function device is configured to receive the fifth request from the host processor, the storage device, or the second computational storage unit.
Statement 293. An embodiment of the disclosure includes the multi-function device according to statement 288, wherein the multi-function device is configured to receive the fifth request from the storage device or the second computational storage unit.
Statement 294. An embodiment of the disclosure includes the multi-function device according to statement 283, wherein:
the multi-function device is configured to expose the fourth function to the second computational storage unit via the second connector and to the first computational storage unit;
the multi-function device is configured to expose the second function to the storage device via the first connector and to the second computational storage unit via the second connector; and
the multi-function device is configured to expose the fifth function to the storage device via the first connector and to the first computational storage unit.
Statement 295. An embodiment of the disclosure includes the multi-function device according to statement 281, further comprising a buffer connected to the first bridge, the second bridge, and the first computational storage unit.
Statement 296. An embodiment of the disclosure includes the multi-function device according to statement 295, wherein the first bridge is configured to receive a request sent from the storage device and direct the request to the buffer.
Statement 297. An embodiment of the disclosure includes the multi-function device according to statement 296, wherein the request is sent from the storage device to the host processor.
Statement 298. An embodiment of the disclosure includes the multi-function device according to statement 296, wherein the storage device is agnostic to the first bridge redirecting the request to the buffer.
Statement 299. An embodiment of the disclosure includes the multi-function device according to statement 296, wherein the first bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 300. An embodiment of the disclosure includes the multi-function device according to statement 299, wherein the buffer includes an address range including the address.
Statement 301. An embodiment of the disclosure includes the multi-function device according to statement 295, wherein the second bridge is configured to receive a request sent from the second computational storage unit and direct the request to the buffer.
Statement 302. An embodiment of the disclosure includes the multi-function device according to statement 301, wherein the request is sent from the second computational storage unit to the host processor.
Statement 303. An embodiment of the disclosure includes the multi-function device according to statement 301, wherein the second computational storage unit is agnostic to the second bridge redirecting the request to the buffer.
Statement 304. An embodiment of the disclosure includes the multi-function device according to statement 301, wherein the second bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 305. An embodiment of the disclosure includes the multi-function device according to statement 304, wherein the buffer includes an address range including the address.
Statement 306. An embodiment of the disclosure includes the multi-function device according to statement 295, wherein the multi-function device is configured to receive a request sent from the first computational storage unit and direct the request to the buffer.
Statement 307. An embodiment of the disclosure includes the multi-function device according to statement 306, wherein the first computational storage unit is agnostic to the multi-function device redirecting the request to the buffer.
Statement 308. An embodiment of the disclosure includes the multi-function device according to statement 306, wherein the multi-function device is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 309. An embodiment of the disclosure includes the multi-function device according to statement 308, wherein the buffer includes an address range including the address.
Statement 310. An embodiment of the disclosure includes the multi-function device according to statement 239, further comprising a storage for a list of device configurations.
Statement 311. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the storage includes a persistent storage.
Statement 312. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured to expose the storage device and the first computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 313. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured not to expose the second computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 314. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured to expose the storage device and the second computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 315. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured not to expose the first computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 316. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured to detect a device connected to the second connector, determine a configuration of the device, and update the list of device configurations based at least in part on the configuration of the device.
Statement 317. An embodiment of the disclosure includes the multi-function device according to statement 316, wherein the device includes a second storage device, a third computational storage unit, a FHE circuit, or a network interface device.
Statement 318. An embodiment of the disclosure includes the multi-function device according to statement 310, wherein the multi-function device is configured to determine the configuration of the device and update the list of device configurations based at least in part on the list of configurations omitting a configuration of the device.
Statement 319. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the storage device is replaceable.
Statement 320. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the second computational storage unit is replaceable.
Statement 321. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein:
the first connector includes a first PCIe port;
the second connector includes a second PCIe port;
the third connector includes a third PCIe port.
Statement 322. An embodiment of the disclosure includes the multi-function device according to statement 321, wherein:
the first PCIe port includes a first root port;
the second PCIe port includes a second root port; and
the third PCIe port includes an endpoint.
Statement 323. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein:
the storage device is configured to expose a first PCIe function to the multi-function device via the first connector;
the first computational storage unit is configured to expose a second PCIe function to the multi-function device;
the second computational storage unit is configured to expose a third PCIe function to the multi-function device via the second connector; and
the multi-function device is configured to expose a fourth PCIe function to the host processor via the third connector.
Statement 324. An embodiment of the disclosure includes the multi-function device according to statement 323, wherein:
the first PCIe function includes a first PF or a first VF;
the second PCIe function includes a second PF or a second VF;
the third PCIe function includes a third PF or a third VF;
the fourth PCIe function includes a fourth PF or a fourth VF.
Statement 325. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the first connector supports at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 326. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the second connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 327. An embodiment of the disclosure includes the multi-function device according to statement 239, wherein the third connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 328. An embodiment of the disclosure includes a method, comprising:
determining that a storage device is connected to a multi-function device;
determining that a first computational storage unit is available;
determining that a second computational storage unit is connected to the multi-function device;
exposing the storage device to a host processor connected to the multi-function device; and
selectively exposing the first computational storage unit and the second computational storage unit to the host processor.
Statement 329. An embodiment of the disclosure includes the method according to statement 328, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 330. An embodiment of the disclosure includes the method according to statement 328, wherein the first computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 331. An embodiment of the disclosure includes the method according to statement 328, wherein the second computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 332. An embodiment of the disclosure includes the method according to statement 328, wherein the storage device includes a Solid State Drive (SSD).
Statement 333. An embodiment of the disclosure includes the method according to statement 328, wherein the first computational storage unit includes an accelerator circuit, a Fully Homomorphic Encryption (FHE) circuit, or a network interface device.
Statement 334. An embodiment of the disclosure includes the method according to statement 328, wherein the second computational storage unit includes an accelerator circuit, an FHE circuit, or a network interface device.
Statement 335. An embodiment of the disclosure includes the method according to statement 328, wherein determining that the first computational storage unit is available includes determining that the first computational storage unit is connected to the multi-function device.
Statement 336. An embodiment of the disclosure includes the method according to statement 335, wherein determining that the first computational storage unit is connected to the multi-function device includes determining that the first computational storage unit is connected to the multi-function device via a connector.
Statement 337. An embodiment of the disclosure includes the method according to statement 328, wherein determining that the first computational storage unit is available includes determining that the first computational storage unit is integrated into the multi-function device.
Statement 338. An embodiment of the disclosure includes the method according to statement 328, wherein
determining that the storage device is connected to the multi-function device includes determining that the storage device is connected to the multi-function device via a first connector; and
determining that the second computational storage unit is connected to the multi-function device includes determining that the second computational storage unit is connected to the multi-function device via a second connector.
Statement 339. An embodiment of the disclosure includes the method according to statement 328, wherein selectively exposing the first computational storage unit and the second computational storage unit to a host processor connected to the multi-function device includes:
exposing the first computational storage unit to the host processor; and
not exposing the second computational storage unit to the host processor.
Statement 340. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request at the multi-function device from the storage device to invoke a capability of the first computational storage unit or the second computational storage unit; and
sending the request to the first computational storage unit or the second computational storage unit.
Statement 341. An embodiment of the disclosure includes the method according to statement 340, wherein sending the request to the first computational storage unit or the second computational storage unit includes sending the request to the first computational storage unit or the second computational storage unit without sending the request to the host processor.
Statement 342. An embodiment of the disclosure includes the method according to statement 340, wherein sending the request to the first computational storage unit or the second computational storage unit includes sending the request to the first computational storage unit or the second computational storage unit without management by the host processor.
Statement 343. An embodiment of the disclosure includes the method according to statement 340, further comprising:
receiving a reply at the multi-function device from the first computational storage unit or the second computational storage unit; and
sending the reply to the storage device.
Statement 344. An embodiment of the disclosure includes the method according to statement 343, wherein sending the reply to the storage device includes sending the reply to the storage device without sending the reply to the host processor.
Statement 345. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request at the multi-function device from the first computational storage unit to invoke a capability of the storage device or the second computational storage unit; and
sending the request to the storage device or the second computational storage unit.
Statement 346. An embodiment of the disclosure includes the method according to statement 345, wherein sending the request to the storage device or the second computational storage unit includes sending the request to the storage device or the second computational storage unit without sending the request to the host processor.
Statement 347. An embodiment of the disclosure includes the method according to statement 345, wherein sending the request to the storage device or the second computational storage unit includes sending the request to the storage device or the second computational storage unit without management by the host processor.
Statement 348. An embodiment of the disclosure includes the method according to statement 345, further comprising:
receiving a reply at the multi-function device from the storage device or the second computational storage unit; and
sending the reply to the first computational storage unit.
Statement 349. An embodiment of the disclosure includes the method according to statement 348, wherein sending the reply to the first computational storage unit includes sending the reply to the first computational storage unit without sending the reply to the host processor.
Statement 350. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request at the multi-function device from the second computational storage unit to invoke a capability of the storage device or the first computational storage unit; and
sending the request to the storage device or the first computational storage unit.
Statement 351. An embodiment of the disclosure includes the method according to statement 350, wherein sending the request to the storage device or the first computational storage unit includes sending the request to the storage device or the first computational storage unit without sending the request to the host processor.
Statement 352. An embodiment of the disclosure includes the method according to statement 350, wherein sending the request to the storage device or the first computational storage unit includes sending the request to the storage device or the first computational storage unit without management by the host processor.
Statement 353. An embodiment of the disclosure includes the method according to statement 350, further comprising:
receiving a reply at the multi-function device from the storage device or the first computational storage unit; and
sending the reply to the second computational storage unit.
Statement 354. An embodiment of the disclosure includes the method according to statement 353, wherein sending the reply to the second computational storage unit includes sending the reply to the second computational storage unit without sending the reply to the host processor.
Statement 355. An embodiment of the disclosure includes the method according to statement 328, further comprising:
accessing a data in a buffer in the multi-function device by the storage device; and
accessing the data in the buffer in the multi-function device by the first computational storage unit.
Statement 356. An embodiment of the disclosure includes the method according to statement 355, further comprising:
accessing the data in the buffer in the multi-function device by the second computational storage unit.
Statement 357. An embodiment of the disclosure includes the method according to statement 355, wherein:
the buffer includes an address range; and
the method further comprises determining the address range of the buffer from the host processor.
Statement 358. An embodiment of the disclosure includes the method according to statement 355, wherein:
accessing the data in the buffer in the multi-function device by the storage device includes accessing the data in the buffer in the multi-function device by the storage device using a first protocol; and
accessing the data in the buffer in the multi-function device by the first computational storage unit includes accessing the data in the buffer in the multi-function device by the first computational storage unit using a second protocol.
Statement 359. An embodiment of the disclosure includes the method according to statement 358, wherein:
the first protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol; and
the second protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 360. An embodiment of the disclosure includes the method according to statement 358, further comprising accessing the data in the buffer in the multi-function device by the second computational storage unit using a third protocol.
Statement 361. An embodiment of the disclosure includes the method according to statement 360, wherein the third protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 362. An embodiment of the disclosure includes the method according to statement 355, further comprising processing the data in the buffer using a data processor of the multi-function device.
Statement 363. An embodiment of the disclosure includes the method according to statement 362, wherein processing the data in the buffer using the data processor of the multi-function device includes processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 364. An embodiment of the disclosure includes the method according to statement 363, wherein:
the method further comprises:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit includes receiving the request from at least one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit, the request triggering the function.
Statement 365. An embodiment of the disclosure includes the method according to statement 364, wherein determining that the function is exposed by the data processor includes determining that a Peripheral Component Interconnect Express (PCIe) function is exposed by the data processor.
Statement 366. An embodiment of the disclosure includes the method according to statement 365, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 367. An embodiment of the disclosure includes the method according to statement 363, wherein:
the method further comprises:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit includes:
Statement 368. An embodiment of the disclosure includes the method according to statement 367, wherein triggering the function of the data processor includes mapping the second function to the function of the data processor.
Statement 369. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device; and
passing the request through the bridge to the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 370. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device, the request triggering a function exposed by the storage device, the first computational storage unit, or the second computational storage unit; and
sending the request from the bridge to the storage device, the first computational storage unit, or the second computational storage unit based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 371. An embodiment of the disclosure includes the method according to statement 370, wherein receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 372. An embodiment of the disclosure includes the method according to statement 370, wherein:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device, the request triggering a second function exposed by the multi-function device;
the method further comprises mapping the second function to the function exposed by the storage device, the first computational storage unit, or the second computational storage unit; and
sending the request from the bridge to the storage device, the first computational storage unit, or the second computational storage unit based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 373. An embodiment of the disclosure includes the method according to statement 372, wherein receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the second function exposed by the multi-function device.
Statement 374. An embodiment of the disclosure includes the method according to statement 370, wherein the multi-function device does not expose the function to the host processor.
Statement 375. An embodiment of the disclosure includes the method according to statement 328, further comprising:
receiving a request from the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device; and
sending the request from the bridge to a buffer of the multi-function device.
Statement 376. An embodiment of the disclosure includes the method according to statement 375, wherein the request is sent from the storage device, the first computational storage unit, or the second computational storage unit to the host processor.
Statement 377. An embodiment of the disclosure includes the method according to statement 375, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device without notifying the storage device, the first computational storage unit, or the second computational storage unit.
Statement 378. An embodiment of the disclosure includes the method according to statement 375, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device based at least in part on an address, the request including the address.
Statement 379. An embodiment of the disclosure includes the method according to statement 378, wherein the buffer includes an address range including the address.
Statement 380. An embodiment of the disclosure includes the method according to statement 379, further comprising receiving the address range for the buffer from the host processor.
Statement 381. An embodiment of the disclosure includes the method according to statement 328, wherein:
exposing the storage device to the host processor connected to the multi-function device includes exposing the storage device to the host processor connected to the multi-function device based at least in part on a list of device configurations; and
selectively exposing the first computational storage unit and the second computational storage unit to the host processor includes selectively exposing the first computational storage unit and the second computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 382. An embodiment of the disclosure includes the method according to statement 381, wherein further comprising accessing the list of device configurations from a storage of the multi-function device.
Statement 383. An embodiment of the disclosure includes the method according to statement 382, wherein accessing the list of device configurations from the storage of the multi-function device includes accessing the list of device configurations from a persistent storage of the multi-function device.
Statement 384. An embodiment of the disclosure includes the method according to statement 381, further comprising:
determining that a device is connected to the multi-function device;
determining a configuration of the device; and
updating the list of device configurations based at least in part on the configuration of the device.
Statement 385. An embodiment of the disclosure includes the method according to statement 384, wherein the device includes a second storage device, a third computational storage unit, a FHE circuit, or a network interface device.
Statement 386. An embodiment of the disclosure includes the method according to statement 384, wherein updating the list of device configurations based at least in part on the configuration of the device includes determining that the list of device configurations omits the configuration of the device.
Statement 387. An embodiment of the disclosure includes the method according to statement 328, further comprising replacing the storage device with a device.
Statement 388. An embodiment of the disclosure includes the method according to statement 328, further comprising replacing the first computational storage unit with a device.
Statement 389. An embodiment of the disclosure includes the method according to statement 328, further comprising replacing the second computational storage unit with a device.
Statement 390. An embodiment of the disclosure includes the method according to statement 328, wherein the multi-function device communicates with the storage device using at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 391. An embodiment of the disclosure includes the method according to statement 328, wherein the multi-function device communicates with the first computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 392. An embodiment of the disclosure includes the method according to statement 328, wherein the multi-function device communicates with the second computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 393. An embodiment of the disclosure includes the method according to statement 328, wherein the multi-function device communicates with the host processor using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 394. An embodiment of the disclosure includes an article, comprising a non-transitory storage medium, the non-transitory storage medium having stored thereon instructions that, when executed by a machine, result in:
determining that a storage device is connected to a multi-function device;
determining that a first computational storage unit is available;
determining that a second computational storage unit is connected to the multi-function device;
exposing the storage device to a host processor connected to the multi-function device; and
selectively exposing the first computational storage unit and the second computational storage unit to the host processor.
Statement 395. An embodiment of the disclosure includes the article according to statement 394, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 396. An embodiment of the disclosure includes the article according to statement 394, wherein the first computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 397. An embodiment of the disclosure includes the article according to statement 394, wherein the second computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 398. An embodiment of the disclosure includes the article according to statement 394, wherein the storage device includes a Solid State Drive (SSD).
Statement 399. An embodiment of the disclosure includes the article according to statement 394, wherein the first computational storage unit includes an accelerator circuit, a Fully Homomorphic Encryption (FHE) circuit, or a network interface device.
Statement 400. An embodiment of the disclosure includes the article according to statement 394, wherein the second computational storage unit includes an accelerator circuit, an FHE circuit, or a network interface device.
Statement 401. An embodiment of the disclosure includes the article according to statement 394, wherein determining that the first computational storage unit is available includes determining that the first computational storage unit is connected to the multi-function device.
Statement 402. An embodiment of the disclosure includes the article according to statement 401, wherein determining that the first computational storage unit is connected to the multi-function device includes determining that the first computational storage unit is connected to the multi-function device via a connector.
Statement 403. An embodiment of the disclosure includes the article according to statement 394, wherein determining that the first computational storage unit is available includes determining that the first computational storage unit is integrated into the multi-function device.
Statement 404. An embodiment of the disclosure includes the article according to statement 394, wherein
determining that the storage device is connected to the multi-function device includes determining that the storage device is connected to the multi-function device via a first connector; and
determining that the second computational storage unit is connected to the multi-function device includes determining that the second computational storage unit is connected to the multi-function device via a second connector.
Statement 405. An embodiment of the disclosure includes the article according to statement 394, wherein selectively exposing the first computational storage unit and the second computational storage unit to a host processor connected to the multi-function device includes:
exposing the first computational storage unit to the host processor; and
not exposing the second computational storage unit to the host processor.
Statement 406. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the storage device to invoke a capability of the first computational storage unit or the second computational storage unit; and
sending the request to the first computational storage unit or the second computational storage unit.
Statement 407. An embodiment of the disclosure includes the article according to statement 406, wherein sending the request to the first computational storage unit or the second computational storage unit includes sending the request to the first computational storage unit or the second computational storage unit without sending the request to the host processor.
Statement 408. An embodiment of the disclosure includes the article according to statement 406, wherein sending the request to the first computational storage unit or the second computational storage unit includes sending the request to the first computational storage unit or the second computational storage unit without management by the host processor.
Statement 409. An embodiment of the disclosure includes the article according to statement 406, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the first computational storage unit or the second computational storage unit; and
sending the reply to the storage device.
Statement 410. An embodiment of the disclosure includes the article according to statement 409, wherein sending the reply to the storage device includes sending the reply to the storage device without sending the reply to the host processor.
Statement 411. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the first computational storage unit to invoke a capability of the storage device or the second computational storage unit; and
sending the request to the storage device or the second computational storage unit.
Statement 412. An embodiment of the disclosure includes the article according to statement 411, wherein sending the request to the storage device or the second computational storage unit includes sending the request to the storage device or the second computational storage unit without sending the request to the host processor.
Statement 413. An embodiment of the disclosure includes the article according to statement 411, wherein sending the request to the storage device or the second computational storage unit includes sending the request to the storage device or the second computational storage unit without management by the host processor.
Statement 414. An embodiment of the disclosure includes the article according to statement 411, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the storage device or the second computational storage unit; and
sending the reply to the first computational storage unit.
Statement 415. An embodiment of the disclosure includes the article according to statement 414, wherein sending the reply to the first computational storage unit includes sending the reply to the first computational storage unit without sending the reply to the host processor.
Statement 416. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the second computational storage unit to invoke a capability of the storage device or the first computational storage unit; and
sending the request to the storage device or the first computational storage unit.
Statement 417. An embodiment of the disclosure includes the article according to statement 416, wherein sending the request to the storage device or the first computational storage unit includes sending the request to the storage device or the first computational storage unit without sending the request to the host processor.
Statement 418. An embodiment of the disclosure includes the article according to statement 416, wherein sending the request to the storage device or the first computational storage unit includes sending the request to the storage device or the first computational storage unit without management by the host processor.
Statement 419. An embodiment of the disclosure includes the article according to statement 416, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the storage device or the first computational storage unit; and
sending the reply to the second computational storage unit.
Statement 420. An embodiment of the disclosure includes the article according to statement 419, wherein sending the reply to the second computational storage unit includes sending the reply to the second computational storage unit without sending the reply to the host processor.
Statement 421. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
accessing a data in a buffer in the multi-function device by the storage device; and
accessing the data in the buffer in the multi-function device by the first computational storage unit.
Statement 422. An embodiment of the disclosure includes the article according to statement 421, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
accessing the data in the buffer in the multi-function device by the second computational storage unit.
Statement 423. An embodiment of the disclosure includes the article according to statement 421, wherein:
the buffer includes an address range; and
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in determining the address range of the buffer from the host processor.
Statement 424. An embodiment of the disclosure includes the article according to statement 421, wherein:
accessing the data in the buffer in the multi-function device by the storage device includes accessing the data in the buffer in the multi-function device by the storage device using a first protocol; and
accessing the data in the buffer in the multi-function device by the first computational storage unit includes accessing the data in the buffer in the multi-function device by the first computational storage unit using a second protocol.
Statement 425. An embodiment of the disclosure includes the article according to statement 424, wherein:
the first protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol; and
the second protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 426. An embodiment of the disclosure includes the article according to statement 424, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in accessing the data in the buffer in the multi-function device by the second computational storage unit using a third protocol.
Statement 427. An embodiment of the disclosure includes the article according to statement 426, wherein the third protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 428. An embodiment of the disclosure includes the article according to statement 421, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in processing the data in the buffer using a data processor of the multi-function device.
Statement 429. An embodiment of the disclosure includes the article according to statement 428, wherein processing the data in the buffer using the data processor of the multi-function device includes processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 430. An embodiment of the disclosure includes the article according to statement 429, wherein:
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit includes receiving the request from at least one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit, the request triggering the function.
Statement 431. An embodiment of the disclosure includes the article according to statement 430, wherein determining that the function is exposed by the data processor includes determining that a Peripheral Component Interconnect Express (PCIe) function is exposed by the data processor.
Statement 432. An embodiment of the disclosure includes the article according to statement 431, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 433. An embodiment of the disclosure includes the article according to statement 429, wherein:
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the first computational storage unit, or the second computational storage unit includes:
Statement 434. An embodiment of the disclosure includes the article according to statement 433, wherein triggering the function of the data processor includes mapping the second function to the function of the data processor.
Statement 435. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device; and
passing the request through the bridge to the host processor, the storage device, the first computational storage unit, or the second computational storage unit.
Statement 436. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device, the request triggering a function exposed by the storage device, the first computational storage unit, or the second computational storage unit; and
sending the request from the bridge to the storage device, the first computational storage unit, or the second computational storage unit based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 437. An embodiment of the disclosure includes the article according to statement 436, wherein receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 438. An embodiment of the disclosure includes the article according to statement 436, wherein:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device, the request triggering a second function exposed by the multi-function device;
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in mapping the second function to the function exposed by the storage device, the first computational storage unit, or the second computational storage unit; and
sending the request from the bridge to the storage device, the first computational storage unit, or the second computational storage unit based at least in part on the function exposed by the storage device, the first computational storage unit, or the second computational storage unit.
Statement 439. An embodiment of the disclosure includes the article according to statement 438, wherein receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the first computational storage unit, or the second computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the second function exposed by the multi-function device.
Statement 440. An embodiment of the disclosure includes the article according to statement 436, wherein the multi-function device does not expose the function to the host processor.
Statement 441. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the storage device, the first computational storage unit, or the second computational storage unit at a bridge of the multi-function device; and
sending the request from the bridge to a buffer of the multi-function device.
Statement 442. An embodiment of the disclosure includes the article according to statement 441, wherein the request is sent from the storage device, the first computational storage unit, or the second computational storage unit to the host processor.
Statement 443. An embodiment of the disclosure includes the article according to statement 441, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device without notifying the storage device, the first computational storage unit, or the second computational storage unit.
Statement 444. An embodiment of the disclosure includes the article according to statement 441, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device based at least in part on an address, the request including the address.
Statement 445. An embodiment of the disclosure includes the article according to statement 444, wherein the buffer includes an address range including the address.
Statement 446. An embodiment of the disclosure includes the article according to statement 445, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in receiving the address range for the buffer from the host processor.
Statement 447. An embodiment of the disclosure includes the article according to statement 394, wherein:
exposing the storage device to the host processor connected to the multi-function device includes exposing the storage device to the host processor connected to the multi-function device based at least in part on a list of device configurations; and
selectively exposing the first computational storage unit and the second computational storage unit to the host processor includes selectively exposing the first computational storage unit and the second computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 448. An embodiment of the disclosure includes the article according to statement 447, wherein the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in accessing the list of device configurations from a storage of the multi-function device.
Statement 449. An embodiment of the disclosure includes the article according to statement 448, wherein accessing the list of device configurations from the storage of the multi-function device includes accessing the list of device configurations from a persistent storage of the multi-function device.
Statement 450. An embodiment of the disclosure includes the article according to statement 447, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
determining that a device is connected to the multi-function device;
determining a configuration of the device; and
updating the list of device configurations based at least in part on the configuration of the device.
Statement 451. An embodiment of the disclosure includes the article according to statement 450, wherein the device includes a second storage device, a third computational storage unit, a FHE circuit, or a network interface device.
Statement 452. An embodiment of the disclosure includes the article according to statement 450, wherein updating the list of device configurations based at least in part on the configuration of the device includes determining that the list of device configurations omits the configuration of the device.
Statement 453. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the storage device with a device.
Statement 454. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the first computational storage unit with a device.
Statement 455. An embodiment of the disclosure includes the article according to statement 394, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the second computational storage unit with a device.
Statement 456. An embodiment of the disclosure includes the article according to statement 394, wherein the multi-function device communicates with the storage device using at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 457. An embodiment of the disclosure includes the article according to statement 394, wherein the multi-function device communicates with the first computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 458. An embodiment of the disclosure includes the article according to statement 394, wherein the multi-function device communicates with the second computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 459. An embodiment of the disclosure includes the article according to statement 394, wherein the multi-function device communicates with the host processor using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 460. An embodiment of the disclosure includes a multi-function device, comprising:
a first connector for communicating with a storage device;
a second connector for communicating with a Fully Homomorphic Encryption (FHE) circuit; and
a third connector for communicating with a host processor;
wherein the multi-function device is configured to expose the storage device to the host processor via the third connector.
Statement 461. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 462. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the FHE circuit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 463. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the multi-function device is configured to expose the storage device and the FHE circuit to the host processor via the third connector.
Statement 464. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the multi-function device does not expose the FHE circuit to the host processor via the third connector.
Statement 465. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the FHE circuit is configured to invoke a capability of the storage device.
Statement 466. An embodiment of the disclosure includes the multi-function device according to statement 465, wherein the multi-function device is configured to receive a request from the FHE circuit and send the request to the storage device.
Statement 467. An embodiment of the disclosure includes the multi-function device according to statement 466, wherein the multi-function device is configured to receive the request from the FHE circuit and send the request to the storage device without sending the request to the host processor.
Statement 468. An embodiment of the disclosure includes the multi-function device according to statement 465, wherein the FHE circuit is configured to invoke the capability of the storage device without management by the host processor.
Statement 469. An embodiment of the disclosure includes the multi-function device according to statement 465, wherein the multi-function device is configured to receive a reply from the storage device and send the reply to the FHE circuit.
Statement 470. An embodiment of the disclosure includes the multi-function device according to statement 469, wherein the multi-function device is configured to receive the reply from the storage device and send the reply to the FHE circuit without sending the reply to the host processor.
Statement 471. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the storage device is configured to invoke a capability of the FHE circuit.
Statement 472. An embodiment of the disclosure includes the multi-function device according to statement 471, wherein the multi-function device is configured to receive a request from the storage device and send the request to the FHE circuit.
Statement 473. An embodiment of the disclosure includes the multi-function device according to statement 472, wherein the multi-function device is configured to receive the request from the storage device and send the request to the FHE circuit without sending the request to the host processor.
Statement 474. An embodiment of the disclosure includes the multi-function device according to statement 471, wherein the storage device is configured to invoke the capability of the FHE circuit without management by the host processor.
Statement 475. An embodiment of the disclosure includes the multi-function device according to statement 471, wherein the multi-function device is configured to receive a reply from the FHE circuit and send the reply to the storage device.
Statement 476. An embodiment of the disclosure includes the multi-function device according to statement 475, wherein the multi-function device is configured to receive the reply from the FHE circuit and send the reply to the storage device without sending the reply to the host processor.
Statement 477. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the storage device includes a Solid State Drive (SSD).
Statement 478. An embodiment of the disclosure includes the multi-function device according to statement 460, further comprising a buffer connected to the storage device and the FHE circuit.
Statement 479. An embodiment of the disclosure includes the multi-function device according to statement 478, wherein the storage device and the FHE circuit are configured to access a data in the buffer.
Statement 480. An embodiment of the disclosure includes the multi-function device according to statement 478, wherein the buffer includes an address range.
Statement 481. An embodiment of the disclosure includes the multi-function device according to statement 480, wherein the host processor determines the address range of the buffer.
Statement 482. An embodiment of the disclosure includes the multi-function device according to statement 478, wherein the storage device is configured to access the buffer using a protocol.
Statement 483. An embodiment of the disclosure includes the multi-function device according to statement 482, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 484. An embodiment of the disclosure includes the multi-function device according to statement 478, wherein the FHE circuit is configured to access the buffer using a protocol.
Statement 485. An embodiment of the disclosure includes the multi-function device according to statement 484, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 486. An embodiment of the disclosure includes the multi-function device according to statement 478, wherein:
the multi-function device further comprises a fourth connector for communicating with a computational storage unit; and
the buffer is connected to the storage device, the FHE circuit, and the computational storage unit.
Statement 487. An embodiment of the disclosure includes the multi-function device according to statement 486, wherein the storage device, the FHE circuit, and the computational storage unit are configured to access a data in the buffer.
Statement 488. An embodiment of the disclosure includes the multi-function device according to statement 486, wherein the computational storage unit is configured to access the buffer using a protocol.
Statement 489. An embodiment of the disclosure includes the multi-function device according to statement 488, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 490. An embodiment of the disclosure includes the multi-function device according to statement 478, further comprising a data processor, the data processor configured to process a data in the buffer,
wherein the buffer is connected to the storage device, the FHE circuit, and the data processor.
Statement 491. An embodiment of the disclosure includes the multi-function device according to statement 490, wherein the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor the storage device, or the FHE circuit.
Statement 492. An embodiment of the disclosure includes the multi-function device according to statement 491, wherein:
the multi-function device includes a fourth connector for communicating with a computational storage unit; and
the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor, the storage device, the FHE circuit, or a computational storage unit.
Statement 493. An embodiment of the disclosure includes the multi-function device according to statement 491, wherein:
the data processor is configured to expose a function;
the request is from the host processor; and
the request triggers the function of the data processor.
Statement 494. An embodiment of the disclosure includes the multi-function device according to statement 493, wherein the function includes a Peripheral Component Interconnect Express (PCIe) function.
Statement 495. An embodiment of the disclosure includes the multi-function device according to statement 494, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 496. An embodiment of the disclosure includes the multi-function device according to statement 493, wherein:
the multi-function device is configured to expose a second function to the host processor via the third connector;
the multi-function device is configured to receive the request from the host processor via the third connector; and
the multi-function device triggers the function of the data processor.
Statement 497. An embodiment of the disclosure includes the multi-function device according to statement 496, wherein:
the request includes the second function; and
the multi-function device is configured to map the second function to the function of the data processor.
Statement 498. An embodiment of the disclosure includes the multi-function device according to statement 460, further comprising a first bridge connecting the third connector and the first connector.
Statement 499. An embodiment of the disclosure includes the multi-function device according to statement 498, wherein the first bridge supports pass-through of a first request between the host processor and the storage device.
Statement 500. An embodiment of the disclosure includes the multi-function device according to statement 498, further comprising a second bridge connecting the third connector and the second connector.
Statement 501. An embodiment of the disclosure includes the multi-function device according to statement 500, wherein the second bridge supports pass-through of a second request between the host processor and the FHE circuit
Statement 502. An embodiment of the disclosure includes the multi-function device according to statement 498, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second function to the multi-function device via the second connector;
the multi-function device is configured to expose a third function to the host processor via the third connector; and
the first bridge is configured to map a first request using the third function to a second request using the first function; and
the second bridge is configured to map a third request using a fourth function to a fourth request using the second function.
Statement 503. An embodiment of the disclosure includes the multi-function device according to statement 502, wherein the multi-function device is configured to expose the fourth function to the host processor via the third connector.
Statement 504. An embodiment of the disclosure includes the multi-function device according to statement 502, wherein the multi-function device does not expose the fourth function to the host processor via the third connector.
Statement 505. An embodiment of the disclosure includes the multi-function device according to statement 502, wherein:
the multi-function device is configured to direct the first request to the first bridge; and
the multi-function device is configured to direct the third request to the second bridge.
Statement 506. An embodiment of the disclosure includes the multi-function device according to statement 505, wherein:
the multi-function device is configured to receive the first request from the host processor or the FHE circuit; and
the multi-function device is configured to receive the third request from the host processor or the storage device.
Statement 507. An embodiment of the disclosure includes the multi-function device according to statement 506, wherein:
the multi-function device is configured to receive the first request from the host processor, the FHE circuit, or a computational storage unit;
the multi-function device is configured to receive the third request from the host processor, the storage device, or the computational storage unit.
Statement 508. An embodiment of the disclosure includes the multi-function device according to statement 498, further comprising a buffer connected to the first bridge and the second bridge.
Statement 509. An embodiment of the disclosure includes the multi-function device according to statement 508, wherein the first bridge is configured to receive a request sent from the storage device and direct the request to the buffer.
Statement 510. An embodiment of the disclosure includes the multi-function device according to statement 509, wherein the request is sent from the storage device to the host processor.
Statement 511. An embodiment of the disclosure includes the multi-function device according to statement 509, wherein the storage device is agnostic to the first bridge redirecting the request to the buffer.
Statement 512. An embodiment of the disclosure includes the multi-function device according to statement 509, wherein the first bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 513. An embodiment of the disclosure includes the multi-function device according to statement 512, wherein the buffer includes an address range including the address.
Statement 514. An embodiment of the disclosure includes the multi-function device according to statement 508, wherein the second bridge is configured to receive a request sent from the FHE circuit and direct the request to the buffer.
Statement 515. An embodiment of the disclosure includes the multi-function device according to statement 514, wherein the request is sent from the FHE circuit to the host processor.
Statement 516. An embodiment of the disclosure includes the multi-function device according to statement 514, wherein the FHE circuit is agnostic to the second bridge redirecting the request to the buffer.
Statement 517. An embodiment of the disclosure includes the multi-function device according to statement 514, wherein the second bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 518. An embodiment of the disclosure includes the multi-function device according to statement 517, wherein the buffer includes an address range including the address.
Statement 519. An embodiment of the disclosure includes the multi-function device according to statement 460, further comprising a storage for a list of device configurations.
Statement 520. An embodiment of the disclosure includes the multi-function device according to statement 519, wherein the storage includes a persistent storage.
Statement 521. An embodiment of the disclosure includes the multi-function device according to statement 519, wherein the multi-function device is configured to expose the storage device to the host processor based at least in part on the list of device configurations.
Statement 522. An embodiment of the disclosure includes the multi-function device according to statement 521, wherein the multi-function device is configured to expose the storage device and the FHE circuit to the host processor based at least in part on the list of device configurations.
Statement 523. An embodiment of the disclosure includes the multi-function device according to statement 521, wherein the multi-function device is configured not to expose the FHE circuit to the host processor based at least in part on the list of device configurations.
Statement 524. An embodiment of the disclosure includes the multi-function device according to statement 519, wherein the multi-function device is configured to detect a device connected to the second connector, determine a configuration of the device, and update the list of device configurations based at least in part on the configuration of the device.
Statement 525. An embodiment of the disclosure includes the multi-function device according to statement 524, wherein the device includes a second storage device, a second FHE circuit, a computational storage unit, or a network interface device.
Statement 526. An embodiment of the disclosure includes the multi-function device according to statement 519, wherein the multi-function device is configured to determine the configuration of the device and update the list of device configurations based at least in part on the list of configurations omitting a configuration of the device.
Statement 527. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the storage device is replaceable.
Statement 528. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the FHE circuit is replaceable.
Statement 529. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein:
the first connector includes a first PCIe port;
the second connector includes a second PCIe port;
the third connector includes a third PCIe port.
Statement 530. An embodiment of the disclosure includes the multi-function device according to statement 529, wherein:
the first PCIe port includes a first root port;
the second PCIe port includes a second root port;
the third PCIe port includes an endpoint.
Statement 531. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein:
the storage device is configured to expose a first PCIe function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second PCIe function to the multi-function device via the second connector; and
the multi-function device is configured to expose a third PCIe function to the host processor via the third connector.
Statement 532. An embodiment of the disclosure includes the multi-function device according to statement 531, wherein:
the first PCIe function includes a first PF or a first VF;
the second PCIe function includes a second PF or a second VF; and
the third PCIe function includes a third PF or a third VF.
Statement 533. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the first connector supports at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal
Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 534. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the second connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 535. An embodiment of the disclosure includes the multi-function device according to statement 460, wherein the third connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 536. An embodiment of the disclosure includes the multi-function device according to statement 460, further comprising a fourth connector for communicating with a device.
Statement 537. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the device includes a second storage device, a second FHE circuit, a computational storage unit, or a network interface device.
Statement 538. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the device is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 539. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the multi-function device does not expose the device to the host processor.
Statement 540. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the FHE circuit is configured to invoke a capability of the device.
Statement 541. An embodiment of the disclosure includes the multi-function device according to statement 540, wherein the multi-function device is configured to receive a request from the FHE circuit and send the request to the device.
Statement 542. An embodiment of the disclosure includes the multi-function device according to statement 541, wherein the multi-function device is configured to receive the request from the FHE circuit and send the request to the device without sending the request to the host processor.
Statement 543. An embodiment of the disclosure includes the multi-function device according to statement 540, wherein the FHE circuit is configured to invoke the capability of the device without management by the host processor.
Statement 544. An embodiment of the disclosure includes the multi-function device according to statement 540, wherein the multi-function device is configured to receive a reply from the device and send the reply to the FHE circuit.
Statement 545. An embodiment of the disclosure includes the multi-function device according to statement 544, wherein the multi-function device is configured to receive the reply from the device and send the reply to the FHE circuit without sending the reply to the host processor.
Statement 546. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the storage device is configured to invoke a capability of the device.
Statement 547. An embodiment of the disclosure includes the multi-function device according to statement 546, wherein the multi-function device is configured to receive a request from the storage device and send the request to the device.
Statement 548. An embodiment of the disclosure includes the multi-function device according to statement 547, wherein the multi-function device is configured to receive the request from the storage device and send the request to the device without sending the request to the host processor.
Statement 549. An embodiment of the disclosure includes the multi-function device according to statement 546, wherein the storage device is configured to invoke the capability of the device without management by the host processor.
Statement 550. An embodiment of the disclosure includes the multi-function device according to statement 546, wherein the multi-function device is configured to receive a reply from the device and send the reply to the storage device.
Statement 551. An embodiment of the disclosure includes the multi-function device according to statement 550, wherein the multi-function device is configured to receive the reply from the device and send the reply to the storage device without sending the reply to the host processor.
Statement 552. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the device is configured to invoke a capability of the storage device or the FHE circuit.
Statement 553. An embodiment of the disclosure includes the multi-function device according to statement 552, wherein the multi-function device is configured to receive a request from the device and send the request to the storage device or the FHE circuit.
Statement 554. An embodiment of the disclosure includes the multi-function device according to statement 553, wherein the multi-function device is configured to receive the request from the device and send the request to the storage device or the FHE circuit without sending the request to the host processor.
Statement 555. An embodiment of the disclosure includes the multi-function device according to statement 552, wherein the device is configured to invoke the capability of the storage device or the FHE circuit without management by the host processor.
Statement 556. An embodiment of the disclosure includes the multi-function device according to statement 552, wherein the multi-function device is configured to receive a reply from the storage device or the FHE circuit and send the reply to the device.
Statement 557. An embodiment of the disclosure includes the multi-function device according to statement 556, wherein the multi-function device is configured to receive the reply from the storage device or the FHE circuit and send the reply to the device without sending the reply to the host processor.
Statement 558. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the device includes an accelerator circuit, a second FHE circuit, or a network interface device.
Statement 559. An embodiment of the disclosure includes the multi-function device according to statement 536, further comprising:
a first bridge connecting the third connector and the first connector;
a second bridge connecting the third connector and the second connector; and
a third bridge connecting the third connector and the fourth connector.
Statement 560. An embodiment of the disclosure includes the multi-function device according to statement 559, wherein the third bridge supports pass-through of a request between the host processor and the device.
Statement 561. An embodiment of the disclosure includes the multi-function device according to statement 559, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second function to the multi-function device via the second connector;
the device is configured to expose a third function to the multi-function device via the fourth connector;
the multi-function device is configured to expose a fourth function and a fifth function to the host processor via the third connector;
the multi-function device is configured to expose the fourth function to the FHE circuit via the second connector and to the device via the fourth connector;
the multi-function device is configured to expose the fifth function to the storage device via the first connector and to the device via the fourth connector;
the multi-function device is configured to expose a sixth function to the storage device via the first connector and to the FHE circuit via the second connector;
the first bridge is configured to map a first request using the fourth function to a second request using the first function;
the second bridge is configured to map a third request using the fifth function to a fourth request using the second function; and
the third bridge is configured to map a fifth request using the sixth function to a sixth request using the third function.
Statement 562. An embodiment of the disclosure includes the multi-function device according to statement 559, further comprising a buffer connected to the first bridge, the second bridge, and the third bridge.
Statement 563. An embodiment of the disclosure includes the multi-function device according to statement 562, wherein the third bridge is configured to receive a request sent from the device and direct the request to the buffer.
Statement 564. An embodiment of the disclosure includes the multi-function device according to statement 563, wherein the device is agnostic to the third bridge redirecting the request to the buffer.
Statement 565. An embodiment of the disclosure includes the multi-function device according to statement 563, wherein the third bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 566. An embodiment of the disclosure includes the multi-function device according to statement 565, wherein the buffer includes an address range including the address.
Statement 567. An embodiment of the disclosure includes the multi-function device according to statement 536, wherein the multi-function device is configured not to expose the device to the host processor based at least in part on a list of device configurations.
Statement 568. An embodiment of the disclosure includes a multi-function device, comprising:
a first connector for communicating with a storage device;
a Fully Homomorphic Encryption (FHE) circuit integrated with the multi-function device; and
a second connector for communicating with a host processor;
wherein the multi-function device is configured to expose the storage device to the host processor via the second connector.
Statement 569. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 570. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the FHE circuit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 571. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the multi-function device is configured to expose the storage device and the FHE circuit to the host processor via the second connector.
Statement 572. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the multi-function device does not expose the FHE circuit to the host processor via the second connector.
Statement 573. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the FHE circuit is configured to invoke a capability of the storage device.
Statement 574. An embodiment of the disclosure includes the multi-function device according to statement 573, wherein the multi-function device is configured to receive a request from the FHE circuit and send the request to the storage device.
Statement 575. An embodiment of the disclosure includes the multi-function device according to statement 574, wherein the multi-function device is configured to receive the request from the FHE circuit and send the request to the storage device without sending the request to the host processor.
Statement 576. An embodiment of the disclosure includes the multi-function device according to statement 573, wherein the FHE circuit is configured to invoke the capability of the storage device without management by the host processor.
Statement 577. An embodiment of the disclosure includes the multi-function device according to statement 573, wherein the multi-function device is configured to receive a reply from the storage device and send the reply to the FHE circuit.
Statement 578. An embodiment of the disclosure includes the multi-function device according to statement 577, wherein the multi-function device is configured to receive the reply from the storage device and send the reply to the FHE circuit without sending the reply to the host processor.
Statement 579. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the storage device is configured to invoke a capability of the FHE circuit.
Statement 580. An embodiment of the disclosure includes the multi-function device according to statement 579, wherein the multi-function device is configured to receive a request from the storage device and send the request to the FHE circuit.
Statement 581. An embodiment of the disclosure includes the multi-function device according to statement 580, wherein the multi-function device is configured to receive the request from the storage device and send the request to the FHE circuit without sending the request to the host processor.
Statement 582. An embodiment of the disclosure includes the multi-function device according to statement 579, wherein the storage device is configured to invoke the capability of the FHE circuit without management by the host processor.
Statement 583. An embodiment of the disclosure includes the multi-function device according to statement 579, wherein the multi-function device is configured to receive a reply from the FHE circuit and send the reply to the storage device.
Statement 584. An embodiment of the disclosure includes the multi-function device according to statement 583, wherein the multi-function device is configured to receive the reply from the FHE circuit and send the reply to the storage device without sending the reply to the host processor.
Statement 585. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the storage device includes a Solid State Drive (SSD).
Statement 586. An embodiment of the disclosure includes the multi-function device according to statement 568, further comprising a buffer connected to the storage device and the FHE circuit.
Statement 587. An embodiment of the disclosure includes the multi-function device according to statement 586, wherein the storage device and the FHE circuit are configured to access a data in the buffer.
Statement 588. An embodiment of the disclosure includes the multi-function device according to statement 586, wherein the buffer includes an address range.
Statement 589. An embodiment of the disclosure includes the multi-function device according to statement 588, wherein the host processor determines the address range of the buffer.
Statement 590. An embodiment of the disclosure includes the multi-function device according to statement 586, wherein the storage device is configured to access the buffer using a protocol.
Statement 591. An embodiment of the disclosure includes the multi-function device according to statement 590, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 592. An embodiment of the disclosure includes the multi-function device according to statement 586, wherein the FHE circuit is configured to access the buffer using a protocol.
Statement 593. An embodiment of the disclosure includes the multi-function device according to statement 592, wherein the protocol includes at least one of a File Read protocol, a
File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 594. An embodiment of the disclosure includes the multi-function device according to statement 586, wherein:
the multi-function device further comprises a third connector for communicating with a computational storage unit; and
the buffer is connected to the storage device, the FHE circuit, and the computational storage unit.
Statement 595. An embodiment of the disclosure includes the multi-function device according to statement 594, wherein the storage device, the FHE circuit, and the computational storage unit are configured to access a data in the buffer.
Statement 596. An embodiment of the disclosure includes the multi-function device according to statement 594, wherein the computational storage unit is configured to access the buffer using a protocol.
Statement 597. An embodiment of the disclosure includes the multi-function device according to statement 596, wherein the protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol.
Statement 598. An embodiment of the disclosure includes the multi-function device according to statement 586, further comprising a data processor, the data processor configured to process a data in the buffer,
wherein the buffer is connected to the storage device, the FHE circuit, and the data processor.
Statement 599. An embodiment of the disclosure includes the multi-function device according to statement 598, wherein the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor the storage device, or the FHE circuit.
Statement 600. An embodiment of the disclosure includes the multi-function device according to statement 599, wherein:
the multi-function device includes a third connector for communicating with a computational storage unit; and
the data processor is configured to process the data in the buffer based at least in part on a request from at least one of the host processor, the storage device, the FHE circuit, or a computational storage unit.
Statement 601. An embodiment of the disclosure includes the multi-function device according to statement 599, wherein:
the data processor is configured to expose a function;
the request is from the host processor; and
the request triggers the function of the data processor.
Statement 602. An embodiment of the disclosure includes the multi-function device according to statement 601, wherein the function includes a Peripheral Component Interconnect Express (PCIe) function.
Statement 603. An embodiment of the disclosure includes the multi-function device according to statement 602, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 604. An embodiment of the disclosure includes the multi-function device according to statement 601, wherein:
the multi-function device is configured to expose a second function to the host processor via the second connector;
the multi-function device is configured to receive the request from the host processor via the second connector; and
the multi-function device triggers the function of the data processor.
Statement 605. An embodiment of the disclosure includes the multi-function device according to statement 604, wherein:
the request includes the second function; and
the multi-function device is configured to map the second function to the function of the data processor.
Statement 606. An embodiment of the disclosure includes the multi-function device according to statement 568, further comprising a bridge connecting the second connector and the first connector.
Statement 607. An embodiment of the disclosure includes the multi-function device according to statement 606, wherein the bridge supports pass-through of a first request between the host processor and the storage device.
Statement 608. An embodiment of the disclosure includes the multi-function device according to statement 606, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second function;
the multi-function device is configured to expose a third function to the host processor via the second connector; and
the bridge is configured to map a request using the third function to a second request using the first function.
Statement 609. An embodiment of the disclosure includes the multi-function device according to statement 608, wherein the multi-function device is configured to expose the second function to the host processor via the second connector.
Statement 610. An embodiment of the disclosure includes the multi-function device according to statement 608, wherein the multi-function device does not expose the second function to the host processor via the second connector.
Statement 611. An embodiment of the disclosure includes the multi-function device according to statement 608, wherein:
the multi-function device is configured to direct the request to the bridge; and
the multi-function device is configured to direct a third request to the FHE circuit.
Statement 612. An embodiment of the disclosure includes the multi-function device according to statement 611, wherein:
the multi-function device is configured to receive the first request from the host processor or the FHE circuit; and
the multi-function device is configured to receive the third request from the storage device.
Statement 613. An embodiment of the disclosure includes the multi-function device according to statement 612, wherein:
the multi-function device is configured to receive the first request from the host processor, the FHE circuit, or a computational storage unit;
the multi-function device is configured to receive the third request from the storage device or the computational storage unit.
Statement 614. An embodiment of the disclosure includes the multi-function device according to statement 611, wherein:
the multi-function device is configured to expose the second function to the host processor via the second connector; and
the multi-function device is configured to receive the third request from the host processor.
Statement 615. An embodiment of the disclosure includes the multi-function device according to statement 606, further comprising a buffer connected to the bridge and the FHE circuit.
Statement 616. An embodiment of the disclosure includes the multi-function device according to statement 615, wherein the bridge is configured to receive a request sent from the storage device and direct the request to the buffer.
Statement 617. An embodiment of the disclosure includes the multi-function device according to statement 616, wherein the request is sent from the storage device to the host processor.
Statement 618. An embodiment of the disclosure includes the multi-function device according to statement 616, wherein the storage device is agnostic to the bridge redirecting the request to the buffer.
Statement 619. An embodiment of the disclosure includes the multi-function device according to statement 616, wherein the bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 620. An embodiment of the disclosure includes the multi-function device according to statement 619, wherein the buffer includes an address range including the address.
Statement 621. An embodiment of the disclosure includes the multi-function device according to statement 615, wherein the multi-function device is configured to receive a request sent from the FHE circuit and direct the request to the buffer.
Statement 622. An embodiment of the disclosure includes the multi-function device according to statement 621, wherein the request is sent from the FHE circuit to the host processor.
Statement 623. An embodiment of the disclosure includes the multi-function device according to statement 621, wherein the FHE circuit is agnostic to the multi-function device redirecting the request to the buffer.
Statement 624. An embodiment of the disclosure includes the multi-function device according to statement 621, wherein the multi-function device is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 625. An embodiment of the disclosure includes the multi-function device according to statement 624, wherein the buffer includes an address range including the address.
Statement 626. An embodiment of the disclosure includes the multi-function device according to statement 568, further comprising a storage for a list of device configurations.
Statement 627. An embodiment of the disclosure includes the multi-function device according to statement 626, wherein the storage includes a persistent storage.
Statement 628. An embodiment of the disclosure includes the multi-function device according to statement 626, wherein the multi-function device is configured to expose the storage device to the host processor based at least in part on the list of device configurations.
Statement 629. An embodiment of the disclosure includes the multi-function device according to statement 628, wherein the multi-function device is configured to expose the storage device and the FHE circuit to the host processor based at least in part on the list of device configurations.
Statement 630. An embodiment of the disclosure includes the multi-function device according to statement 628, wherein the multi-function device is configured not to expose the FHE circuit to the host processor based at least in part on the list of device configurations.
Statement 631. An embodiment of the disclosure includes the multi-function device according to statement 626, wherein the multi-function device is configured to detect a device connected to a third connector, determine a configuration of the device, and update the list of device configurations based at least in part on the configuration of the device.
Statement 632. An embodiment of the disclosure includes the multi-function device according to statement 631, wherein the device includes a second storage device, a second FHE circuit, a computational storage unit, or a network interface device.
Statement 633. An embodiment of the disclosure includes the multi-function device according to statement 626, wherein the multi-function device is configured to determine the configuration of the device and update the list of device configurations based at least in part on the list of configurations omitting a configuration of the device.
Statement 634. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the storage device is replaceable.
Statement 635. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein:
the first connector includes a first PCIe port; and
the second connector includes a second PCIe port.
Statement 636. An embodiment of the disclosure includes the multi-function device according to statement 635, wherein:
the first PCIe port includes a first root port; and
the second PCIe port includes an endpoint.
Statement 637. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein:
the storage device is configured to expose a first PCIe function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second PCIe function; and
the multi-function device is configured to expose a third PCIe function to the host processor via the second connector.
Statement 638. An embodiment of the disclosure includes the multi-function device according to statement 637, wherein:
the first PCIe function includes a first PF or a first VF;
the second PCIe function includes a second PF or a second VF; and
the third PCIe function includes a third PF or a third VF.
Statement 639. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the first connector supports at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 640. An embodiment of the disclosure includes the multi-function device according to statement 568, wherein the second connector supports at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 641. An embodiment of the disclosure includes the multi-function device according to statement 568, further comprising a third connector for communicating with a device.
Statement 642. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the device includes a second storage device, a second FHE circuit, a computational storage unit, or a network interface device.
Statement 643. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the device is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 644. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the multi-function device does not expose the device to the host processor.
Statement 645. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the FHE circuit is configured to invoke a capability of the device.
Statement 646. An embodiment of the disclosure includes the multi-function device according to statement 645, wherein the multi-function device is configured to receive a request from the FHE circuit and send the request to the device.
Statement 647. An embodiment of the disclosure includes the multi-function device according to statement 646, wherein the multi-function device is configured to receive the request from the FHE circuit and send the request to the device without sending the request to the host processor.
Statement 648. An embodiment of the disclosure includes the multi-function device according to statement 645, wherein the FHE circuit is configured to invoke the capability of the device without management by the host processor.
Statement 649. An embodiment of the disclosure includes the multi-function device according to statement 645, wherein the multi-function device is configured to receive a reply from the device and send the reply to the FHE circuit.
Statement 650. An embodiment of the disclosure includes the multi-function device according to statement 649, wherein the multi-function device is configured to receive the reply from the device and send the reply to the FHE circuit without sending the reply to the host processor.
Statement 651. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the storage device is configured to invoke a capability of the device.
Statement 652. An embodiment of the disclosure includes the multi-function device according to statement 651, wherein the multi-function device is configured to receive a request from the storage device and send the request to the device.
Statement 653. An embodiment of the disclosure includes the multi-function device according to statement 652, wherein the multi-function device is configured to receive the request from the storage device and send the request to the device without sending the request to the host processor.
Statement 654. An embodiment of the disclosure includes the multi-function device according to statement 651, wherein the storage device is configured to invoke the capability of the device without management by the host processor.
Statement 655. An embodiment of the disclosure includes the multi-function device according to statement 651, wherein the multi-function device is configured to receive a reply from the device and send the reply to the storage device.
Statement 656. An embodiment of the disclosure includes the multi-function device according to statement 655, wherein the multi-function device is configured to receive the reply from the device and send the reply to the storage device without sending the reply to the host processor.
Statement 657. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the device is configured to invoke a capability of the storage device or the FHE circuit.
Statement 658. An embodiment of the disclosure includes the multi-function device according to statement 657, wherein the multi-function device is configured to receive a request from the device and send the request to the storage device or the FHE circuit.
Statement 659. An embodiment of the disclosure includes the multi-function device according to statement 658, wherein the multi-function device is configured to receive the request from the device and send the request to the storage device or the FHE circuit without sending the request to the host processor.
Statement 660. An embodiment of the disclosure includes the multi-function device according to statement 657, wherein the device is configured to invoke the capability of the storage device or the FHE circuit without management by the host processor.
Statement 661. An embodiment of the disclosure includes the multi-function device according to statement 657, wherein the multi-function device is configured to receive a reply from the storage device or the FHE circuit and send the reply to the device.
Statement 662. An embodiment of the disclosure includes the multi-function device according to statement 661, wherein the multi-function device is configured to receive the reply from the storage device or the FHE circuit and send the reply to the device without sending the reply to the host processor.
Statement 663. An embodiment of the disclosure includes the multi-function device according to statement 641, further comprising:
a first bridge connecting the third connector and the first connector; and
a second bridge connecting the third connector and the third connector.
Statement 664. An embodiment of the disclosure includes the multi-function device according to statement 663, wherein the second bridge supports pass-through of a request between the host processor and the device.
Statement 665. An embodiment of the disclosure includes the multi-function device according to statement 663, wherein:
the storage device is configured to expose a first function to the multi-function device via the first connector;
the FHE circuit is configured to expose a second function;
the device is configured to expose a third function to the multi-function device via the third connector;
the multi-function device is configured to expose a fourth function and a fifth function to the host processor via the second connector;
the multi-function device is configured to expose the fourth function to the device via the third connector and to the FHE circuit;
the multi-function device is configured to expose the fifth function to the storage device via the first connector and to the device via the third connector;
the multi-function device is configured to expose a sixth function to the storage device via the first connector and to the FHE circuit;
the first bridge is configured to map a first request using the fourth function to a second request using the first function; and
the second bridge is configured to map a third request using the fifth function to a fourth request using the third function.
Statement 666. An embodiment of the disclosure includes the multi-function device according to statement 663, further comprising a buffer connected to the first bridge, the FHE circuit, and the second bridge.
Statement 667. An embodiment of the disclosure includes the multi-function device according to statement 666, wherein the second bridge is configured to receive a request sent from the device and direct the request to the buffer.
Statement 668. An embodiment of the disclosure includes the multi-function device according to statement 667, wherein the device is agnostic to the second bridge redirecting the request to the buffer.
Statement 669. An embodiment of the disclosure includes the multi-function device according to statement 667, wherein the second bridge is configured to direct the request to the buffer based at least in part on an address, the request including the address.
Statement 670. An embodiment of the disclosure includes the multi-function device according to statement 669, wherein the buffer includes an address range including the address.
Statement 671. An embodiment of the disclosure includes the multi-function device according to statement 641, wherein the multi-function device is configured not to expose the device to the host processor based at least in part on a list of device configurations.
Statement 672. An embodiment of the disclosure includes a method, comprising:
determining that a storage device is connected to a multi-function device;
determining that a Fully Homomorphic Encryption (FHE) circuit is available;
determining that a computational storage unit is connected to the multi-function device;
exposing the storage device to a host processor connected to the multi-function device; and
selectively exposing the FHE circuit and the computational storage unit to the host processor.
Statement 673. An embodiment of the disclosure includes the method according to statement 672, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 674. An embodiment of the disclosure includes the method according to statement 672, wherein the FHE circuit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 675. An embodiment of the disclosure includes the method according to statement 672, wherein the computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 676. An embodiment of the disclosure includes the method according to statement 672, wherein the storage device includes a Solid State Drive (SSD).
Statement 677. An embodiment of the disclosure includes the method according to statement 672, wherein the computational storage unit includes an accelerator circuit, a second FHE circuit, or a network interface device.
Statement 678. An embodiment of the disclosure includes the method according to statement 672, wherein determining that the FHE circuit is available includes determining that the FHE circuit is connected to the multi-function device.
Statement 679. An embodiment of the disclosure includes the method according to statement 678, wherein determining that the FHE circuit is connected to the multi-function device includes determining that the FHE circuit is connected to the multi-function device via a connector.
Statement 680. An embodiment of the disclosure includes the method according to statement 672, wherein determining that the FHE circuit is available includes determining that the FHE circuit is integrated into the multi-function device.
Statement 681. An embodiment of the disclosure includes the method according to statement 672, wherein determining that the storage device is connected to the multi-function device includes determining that the storage device is connected to the multi-function device via a first connector; and
determining that the computational storage unit is connected to the multi-function device includes determining that the computational storage unit is connected to the multi-function device via a second connector.
Statement 682. An embodiment of the disclosure includes the method according to statement 672, wherein selectively exposing the FHE circuit and the computational storage unit to a host processor connected to the multi-function device includes:
exposing the FHE circuit to the host processor; and
not exposing the computational storage unit to the host processor.
Statement 683. An embodiment of the disclosure includes the method according to statement 672, wherein selectively exposing the FHE circuit and the computational storage unit to a host processor connected to the multi-function device includes:
exposing the computational storage unit to the host processor; and
not exposing the FHE circuit to the host processor.
Statement 684. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request at the multi-function device from the storage device to invoke a capability of the FHE circuit or the computational storage unit; and
sending the request to the FHE circuit or the computational storage unit.
Statement 685. An embodiment of the disclosure includes the method according to statement 684, wherein sending the request to the FHE circuit or the computational storage unit includes sending the request to the FHE circuit or the computational storage unit without sending the request to the host processor.
Statement 686. An embodiment of the disclosure includes the method according to statement 684, wherein sending the request to the FHE circuit or the computational storage unit includes sending the request to the FHE circuit or the computational storage unit without management by the host processor.
Statement 687. An embodiment of the disclosure includes the method according to statement 684, further comprising:
receiving a reply at the multi-function device from the FHE circuit or the computational storage unit; and
sending the reply to the storage device.
Statement 688. An embodiment of the disclosure includes the method according to statement 687, wherein sending the reply to the storage device includes sending the reply to the storage device without sending the reply to the host processor.
Statement 689. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request at the multi-function device from the FHE circuit to invoke a capability of the storage device or the computational storage unit; and
sending the request to the storage device or the computational storage unit.
Statement 690. An embodiment of the disclosure includes the method according to statement 689, wherein sending the request to the storage device or the computational storage unit includes sending the request to the storage device or the computational storage unit without sending the request to the host processor.
Statement 691. An embodiment of the disclosure includes the method according to statement 689, wherein sending the request to the storage device or the computational storage unit includes sending the request to the storage device or the computational storage unit without management by the host processor.
Statement 692. An embodiment of the disclosure includes the method according to statement 689, further comprising:
receiving a reply at the multi-function device from the storage device or the computational storage unit; and
sending the reply to the FHE circuit.
Statement 693. An embodiment of the disclosure includes the method according to statement 692, wherein sending the reply to the FHE circuit includes sending the reply to the FHE circuit without sending the reply to the host processor.
Statement 694. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request at the multi-function device from the computational storage unit to invoke a capability of the storage device or the FHE circuit; and
sending the request to the storage device or the FHE circuit.
Statement 695. An embodiment of the disclosure includes the method according to statement 694, wherein sending the request to the storage device or the FHE circuit includes sending the request to the storage device or the FHE circuit without sending the request to the host processor.
Statement 696. An embodiment of the disclosure includes the method according to statement 694, wherein sending the request to the storage device or the FHE circuit includes sending the request to the storage device or the FHE circuit without management by the host processor.
Statement 697. An embodiment of the disclosure includes the method according to statement 694, further comprising:
receiving a reply at the multi-function device from the storage device or the FHE circuit; and
sending the reply to the computational storage unit.
Statement 698. An embodiment of the disclosure includes the method according to statement 697, wherein sending the reply to the computational storage unit includes sending the reply to the computational storage unit without sending the reply to the host processor.
Statement 699. An embodiment of the disclosure includes the method according to statement 672, further comprising:
accessing a data in a buffer in the multi-function device by the storage device; and
accessing the data in the buffer in the multi-function device by the FHE circuit.
Statement 700. An embodiment of the disclosure includes the method according to statement 699, further comprising:
accessing the data in the buffer in the multi-function device by the computational storage unit.
Statement 701. An embodiment of the disclosure includes the method according to statement 699, wherein:
the buffer includes an address range; and
the method further comprises determining the address range of the buffer from the host processor.
Statement 702. An embodiment of the disclosure includes the method according to statement 699, wherein:
accessing the data in the buffer in the multi-function device by the storage device includes accessing the data in the buffer in the multi-function device by the storage device using a first protocol; and
accessing the data in the buffer in the multi-function device by the FHE circuit includes accessing the data in the buffer in the multi-function device by the FHE circuit using a second protocol.
Statement 703. An embodiment of the disclosure includes the method according to statement 702, wherein:
the first protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol; and
the second protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 704. An embodiment of the disclosure includes the method according to statement 702, further comprising accessing the data in the buffer in the multi-function device by the computational storage unit using a third protocol.
Statement 705. An embodiment of the disclosure includes the method according to statement 704, wherein the third protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 706. An embodiment of the disclosure includes the method according to statement 699, further comprising processing the data in the buffer using a data processor of the multi-function device.
Statement 707. An embodiment of the disclosure includes the method according to statement 706, wherein processing the data in the buffer using the data processor of the multi-function device includes processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit.
Statement 708. An embodiment of the disclosure includes the method according to statement 707, wherein:
the method further comprises:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit includes receiving the request from at least one of the host processor, the storage device, the FHE circuit, or the computational storage unit, the request triggering the function.
Statement 709. An embodiment of the disclosure includes the method according to statement 708, wherein determining that the function is exposed by the data processor includes determining that a Peripheral Component Interconnect Express (PCIe) function is exposed by the data processor.
Statement 710. An embodiment of the disclosure includes the method according to statement 709, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 711. An embodiment of the disclosure includes the method according to statement 707, wherein:
the method further comprises:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit includes:
Statement 712. An embodiment of the disclosure includes the method according to statement 711, wherein triggering the function of the data processor includes mapping the second function to the function of the data processor.
Statement 713. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request from the host processor, the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device; and
passing the request through the bridge to the host processor, the storage device, the FHE circuit, or the computational storage unit.
Statement 714. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request from the host processor, the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device, the request triggering a function exposed by the storage device, the FHE circuit, or the computational storage unit; and
sending the request from the bridge to the storage device, the FHE circuit, or the computational storage unit based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 715. An embodiment of the disclosure includes the method according to statement 714, wherein receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 716. An embodiment of the disclosure includes the method according to statement 714, wherein:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device, the request triggering a second function exposed by the multi-function device;
the method further comprises mapping the second function to the function exposed by the storage device, the FHE circuit, or the computational storage unit; and
sending the request from the bridge to the storage device, the FHE circuit, or the computational storage unit based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 717. An embodiment of the disclosure includes the method according to statement 716, wherein receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the second function exposed by the multi-function device.
Statement 718. An embodiment of the disclosure includes the method according to statement 714, wherein the multi-function device does not expose the function to the host processor.
Statement 719. An embodiment of the disclosure includes the method according to statement 672, further comprising:
receiving a request from the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device; and
sending the request from the bridge to a buffer of the multi-function device.
Statement 720. An embodiment of the disclosure includes the method according to statement 719, wherein the request is sent from the storage device, the FHE circuit, or the computational storage unit to the host processor.
Statement 721. An embodiment of the disclosure includes the method according to statement 719, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device without notifying the storage device, the FHE circuit, or the computational storage unit.
Statement 722. An embodiment of the disclosure includes the method according to statement 719, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device based at least in part on an address, the request including the address.
Statement 723. An embodiment of the disclosure includes the method according to statement 722, wherein the buffer includes an address range including the address.
Statement 724. An embodiment of the disclosure includes the method according to statement 723, further comprising receiving the address range for the buffer from the host processor.
Statement 725. An embodiment of the disclosure includes the method according to statement 672, wherein:
exposing the storage device to the host processor connected to the multi-function device includes exposing the storage device to the host processor connected to the multi-function device based at least in part on a list of device configurations; and
selectively exposing the FHE circuit and the computational storage unit to the host processor includes selectively exposing the FHE circuit and the computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 726. An embodiment of the disclosure includes the method according to statement 725, wherein further comprising accessing the list of device configurations from a storage of the multi-function device.
Statement 727. An embodiment of the disclosure includes the method according to statement 726, wherein accessing the list of device configurations from the storage of the multi-function device includes accessing the list of device configurations from a persistent storage of the multi-function device.
Statement 728. An embodiment of the disclosure includes the method according to statement 725, further comprising:
determining that a device is connected to the multi-function device;
determining a configuration of the device; and
updating the list of device configurations based at least in part on the configuration of the device.
Statement 729. An embodiment of the disclosure includes the method according to statement 728, wherein the device includes a second storage device, a second computational storage unit, a second FHE circuit, or a network interface device.
Statement 730. An embodiment of the disclosure includes the method according to statement 728, wherein updating the list of device configurations based at least in part on the configuration of the device includes determining that the list of device configurations omits the configuration of the device.
Statement 731. An embodiment of the disclosure includes the method according to statement 672, further comprising replacing the storage device with a device.
Statement 732. An embodiment of the disclosure includes the method according to statement 672, further comprising replacing the FHE circuit with a device.
Statement 733. An embodiment of the disclosure includes the method according to statement 672, further comprising replacing the computational storage unit with a device.
Statement 734. An embodiment of the disclosure includes the method according to statement 672, wherein the multi-function device communicates with the storage device using at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 735. An embodiment of the disclosure includes the method according to statement 672, wherein the multi-function device communicates with the FHE circuit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 736. An embodiment of the disclosure includes the method according to statement 672, wherein the multi-function device communicates with the computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 737. An embodiment of the disclosure includes the method according to statement 672, wherein the multi-function device communicates with the host processor using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 738. An embodiment of the disclosure includes an article, comprising a non-transitory storage medium, the non-transitory storage medium having stored thereon instructions that, when executed by a machine, result in:
determining that a storage device is connected to a multi-function device;
determining that a Fully Homomorphic Encryption (FHE) circuit is available;
determining that a computational storage unit is connected to the multi-function device;
exposing the storage device to a host processor connected to the multi-function device; and
selectively exposing the FHE circuit and the computational storage unit to the host processor.
Statement 739. An embodiment of the disclosure includes the article according to statement 738, wherein the multi-function device is implemented using at least one of a Field Programmable Gate Array (FPGA), an Application-Specific Integrated Circuit (ASIC), a System-on-a-Chip (SoC), a Graphics Processing Unit (GPU), a General Purpose GPU (GPGPU), a Central Processing Unit (CPU), a Tensor Processing Unit (TPU), or a Neural Processing Unit (NPU).
Statement 740. An embodiment of the disclosure includes the article according to statement 738, wherein the FHE circuit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 741. An embodiment of the disclosure includes the article according to statement 738, wherein the computational storage unit is implemented using at least one of an FPGA, an ASIC, an SoC, a GPU, a GPGPU, a CPU, a TPU, or an NPU.
Statement 742. An embodiment of the disclosure includes the article according to statement 738, wherein the storage device includes a Solid State Drive (SSD).
Statement 743. An embodiment of the disclosure includes the article according to statement 738, wherein the computational storage unit includes an accelerator circuit, a second FHE circuit, or a network interface device.
Statement 744. An embodiment of the disclosure includes the article according to statement 738, wherein determining that the FHE circuit is available includes determining that the FHE circuit is connected to the multi-function device.
Statement 745. An embodiment of the disclosure includes the article according to statement 744, wherein determining that the FHE circuit is connected to the multi-function device includes determining that the FHE circuit is connected to the multi-function device via a connector.
Statement 746. An embodiment of the disclosure includes the article according to statement 738, wherein determining that the FHE circuit is available includes determining that the FHE circuit is integrated into the multi-function device.
Statement 747. An embodiment of the disclosure includes the article according to statement 738, wherein:
determining that the storage device is connected to the multi-function device includes determining that the storage device is connected to the multi-function device via a first connector; and
determining that the computational storage unit is connected to the multi-function device includes determining that the computational storage unit is connected to the multi-function device via a second connector.
Statement 748. An embodiment of the disclosure includes the article according to statement 738, wherein selectively exposing the FHE circuit and the computational storage unit to a host processor connected to the multi-function device includes:
exposing the FHE circuit to the host processor; and
not exposing the computational storage unit to the host processor.
Statement 749. An embodiment of the disclosure includes the article according to statement 738, wherein selectively exposing the FHE circuit and the computational storage unit to a host processor connected to the multi-function device includes:
exposing the computational storage unit to the host processor; and
not exposing the FHE circuit to the host processor.
Statement 750. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the storage device to invoke a capability of the FHE circuit or the computational storage unit; and
sending the request to the FHE circuit or the computational storage unit.
Statement 751. An embodiment of the disclosure includes the article according to statement 750, wherein sending the request to the FHE circuit or the computational storage unit includes sending the request to the FHE circuit or the computational storage unit without sending the request to the host processor.
Statement 752. An embodiment of the disclosure includes the article according to statement 750, wherein sending the request to the FHE circuit or the computational storage unit includes sending the request to the FHE circuit or the computational storage unit without management by the host processor.
Statement 753. An embodiment of the disclosure includes the article according to statement 750, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the FHE circuit or the computational storage unit; and
sending the reply to the storage device.
Statement 754. An embodiment of the disclosure includes the article according to statement 753, wherein sending the reply to the storage device includes sending the reply to the storage device without sending the reply to the host processor.
Statement 755. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the FHE circuit to invoke a capability of the storage device or the computational storage unit; and
sending the request to the storage device or the computational storage unit.
Statement 756. An embodiment of the disclosure includes the article according to statement 755, wherein sending the request to the storage device or the computational storage unit includes sending the request to the storage device or the computational storage unit without sending the request to the host processor.
Statement 757. An embodiment of the disclosure includes the article according to statement 755, wherein sending the request to the storage device or the computational storage unit includes sending the request to the storage device or the computational storage unit without management by the host processor.
Statement 758. An embodiment of the disclosure includes the article according to statement 755, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the storage device or the computational storage unit; and
sending the reply to the FHE circuit.
Statement 759. An embodiment of the disclosure includes the article according to statement 758, wherein sending the reply to the FHE circuit includes sending the reply to the FHE circuit without sending the reply to the host processor.
Statement 760. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request at the multi-function device from the computational storage unit to invoke a capability of the storage device or the FHE circuit; and
sending the request to the storage device or the FHE circuit.
Statement 761. An embodiment of the disclosure includes the article according to statement 760, wherein sending the request to the storage device or the FHE circuit includes sending the request to the storage device or the FHE circuit without sending the request to the host processor.
Statement 762. An embodiment of the disclosure includes the article according to statement 760, wherein sending the request to the storage device or the FHE circuit includes sending the request to the storage device or the FHE circuit without management by the host processor.
Statement 763. An embodiment of the disclosure includes the article according to statement 760, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a reply at the multi-function device from the storage device or the FHE circuit; and
sending the reply to the computational storage unit.
Statement 764. An embodiment of the disclosure includes the article according to statement 763, wherein sending the reply to the computational storage unit includes sending the reply to the computational storage unit without sending the reply to the host processor.
Statement 765. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
accessing a data in a buffer in the multi-function device by the storage device; and
accessing the data in the buffer in the multi-function device by the FHE circuit.
Statement 766. An embodiment of the disclosure includes the article according to statement 765, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
accessing the data in the buffer in the multi-function device by the computational storage unit.
Statement 767. An embodiment of the disclosure includes the article according to statement 765, wherein:
the buffer includes an address range; and
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in determining the address range of the buffer from the host processor.
Statement 768. An embodiment of the disclosure includes the article according to statement 765, wherein:
accessing the data in the buffer in the multi-function device by the storage device includes accessing the data in the buffer in the multi-function device by the storage device using a first protocol; and
accessing the data in the buffer in the multi-function device by the FHE circuit includes accessing the data in the buffer in the multi-function device by the FHE circuit using a second protocol.
Statement 769. An embodiment of the disclosure includes the article according to statement 768, wherein:
the first protocol includes at least one of a File Read protocol, a File Write protocol, a Direct Memory Access (DMA) protocol, or a Non-Volatile Memory Express (NVMe) protocol; and
the second protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 770. An embodiment of the disclosure includes the article according to statement 768, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in accessing the data in the buffer in the multi-function device by the computational storage unit using a third protocol.
Statement 771. An embodiment of the disclosure includes the article according to statement 770, wherein the third protocol includes at least one of the File Read protocol, the File Write protocol, the DMA protocol, or the NVMe protocol.
Statement 772. An embodiment of the disclosure includes the article according to statement 765, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in processing the data in the buffer using a data processor of the multi-function device.
Statement 773. An embodiment of the disclosure includes the article according to statement 772, wherein processing the data in the buffer using the data processor of the multi-function device includes processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit.
Statement 774. An embodiment of the disclosure includes the article according to statement 773, wherein:
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit includes receiving the request from at least one of the host processor, the storage device, the FHE circuit, or the computational storage unit, the request triggering the function.
Statement 775. An embodiment of the disclosure includes the article according to statement 774, wherein determining that the function is exposed by the data processor includes determining that a Peripheral Component Interconnect Express (PCIe) function is exposed by the data processor.
Statement 776. An embodiment of the disclosure includes the article according to statement 775, wherein the PCIe function includes a first physical function (PF) or a first virtual function (VF).
Statement 777. An embodiment of the disclosure includes the article according to statement 773, wherein:
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in:
processing the data in the buffer using the data processor of the multi-function device based at least in part on a request from one of the host processor, the storage device, the FHE circuit, or the computational storage unit includes:
Statement 778. An embodiment of the disclosure includes the article according to statement 777, wherein triggering the function of the data processor includes mapping the second function to the function of the data processor.
Statement 779. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the host processor, the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device; and
passing the request through the bridge to the host processor, the storage device, the FHE circuit, or the computational storage unit.
Statement 780. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the host processor, the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device, the request triggering a function exposed by the storage device, the FHE circuit, or the computational storage unit; and
sending the request from the bridge to the storage device, the FHE circuit, or the computational storage unit based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 781. An embodiment of the disclosure includes the article according to statement 780, wherein receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 782. An embodiment of the disclosure includes the article according to statement 780, wherein:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device, the request triggering a second function exposed by the multi-function device;
the non-transitory storage medium has stored thereon further instructions that, when executed by the machine, result in mapping the second function to the function exposed by the storage device, the FHE circuit, or the computational storage unit; and
sending the request from the bridge to the storage device, the FHE circuit, or the computational storage unit based at least in part on the function exposed by the storage device, the FHE circuit, or the computational storage unit.
Statement 783. An embodiment of the disclosure includes the article according to statement 782, wherein receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the bridge of the multi-function device includes:
receiving the request from the host processor, the storage device, the FHE circuit, or the computational storage unit at the multi-function device; and
sending the request to the bridge based at least in part on the second function exposed by the multi-function device.
Statement 784. An embodiment of the disclosure includes the article according to statement 780, wherein the multi-function device does not expose the function to the host processor.
Statement 785. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
receiving a request from the storage device, the FHE circuit, or the computational storage unit at a bridge of the multi-function device; and
sending the request from the bridge to a buffer of the multi-function device.
Statement 786. An embodiment of the disclosure includes the article according to statement 785, wherein the request is sent from the storage device, the FHE circuit, or the computational storage unit to the host processor.
Statement 787. An embodiment of the disclosure includes the article according to statement 785, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device without notifying the storage device, the FHE circuit, or the computational storage unit.
Statement 788. An embodiment of the disclosure includes the article according to statement 785, wherein sending the request from the bridge to the buffer of the multi-function device includes sending the request from the bridge to the buffer of the multi-function device based at least in part on an address, the request including the address.
Statement 789. An embodiment of the disclosure includes the article according to statement 788, wherein the buffer includes an address range including the address.
Statement 790. An embodiment of the disclosure includes the article according to statement 789, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in receiving the address range for the buffer from the host processor.
Statement 791. An embodiment of the disclosure includes the article according to statement 738, wherein:
exposing the storage device to the host processor connected to the multi-function device includes exposing the storage device to the host processor connected to the multi-function device based at least in part on a list of device configurations; and
selectively exposing the FHE circuit and the computational storage unit to the host processor includes selectively exposing the FHE circuit and the computational storage unit to the host processor based at least in part on the list of device configurations.
Statement 792. An embodiment of the disclosure includes the article according to statement 791, wherein the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in accessing the list of device configurations from a storage of the multi-function device.
Statement 793. An embodiment of the disclosure includes the article according to statement 792, wherein accessing the list of device configurations from the storage of the multi-function device includes accessing the list of device configurations from a persistent storage of the multi-function device.
Statement 794. An embodiment of the disclosure includes the article according to statement 791, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in:
determining that a device is connected to the multi-function device;
determining a configuration of the device; and
updating the list of device configurations based at least in part on the configuration of the device.
Statement 795. An embodiment of the disclosure includes the article according to statement 794, wherein the device includes a second storage device, a second computational storage unit, a second FHE circuit, or a network interface device.
Statement 796. An embodiment of the disclosure includes the article according to statement 794, wherein updating the list of device configurations based at least in part on the configuration of the device includes determining that the list of device configurations omits the configuration of the device.
Statement 797. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the storage device with a device.
Statement 798. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the FHE circuit with a device.
Statement 799. An embodiment of the disclosure includes the article according to statement 738, the non-transitory storage medium having stored thereon further instructions that, when executed by the machine, result in replacing the computational storage unit with a device.
Statement 800. An embodiment of the disclosure includes the article according to statement 738, wherein the multi-function device communicates with the storage device using at least one of an Ethernet protocol, a Transmission Control Protocol/Internet Protocol (TCP/IP) protocol, a Remote DMA (RDMA) protocol, an NVMe protocol, an NVMe over Fabrics (NVMe-oF) protocol, a Universal Flash Storage (UFS) protocol, an embedded MultiMediaCard (eMMC) protocol, a Serial Attached Small Computer System Interface (SCSI) (SAS) protocol, or a Serial AT Attachment (SATA) protocol.
Statement 801. An embodiment of the disclosure includes the article according to statement 738, wherein the multi-function device communicates with the FHE circuit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 802. An embodiment of the disclosure includes the article according to statement 738, wherein the multi-function device communicates with the computational storage unit using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Statement 803. An embodiment of the disclosure includes the article according to statement 738, wherein the multi-function device communicates with the host processor using at least one of an Ethernet protocol, a TCP/IP protocol, an RDMA protocol, an NVMe protocol, an NVMe-oF protocol, a UFS protocol, an eMMC protocol, an SAS protocol, or a SATA protocol.
Consequently, in view of the wide variety of permutations to the embodiments described herein, this detailed description and accompanying material is intended to be illustrative only, and should not be taken as limiting the scope of the disclosure. What is claimed as the disclosure, therefore, is all such modifications as may come within the scope and spirit of the following claims and equivalents thereto.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 63/403,679, filed Sep. 2, 2022 and U.S. Provisional Patent Application Ser. No. 63/403,682, filed Sep. 2, 2022, both of which are incorporated by reference herein for all purposes. This application is a continuation in part of U.S. patent application Ser. No. 18/074,360, filed Dec. 2, 2022, which claims the benefit of U.S. Provisional Patent Application Ser. No. 63/292,421, filed Dec. 21, 2021, both of which are incorporated by reference herein for all purposes. This application is related to U.S. patent application Ser. No. 16/846,271, filed Apr. 10, 2020, now allowed, which claims the benefit of U.S. Provisional Patent Application Ser. No. 62/964,114, filed Jan. 21, 2020, and U.S. Provisional Patent Application Ser. No. 62/865,962, filed Jun. 24, 2019, all of which are incorporated by reference herein for all purposes. This application is related to U.S. patent application Ser. No. 17/669,351, filed Feb. 10, 2022, which claims the benefit of U.S. Provisional Patent Application Ser. No. 63/232,631, filed Aug. 12, 2021, both of which are incorporated by reference herein for all purposes. This application is related to U.S. patent application Ser. No. ______, filed ______, which claims the benefit of U.S. Provisional Patent Application Ser. No. 63/403,679, filed Sep. 2, 2022 and U.S. Provisional Patent Application Ser. No. 63/403,682, filed Sep. 2, 2022, both of which are incorporated by reference herein for all purposes.
Number | Date | Country | |
---|---|---|---|
63403679 | Sep 2022 | US | |
63403682 | Sep 2022 | US | |
63292421 | Dec 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 18074360 | Dec 2022 | US |
Child | 18108575 | US |