CN114157654A - Integrated circuit collaborative design system and method - Google Patents

Integrated circuit collaborative design system and method Download PDF

Info

Publication number
CN114157654A
CN114157654A CN202111265414.3A CN202111265414A CN114157654A CN 114157654 A CN114157654 A CN 114157654A CN 202111265414 A CN202111265414 A CN 202111265414A CN 114157654 A CN114157654 A CN 114157654A
Authority
CN
China
Prior art keywords
eda
service
integrated circuit
compiling
operation request
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202111265414.3A
Other languages
Chinese (zh)
Other versions
CN114157654B (en
Inventor
孙广宇
罗国杰
韩平
张波
李亚军
李加敏
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Advanced Institute of Information Technology AIIT of Peking University
Hangzhou Weiming Information Technology Co Ltd
Original Assignee
Advanced Institute of Information Technology AIIT of Peking University
Hangzhou Weiming Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Advanced Institute of Information Technology AIIT of Peking University, Hangzhou Weiming Information Technology Co Ltd filed Critical Advanced Institute of Information Technology AIIT of Peking University
Priority to CN202111265414.3A priority Critical patent/CN114157654B/en
Publication of CN114157654A publication Critical patent/CN114157654A/en
Application granted granted Critical
Publication of CN114157654B publication Critical patent/CN114157654B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 

Abstract

The invention discloses a system and a method for integrated circuit collaborative design, wherein the system comprises: a client and an EDA cloud platform; the client side is in communication connection with the EDA cloud platform; the EDA cloud platform comprises a client side and an EDA cloud platform, wherein the client side is used for forwarding an operation request of the integrated circuit to the EDA cloud platform when receiving the operation request; and the EDA cloud platform is used for determining whether to create an integrated circuit compiling task according to the received operation request and carrying out automatic compiling based on the integrated circuit compiling task. Because the EDA tool is deployed to the cloud side to realize EDA development, the performance of the EDA tool can meet the complex chip design scene with the optimal configuration, the cost can be optimized, rapid expansion and recovery are realized, and the safety of each level of chip design can be ensured at last, so that the development cost of the integrated circuit is reduced, and the development efficiency of the integrated circuit is improved.

Description

Integrated circuit collaborative design system and method
Technical Field
The present invention relates to the field of integrated circuit design technologies, and in particular, to a system and a method for integrated circuit collaborative design.
Background
EDA (Electronic Design Automation) is a Design method for completing the processes of functional Design, integration, verification, physical Design (including layout, wiring, layout, Design rule check, etc.) and the like of a very large scale integrated circuit chip.
In conventional integrated circuit design steps, the design of a circuit designer is usually based on the conceptual idea of what functions the integrated circuit should perform. The circuit designer then performs the circuit design on a computer, often referred to as a server, and then runs one or more Electronic Design Automation (EDA) tools on the server to verify the circuit to ensure that it is functioning as intended. Current integrated circuits become more complex and circuit designers require a significant amount of computational power to help perform computational tasks to run these Electronic Design Automation (EDA) tools. The conventional EDA industry has a number of problems in developing EDA, such as: hardware cost is high, the flexibility is poor, one-time purchase investment is large, the research and development period is long, investment and risk are high, and due to the fact that hardware development thresholds are high, cost is large, and time is long, a plurality of users can be forbidden. Meanwhile, with the great growth of the market on chip requirements and the acceleration of product iteration speed, the cycle of chip design is required to be shorter. With the continuous evolution of the process, the total cost of chip design is also increased, the cost of EDA software and the cost of verification occupy most of the overall cost, and the time for verification and simulation greatly prolongs the research and development time.
Disclosure of Invention
The embodiment of the application provides a system and a method for integrated circuit collaborative design. The following presents a simplified summary in order to provide a basic understanding of some aspects of the disclosed embodiments. This summary is not an extensive overview and is intended to neither identify key/critical elements nor delineate the scope of such embodiments. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is presented later.
In a first aspect, an embodiment of the present application provides an integrated circuit collaborative design system, where the system includes:
a client and an EDA cloud platform; wherein the content of the first and second substances,
the client is in communication connection with the EDA cloud platform; wherein the content of the first and second substances,
the client is used for forwarding an operation request to the EDA cloud platform when the operation request of the integrated circuit is received;
and the EDA cloud platform is used for determining whether to create an integrated circuit compiling task according to the received operation request and carrying out automatic compiling based on the integrated circuit compiling task.
Optionally, the EDA cloud platform includes a task analysis module, an environment coordination module, and a compiling module; wherein the content of the first and second substances,
the task analysis module, the environment coordination module and the compiling module are electrically connected; wherein the content of the first and second substances,
the EDA cloud platform runs in a Docker environment, and the task analysis module, the environment cooperation module and the compiling module perform one-key deployment in a Docker mirror image mode.
Optionally, the task analysis module includes an EDA webpage end, a scheduling service, a Redis component, and an ETCD component; wherein the content of the first and second substances,
the EDA webpage end, the scheduling service, the Redis component and the ETCD component are electrically connected.
Optionally, the EDA webpage is configured to receive an operation request of the integrated circuit sent by the client, and determine whether to send the operation request to the scheduling service based on the operation request;
and the scheduling service is used for creating the compiling task when the operation request is the creating of the compiling task, updating the state of the compiling task to the ETCD component in real time, generating a calling instruction, sending the calling instruction to the cloud service, and sending the connecting address and the verification information to the EDA service when receiving the connecting address and the verification information sent by the cloud service.
Optionally, determining whether to send the operation request to the scheduling service based on the operation request includes:
analyzing the operation request to generate analysis information;
acquiring identity information of a requesting user from the analysis information;
identifying the identity information;
performing authority identification on the identified identity information to obtain an identification result;
and when the authentication result is the identifier passing the preset authentication, sending the operation request to the dispatching service.
Optionally, the environment coordination module includes a cloud service and an EDA service; wherein the content of the first and second substances,
cloud services and EDA services are communicatively connected.
Optionally, the cloud service is configured to obtain a parameter of the compiling task when receiving a call instruction from the scheduling service, create an operating environment of the compiling task based on the parameter, generate a connection address and verification information, and send the connection address and the verification information to the scheduling service;
and the EDA service is used for rendering an input file which can be acquired by the EDA proxy service according to the connection address and the verification information when the connection address and the verification information sent by the scheduling service are received, sending the input file to the EDA proxy service, and acquiring log information sent by the EDA proxy service in real time and forwarding the log information to the Redis component.
Optionally, the compiling module comprises an EDA agent service, a sentinel service, a compiling component set and an object storage component;
wherein the EDA agent service, the sentinel service, the compilation component set, and the object storage component are communicatively coupled.
Optionally, the EDA proxy service is configured to receive an input file sent by the EDA service, obtain the target compilation component from the compilation component set based on a task type of the compilation task, create a cloud server instance according to the input file, generate an execution result and log information after executing the cloud server instance according to the target compilation component, send the execution result to the object storage component for persistent storage, and forward the log information to the EDA service in real time;
and the sentinel service is used for destroying the cloud server instance after the cloud server instance execution is detected to be finished.
Optionally, the compilation component set includes a vivadd compiler, a vitas compiler, and an HLS compiler.
In a second aspect, an embodiment of the present application provides an integrated circuit collaborative design method, where the method includes:
when receiving an operation request of the integrated circuit, the client forwards the operation request to the EDA cloud platform;
the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request, and carries out automatic compiling based on the integrated circuit compiling task.
The technical scheme provided by the embodiment of the application can have the following beneficial effects:
in the embodiment of the application, when receiving an operation request of an integrated circuit, a client forwards the operation request to an EDA cloud platform, and the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request and carries out automatic compiling based on the integrated circuit compiling task. Because the EDA tool is deployed to the cloud side to realize EDA development, the performance of the EDA tool can meet the complex chip design scene with the optimal configuration, the cost can be optimized, rapid expansion and recovery are realized, and the safety of each level of chip design can be ensured at last, so that the development cost of the integrated circuit is reduced, and the development efficiency of the integrated circuit is improved.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
Drawings
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate embodiments consistent with the invention and together with the description, serve to explain the principles of the invention.
Fig. 1 is a schematic system structure diagram of an integrated circuit collaborative design system according to an embodiment of the present application;
fig. 2 is a schematic flowchart of a method for integrated circuit co-design according to an embodiment of the present disclosure;
fig. 3 is a schematic structural diagram of an electronic device according to an embodiment of the present application;
fig. 4 is a schematic diagram of a storage medium according to an embodiment of the present application.
Detailed Description
The following description and the drawings sufficiently illustrate specific embodiments of the invention to enable those skilled in the art to practice them.
It should be understood that the described embodiments are only some embodiments of the invention, and not all embodiments. All other embodiments, which can be derived by a person skilled in the art from the embodiments given herein without making any creative effort, shall fall within the protection scope of the present invention.
When the following description refers to the accompanying drawings, like numbers in different drawings represent the same or similar elements unless otherwise indicated. The embodiments described in the following exemplary embodiments do not represent all embodiments consistent with the present invention. Rather, they are merely examples of apparatus and methods consistent with certain aspects of the invention, as detailed in the appended claims.
In the description of the present invention, it is to be understood that the terms "first," "second," and the like are used for descriptive purposes only and are not to be construed as indicating or implying relative importance. The specific meanings of the above terms in the present invention can be understood in specific cases to those skilled in the art. In addition, in the description of the present invention, "a plurality" means two or more unless otherwise specified. "and/or" describes the association relationship of the associated objects, meaning that there may be three relationships, e.g., a and/or B, which may mean: a exists alone, A and B exist simultaneously, and B exists alone. The character "/" generally indicates that the former and latter associated objects are in an "or" relationship.
The application provides an integrated circuit collaborative design method, an integrated circuit collaborative design device, a storage medium and a terminal, which are used for solving the problems in the related technical problems. In the technical scheme provided by the application, because the EDA tool is deployed to the cloud side to realize EDA development, the performance of the EDA tool can meet the complex chip design scene with optimal configuration, cost optimization can be achieved, rapid expansion and recovery can be achieved, and finally the safety of each level of chip design can be guaranteed, so that the development cost of the integrated circuit is reduced, the development efficiency of the integrated circuit is improved, and the detailed description is carried out by adopting an exemplary embodiment.
Referring to fig. 1, a schematic structural diagram of an integrated circuit co-design system is provided according to an embodiment of the present disclosure. As shown in fig. 1, the system of the embodiment of the present application may include: a client and an EDA cloud platform; the client side is in communication connection with the EDA cloud platform; the EDA cloud platform comprises a client side and an EDA cloud platform, wherein the client side is used for forwarding an operation request of the integrated circuit to the EDA cloud platform when receiving the operation request; and the EDA cloud platform is used for determining whether to create an integrated circuit compiling task according to the received operation request and carrying out automatic compiling based on the integrated circuit compiling task.
In this embodiment, the EDA cloud platform includes a task analysis module, an environment coordination module, and a compiling module; the task analysis module, the environment coordination module and the compiling module are electrically connected; the EDA cloud platform runs in a Docker environment, and the task analysis module, the environment cooperation module and the compiling module are deployed in a one-key mode in a Docker mirror image mode.
Specifically, the client supports two use modes, namely a WEB interface and an SDK, provides an interactive interface and a programmable SDK for a user, and communicates with the EDA cloud platform through HTTP and WebSocket protocols.
Specifically, the EDA cloud platform supports both public cloud and private cloud deployments.
In this embodiment, the task analysis module includes an EDA webpage, a scheduling service, a Redis component, and an ETCD component; the EDA webpage end, the scheduling service, the Redis assembly and the ETCD assembly are electrically connected.
Further, the EDA webpage end is used for receiving an operation request of the integrated circuit sent by the client end and determining whether to send the operation request to the scheduling service or not based on the operation request; and the scheduling service is used for creating the compiling task when the operation request is the creating of the compiling task, updating the state of the compiling task to the ETCD component in real time, generating a calling instruction, sending the calling instruction to the cloud service, and sending the connecting address and the verification information to the EDA service when receiving the connecting address and the verification information sent by the cloud service.
Further, when determining whether to send the operation request to the scheduling service based on the operation request, the operation request is firstly analyzed to generate analysis information, the identity information of the requesting user is obtained from the analysis information, then the identity information is identified, then the identified identity information is subjected to authority identification to obtain an identification result, and finally the operation request is sent to the scheduling service when the identification result is an identifier which is passed through the preset identification.
Specifically, the EDA web page provides a uniform service interface for external components (e.g., clients) of the system, and facilitates interfacing with various front-end clients, such as: web interfaces and command lines, etc.
Specifically, the EDA webpage end mainly comprises an interaction component, namely a scheduling service and a Redis component. For example, when the obtained operation instruction is to create a compiling task or query a compiling task, the EDA webpage end forwards the operation request to the scheduling service through the RPC protocol after the user identification and authentication are made to pass, so as to create and query the compiling task; the EDA webpage end also integrates a Redis component and is used for monitoring the log information of the compiling task in real time.
Specifically, after receiving the operation request, the scheduling service integrally manages the execution of the compiling task, and executes the complex compiling task step by step according to the compiling task category and the state information reported by the task stream-end component.
Specifically, the scheduling service mainly includes a cloud service, an EDA service, an etc component, and an EDA web page side. After receiving the operation request, the scheduling service overall manages the execution of the compiling task, and the main interaction between the scheduling service and the EDA webpage end is the creation, query, deletion and the like of the compiling task, so that a query interface of the progress of the compiling task in the system is provided for the outside. The current state of the tasks is uniformly updated to the ETCD assembly. For the internal aspect, different compiling tasks need different running environments, and the different running environments can call an interface of a cloud service and create the running environments needed by the tasks; after the runtime environment is ready, the connection method and verification information of the runtime environment are collected and notified to the EDA service. Meanwhile, the scheduling service is also responsible for the functions of pre-checking of the execution of the compiling task, processing and retrying of errors reported by different components and the like.
In this embodiment, the environment coordination module includes a cloud service and an EDA service; wherein the cloud service and the EDA service are communicatively connected.
Specifically, the cloud service is used for acquiring parameters of the compiling task when receiving a calling instruction from the scheduling service, creating an operating environment of the compiling task based on the parameters, generating a connection address and verification information, and sending the connection address and the verification information to the scheduling service; and the EDA service is used for rendering an input file which can be acquired by the EDA proxy service according to the connection address and the verification information when the connection address and the verification information sent by the scheduling service are received, sending the input file to the EDA proxy service, and acquiring log information sent by the EDA proxy service in real time and forwarding the log information to the Redis component.
Specifically, the cloud service is an operating environment for preparing task execution, and supports public cloud and private cloud scenarios. An ECS cloud host running an EDA-Agent component and a Docker container are respectively created according to the deployment scene of the system. After the executable task environment is created, the scheduling service is informed of information such as a connection address of the task execution environment. And after the task is executed, the task is also responsible for destroying the operating environment.
Further, the compiling module comprises an EDA agent service, a sentinel service, a compiling component set and an object storage component;
wherein the EDA agent service, the sentinel service, the compilation component set, and the object storage component are communicatively coupled.
The EDA agent service is used for receiving an input file sent by the EDA service, acquiring a target compiling component from the compiling component set based on the task type of the compiling task, creating a cloud server instance according to the input file, generating an execution result and log information after executing the cloud server instance according to the target compiling component, sending the execution result to the object storage component for persistent storage, and forwarding the log information to the EDA service in real time; and the sentinel service is used for destroying the cloud server instance after the cloud server instance execution is detected to be finished.
Specifically, the sentinel service is used for security guard, and if a cloud computing instance is not destroyed in time, the sentinel service detects and forcibly destroys the instance.
Specifically, the EDA service is responsible for input preparation, execution and real-time task log forwarding of the compilation task. Before connecting the EDA agent service, the EDA agent service needs to be ready to render to be ready for acquiring the input file. And after the main and standby of the related files are finished, sending the related requests to an EDA proxy service to execute the compiling task, and forwarding the compiling log of the task in real time. Meanwhile, the related input file of the task is recorded to the ETCD component.
In particular, the EDA proxy service is a specific execution component for each compilation task. According to different task types, after the input file is acquired, VIVADO, VITIS or HLS related components are called to execute tasks; and synchronizing the log to a designated channel, and after the task is executed, uploading the important compiled product to an object storage component for persistent storage and subsequently providing access for a user.
Further, the compilation component set includes a vivadd compiler, a vitas compiler, and an HLS compiler.
Specifically, the vivadd compiler, the VITIS compiler, and the HLS compiler support the compilation (synthesis, placement, routing) of the vivadd, the VITIS, and the HLS.
Specifically, the Redis component is responsible for subscribing and publishing a real-time log information channel, the ETCD component is responsible for storing and notifying a task execution state, and the object storage component is responsible for storing data needing to be persisted, including log information, a source file submitted by a user and the like.
In this embodiment, the container of the cloud server instance is an EDA software execution environment, and the EDA proxy service, the vivadd compiler, the vitas compiler, and the HLS compiler all run in this environment. The preset software is mounted in the running environment in a read-only mode through the file system, and the preset installation effect of compiling the software is achieved. When the component is started, the EDA agent service is immediately run, and the service port is exposed to the outside. When a new task is executed, a cloud server instance is newly built to perform specific task execution work, and after the execution is completed, the cloud server instance is destroyed, so that resources are saved, and the cost is saved.
It should be noted that each component of the EDA cloud platform is made into a Docker image, and can run in a Docker environment. In a public cloud environment, the EDA cloud platform can perform one-key deployment by using Docker; one-key deployment of Doker images with k8s is possible in private cloud environments.
It should be noted that the EDA cloud platform needs to simultaneously deploy Redis, ETCD, and Postgresql components to provide basic services for the platform, and these basic services are also made into standard Docker images, and the entire EDA cloud platform supports Docker-based one-key deployment, and the deployment and the later maintenance are very convenient.
In the embodiment of the application, when receiving an operation request of an integrated circuit, a client forwards the operation request to an EDA cloud platform, and the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request and carries out automatic compiling based on the integrated circuit compiling task. Because the EDA tool is deployed to the cloud side to realize EDA development, the performance of the EDA tool can meet the complex chip design scene with the optimal configuration, the cost can be optimized, rapid expansion and recovery are realized, and the safety of each level of chip design can be ensured at last, so that the development cost of the integrated circuit is reduced, and the development efficiency of the integrated circuit is improved.
Referring to fig. 2, a method flow diagram of an integrated circuit co-design method is provided according to an embodiment of the present application. As shown in fig. 2, the method of the embodiment of the present application includes the following steps:
s101, when receiving an operation request of an integrated circuit, a client forwards the operation request to an EDA cloud platform;
and S102, the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request, and carries out automatic compiling based on the integrated circuit compiling task.
In a possible implementation manner, after the automatic compiling is finished, a required compiling file can be generated, and the compiling file can be mounted in an FPGA preset in the EDA cloud platform to run to obtain a running result.
In the embodiment of the application, when receiving an operation request of an integrated circuit, a client forwards the operation request to an EDA cloud platform, and the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request and carries out automatic compiling based on the integrated circuit compiling task. Because the EDA tool is deployed to the cloud side to realize EDA development, the performance of the EDA tool can meet the complex chip design scene with the optimal configuration, the cost can be optimized, rapid expansion and recovery are realized, and the safety of each level of chip design can be ensured at last, so that the development cost of the integrated circuit is reduced, and the development efficiency of the integrated circuit is improved.
The embodiment of the application also provides electronic equipment so as to execute the integrated circuit collaborative design method of the electronic equipment. Please refer to fig. 3, which illustrates a schematic diagram of an electronic device according to some embodiments of the present application. As shown in fig. 3, the electronic apparatus 4 includes: a processor 400, a memory 401, a bus 402 and a communication interface 403, wherein the processor 400, the communication interface 403 and the memory 401 are connected through the bus 402; the memory 401 stores a computer program that can be executed on the processor 400, and the processor 400 executes the method for designing an integrated circuit of an electronic device provided in any of the foregoing embodiments when executing the computer program.
The Memory 401 may include a high-speed Random Access Memory (RAM) and may further include a non-volatile Memory (non-volatile Memory), such as at least one disk Memory. The communication connection between the network element of the apparatus and at least one other network element is realized through at least one communication interface 403 (which may be wired or wireless), and the internet, a wide area network, a local network, a metropolitan area network, etc. may be used.
Bus 402 can be an ISA bus, PCI bus, EISA bus, or the like. The bus may be divided into an address bus, a data bus, a control bus, etc. The memory 401 is used for storing a program, and the processor 400 executes the program after receiving an execution instruction, and the method for integrated circuit co-design of an electronic device disclosed in any of the embodiments of the present application may be applied to the processor 400, or implemented by the processor 400.
Processor 400 may be an integrated circuit chip having signal processing capabilities. In implementation, the steps of the above method may be performed by integrated logic circuits of hardware or instructions in the form of software in the processor 400. The Processor 400 may be a general-purpose Processor, and includes a Central Processing Unit (CPU), a Network Processor (NP), and the like; but may also be a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), an off-the-shelf programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components. The various methods, steps, and logic blocks disclosed in the embodiments of the present application may be implemented or performed. A general purpose processor may be a microprocessor or the processor may be any conventional processor or the like. The steps of the method disclosed in connection with the embodiments of the present application may be directly implemented by a hardware decoding processor, or implemented by a combination of hardware and software modules in the decoding processor. The software module may be located in ram, flash memory, rom, prom, or eprom, registers, etc. storage media as is well known in the art. The storage medium is located in the memory 401, and the processor 400 reads the information in the memory 401 and completes the steps of the method in combination with the hardware.
The electronic device provided by the embodiment of the present application and the integrated circuit co-design method provided by the electronic device provided by the embodiment of the present application have the same beneficial effects as the methods adopted, operated or implemented by the electronic device, based on the same inventive concept.
Referring to fig. 4, the computer readable storage medium is an optical disc 30, and a computer program (i.e., a program product) is stored thereon, and when being executed by a processor, the computer program executes the integrated circuit co-design method provided in any of the foregoing embodiments.
It should be noted that examples of the computer-readable storage medium may also include, but are not limited to, phase change memory (PRAM), Static Random Access Memory (SRAM), Dynamic Random Access Memory (DRAM), other types of Random Access Memory (RAM), Read Only Memory (ROM), Electrically Erasable Programmable Read Only Memory (EEPROM), flash memory, or other optical and magnetic storage media, which are not described in detail herein.
The computer-readable storage medium provided by the above-mentioned embodiments of the present application and the integrated circuit co-design method provided by the embodiments of the present application have the same beneficial effects as the method adopted, operated or implemented by the application program stored in the computer-readable storage medium.
The above description is only for the preferred embodiment of the present application, but the scope of the present application is not limited thereto, and any changes or substitutions that can be easily conceived by those skilled in the art within the technical scope of the present application should be covered within the scope of the present application. Therefore, the protection scope of the present application shall be subject to the protection scope of the claims.
It will be understood by those skilled in the art that all or part of the processes of the methods of the embodiments described above can be implemented by a computer program to instruct associated hardware, and the integrated circuit co-design program can be stored in a computer-readable storage medium, and when executed, can include the processes of the embodiments of the methods described above. The storage medium may be a magnetic disk, an optical disk, a read-only memory or a random access memory.
The above disclosure is only for the purpose of illustrating the preferred embodiments of the present application and is not to be construed as limiting the scope of the present application, so that the present application is not limited thereto, and all equivalent variations and modifications can be made to the present application.

Claims (10)

1. An integrated circuit co-design system, the system comprising:
a client and an EDA cloud platform; wherein the content of the first and second substances,
the client is in communication connection with the EDA cloud platform; wherein the content of the first and second substances,
the client is used for forwarding an operation request of the integrated circuit to the EDA cloud platform when the operation request is received;
the EDA cloud platform is used for determining whether to create an integrated circuit compiling task according to the received operation request and carrying out automatic compiling based on the integrated circuit compiling task.
2. An integrated circuit co-design system according to claim 1,
the EDA cloud platform comprises a task analysis module, an environment cooperation module and a compiling module; wherein the content of the first and second substances,
the task analysis module, the environment coordination module and the compiling module are electrically connected; wherein the content of the first and second substances,
the EDA cloud platform runs in a Docker environment, and the task analysis module, the environment cooperation module and the compiling module are deployed in a one-key mode in a Docker mirror image mode.
3. An integrated circuit co-design system according to claim 2,
the task analysis module comprises an EDA webpage end, a scheduling service, a Redis component and an ETCD component; wherein the content of the first and second substances,
the EDA webpage end, the scheduling service, the Redis assembly and the ETCD assembly are electrically connected.
4. An integrated circuit co-design system according to claim 3,
the EDA webpage end is used for receiving an operation request of the integrated circuit sent by a client end and determining whether to send the operation request to a scheduling service or not based on the operation request;
and the scheduling service is used for creating a compiling task when the operation request is the compiling task, updating the state of the compiling task to the ETCD assembly in real time, generating a calling instruction, sending the calling instruction to a cloud service, and sending a connection address and verification information to the EDA service when receiving the connection address and the verification information sent by the cloud service.
5. The IC co-design system of claim 4, wherein the determining whether to send the operation request to a scheduling service based on the operation request comprises:
analyzing the operation request to generate analysis information;
acquiring identity information of a requesting user from the analysis information;
identifying the identity information;
performing authority identification on the identified identity information to obtain an identification result;
and when the identification result is the identifier passing the preset identification, sending the operation request to a dispatching service.
6. An integrated circuit co-design system according to claim 4,
the environment cooperation module comprises cloud services and EDA services; wherein the content of the first and second substances,
the cloud service and the EDA service are in communication connection.
7. An integrated circuit co-design system according to claim 6,
the cloud service is used for acquiring parameters of the compiling task when receiving a calling instruction from the scheduling service, creating an operating environment of the compiling task based on the parameters, generating a connection address and verification information and sending the connection address and the verification information to the scheduling service;
the EDA service is used for rendering an input file which can be acquired by the EDA proxy service according to the connection address and the verification information when the connection address and the verification information sent by the scheduling service are received, sending the input file to the EDA proxy service, and acquiring log information sent by the EDA proxy service in real time and forwarding the log information to the Redis component.
8. An integrated circuit co-design system according to claim 4,
the compiling module comprises an EDA agent service, a sentinel service, a compiling component set and an object storage component;
wherein the EDA agent service, the sentinel service, the compilation component set, and the object storage component are communicatively coupled.
9. An integrated circuit co-design system according to claim 8,
the EDA agent service is used for receiving an input file sent by the EDA service, acquiring a target compiling component from the compiling component set based on the task type of the compiling task, creating a cloud server instance according to the input file, generating an execution result and log information after executing the cloud server instance according to the target compiling component, sending the execution result to the object storage component for persistent storage, and forwarding the log information to the EDA service in real time;
and the sentinel service is used for destroying the cloud server instance after the execution of the cloud server instance is detected to be finished.
10. A method of integrated circuit co-design, the method comprising:
when receiving an operation request of an integrated circuit, a client forwards the operation request to the EDA cloud platform;
the EDA cloud platform determines whether to create an integrated circuit compiling task according to the received operation request, and carries out automatic compiling based on the integrated circuit compiling task.
CN202111265414.3A 2021-10-28 2021-10-28 Integrated circuit collaborative design system and method Active CN114157654B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111265414.3A CN114157654B (en) 2021-10-28 2021-10-28 Integrated circuit collaborative design system and method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111265414.3A CN114157654B (en) 2021-10-28 2021-10-28 Integrated circuit collaborative design system and method

Publications (2)

Publication Number Publication Date
CN114157654A true CN114157654A (en) 2022-03-08
CN114157654B CN114157654B (en) 2024-03-19

Family

ID=80458493

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111265414.3A Active CN114157654B (en) 2021-10-28 2021-10-28 Integrated circuit collaborative design system and method

Country Status (1)

Country Link
CN (1) CN114157654B (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114938279A (en) * 2022-06-16 2022-08-23 浪潮集团有限公司 Quantum chip EDA design method with safety certification based on cloud platform
CN115081369A (en) * 2022-08-16 2022-09-20 中国电子科技集团公司信息科学研究院 Micro-system collaborative design method

Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100115501A1 (en) * 2008-10-30 2010-05-06 International Business Machines Corporation Distributed just-in-time compilation
CN102263823A (en) * 2011-07-25 2011-11-30 中兴通讯股份有限公司 Communication method and communication device based on cloud computing
CN104539487A (en) * 2015-01-20 2015-04-22 成都益联科创科技有限公司 Method for testing system based on cloud platform and evaluating reliability
CN106095523A (en) * 2016-06-03 2016-11-09 北京奇虎科技有限公司 A kind of method and system realizing Android compiling isolation
CN108121543A (en) * 2017-11-30 2018-06-05 北京奇安信科技有限公司 A kind of software code process of compilation method and device
US20180173822A1 (en) * 2016-12-21 2018-06-21 Arm Limited Corner Database Generator
CN109240662A (en) * 2018-08-09 2019-01-18 赛尔网络有限公司 A kind of software development methodology based on cloud platform, cloud platform, equipment and medium
CN110955432A (en) * 2019-11-20 2020-04-03 中国联合网络通信集团有限公司 Continuously integrated publishing method, device and system
CN111240686A (en) * 2020-01-09 2020-06-05 江苏满运软件科技有限公司 Cloud compiling method and system, terminal device, cloud server and storage medium
CN111273960A (en) * 2020-01-20 2020-06-12 山东汇贸电子口岸有限公司 Method for realizing cloud native MIPS architecture container cloud
CN111381829A (en) * 2020-03-06 2020-07-07 北京达佳互联信息技术有限公司 Online programming method and device, electronic equipment and storage medium
CN111984261A (en) * 2019-05-24 2020-11-24 北京京东尚科信息技术有限公司 Compiling method and compiling system
CN112328301A (en) * 2020-10-28 2021-02-05 北京百度网讯科技有限公司 Method and device for maintaining consistency of operating environments, storage medium and electronic equipment
CN113467857A (en) * 2020-08-20 2021-10-01 深圳市洲明科技股份有限公司 FPGA system based on user customization, firmware generation method and display device

Patent Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100115501A1 (en) * 2008-10-30 2010-05-06 International Business Machines Corporation Distributed just-in-time compilation
CN102263823A (en) * 2011-07-25 2011-11-30 中兴通讯股份有限公司 Communication method and communication device based on cloud computing
CN104539487A (en) * 2015-01-20 2015-04-22 成都益联科创科技有限公司 Method for testing system based on cloud platform and evaluating reliability
CN106095523A (en) * 2016-06-03 2016-11-09 北京奇虎科技有限公司 A kind of method and system realizing Android compiling isolation
US20180173822A1 (en) * 2016-12-21 2018-06-21 Arm Limited Corner Database Generator
CN108121543A (en) * 2017-11-30 2018-06-05 北京奇安信科技有限公司 A kind of software code process of compilation method and device
CN109240662A (en) * 2018-08-09 2019-01-18 赛尔网络有限公司 A kind of software development methodology based on cloud platform, cloud platform, equipment and medium
CN111984261A (en) * 2019-05-24 2020-11-24 北京京东尚科信息技术有限公司 Compiling method and compiling system
CN110955432A (en) * 2019-11-20 2020-04-03 中国联合网络通信集团有限公司 Continuously integrated publishing method, device and system
CN111240686A (en) * 2020-01-09 2020-06-05 江苏满运软件科技有限公司 Cloud compiling method and system, terminal device, cloud server and storage medium
CN111273960A (en) * 2020-01-20 2020-06-12 山东汇贸电子口岸有限公司 Method for realizing cloud native MIPS architecture container cloud
CN111381829A (en) * 2020-03-06 2020-07-07 北京达佳互联信息技术有限公司 Online programming method and device, electronic equipment and storage medium
CN113467857A (en) * 2020-08-20 2021-10-01 深圳市洲明科技股份有限公司 FPGA system based on user customization, firmware generation method and display device
CN112328301A (en) * 2020-10-28 2021-02-05 北京百度网讯科技有限公司 Method and device for maintaining consistency of operating environments, storage medium and electronic equipment

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
陈凡;: "嵌入式系统可视化编译平台设计", 电子技术与软件工程, no. 14, pages 1 - 3 *
陈文驰;: "Docker前端发布平台的开发设计", 信息与电脑(理论版), no. 11, pages 1 - 3 *
黄诤杰 等: "基于云计算技术的在线编译平台的设计分析", 安全模型、算法与编程, pages 0 - 3 *
黄诤杰;董希福;郑川;: "基于云计算技术的在线编译平台的设计分析", 网络安全技术与应用, no. 08, pages 1 - 3 *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114938279A (en) * 2022-06-16 2022-08-23 浪潮集团有限公司 Quantum chip EDA design method with safety certification based on cloud platform
CN115081369A (en) * 2022-08-16 2022-09-20 中国电子科技集团公司信息科学研究院 Micro-system collaborative design method
CN115081369B (en) * 2022-08-16 2022-11-15 中国电子科技集团公司信息科学研究院 Micro-system collaborative design method

Also Published As

Publication number Publication date
CN114157654B (en) 2024-03-19

Similar Documents

Publication Publication Date Title
CN110704518B (en) Business data processing method and device based on Flink engine
CN107896162B (en) Deployment method and device of monitoring system, computer equipment and storage medium
WO2019072110A1 (en) Method for generating application program, apparatus, system, device, and medium
CN114157654B (en) Integrated circuit collaborative design system and method
CN111427766A (en) Request processing method and device and proxy server
CN109271359B (en) Log information processing method and device, electronic equipment and readable storage medium
CN111988337B (en) Authority management method and system
CN107608681A (en) Installation method of operating system, device and server
CN110673923A (en) XWIKI system configuration method, system and computer equipment
CN110928802A (en) Test method, device, equipment and storage medium based on automatic generation of case
CN109040263B (en) Service processing method and device based on distributed system
CN113590595A (en) Database multi-writing method and device and related equipment
CN112954040A (en) Method, system, device and storage medium for embedding application release server
CN112579142A (en) Application program issuing method and device for industrial Internet
CN110727575B (en) Information processing method, system, device and storage medium
CN106802790B (en) Method, equipment and system for managing application user use information based on cloud platform
CN111124480A (en) Application package generation method and device, electronic equipment and storage medium
CN108595178B (en) Hook-based data acquisition method, device and equipment
CN113434932A (en) Collision detection method and device of BIM (building information modeling) model and electronic equipment
CN109508193B (en) Application deployment and operation method, device, terminal equipment and medium
CN112527459A (en) Log analysis method and device based on Kubernetes cluster
CN111367519B (en) Page part using method and device, computing equipment and computer storage medium
CN115048082A (en) Micro front-end system construction method and device, server and readable storage medium
CN113721940A (en) Software deployment method and device, electronic equipment and storage medium
CN112579448A (en) Debugging method and system for hybrid application

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant