This application claims the benefits of priority to Chinese Application No. 202111374748.4, filed Nov. 17, 2021, the entire content of which is incorporated herein by reference.
The present disclosure relates to the technical field of computers, and in particular, to a method, apparatus, system, and storage medium for performing an Electronic Design Automation (EDA) task.
In recent years, as the scale of an integrated chip (IC) design increases, the local computing power can be insufficient during the verification process of the IC design. Furthermore, the verification process usually involves a plurality of tools, such as a simulator, a formal verification tool, an emulator (including a prototyping apparatus). A full process of an IC design involves even more tools.
Therefore, in the IC design industry, some tools can be short of computing resources during a specific period, while some other tools cannot make full use of computing resources because the tool chain is too long.
How to integrate existing EDA tools and improve the efficiency of computing resources is an urgent problem to be addressed.
Therefore, there is provided a method, apparatus, system, and storage medium for performing an EDA task.
Embodiments of the disclosure provide a method for performing an EDA task, the method comprising: reconstructing the EDA task into a plurality of subtasks that are executed according to a given process, the plurality of subtasks comprising a first subtask and a second subtask; determining a plurality of computing resources corresponding to the plurality of subtasks, the plurality of computing resources comprising a first computing resource corresponding to the first subtask and a second computing resource corresponding to the second subtask; and invoking the plurality of computing resources according to the given process to execute the plurality of subtasks.
Embodiments of the disclosure also provide a computing apparatus for performing an EDA task, comprising: a memory storing a set of instructions; and at least one processor configured to execute the set of instructions to perform a method for performing the EDA task, the method comprising: reconstructing the EDA task into a plurality of subtasks that are executed according to a given process, the plurality of subtasks comprising a first subtask and a second subtask; determining a plurality of computing resources corresponding to the plurality of subtasks, the plurality of computing resources comprising a first computing resource corresponding to the first subtask and a second computing resource corresponding to the second subtask; and invoking the plurality of computing resources according to the given process to execute the plurality of subtasks.
Embodiments of the present disclosure provide a computing system for performing an EDA task, comprising: the computing apparatus for performing an EDA task as described above; and local computing resources communicatively connected to the computing apparatus. The local computing resources comprise: at least one of a server or a hardware verification tool.
Embodiments of the present disclosure provide a non-transitory computer-readable storage medium that stores a set of instructions of a computing apparatus. The set of instructions is used to cause the computing apparatus to perform a method for performing an EDA task, the method comprising: reconstructing the EDA task into a plurality of subtasks that are executed according to a given process, the plurality of subtasks comprising a first subtask and a second subtask; determining a plurality of computing resources corresponding to the plurality of subtasks, the plurality of computing resources comprising a first computing resource corresponding to the first subtask and a second computing resource corresponding to the second subtask; and invoking the plurality of computing resources according to the given process to execute the plurality of subtasks.
To describe the technical solutions in the present disclosure more clearly, the following will briefly introduce the figures that need to be used in the embodiments. Obviously, the figures in the following description are merely exemplary, for those ordinary skilled in the art, without inventive work, other figures can be obtained based on these figures.
Exemplary embodiments will be described in detail herein, and examples thereof are shown in the accompanying drawings. In the following description involving the accompanying drawings, the same numerals in different accompanying drawings indicate the same or similar elements, unless specified otherwise. Implementations described in the following exemplary embodiments do not represent all implementations consistent with the disclosure. In contrast, they are merely examples of devices and methods consistent with some aspects of the disclosure as described in detail below.
Terms in the disclosure are merely used for describing specific embodiments, rather than limiting the disclosure. Singular-form words “a (an)”, “said”, and “the” used in the present disclosure and the appended claims also include plural forms, unless clearly specified in the context that other meanings are denoted. It should be further understood that the term “and/or” used herein refers to and includes any or all possible combinations of one or more associated items listed.
It should be understood that, although terms such as “first”, “second”, and “third” can be used to describe various kinds of information in the disclosure, these kinds of information should not be limited by the terms. These terms are merely used to distinguish information of the same type from each other. For example, without departing from the scope of the disclosure, the first information can also be referred to as second information, and similarly, the second information can also be referred to as first information. Depending on the context, the word “if” used herein can be understood as “when . . . ”, “as . . . ”, or “in response to the determination”.
While ordinary software technology or software engineering can be capable of completing software design tasks with the assistance of very few tools, EDA technology for designing an IC can involve dozens of EDA tools, and the EDA tools need to be separately used according to the progress of EDA tasks. Conventionally, an engineer can use an EDA tool to complete an EDA task and then manually provide the results generated by the EDA tool to another EDA tool for the execution of a next EDA task.
These inherent characteristics of EDA tools at least lead to the following problems.
Firstly, it is inefficient to manually invoke a plurality of EDA tools. Obviously, manually invoking EDA tools requires engineers to keep an eye on the running status of EDA tasks, and to manually provide the task results of the previous tool to the next tool. These operations are inefficient.
Secondly, because the resource configuration cannot be globally performed, a shortage of some computing resources (e.g., emulators) can cause a plurality of EDA tasks to wait. Generally, IC design companies can only afford a small number of emulators because the emulators (e.g., HuaEmu of XEPIC Corporation Limited) are expensive. While a plurality of verification work groups within an IC design company need to use emulators, there can be a wait due to the shortage of emulators. It is essentially due to the lack of global resource configuration.
Thirdly, the task results cannot be reused and corroborated with each other across a plurality of EDA tools. For example, conventionally, a waveform file generated by a simulator during verification and a waveform file generated by an emulator during verification cannot be reused and corroborated with each other. The above problem is caused by the isolation of a plurality of EDA tools from each other.
Fourthly, because conventional cloud computing requires users to provide source codes of IC designs, users are less motivated to use the cloud computing for computing flexibility.
Embodiments of the disclosure provide a method, apparatus, system, and computer-readable storage medium for performing an EDA task to construct a new EDA architecture, intended to at least partially resolve the above-mentioned problems.
The disclosure only takes a verification tool and a verification task of a logic system design as examples for illustration. But it should be understood that, the method, apparatus, system, and computer-readable storage medium for performing an EDA task provided by embodiments of the disclosure can be applied to various EDA tools, instead of being limited to verification tools.
Processor 102 can be a central processing unit (CPU), an image processor, a neural network processor (NPU), a microcontroller (MCU), a programmable logical device, a digital signal processor (DSP), an application specific integrated circuit (ASIC), or one or more integrated circuits. Processor 102 can perform functions related to the techniques described in the disclosure. In some embodiments, processor 102 can also include a plurality of processors integrated into a single logical component. As shown in
Memory 104 can be configured to store data (e.g., an instruction set, lists of TCL objects, computer codes, properties of objects and values of properties, etc.). As shown in
Network interface 106 can be configured to enable computing apparatus 100 to communicate with other external devices via a network. The network can be any wired or wireless network capable of transmitting and receiving data. For example, the network can be a wired network, a local wireless network (e.g., a Bluetooth network, a Wi-Fi network, a near field communication (NFC), etc.), a cellular network, the Internet, or a combination of the above. It is appreciated that the type of network is not limited to the above specific examples. In some embodiments, network interface 106 can include any number of network interface controllers (NICs), radio frequency modules, receivers, modems, routers, gateways, adapters, cellular network chips, or random combinations of two or more of the above.
Peripheral interface 108 can be configured to connect the computing apparatus 100 to one or more peripheral devices to implement input and output information. For example, the peripheral devices can include input devices, such as keyboards, mice, touch pads, touch screens, microphones, various sensors, and output devices, such as displays, speakers, vibrators, and indicator lights.
Bus 110, such as an internal bus (e.g., a processor-storage bus), an external bus (e.g., a USB port, a PCI-E bus), and the like, can be configured to transmit information among various components of computing apparatus 100 (e.g., processor 102, memory 104, network interface 106, and peripheral interface 108).
It should be noted that, although the above computing apparatus merely illustrates processor 102, memory 104, network interface 106, peripheral interface 108, and bus 110, the computing apparatus architecture can also include other components needed for normal operations. In addition, it can be appreciated for those ordinary skilled in the art that the foregoing devices can also include the components needed to implement the solutions of embodiments of the present disclosure and do not require to include all the components of figures.
As shown in
EDA computing system 130 of the present disclosure can be a local computing system, and can include a computing device 132 and a local computing resource 134.
Computing device 132 can be computing apparatus 100 as shown in
Local computing resource 134 can provide users with a plurality of EDA tools and vessels for running the EDA tools. In some embodiments, local computing resource 134 can include at least one of server 134a or hardware verification tool 134b.
Server 134a can be computing apparatus 100 as shown in
Hardware verification tool 134b can exemplarily include hardware verification tools, such as a prototype verification board or an emulator.
Although only a limited number of local computing resource 134 are shown in
As shown in
Interface layer 202 can be configured to provide an interactive interface to a user. In some embodiments, interface layer 202 can provide a command line console or a graphic interface to a user (e.g., an employee of an IC design company). The command line console or the graphic interface allows the user to initiate EDA tasks (e.g., a simulation task, a formal verification task, etc.), trace the execution of EDA tasks, and read the execution results of EDA tasks (e.g., waveform files, coverage files, etc.).
In some embodiments, interface layer 202 can provide a graphic interface to a user for configuring computing resources for each EDA task. Usually, an IC design company can carry out a plurality of IC design projects in parallel, and there are a plurality of sub-projects within one design project that need to perform EDA tasks. These projects or sub-projects can compete for the limited resources controlled by resource manager 200 to perform the required EDA tasks at the same time. Interface layer 202 can allow the user to assign resources for different projects or EDA tasks. For example, different projects can be assigned with different levels, each level corresponding to different permissions to allocate resources and the maximum number of resources allowed to be used.
Interface layer 202 can send these EDA task instructions (e.g., instructions to initiate an EDA task, configure computing resources) from the user to gateway layer 204, so as to allocate the computing resources to perform the EDA task.
According to the EDA task, gateway layer 204 can be configured to reconstruct the EDA task from interface layer 202 into a process and a plurality of subtasks that are executed according to the process. The reconstructed process can include the execution order of the plurality of subtasks, thereby allowing the plurality of subtasks to be executed according to the reconstructed process.
Gateway layer 204 can also be configured to be connected to cloud system 120, so that one or more subtasks can be sent to cloud system 120 for computing, thereby realizing the invocation of cloud computing resources. In some embodiments, gateway layer 204 can include a security gateway 2042 to ensure that communications between gateway layer 204 belonging to the local computing system and external cloud system 120 are secure. It is appreciated that gateway layer 204 can be connected with cloud systems provided by a plurality of cloud service providers.
In some embodiments, interface layer 202 and gateway layer 204 can be provided by separate computing devices 132. For example, interface layer 202 can be implemented on a specific user's personal computer, while gateway layer 204 can be implemented on a server connected to the personal computer. In some embodiments, interface layer 202 and gateway layer 204 can be implemented by the same computing device 132.
Gateway layer 204 can select EDA tools corresponding to these subtasks and allocate corresponding computing resources for the selected EDA tools. It is appreciated that gateway layer 204 can merely select one or more EDA tools among the EDA tools provided by computing resources 134. In some embodiments, gateway layer 204 can provide the user with suggestions for adding a new EDA tool that is required by the EDA task but not provided by computing resources 134 via interface layer 202.
In some embodiments, the EDA task from interface layer 202 can be a coverage testing task of an IC design. In response to receiving the EDA task, gateway layer 204 can reconstruct the task and generate a reconstructed process.
As shown in
Reconstructed process 210 can also specify the execution order of each subtask. As shown in
In some embodiments, when a subtask is completed, the corresponding resource can be released for use by other tasks. For example, after hardware emulation test 216 is completed, the corresponding hardware verification tool can return the execution result to gateway layer 204 and the hardware verification tool can be released.
In some embodiments, an EDA task from interface layer 202 can be a formal verification task of an IC design. In response to receiving the EDA task, gateway layer 204 can similarly reconstruct the task and generate a reconstructed process.
As shown in
Reconstructed process 220 can also specify the execution order of each subtask. As shown in
Gateway layer 204 can allocate computing resources for each subtask according to the characteristics of the subtask.
In some embodiments, gateway layer 204 can determine whether each of the above-described plurality of subtasks is suitable for cloud computing. In the conventional cloud computing, when a computing task requires computing elasticity (that is, it can require a large amount of computing resources in a short period of time), it can be considered that the computing task is suitable for cloud computing. However, in the EDA industry, users pay more attention to the source code security of the IC design, in addition to the consideration of computing elasticity requirements. Thus, in one example, gateway layer 204 can determine whether an input of each subtask is source code secure. The source code here refers to the source code of the logic system design related to the EDA task. If it is determined that the input of a subtask is not source code secure, a local computing resource can be allocated for the subtask as the computing resource. In this way, it can be ensured that the execution of the subtask is performed in a local secured environment without any risk of leaking the source code. If it is determined that the input of a subtask is source code secure, a cloud computing resource (e.g., cloud system 120) can be allocated for the subtask as the computing resource. In this way, the advantages of cloud computing can be fully utilized to accelerate EDA tasks.
As shown in
As another example, as shown in
Returning to
As discussed above, computing resources 134 can include a plurality of servers 134a and a plurality of hardware verification tools 134b. Each server 134a can be treated as a computing node. In some embodiments, server 134a can be further treated as a host connected with one or more hardware verification tools 134b, thereby including the one or more hardware verification tools 134b within the computing node. Each computing node is separately connected to each scheduler of scheduling layer 206. In some embodiments, the connection between the scheduler and hardware verification tool 134b needs to be implemented through server 134a as the host.
In some embodiments, computing resources 134 provide computing resources to resource manager 200 in a cloud-native manner. In this way, the increase or decrease of the underlying computing resources (e.g., servers or hardware verification tools) can not affect the provision of overall computing services.
While conventional technology can only start one EDA tool to complete one task (e.g., subtask in the present application) at a time, resource manager 200 of the embodiments of the present disclosure automates the execution of EDA tasks by reconstructing the process, so that the user does not have to keep an eye on the operation of EDA tools all the time and manually invoke the next EDA tool. It is appreciated that, conventionally, it is impossible to decompose one EDA task into a plurality of subtasks, reconstruct the process of one EDA task, and automatically allocate appropriate computing resources according to the characteristics of the subtasks.
At step 302, according to the EDA task, resource manager 200 can reconstruct the EDA task (e.g., an EDA task for coverage testing, an EDA task for formal verification, or the like) into a plurality of subtasks (e.g., subtasks 212-218 of
At step 304, resource manager 200 can determine a plurality of computing resources (e.g., local computing resource 134, cloud system 120 of
In some embodiments, resource manager 200 can reconstruct the EDA task into a plurality of subtasks that are executed according to a given process based on a plurality of currently available computing resources. For example, when local computing resources 134 have a large number of idle servers, resource manager 200 can preferentially allocate local computing resources 134 for executing the plurality of subtasks. As another example, when the timeliness of the EDA task is very high and local computing resources cannot complete the computation on time, resource manager 200 can preferentially invoke cloud computing resource 120 to execute at least a part of the plurality of subtasks. Therefore, even for the same EDA task, resource manager 200 can generate different given processes and different plurality of subtasks when the plurality of computing resources currently available are different.
The plurality of computing resources can include a first computing resource corresponding to the first subtask and a second computing resource corresponding to the second subtask. In some embodiments, the first computing resource and the second computing resource are different types of computing resources. For example, the first computing resource is a server, and the second computing resource is a hardware verification tool. In some embodiments, the first computing resource and the second computing resource are the same type of computing resource. For example, the first computing resource is a first server, and the second computing resource is a second server.
In some embodiments, determining the plurality of computing resources corresponding to the plurality of subtasks further includes: determining whether inputs of the first subtask (e.g., task 222 or 224 of
In some embodiments, determining the plurality of computing resources corresponding to the plurality of subtasks further includes: determining a plurality of EDA tools for respectively executing the plurality of subtasks; and determining a plurality of computing resources corresponding to the plurality of subtasks according to the plurality of EDA tools. For example, please refer to the description of
In some embodiments, the second subtask includes a plurality of parallel grandchild tasks. For example, when the second subtask is model-based solving 226 of
At step 306, resource manager 200 can invoke the plurality of computing resources according to the given process to execute the plurality of subtasks. In some embodiments, invoking the plurality of computing resources according to the given process to execute the plurality of subtasks further includes: receiving sub-execution results of the first subtask and the second subtask; and combining the sub-execution results into a single execution result. For example, subtask 218 can combine the execution results of subtasks 214 and 216, and generate a single execution result.
In some embodiments, in the given process, the first subtask (e.g., subtask 214 or 216 of
At step 308, resource manager 200 can generate an execution result of the EDA task according to the sub-execution results of the plurality of subtasks.
Embodiments of the disclosure also provide a computing apparatus for performing an EDA task (e.g., computing apparatus 100 in
Embodiments of the disclosure also provide a computing system (e.g., computing system 201 in
Embodiments of the present disclosure further provide a non-transitory computer-readable storage medium that stores a set of instructions of a computing apparatus. The set of instructions is used to cause the computing apparatus to perform the above-mentioned method 300.
As mentioned above, the method, apparatus, system, and storage medium for performing an EDA task provided by the present disclosure realize automatic execution of EDA tasks, global configuration of resources, collaboration among a plurality of EDA tasks (or tools) and secure cloud computing by reconstructing EDA tasks into a plurality of subtasks according to a given process sequence. It resolves a plurality of problems in the existing technologies.
Those skilled in the art can easily derive other embodiments of the present disclosure after considering and practicing the above disclosure. The present disclosure is aimed at covering any variations, use or adaptive changes of the present disclosure, and the variations, use or adaptive changes conform to the general principle of the present disclosure and include common knowledge or common technical means in the technical field not disclosed in the present disclosure. The specification and embodiments are merely regarded as exemplary, and the scope of the invention is defined by the accompanied claims.
It should be understood that the present disclosure is not limited to the accurate structure described above and illustrated in the drawings, and various modifications and changes can be made without departing from the scope thereof. The scope of the invention is only limited by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
202111374748.4 | Nov 2021 | CN | national |