US20140040685A1 - Built-in-self-test (bist) organizational file generation - Google Patents
Built-in-self-test (bist) organizational file generation Download PDFInfo
- Publication number
- US20140040685A1 US20140040685A1 US13/567,127 US201213567127A US2014040685A1 US 20140040685 A1 US20140040685 A1 US 20140040685A1 US 201213567127 A US201213567127 A US 201213567127A US 2014040685 A1 US2014040685 A1 US 2014040685A1
- Authority
- US
- United States
- Prior art keywords
- bist
- file
- memory
- organizational
- type
- 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
Links
- 238000012360 testing method Methods 0.000 title claims abstract description 12
- 230000015654 memory Effects 0.000 claims abstract description 122
- 238000013461 design Methods 0.000 claims abstract description 42
- 238000000034 method Methods 0.000 claims abstract description 28
- 238000004590 computer program Methods 0.000 claims description 8
- 238000012546 transfer Methods 0.000 claims description 4
- 238000012545 processing Methods 0.000 description 5
- 230000008520 organization Effects 0.000 description 3
- 238000010586 diagram Methods 0.000 description 2
- 230000037361 pathway Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 230000006837 decompression Effects 0.000 description 1
- 230000010365 information processing Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/54—Arrangements for designing test circuits, e.g. design for test [DFT] tools
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/04—Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
- G11C29/08—Functional testing, e.g. testing during refresh, power-on self testing [POST] or distributed testing
- G11C29/12—Built-in arrangements for testing, e.g. built-in self testing [BIST] or interconnection details
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C5/00—Details of stores covered by group G11C11/00
- G11C5/02—Disposition of storage elements, e.g. in the form of a matrix array
- G11C5/04—Supports for storage elements, e.g. memory modules; Mounting or fixing of storage elements on such supports
Definitions
- the subject matter disclosed herein relates generally to integrated circuits. More specifically, the disclosure provided herein relates to methods for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip.
- BIST built-in-self-test
- a BIST organizational file is a data structure that represents a customer's desired memory BIST organization for a particular chip design, or a subset of the chip design.
- a chip design may contain hundreds or thousands of embedded memories that must be tested. Since each hierarchical memory wrapper instance name must be represented in the BIST organizational file, it would take a significant amount of time to manually develop a BIST organizational file.
- a method includes: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- a first aspect of the invention provides a computer-implemented method of creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip, the method comprising: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- BIST built-in-self-test
- a second aspect of the invention provides a computer program comprising program code embodied in at least one computer-readable medium, which when executed, enables a computer system to implement a method of creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip, the method comprising: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- BIST built-in-self-test
- a third aspect of the invention provides a computer system, comprising: at least one computing device configured to create a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip by: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- BIST built-in-self-test
- FIG. 1 shows an illustrative environment according to embodiments of the invention.
- FIG. 2 shows a flow diagram according to embodiments of the invention.
- FIG. 3 shows a design file according to embodiments of the invention.
- FIG. 4 shows an ordered list of memory wrappers according to embodiments of the invention.
- FIG. 5 shows a design file according to embodiments of the invention.
- FIG. 6 shows a module reference file according to embodiments of the invention.
- FIG. 7 shows an ordered list of memory wrappers according to embodiments of the invention.
- FIG. 8A-8B show a BIST organizational file according to embodiments of the invention.
- FIG. 9 shows a design file according to embodiments of the invention.
- FIG. 10 shows a module reference file according to embodiments of the invention.
- FIG. 11 shows a BIST organizational file according to embodiments of the invention.
- the subject matter disclosed herein relates generally to integrated circuits. More specifically, the disclosure provided herein relates to methods for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip.
- BIST built-in-self-test
- a BIST organizational file is a data structure that represents a customer's desired memory BIST organization for a particular chip design, or a subset of the chip design.
- a chip design may contain hundreds or thousands of embedded memories that must be tested. Since each hierarchical memory wrapper instance name must be represented in the BIST organizational file, it would take a significant amount of time to manually develop a BIST organizational file.
- a method includes: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- the BIST organizational file created is a default file that can be modified by the customer, according to the customer's specific desired arrangement.
- environment 10 includes a computer system 20 that can perform a process described herein in order to create a BIST organizational file 60 for an IC.
- computer system 20 is shown including a grouping program BIST file program 30 , which makes computer system 20 operable to create BIST organizational file 10 by performing the process described below with respect to FIGS. 2-10 .
- Computer system 20 is shown including a processing component 22 (e.g., one or more processors), a storage component 24 (e.g., a storage hierarchy), an input/output (I/O) component 26 (e.g., one or more I/O interfaces and/or devices), and a communications pathway 28 .
- processing component 22 executes program code, such as BIST file program 30 , which is at least partially fixed in storage component 24 . While executing program code, processing component 22 can process data, which can result in reading and/or writing transformed data from/to storage component 24 and/or I/O component 26 for further processing.
- Pathway 28 provides a communications link between each of the components in computer system 20 .
- I/O component 26 can comprise one or more human I/O devices, which enable a human user 12 to interact with computer system 20 and/or one or more communications devices to enable a system user 12 to communicate with computer system 20 using any type of communications link.
- BIST file program 30 can manage a set of interfaces (e.g., graphical user interface(s), application program interface, and/or the like) that enable human and/or system users 12 to interact with BIST file program 30 .
- BIST file program 30 can manage (e.g., store, retrieve, create, manipulate, organize, present, etc.) the data, such as a design file 40 , a module reference file (MRF) 42 , or a BIST tech file (BTF) 46 , using any solution.
- MRF module reference file
- BTF BIST tech file
- computer system 20 can comprise one or more general purpose computing articles of manufacture (e.g., computing devices) capable of executing program code, such as BIST file program 30 , installed thereon.
- program code means any collection of instructions, in any language, code or notation, that cause a computing device having an information processing capability to perform a particular action either directly or after any combination of the following: (a) conversion to another language, code or notation; (b) reproduction in a different material form; and/or (c) decompression.
- BIST file program 30 can be embodied as any combination of system software and/or application software.
- BIST file program 30 can be implemented using a set of modules 32 .
- a module 32 can enable computer system 20 to perform a set of tasks used by BIST file program 30 , and can be separately developed and/or implemented apart from other portions of BIST file program 30 .
- the term “component” means any configuration of hardware, with or without software, which implements the functionality described in conjunction therewith using any solution, while the term “module” means program code that enables a computer system 20 to implement the actions described in conjunction therewith using any solution.
- a module is a substantial portion of a component that implements the actions. Regardless, it is understood that two or more components, modules, and/or systems may share some/all of their respective hardware and/or software. Further, it is understood that some of the functionality discussed herein may not be implemented or additional functionality may be included as part of computer system 20 .
- each computing device can have only a portion of BIST file program 30 fixed thereon (e.g., one or more modules 32 ).
- BIST file program 30 are only representative of various possible equivalent computer systems that may perform a process described herein.
- the functionality provided by computer system 20 and BIST file program 30 can be at least partially implemented by one or more computing devices that include any combination of general and/or specific purpose hardware with or without program code.
- the hardware and program code, if included, can be created using standard engineering and programming techniques, respectively.
- computer system 20 when computer system 20 includes multiple computing devices, the computing devices can communicate over any type of communications link. Further, while performing a process described herein, computer system 20 can communicate with one or more other computer systems using any type of communications link.
- the communications link can comprise any combination of various types of optical fiber, wired, and/or wireless links; comprise any combination of one or more types of networks; and/or utilize any combination of various types of transmission techniques and protocols.
- BIST file program 30 enables computer system 20 to create a BIST organizational file 60 of an IC (e.g., represented by design file 40 ). To this extent, computer system 20 may perform the method according to aspects of the invention, as discussed herein with respect to FIGS. 2-11 .
- a design file 40 is received that includes a hierarchy of memory modules.
- a top level memory module 102 (“Module 1”) includes memory modules 106 , 108 , 110 .
- the design file 40 may include any type of abstraction or specification, as known in the art, including, but not limited to register-transfer-level abstraction.
- InstA memory module 106 (“Module_a”) and InstaB memory module 108 (“Module_a”) are identical modules. That is, they contain the same plurality of memory wrappers. Hence, both are “Module_a.”
- InstC memory module 110 (“Module_b”) is a different memory module and includes different memory wrappers.
- some examples of memory wrappers include, but are not limited to, “WRAP1S,” “WRAP2T,” and “WRAPCAM.” However, it is understood that these types of memory wrappers are for exemplary purposes only, and that any now known or later developed memory wrappers may be applicable to this disclosure. Additional top-level memory wrappers 104 are also shown.
- each memory wrapper in each hierarchical level of memory modules 102 , 106 , 108 , 110 are scanned to determine a BIST type for each memory wrapper.
- a BIST tech file 44 ( FIG. 1 ) is received and scanned.
- the hierarchical level of the memory wrapper (i.e., which memory module the memory wrapper belongs to) and the BIST type is used to create an ordered list of memory wrappers.
- FIG. 4 an ordered list 46 of memory wrappers for the design file 40 of FIG. 3 is shown.
- the top level memory wrappers 104 (“Inst1,” “Inst2,” “Inst3,” “Inst4,” “Inst5,” “Inst6,” and “Inst7) are shown in a first group 48 .
- the memory wrappers for InstA memory module 106 are shown in a second group 50 .
- the memory wrappers for InstB memory module 108 are shown in a third group 52 and the memory wrappers for InstC memory module 110 are shown in a fourth group 54 .
- FIG. 5 a design file 40 according to an alternative embodiment of the invention is shown.
- InstA memory module 106 and InstB memory module 108 in design file 40 in FIG. 5 already include BIST engines (“BIST1S” and “BIST2T”) for the plurality of memory wrappers within these memory modules. Therefore, in this embodiment, a module reference file (MRF) 42 is received, at S 5 .
- An example of a MRF 42 is shown in FIG. 6 .
- MRF 42 lists “Module_a” as already including BIST engines.
- S 2 only the memory modules not listed in the MRF 42 are scanned for a BIST type. Therefore, InstA memory module 106 and InstB memory module 108 , since they are “Module_a” type, are not scanned at S 2 . Only the top level memory modules 104 and InstC memory module 110 are scanned.
- FIG. 7 An example of the ordered list 46 for the design file 40 shown in FIG. 5 is shown in FIG. 7 . As clearly seen in FIG. 7 , only a first group 48 for the top level memory modules 104 and a fourth group 54 for InstC memory module 110 is shown.
- a BIST engine based on the BIST type from the BTF 44 ( FIG. 1 ), is added for each memory wrapper listed in the ordered list 46 .
- MRF 42 FIG. 6
- MRF 42 FIG. 6
- a level for creating the BIST organizational file 60 is determined The level is directed by the user, as an additional User Input 31 , as shown in FIG. 1 , when running BIST program file 30 .
- the level is assumed to be a level lower than the “top level”.
- a plurality of additional statements are added to the ordered list 46 in order to create the BIST organizational file 60 , as shown, for example, in FIGS. 8A and 8B or FIG. 11 .
- FIGS. 8A and 8B show the BIST organizational file 60 that is created by adding additional statements.
- FIG. 9 is exemplary of a design file 40 where only the top level memory wrappers 104 need BIST engines. All other memory modules 106 , 108 , 110 already include the necessary BIST engines for the plurality of memory wrappers.
- MRF 43 is used to specify, for design file 40 of FIG. 9 , that both Module_a and Module_b have already have had BIST engines inserted, and all instances of both Module_a and Module_b must be excluded, when searching design file 40 for instances of memory wrappers. Furthermore, as shown in MRF 43 , it is also specified that Module_a has one occurrence of a “BISTCNTL_ref1” view and Module_b has two occurrences of views associated with it, specifically a “WRAP_FUSECNTL_ref1” view and a “BISTCNTL_ref1” view.
- top_ref Top”; “WRAP_CC_ECID_T09”; “WRAP FUSECENTL_T09”; “WRAP_BISTCNTL_T09”; and “end_top_ref.”
- the BIST organization file 60 shown in the figures may be a text file, or any other file as known in the art. Therefore, once a customer receives the default BIST organizational file 60 as shown in FIGS. 6 and 11 , the customer may modify the BIST organizational 60 .
Landscapes
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
Description
- The subject matter disclosed herein relates generally to integrated circuits. More specifically, the disclosure provided herein relates to methods for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip.
- A BIST organizational file is a data structure that represents a customer's desired memory BIST organization for a particular chip design, or a subset of the chip design. A chip design may contain hundreds or thousands of embedded memories that must be tested. Since each hierarchical memory wrapper instance name must be represented in the BIST organizational file, it would take a significant amount of time to manually develop a BIST organizational file.
- Aspects of the invention provide for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip. In one embodiment, a method includes: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- A first aspect of the invention provides a computer-implemented method of creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip, the method comprising: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- A second aspect of the invention provides a computer program comprising program code embodied in at least one computer-readable medium, which when executed, enables a computer system to implement a method of creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip, the method comprising: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- A third aspect of the invention provides a computer system, comprising: at least one computing device configured to create a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip by: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file.
- These and other features of this invention will be more readily understood from the following detailed description of the various aspects of the invention taken in conjunction with the accompanying drawings that depict various embodiments of the invention, in which:
-
FIG. 1 shows an illustrative environment according to embodiments of the invention. -
FIG. 2 shows a flow diagram according to embodiments of the invention. -
FIG. 3 shows a design file according to embodiments of the invention. -
FIG. 4 shows an ordered list of memory wrappers according to embodiments of the invention. -
FIG. 5 shows a design file according to embodiments of the invention. -
FIG. 6 shows a module reference file according to embodiments of the invention. -
FIG. 7 shows an ordered list of memory wrappers according to embodiments of the invention. -
FIG. 8A-8B show a BIST organizational file according to embodiments of the invention. -
FIG. 9 shows a design file according to embodiments of the invention. -
FIG. 10 shows a module reference file according to embodiments of the invention. -
FIG. 11 shows a BIST organizational file according to embodiments of the invention. - It is noted that the drawings of the invention are not to scale. The drawings are intended to depict only typical aspects of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements between the drawings.
- As mentioned above, the subject matter disclosed herein relates generally to integrated circuits. More specifically, the disclosure provided herein relates to methods for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip.
- A BIST organizational file is a data structure that represents a customer's desired memory BIST organization for a particular chip design, or a subset of the chip design. A chip design may contain hundreds or thousands of embedded memories that must be tested. Since each hierarchical memory wrapper instance name must be represented in the BIST organizational file, it would take a significant amount of time to manually develop a BIST organizational file.
- Aspects of the invention provide for creating a built-in-self-test (BIST) organizational file for an integrated circuit (IC) chip. In one embodiment, a method includes: receiving a design file including a hierarchy of memory modules, each module including a plurality of memory wrappers; scanning each memory wrapper in each hierarchical level of memory modules for a BIST type; creating, based on the hierarchical level and the BIST type, an ordered list of memory wrappers; adding, based on the BIST type, a BIST engine for each memory wrapper listed in the ordered list; and adding a plurality of references statements to the ordered list to create the BIST organizational file. The BIST organizational file created is a default file that can be modified by the customer, according to the customer's specific desired arrangement.
- Turning now to
FIG. 1 , anillustrative environment 10 for creating a BISTorganizational file 60 for an IC according to embodiments of the invention is shown. To this extent,environment 10 includes acomputer system 20 that can perform a process described herein in order to create a BISTorganizational file 60 for an IC. In particular,computer system 20 is shown including a grouping programBIST file program 30, which makescomputer system 20 operable to create BISTorganizational file 10 by performing the process described below with respect toFIGS. 2-10 . -
Computer system 20 is shown including a processing component 22 (e.g., one or more processors), a storage component 24 (e.g., a storage hierarchy), an input/output (I/O) component 26 (e.g., one or more I/O interfaces and/or devices), and acommunications pathway 28. In general,processing component 22 executes program code, such asBIST file program 30, which is at least partially fixed instorage component 24. While executing program code,processing component 22 can process data, which can result in reading and/or writing transformed data from/tostorage component 24 and/or I/O component 26 for further processing. Pathway 28 provides a communications link between each of the components incomputer system 20. I/O component 26 can comprise one or more human I/O devices, which enable ahuman user 12 to interact withcomputer system 20 and/or one or more communications devices to enable asystem user 12 to communicate withcomputer system 20 using any type of communications link. To this extent,BIST file program 30 can manage a set of interfaces (e.g., graphical user interface(s), application program interface, and/or the like) that enable human and/orsystem users 12 to interact withBIST file program 30. Further,BIST file program 30 can manage (e.g., store, retrieve, create, manipulate, organize, present, etc.) the data, such as adesign file 40, a module reference file (MRF) 42, or a BIST tech file (BTF) 46, using any solution. - In any event,
computer system 20 can comprise one or more general purpose computing articles of manufacture (e.g., computing devices) capable of executing program code, such asBIST file program 30, installed thereon. As used herein, it is understood that “program code” means any collection of instructions, in any language, code or notation, that cause a computing device having an information processing capability to perform a particular action either directly or after any combination of the following: (a) conversion to another language, code or notation; (b) reproduction in a different material form; and/or (c) decompression. To this extent,BIST file program 30 can be embodied as any combination of system software and/or application software. - Further,
BIST file program 30 can be implemented using a set ofmodules 32. In this case, amodule 32 can enablecomputer system 20 to perform a set of tasks used byBIST file program 30, and can be separately developed and/or implemented apart from other portions ofBIST file program 30. As used herein, the term “component” means any configuration of hardware, with or without software, which implements the functionality described in conjunction therewith using any solution, while the term “module” means program code that enables acomputer system 20 to implement the actions described in conjunction therewith using any solution. When fixed in astorage component 24 of acomputer system 20 that includes aprocessing component 22, a module is a substantial portion of a component that implements the actions. Regardless, it is understood that two or more components, modules, and/or systems may share some/all of their respective hardware and/or software. Further, it is understood that some of the functionality discussed herein may not be implemented or additional functionality may be included as part ofcomputer system 20. - When
computer system 20 comprises multiple computing devices, each computing device can have only a portion ofBIST file program 30 fixed thereon (e.g., one or more modules 32). However, it is understood thatcomputer system 20 andBIST file program 30 are only representative of various possible equivalent computer systems that may perform a process described herein. To this extent, in other embodiments, the functionality provided bycomputer system 20 andBIST file program 30 can be at least partially implemented by one or more computing devices that include any combination of general and/or specific purpose hardware with or without program code. In each embodiment, the hardware and program code, if included, can be created using standard engineering and programming techniques, respectively. - Regardless, when
computer system 20 includes multiple computing devices, the computing devices can communicate over any type of communications link. Further, while performing a process described herein,computer system 20 can communicate with one or more other computer systems using any type of communications link. In either case, the communications link can comprise any combination of various types of optical fiber, wired, and/or wireless links; comprise any combination of one or more types of networks; and/or utilize any combination of various types of transmission techniques and protocols. - As discussed herein,
BIST file program 30 enablescomputer system 20 to create a BISTorganizational file 60 of an IC (e.g., represented by design file 40). To this extent,computer system 20 may perform the method according to aspects of the invention, as discussed herein with respect toFIGS. 2-11 . - Turning now to
FIG. 2 , a flow diagram for creating a BISTorganizational file 60, with reference toFIG. 1 andFIGS. 3-11 , according to embodiments of the invention is shown. At 51, adesign file 40 is received that includes a hierarchy of memory modules. For example, as shown theexemplary design file 40 inFIG. 3 , a top level memory module 102 (“Module 1”) includes 106, 108, 110. Thememory modules design file 40 may include any type of abstraction or specification, as known in the art, including, but not limited to register-transfer-level abstraction. - As seen in
FIG. 3 , InstA memory module 106 (“Module_a”) and InstaB memory module 108 (“Module_a”) are identical modules. That is, they contain the same plurality of memory wrappers. Hence, both are “Module_a.” InstC memory module 110 (“Module_b”) is a different memory module and includes different memory wrappers. - As shown in
FIG. 3 , some examples of memory wrappers include, but are not limited to, “WRAP1S,” “WRAP2T,” and “WRAPCAM.” However, it is understood that these types of memory wrappers are for exemplary purposes only, and that any now known or later developed memory wrappers may be applicable to this disclosure. Additional top-level memory wrappers 104 are also shown. - At S2, each memory wrapper in each hierarchical level of
102, 106, 108, 110 are scanned to determine a BIST type for each memory wrapper. In order to determine a BIST type for each memory wrappers, at S4, a BIST tech file 44 (memory modules FIG. 1 ) is received and scanned. - The hierarchical level of the memory wrapper (i.e., which memory module the memory wrapper belongs to) and the BIST type is used to create an ordered list of memory wrappers. For example, turning now to
FIG. 4 , an orderedlist 46 of memory wrappers for thedesign file 40 ofFIG. 3 is shown. The top level memory wrappers 104 (“Inst1,” “Inst2,” “Inst3,” “Inst4,” “Inst5,” “Inst6,” and “Inst7) are shown in afirst group 48. Next, the memory wrappers forInstA memory module 106 are shown in asecond group 50. The memory wrappers forInstB memory module 108 are shown in athird group 52 and the memory wrappers forInstC memory module 110 are shown in afourth group 54. - Turning now to
FIG. 5 , adesign file 40 according to an alternative embodiment of the invention is shown.InstA memory module 106 andInstB memory module 108 indesign file 40 inFIG. 5 already include BIST engines (“BIST1S” and “BIST2T”) for the plurality of memory wrappers within these memory modules. Therefore, in this embodiment, a module reference file (MRF) 42 is received, at S5. An example of aMRF 42 is shown inFIG. 6 . As shown inFIG. 6 ,MRF 42 lists “Module_a” as already including BIST engines. In this embodiment, at S2, only the memory modules not listed in theMRF 42 are scanned for a BIST type. Therefore,InstA memory module 106 andInstB memory module 108, since they are “Module_a” type, are not scanned at S2. Only the toplevel memory modules 104 andInstC memory module 110 are scanned. - An example of the ordered
list 46 for thedesign file 40 shown inFIG. 5 is shown inFIG. 7 . As clearly seen inFIG. 7 , only afirst group 48 for the toplevel memory modules 104 and afourth group 54 forInstC memory module 110 is shown. - Following the example of
design file 40 shown inFIG. 5 and the orderedlist 46 shown inFIG. 7 , at S6, a BIST engine, based on the BIST type from the BTF 44 (FIG. 1 ), is added for each memory wrapper listed in the orderedlist 46. Additionally, MRF 42 (FIG. 6 ) is used to specify a “ref” reference statement to be added, for each view of each occurrence of Module_a found indesign file 40. Next, at D1, a level for creating the BIST organizational file 60 (FIG. 1 ) is determined The level is directed by the user, as anadditional User Input 31, as shown inFIG. 1 , when runningBIST program file 30. If the user does not specify thedesign file 40 as a “top level”, then the level is assumed to be a level lower than the “top level”. At S7 or S8, a plurality of additional statements are added to the orderedlist 46 in order to create the BISTorganizational file 60, as shown, for example, inFIGS. 8A and 8B orFIG. 11 . - For example, at S7, additional statements for a particular module view are added to the ordered
list 46 to create a BIST organizational file 60 (FIGS. 8A and 8B ). For the orderedlist 46 shown inFIG. 7 (fordesign file 40 shown inFIG. 5 that includesMRF 42 shown inFIG. 6 ),FIGS. 8A and 8B show the BISTorganizational file 60 that is created by adding additional statements. These additional statements include “hier_ref=Module1”; “view=BISTCNTL_ref1”; and “end_view.” - At S8, additional statements for a “top level” design are added to the ordered
list 46 to create a BIST organizational file 60 (FIG. 11 ). Thedesign file 40 shown inFIG. 9 is exemplary of adesign file 40 where only the toplevel memory wrappers 104 need BIST engines. All 106, 108, 110 already include the necessary BIST engines for the plurality of memory wrappers.other memory modules - In
FIG. 10 ,MRF 43 is used to specify, fordesign file 40 ofFIG. 9 , that both Module_a and Module_b have already have had BIST engines inserted, and all instances of both Module_a and Module_b must be excluded, when searchingdesign file 40 for instances of memory wrappers. Furthermore, as shown inMRF 43, it is also specified that Module_a has one occurrence of a “BISTCNTL_ref1” view and Module_b has two occurrences of views associated with it, specifically a “WRAP_FUSECNTL_ref1” view and a “BISTCNTL_ref1” view. - The additional statements for a top level BIST
organizational file 60, added, at S8, include, for example: “top_ref=Top”; “WRAP_CC_ECID_T09”; “WRAP FUSECENTL_T09”; “WRAP_BISTCNTL_T09”; and “end_top_ref.” - It is understood that the
BIST organization file 60 shown in the figures may be a text file, or any other file as known in the art. Therefore, once a customer receives the default BISTorganizational file 60 as shown inFIGS. 6 and 11 , the customer may modify the BIST organizational 60. - The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. 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.
- This written description uses examples to disclose the invention, including the best mode, and also to enable any person skilled in the art to practice the invention, including making and using any devices or systems and performing any incorporated methods. The patentable scope of the invention is defined by the claims, and may include other examples that occur to those skilled in the art. Such other examples are intended to be within the scope of the claims if they have structural elements that do not differ from the literal language of the claims, or if they include equivalent structural elements with insubstantial differences from the literal languages of the claims.
Claims (20)
Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US13/567,127 US8661399B1 (en) | 2012-08-06 | 2012-08-06 | Built-in-self-test (BIST) organizational file generation |
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US13/567,127 US8661399B1 (en) | 2012-08-06 | 2012-08-06 | Built-in-self-test (BIST) organizational file generation |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| US20140040685A1 true US20140040685A1 (en) | 2014-02-06 |
| US8661399B1 US8661399B1 (en) | 2014-02-25 |
Family
ID=50026731
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US13/567,127 Expired - Fee Related US8661399B1 (en) | 2012-08-06 | 2012-08-06 | Built-in-self-test (BIST) organizational file generation |
Country Status (1)
| Country | Link |
|---|---|
| US (1) | US8661399B1 (en) |
Families Citing this family (1)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US9971663B2 (en) | 2014-08-29 | 2018-05-15 | Qualcomm Incorporated | Method and apparatus for multiple memory shared collar architecture |
Family Cites Families (8)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US5646249A (en) | 1994-02-28 | 1997-07-08 | The United States Of America As Represented By The Department Of Health And Human Services | Isolation and characterization of a novel chaperone protein |
| US6332211B1 (en) | 1998-12-28 | 2001-12-18 | International Business Machines Corporation | System and method for developing test cases using a test object library |
| US6678875B2 (en) * | 2002-01-25 | 2004-01-13 | Logicvision, Inc. | Self-contained embedded test design environment and environment setup utility |
| US6721923B2 (en) | 2002-02-20 | 2004-04-13 | Agilent Technologies, Inc. | System and method for generating integrated circuit boundary register description data |
| US6775811B2 (en) * | 2002-05-22 | 2004-08-10 | Lsi Logic Corporation | Chip design method for designing integrated circuit chips with embedded memories |
| US7493519B2 (en) | 2005-10-24 | 2009-02-17 | Lsi Corporation | RRAM memory error emulation |
| US7926012B1 (en) * | 2007-12-06 | 2011-04-12 | Cadence Design Systems, Inc. | Design-For-testability planner |
| US8239818B1 (en) * | 2011-04-05 | 2012-08-07 | International Business Machines Corporation | Data structure for describing MBIST architecture |
-
2012
- 2012-08-06 US US13/567,127 patent/US8661399B1/en not_active Expired - Fee Related
Also Published As
| Publication number | Publication date |
|---|---|
| US8661399B1 (en) | 2014-02-25 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US10372594B2 (en) | Method and device for retrieving test case based on code coverage | |
| CN107133174A (en) | Test case code automatically generating device and method | |
| Barbour et al. | An empirical study of faults in late propagation clone genealogies | |
| CN104881318B (en) | A kind of interface call method, device and terminal | |
| US9075544B2 (en) | Integration and user story generation and requirements management | |
| CN104899016B (en) | Allocating stack Relation acquisition method and device | |
| CN109510824A (en) | A kind of method of calibration and device of interface packets | |
| CN108319711A (en) | Transaction consistency test method, device, storage medium and the equipment of database | |
| CN103440196B (en) | A kind of operating-system resources failure detecting method | |
| US20120036497A1 (en) | Integrity check while committing changes from an integrated development environment to a source code control system | |
| Dehlinger et al. | Plfaultcat: A product-line software fault tree analysis tool | |
| CN109800147B (en) | Test case generation method and terminal equipment | |
| CN109491884A (en) | Code method for testing performance, device, computer equipment and medium | |
| US20200293592A1 (en) | Methods and systems for browser extension used to generate relative xpath, absolute xpath and/or css selectors | |
| CN106326129A (en) | Program abnormity information generating method and device | |
| CN112231197A (en) | Page testing method and device and storage medium | |
| CN109634569A (en) | Process implementation method, device, equipment and readable storage medium storing program for executing based on note | |
| CN113961192A (en) | Code data processing method and device and electronic equipment | |
| CN111159040A (en) | Test data generation method, device, equipment and storage medium | |
| CN103186463A (en) | Method and system for determining testing range of software | |
| CN106033390A (en) | Mail style testing method and apparatus | |
| Kuttig | Professional React Native: Expert techniques and solutions for building high-quality, cross-platform, production-ready apps | |
| US8661399B1 (en) | Built-in-self-test (BIST) organizational file generation | |
| CN104123104B (en) | Daily record control system and method | |
| CN112667507A (en) | Embedded software demand management method and system and electronic equipment |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:MONROE, CRAIG M.;OUELLETTE, MICHAEL R.;SPRAGUE, DOUGLAS E.;SIGNING DATES FROM 20120802 TO 20120803;REEL/FRAME:028727/0658 |
|
| STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
| AS | Assignment |
Owner name: GLOBALFOUNDRIES U.S. 2 LLC, NEW YORK Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTERNATIONAL BUSINESS MACHINES CORPORATION;REEL/FRAME:036550/0001 Effective date: 20150629 |
|
| AS | Assignment |
Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GLOBALFOUNDRIES U.S. 2 LLC;GLOBALFOUNDRIES U.S. INC.;REEL/FRAME:036779/0001 Effective date: 20150910 |
|
| FPAY | Fee payment |
Year of fee payment: 4 |
|
| AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, DELAWARE Free format text: SECURITY AGREEMENT;ASSIGNOR:GLOBALFOUNDRIES INC.;REEL/FRAME:049490/0001 Effective date: 20181127 |
|
| AS | Assignment |
Owner name: GLOBALFOUNDRIES U.S. INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GLOBALFOUNDRIES INC.;REEL/FRAME:050122/0001 Effective date: 20190821 |
|
| AS | Assignment |
Owner name: MARVELL INTERNATIONAL LTD., BERMUDA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GLOBALFOUNDRIES U.S. INC.;REEL/FRAME:051070/0625 Effective date: 20191105 |
|
| AS | Assignment |
Owner name: CAVIUM INTERNATIONAL, CAYMAN ISLANDS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MARVELL INTERNATIONAL LTD.;REEL/FRAME:052918/0001 Effective date: 20191231 |
|
| AS | Assignment |
Owner name: MARVELL ASIA PTE, LTD., SINGAPORE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CAVIUM INTERNATIONAL;REEL/FRAME:053475/0001 Effective date: 20191231 |
|
| AS | Assignment |
Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION;REEL/FRAME:054636/0001 Effective date: 20201117 |
|
| FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
| FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20220225 |