US6148307A - Method and system for generating product performance history - Google Patents

Method and system for generating product performance history Download PDF

Info

Publication number
US6148307A
US6148307A US09/195,195 US19519598A US6148307A US 6148307 A US6148307 A US 6148307A US 19519598 A US19519598 A US 19519598A US 6148307 A US6148307 A US 6148307A
Authority
US
United States
Prior art keywords
data
database
reformatted
server
archived
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.)
Expired - Lifetime
Application number
US09/195,195
Inventor
Randy Burdick
Richard Kittler
F. Walter Smith
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.)
GlobalFoundries Inc
Original Assignee
Advanced Micro Devices Inc
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 Micro Devices Inc filed Critical Advanced Micro Devices Inc
Priority to US09/195,195 priority Critical patent/US6148307A/en
Application granted granted Critical
Publication of US6148307A publication Critical patent/US6148307A/en
Assigned to GLOBALFOUNDRIES INC. reassignment GLOBALFOUNDRIES INC. AFFIRMATION OF PATENT ASSIGNMENT Assignors: ADVANCED MICRO DEVICES, INC.
Anticipated expiration legal-status Critical
Assigned to GLOBALFOUNDRIES U.S. INC. reassignment GLOBALFOUNDRIES U.S. INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: WILMINGTON TRUST, NATIONAL ASSOCIATION
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/17Details of further file system functions
    • G06F16/178Techniques for file synchronisation in file systems
    • G06F16/1794Details of file format conversion
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/25Integrating or interfacing systems involving database management systems
    • G06F16/252Integrating or interfacing systems involving database management systems between a Database Management System and a front-end application
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/08Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
    • G06Q10/087Inventory or stock management, e.g. order filling, procurement or balancing against orders
    • HELECTRICITY
    • H01ELECTRIC ELEMENTS
    • H01LSEMICONDUCTOR DEVICES NOT COVERED BY CLASS H10
    • H01L22/00Testing or measuring during manufacture or treatment; Reliability measurements, i.e. testing of parts without further processing to modify the parts as such; Structural arrangements therefor
    • H01L22/20Sequence of activities consisting of a plurality of measurements, corrections, marking or sorting steps
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • HELECTRICITY
    • H01ELECTRIC ELEMENTS
    • H01LSEMICONDUCTOR DEVICES NOT COVERED BY CLASS H10
    • H01L2924/00Indexing scheme for arrangements or methods for connecting or disconnecting semiconductor or solid-state bodies as covered by H01L24/00
    • H01L2924/0001Technical content checked by a classifier
    • H01L2924/0002Not covered by any one of groups H01L24/00, H01L24/00 and H01L2224/00
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99933Query processing, i.e. searching
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99944Object-oriented database structure
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99944Object-oriented database structure
    • Y10S707/99945Object-oriented database structure processing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99948Application of database or data structure, e.g. distributed, multimedia, or image

Definitions

  • the present invention relates to providing engineering data related to the manufacture of semiconductor devices in a uniform format in a centralized database and accessing that database including a graphical user interface.
  • the manufacture of semiconductor devices requires a number of discrete process steps to create a packaged semiconductor circuit device from raw semiconductor material.
  • the various processes from the initial melt and refinement of the semiconductor material, the slicing of the semiconductor crystal into individual wafers, the fabrication stages (etching, doping, ion implanting or the like), to the packaging and final testing of the completed device, are so different form one another and specialized that the processes may be performed in different facilities in remote regions of the globe.
  • the process of growing and refining a large semiconductor crystal may be performed by a foundry specializing in such crystal growth techniques.
  • the resultant crystals may then be sold directly to a semiconductor manufacturer, either as large crystals, or as wafers, sliced from a large crystal.
  • the semiconductor manufacturer may then slice the semiconductor crystal into wafers, if the semiconductor material is not already in wafer format,.
  • the semiconductor manufacturer then fabricates semiconductor circuit devices (e.g., microprocessor, DRAM, ASIC or the like) on individual wafers, usually forming a number of devices on each wafer.
  • semiconductor circuit devices e.g., microprocessor, DRAM, ASIC or the like
  • the individual fabrication (or "FAB") processes include photolithography, ion implantation, and other associated FAB processes known in the art.
  • the resultant semiconductor device is tested on the wafer during and after the FAB process.
  • the wafer is sliced up into individual semiconductor chips and packaged.
  • the packaging process includes mounting and wire-bonding the individual chips to chip carriers (e.g., PLCCs, DIPs, CER-DIPs, surface mount carriers or the like) and final testing of the resultant packaged semiconductor device.
  • chip carriers e.g., PLCCs, DIPs, CER-DIPs, surface mount carriers or the like.
  • This packaging process is fairly labor intensive, and thus it may be desirable to perform the mounting, wire-bonding, and final testing at an offshore facility where labor rates may be cheaper.
  • the packaged semiconductor device may again be tested, and then labeled and shipped to customers through a distribution system.
  • individual fabrication machines or computer aided manufacturing systems may provide data regarding operating conditions during the fabrication process. Some of these data are intrinsic data, for example, lot numbers, device model numbers or the like. Other data may be extrinsic data, such as production test data, production conditions, or the like. In the various processes, the various lot numbers may be changed, thus making it difficult for a production engineer to track down and solve difficulties in the production process.
  • a semiconductor crystal or wafers may be assigned a manufacturer's lot number and shipped to a FAB facility.
  • the FAB facility may in turn divide these wafers into different lots of 25 to 50 wafers, each assigned a new and different lot number.
  • Each of these new lots of wafers may be used in the manufacture of a particular model semiconductor device. These lots may further comprise wafers commingled from other received lots of semiconductor wafers.
  • new lot numbers may be assigned to a wafer of group of wafers.
  • the wafers are sliced up into chips, which may be assigned yet again new lot numbers.
  • the production process testing and manufacturing steps are performed, generating data for each semiconductor device. If a problem arises in the manufacture of the semiconductor, for example a low yield of usable semiconductor devices, a production engineer may wish to track the semiconductor devices to determine why the production problem existed, correct the problem if necessary, and intercept other semiconductor devices similarly affected before performing additional process steps or shipping the product to the consumer.
  • shop floor control systems e.g. WorkStreamTM or the like
  • the collection of engineering data has been a by-product of the need to manage the inventory in the factory and manage the factory itself.
  • the multiple facilities if provided with computerized data acquisition systems (e.g., CAM or the like) may utilize different systems within the facility, and each facility may have systems different from the other.
  • the computer systems may be incompatible and not effectively interfaced with one another.
  • the different systems generally collect data in different formats, and thus data from one system cannot readily be compared or merged with data from another system.
  • different lot numbers may be assigned at different steps in the manufacturing process, it may be difficult for an engineer to effectively track a particular chip, group of chips, wafer, or group of wafers back though the process steps. Since many of these CAM processes utilize computer systems dedicated to the manufacturing process, the systems may be unsuitable or too engaged to be used for manually tracking the production process of a semiconductor device.
  • the ability to track production data for a semiconductor device may also be useful to a semiconductor manufacturer in enhancing the value of the semiconductor to the consumer.
  • the consumer may require assurances that the quality control of the semiconductor device can be effectively traced at each step. Further, the consumer may require that each semiconductor be provided with its "lineage,” including the data generated in the manufacture and testing of the semiconductor device.
  • a system for storing and retrieving data comprises a network for transmitting and receiving data and at least one input system for inputting data in at least a first format.
  • a reformatter receives the data and reformats the data into a predetermined standard format.
  • a database coupled to the network stores the reformatted data,
  • a loader loads the reformatted data into the database.
  • At least one client workstation is provided, coupled to the network, for receiving database search requests.
  • a front end server coupled to the network, receives the database search requests and processes the search requests, querying the database, receiving reformatted data from the database, and outputting the reformatted data.
  • FIG. 1 is a block diagram of the database system of the present invention.
  • FIG. 2 is a block diagram of the software structure and data flow between client and database servers of the present invention.
  • FIG. 3 is a sample product performance history generated for a sample lot of semiconductors using the database system of the present invention.
  • FIG. 4 is a diagram showing the relationship between the sections of the physical data model shown in FIGS. 4A, 4B, 4C, 4D, 4E, 4F, 4G, 4H, 4I, 4J, 4K, 4L, 4M, 4N, 4O, 4P and 4Q.
  • FIGS. 4A, 4B, 4E and 4F are a block diagram of the upper left hand corner of the physical data model of the present invention.
  • FIGS. 4I, 4J, 4M and 4N are a block diagram of the upper right hand corner of the physical data model of the present invention.
  • FIGS. 4K, 4L, 4P and 4Q area block diagram of the lower right hand corner of the physical data model of the present invention.
  • FIGS. 4C, 4D, 4G and 4H are a block diagram of the lower left hand corner of the physical data model of the present invention.
  • FIG. 5 is a block diagram illustrating the relationship between the data distributor and database servers within the distributed database of the present invention.
  • FIG. 6 is a block diagram of the architecture of the data distributor of FIG. 5.
  • FIG. 7 is a block diagram showing the architecture of data archiver of the present invention.
  • Worldnet network 111 may comprise, for example, any of many known computer system networks which may be accessed via telephone link, microwave relay, satellite link or the like. As the name implies, worldnet network may provide a data link between system elements located throughout the world. Alternatively, worldnet network may comprise a network more limited in scope, including a local area network (LAN) for use within one plant location, without departing from the spirit and scope of the invention. In the preferred embodiment, worldnet network comprises a global communications network which allows systems elements to be located at various locations throughout the world.
  • LAN local area network
  • Raw data 101 is generated at or within a particular plant facility. As discussed previously, semiconductor circuit manufacturing may be performed in several steps, including crystal growth, wafer sawing, so-called FAB or fabrication, testing, packaging and the like. Raw data 101 may comprise raw data produced from any one or a combination of these steps. Further, raw data 101 may comprise test data from testing performed before, during or after any one of these process steps. For the sake of illustration, only one group of raw data 101 is shown. However, other groups of raw data 101 and associated reformatter servers 102 may be provided for data generated from each process step or groups of steps.
  • Raw data 101 may comprise, for example, data generated from a WorkStreamTM CAM system.
  • This data may include manually keyed data generated by production employees or production engineers and entered at the shop floor into a WorkStreamTM system.
  • the data may also include data automatically loaded by the WorkStreamTM system during the manufacturing process from the manufacturing equipment.
  • These data may include, for example, temperature and pressure data describing the manufacturing process during, e.g., an etching operation. Such data is referred to as extrinsic data.
  • So-called intrinsic data (e.g., lot number, date, time, machine number or the like) may also be manually or automatically entered into the WorkStreamTM system.
  • Raw data 101 may be in one of a number of formats.
  • the format of the data has been previously determined when the CAM or data acquisition system has been installed.
  • the data format has already been determined in accordance with previously determined needs. Since the needs of the process engineers at each process step differ, it is generally the case that raw data 101 may be in one of a number of different formats. Similarly, since a number of data sources or manufacturers of data acquisition systems may differ, it is generally more often the case that raw data 101 may be in one of a number of different formats.
  • Reformatter server 102 is provided to reformat raw data 101 into a standardized data format known as Data Input Standard or DIS.
  • Raw data 101 is fed to a reformatter server which reformats this data into DIS format, which will be discussed below in conjunction with FIGS. 4A-4D.
  • Raw data 101 may be loaded into reformatter server 102 by means of data tape or disk, or through a local area network (LAN) at the data source.
  • LAN local area network
  • Each data source may be provided with a reformatter server, or in the alternative, a reformatter server may serve a number of data sources.
  • reformatter server 102 may be fed with raw data 101 through worldnet network 111, although generally the cost of doing so may be somewhat prohibitive.
  • Reformatter server 102 may comprise a software program run on a computer or computer system.
  • reformatter server 102 may comprise a UNIXTM based computer system or a DOS based computer or computer network.
  • the reformatter server may comprises a software program run on a general purpose UNIXTM based computer coupled to worldnet 111.
  • production data from that foundry may be provided (via contract arrangement with that foundry) in the DIS format or as raw data for input into the database system of the present invention.
  • data for other purchased components may be entered into the database system.
  • This outside data may be provided on tape or disc and may be loaded in the DIS format into a database server 104 via loader 104.
  • an outside supplier may be able to download such data electronically via a commercial network (e.g., CompuserveTM) or via a telephone modem, private network or the like, or by access granted by the manufacture through worldnet network 111.
  • a reformatter server 102 may be provided or adapted to reformat the outside data into the DIS format for inclusion into the database system. If the data in electronic format cannot be obtained from the supplier or foundry, selected production data for the components (e.g., source, lot number, or other intrinsic or extrinsic data) may be manually keyed into the database system of the present invention.
  • raw data 101 may comprise data from a WorkStreamTM CAM system generated at one manufacturing facility, such as a so-called FAB facility.
  • a reformatter server 102 may be provided, interfaced with the WorkStreamTM CAM system by means of a local area network (LAN) or the like.
  • LAN local area network
  • raw data 101 is fed to reformatter server 102 which reformats the data into DIS format to produce DIS data 103.
  • the data in DIS format may then be available through worldnet network 111.
  • DIS data is loaded, via loader 104 into local database server 105 to produce database 106.
  • a plurality of database servers 105, 107 may be provided.
  • local database server 105 represents a database server for a particular client location
  • database server 107 represents all other database servers within the database system.
  • each data source e.g., manufacturing plant or testing facility
  • each data source may be provided with one or more database servers 107.
  • the entirety of the database 106 may be provided, not in any one database server, but rather spread out through a number of database servers logically joined and connected through worldnet network 111.
  • each manufacturing facility may have several database servers 107.
  • each department within a manufacturing facility may be provided with its own local database server 105.
  • a particular department within a processing facility may supply (and pay for) its own portion of the database system.
  • Overall costs of the database system may be paid for by each department using a subscription system similar to that used in on-line subscription systems (e.g., CompuserveTM or the like).
  • the present invention may also be applied to a commercial database systems where each subscriber provides its own portion of an overall database.
  • loader 104 may comprise a software program run on the same computer or computer system as database server 105.
  • database server 105 is a UNIXTM based server connected to worldnet network 111.
  • one centralized loader 104 may be provided to load data into any portion of database 106 in database servers 105, 107 as determined by the content of DIS data 103.
  • a number of loaders 104 are used, each optimized to load data into certain regions of database 106 depending on data type.
  • raw data 101 is loaded only periodically via reformatter server 102.
  • the period between the loading of the data may be determined generally by the engineering needs for that data.
  • structural information such as product lines (e.g., model designations or the like) may change only on a yearly basis.
  • Other data, such as intrinsic and extrinsic data, may change on a daily or hourly basis as individual semiconductor devices pass through various process steps.
  • the range for the time period between successive reformatting and loading of raw data may vary from an hourly to a yearly basis.
  • Distributing database 106 over a number of database servers 105, 107 on worldnet network 111 provides a number of advantages over prior art centralized databases. For example, as discussed above, the task of reformatting and loading raw data 101 can be more easily performed by a series of decentralized reformatter servers 107 and loaders 104 located in proximity to each source of raw data 101. Further, since reformatting and loading is performed locally, the amount of data flow through the worldnet network 111 may be greatly reduced. In addition, the plurality of database servers 105, 107 provides for system redundancy, such that if one database server is disabled, database 106 is not entirely disabled. Finally, since most database search or trace requests will be directed towards data contained in a local database server 105, the speed and response time of database 106 are improved.
  • Access to database 106 is provided through one of a number of client servers located on worldnet network 111.
  • client refers to an end user of the database system (e.g., production engineer or the like).
  • the client server may take the form of a graphical user interface (GUI) provided in an IBMTM compatible personal computer (PC) 109, an AppleTM MacIntoshTM computer 110 or UNIXTM Workstation 108 coupled to worldnet network 111.
  • GUI graphical user interface
  • PC personal computer
  • client servers 108, 109, and 110 and local database server 105 may be referred to as "front-end” servers
  • reformatter server 102 and loader 104 may be referred to as "backend” servers.
  • Client servers 108, 109, 110 are provided with a graphical user interface (GUI) program which allows the client to access database 106.
  • GUI graphical user interface
  • Access to database 106 may take one of several forms.
  • database 106 is decentralized into a number of database servers 105, 107.
  • a production engineer or client within a particular facility, for example, the FAB facility, may have direct on-line access to that portion of database 106 contained within a database server, for example, local database server 105, located within that facility.
  • Most requests by a client will be related to that portion of the database 106 contained within that client's local database server.
  • a production engineer in a FAB facility may be most interested in data generated within that facility. Since that portion of database 106 is located within the local database server 105, information requests entered into client server 108, 109 or 110 may be quickly and easily handled.
  • the next type of data request that may be entered by a client into a client server 108, 109 or 110 is the so-called "browse" request.
  • Such requests are not detailed data search requests, but nevertheless may require data from one of a number of database servers 105, 107 containing database 106.
  • These browse requests are made by the client from client server 108, 109, or 110 and transmitted through worldnet network 111.
  • Worldnet network 111 may access any one of database servers 105, 107 and request browse data. Examples of browse data include specific requests concerning lot numbers or data from a specific lot number or the like.
  • a production engineer attempting to troubleshoot a particular production problem may enter a complex data analysis request.
  • a request for example, may comprise a complete genealogy from a particular chip, the results of which are shown in FIG. 3.
  • Other requests may include, e.g., a search request for all lot numbers of chips processed by a particular machine or plant during a particular time period. For example, if a production engineer determined that a particular fabrication process has malfunctioned for a particular time period, the engineer may wish to trace all products which were processed during that time period and intercept those products before further processing is performed or the product is shipped to customers.
  • These complex search requests may require a relatively large amount of time to complete and thus may be entered as off-line requests to be performed as background jobs.
  • the client Through the GUI in client server 108, 109, or 110, the client enters the search request using logical field operators as is well known in the art.
  • Database servers 105, 107 may operate using, for example, OracleTM database library software, which provides an operating system and search software for a database server 105, 107.
  • a client's local database server 105 then processes the search request, requesting information from other database servers 107 as necessary.
  • the client Through the GUI in client server 108, 109, or 110, the client may be notified when the search request has been complete.
  • FIG. 3 shows an example of a result of a complex search request, in this instance, a genealogy of a semiconductor device.
  • the GUI of the present invention allows the user to view this genealogy in graphical form on a CRT screen, or print the genealogy on a suitably equipped printer.
  • FIG. 3 shows the series of process steps followed by a lot of semiconductor devices through various process steps.
  • the semiconductor devices begin as raw semiconductor wafer material, here shown with the sample lot number "ROOT" in step 381.
  • Steps 382-384 show the fabrication steps in the processing of the wafer, whereas step 385 shows the initial testing stage of the devices.
  • Assembly steps 386-390 show the various steps taken in the assembly process. Not all of the original semiconductor devices are assembled in the same steps.
  • the final step 391 shows the manufacturing lot number assigned to the finished device. Throughout the manufacturing process, the lot numbers assigned to the semiconductors may change at different steps.
  • the genealogy shown in FIG. 3 allows a production engineer to make further inquiries, if necessary, regarding manufacturing conditions or the like, with respect to a particular lot number or step in the process.
  • the GUI of the present invention provides the client with a variety of options with regard to the format of retrieved data from a complex search request.
  • the GUI or the present invention may allow the client to view of browse the produced data, or may reformat that data into one of a number of formats corresponding to commercially available database programs (e.g., Lotus 1-2-3TM, ParadoxTM, ExcelTM, RS1TM, SASTM, or the like).
  • database programs e.g., Lotus 1-2-3TM, ParadoxTM, ExcelTM, RS1TM, SASTM, or the like.
  • FIG. 2 is a block diagram of the software structure and data flow between client and database servers of the present invention.
  • Client server 251 may comprise, for example, PC 109 of FIG. 1. However client server 251 may also be substituted by client servers 108 or 110 shown in FIG. 1 without departing from the spirit or scope of the invention.
  • Client server 251 contains a package of software programs which cooperate to provide a graphical user interface (GUI) for client requests.
  • GUI graphical user interface
  • PC-NFS a product of SUN Microsystems, comprises a software package which allows a DOS based PC to operate as a UNIXTM workstation.
  • the OpenInterfaceTM WindowsTM library a product of MicrosoftTM corporation, provides a standardized set of GUI interface routines.
  • the ORACLETM database library provides the data search and retrieval routines for accessing database 106.
  • Custom written C-code provides a GUI incorporating elements of OpenInterfaceTM and ORACLETM.
  • TCP/IP is a network protocol recognition software which allows the client server to run on an EthernetTM system.
  • the front end server 112 may comprise a software program operating in a general purpose UNIXTM based computer coupled to worldnet 111.
  • Database servers 253 in FIG. 2 represent collectively all database servers 105, 107 in the database 106.
  • Browse requests entered into client server 251 are applied directly to database servers 253, bypassing front end server 112. Since the browse requests are directed towards specific fields of data and do not require large amounts of data to be transferred, these requests can be quickly handled by database servers 253 and transferred to client server 251 through worldnet 111 (not shown).
  • Front end server 112 may comprise a large, general purpose UNIXTM based computer, or alternately may comprise the same computer as local database server 105. Complex database requests and data analysis are processed by front-end server 112. Complex database requests generally ask for data from more than one portion of the process and may require accessing data from more than one region of database 106. Thus, complex requests may be entered into client server 251 and processed by front end server 112 as a so-called "background" job. Once the complex request has been entered into client server 251, front end server 112 processes the request, freeing client server 251 for further browsing or other tasks.
  • client server 251 may comprise any of client servers 108, 109, or 110 (i.e., UNIX, DOS-PC or MAC). As such, the computer housing the software for client server 251 may not be dedicated to the client server task, but may also be used for other tasks commonly assigned to such PCs or workstations.
  • Front end server 112 may generate a query status file, which is periodically updated with the status of a complex search request. This file may be accessed by the client through client server 251 to determine the status of his complex request. For example, the client may wish to determine whether the complex request has been completed, or at what stage the complex request has reached (i.e., percent completed). Further, in some instances, a client may inadvertently issue a complex request which causes the front end server to "hang.” Such a request, for example, may ask for an incompatible combination of data operators (i.e., searching a numerical field for a text operand). The client may then issue commands through client server 251 to front end server 112 to terminate the complex request.
  • a query status file which is periodically updated with the status of a complex search request. This file may be accessed by the client through client server 251 to determine the status of his complex request. For example, the client may wish to determine whether the complex request has been completed, or at what stage the complex request has reached (i.e., percent completed).
  • the front end server may be interfaced with, or provide an E-mail type system to notify clients of completed search requests or to allow communication between different clients in the system. Further, the front end server may "deliver" the completed search result in a desired format (e.g., compatible with a particular print format or in a format compatible with a commercial database program) to a location determined by the client. In addition, the front end server may (if selected by the client in making the complex request) provide a log of the process of the complex request, for example, noting any errors or abnormalities in the processing of the search request. For example, if some requested data is unavailable due to a database serving being down or inaccessible, the front end server may note that unavailability of that data and continue the complex request.
  • a desired format e.g., compatible with a particular print format or in a format compatible with a commercial database program
  • the client server creates a query request file using information entered by the client through the GUI.
  • the query request file includes the name of query definition file which contains the logical search request.
  • the query request file also includes and the destination environment and node (i.e., format and file location).
  • Front end server 112 parses the query request file and scans the query definition to determine which database servers 106 are being referenced. Front end server 112 then partitions the main query definition file into "child" files each of which references one database server 106. Front end server 112 may then run a request for each child definition file using one of two methods.
  • a search request is generated and run against the database.
  • the results are copied out to a series of temporary ASCII files.
  • These row-wise ASCII files are then processed to do any further aggregation as required as well as a final transpose.
  • the transposed data file is then delivered to the destination environment.
  • the second and alternative method of the present invention generates the search request and feeds it into a dynamic search processor program which is responsible for dynamically processing the search request, transposing the data into an internal version of the final data table, and performing any required replication of aggregation.
  • This second technique while possibly quicker that the preferred embodiment, requires more computer resources and code to process.
  • FIG. 4 is a diagram showing the relationship between the sections of the physical data model shown in FIGS. 4A, 4B, 4C and 4D. A detailed description of each of the elements of the data model shown in FIGS. 4A-4D is detailed in the Appendix attached hereto.
  • the core table LOT is shown which contains the basic batch tracking entity.
  • the LOT GENEALOGY TREE table tracks the various splits and submerges of lot numbers and enables the lot tracing capability. Data is added to this table on demand by a client request. For example, if a client requests a lot trace, either forward or backward from a particular point in the manufacturing process, a request goes from the client to application software designed in accordance with the present invention in database server 105.
  • the software runs a routine designed in accordance with the present invention against the two tables and from that summarizes and proves a list of all nodes in the genealogy trees and all of the links between the nodes as shown in FIG. 3. This information is essentially transient, created on demand and purged periodically.
  • the LOT tables contain the core information for the relationship between the lot as an entity and its history in terms of various transactions that have happened to the lot as it splits and merges in the production process.
  • PRODUCT and PRODUCT ATTR (attribute) tables contain model numbers and attributes of various products, which as described above, may change, for example, on a yearly basis.
  • FIGS. 4A-D most of the tables are interconnected with a number of lines, each with an arrow of one of a number of different shapes. These lines and arrows represent relationships between the entities.
  • Each entity comprises a data table within data model 400.
  • the arrows and lines represent the relationship between these entities.
  • a single arrow head indicates that there is a one element in that data table or entity corresponding to the other entity or data table.
  • Two arrow heads indicate that there are a number of elements in a data table which correspond to the entity or data table at the other end of the connecting line.
  • a circle, or zero indicates that there are no elements in a data table corresponding to the data table at the other end of the connecting line.
  • a line with only a zero at its end indicates that there is no entity relationship between two tables, and thus, for the sake of clarity, such lines are not shown.
  • a zero combined with either a single or double arrow head indicates that there may be zero or one (single head) or more (double head) data elements corresponding to the connected entity.
  • the WAFER TO LOT table describes the relationship between the wafers and the lots. Wafers may be tracked individually and a unique identifier may be assigned to each wafer. A given wafer may belong to one or more lots, depending on what stage in processing the wafer is in. Since a lot may be made up of a number of wafers, each entry in the LOT table may correspond to a number (or none) of WAFER TO LOT entries.
  • the WAFER table contains entries of each wafer number. For each WAFER TO LOT entry there may be a number of WAFER entries.
  • the UNIT TO LOT and UNIT tables describe a similar relationship between the UNITs (i.e., individual chips sawed from the wafers) and the LOTS and WAFERS. For example, each WAFER entry may correspond to a number (or none) of corresponding UNITS entries.
  • the data model 400 of the present invention is flexible to accommodate changes in the process steps. For example, another row of data may be added to a table without changing the overall structure of the model.
  • a data distributor software application may be provided to distribute any source database table from a database server (e.g., 105) to any number of other target or destination database servers (e.g., 107) throughout worldnet network 111.
  • the entire contents of a database table or a subset of that table may be replicated from a local database server (e.g., 105) to any number of remote database servers (e.g., 107).
  • the data distributor software application may facilitate the operation of several function of the distributed database system, particularly for manipulating and outputting data into report formats for clients.
  • the client servers 108, 109, 110, 111 and loaders 104 may require timely access to a subset of the distributed database.
  • a lot genealogy for front to back lot traceability (as shown in FIG. 3) may require data elements from a plurality of database servers 105, 107 in the distributed database.
  • lot-based engineering summary data which may be provided to improve communications between different manufacturing locations may require data elements from several database servers 105, 107. Standard worldwide database table joins may not provide the necessary performance characteristics required by some of these applications.
  • FIG. 5 is a block diagram illustrating the relationship between data distributor 509 and database servers 505, 506, 507, and 509 within the distributed database of the present invention.
  • the use of data distributor 509 improves application performance by reducing the requirement for data access across remote sites by subsetting the remote data and replicating it locally. Further, data distributor serves to reduce network traffic during an application's run time and increases control over the timing of network transfers, for the better overall utilization of network resources. Data distributor 509 also serves to provide a redundant data source, and thus eliminate some points of system failure. If one portion of the distributed database is down (e.g., for maintenance, repair, or for data loading) client application programs may still be run if the necessary data has been replicated by data distributor 509.
  • FIG. 6 is a block diagram of the architecture of data distributor 509 of FIG. 5.
  • Loader 604 represents any loader 501-504 within the distributed database.
  • local table 605 represents any local database server 505, 506, 507, 509 within the distributed database. Coupled to local table 605 is a shadow table 606, which may shadow the contents of local table 605.
  • Local table 605 and Shadow table 606 are coupled to data distributor 609, which in turn is coupled to a remote table 607.
  • Remote table 607 may represent any other database server within the distributed database system.
  • Data distributor 609 is designed to dynamically learn which data should be replicated, and to which destinations such data should be replicated to.
  • Data distributor 609 is integrated into the client server query software and system data dictionary so as to learn which data should be replicated and to which remote databases the data should be replicated to.
  • the data distributor of the present invention provides a balance between data cost and accessibility.
  • Data distributor 609 determines which data from the data model shown in FIG. 4, and which related data elements should be transferred in response to a transfer request. If the integrity constraints of the data model shown in FIG. 4 are changed, data distributor 609 automatically "learns" to retrieve the correctly related data. In addition, data distributor 609 may be programmed to learn which data to replicate based upon other criteria, such as frequency of requests for particular data elements of the frequency of particular data queries (e.g., lot genealogy or the like).
  • Shadow table 606 is created to mirror source table (local table) 605 with additional data distributor application attributes.
  • Database triggers on the source (local) table 605 capture and post all inserts, updates, and deletes (i.e., incremental changes) to the shadow table 606.
  • the main program of data distributor 609 then executes to replicate a data configuration to predefined remote nodes, shown here as remote table (database) 608.
  • An incremental run of database distributor 609 will replicate appropriate rows within shadow table 606.
  • a full run of database distributor 609 will replicate all designated rows from source (local) table 605.
  • the data designator delete application program 607 will execute to clean up shadow table 606 after rows have been replicated successively.
  • Remote table 608 comprises one or more destination table objects in a remote database server. More than one remote database server may be targeted, however, for the sake of illustration, only one remote table 608 is shown here. Changes from the local source node (604, 605, 606) may be transferred directly via database distributor 609 to the remote target table 608. Thus, data maintained at multiple sites throughout the distributed database is updated whenever incremental changes occur, or new data is entered.
  • Data distributor 609 has the ability to provide both incremental and full refreshes of database tables to remote site databases. replicating incremental changes dramatically reduces the overall volume of data transfers. Full refresh capability is provided to restore lost data, as well as for system initialization. Once a database has be suitably replicated using a full refresh, subsequent incremental refreshes should keep all replicated data current.
  • the distributor mechanism of data distributor 609 comprehends the table dependencies shown in FIGS. 4A-D and distributes only those related rows from dependent tables.
  • the distributed database system of the present invention may receive a large amount of data from various sources on a daily basis.
  • the amount of space available (on a disk drive or the like) may quickly be filled.
  • a database archiver is provided.
  • the database archiver is a software application which archives data from a local database based upon customizable options.
  • the database archiver also provides for client requestable de-archival of data. De-archived data may be available to all clients throughout the distributed database in a transparent fashion, either through normal inquiries, or as updated by data distributor 609. In the preferred embodiment, archived data should be available to a client within twenty four hours after a request.
  • FIG. 7 is a block diagram showing the architecture of data archiver of the present invention. Archiver 710 and recovery 713 are shown as separate elements in FIG. 7, however, the two may be combined into one application.
  • Loader 704 and associated local table (database) 705 may comprise any local loader and database, for example, as shown in FIG. 5. For the purposes of illustration, only one loader 704 and local table (database) 705 are shown here.
  • Archiver 710 may archive data from local table 705 based upon one or more predetermined criteria. Lot level archives are triggered based upon the retention days of the data and the lot complete data (which is added to the LOT table). Non-lot based levels may be triggered based upon the retention days of the data and a defined level date. A lot complete data is defined as wither the date a lot of finished product ships from one area type to another (e.g., fabrication to packaging and final test) or the date at which the lot is moved out of a manufacturing step with a zero quantity. One a lot complete trigger has occurred, the data retention clock may be triggered. Thus, for example, data relating to a particular lot of semiconductor devices may be archived 60 days after the lot has left the fabrication step.
  • Archived data may be written out by archiver 710 into individual data files, one per lot, per level, shown as archive file 711 in FIG. 7. In this manner, the archived files may be reloaded into a database using the same loader 704 used to originally load the data.
  • Archive file 711 is stored to and retrieved from a long-term secondary storage media 712, such as a magnetic tape or optical drive.
  • the schema version e.g., software version, database format and the like
  • a client may initiate a de-archive request from a lot status screen in the client graphical user interface run on client server 108, 109, 110, 112. Data level de-archive requests are then entered in a de-archival queue. Within twenty-four hours, a job will run which scans the de-archive queue to determined which data to return to the database. The de-archival program determines the current schema version, and build the appropriate loader control files necessary to reload the data. De-archived data may remain in the database for a defined period of time (e.g., 30 days) depending on the type of data (level). The client may be notified by electronic mail when the requested data has been de-archived.
  • a defined period of time e.g. 30 days
  • the present invention may also be applied to other process steps which generate large amounts of disparate data, without departing from the spirit and scope of the invention.
  • the database distributor and archiver of the present invention may be similarly applied to other types of distributed databases.
  • the WorkStreamTM CAM system is discussed here for the purposes of illustration, other data acquisition systems, databases, data acquisition systems, or data sources may be used without departing from the spirit and scope of the invention.
  • GUI graphical user interface

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Accounting & Taxation (AREA)
  • Strategic Management (AREA)
  • Finance (AREA)
  • Development Economics (AREA)
  • Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • General Business, Economics & Management (AREA)
  • Marketing (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Human Resources & Organizations (AREA)
  • Manufacturing & Machinery (AREA)
  • Power Engineering (AREA)
  • Operations Research (AREA)
  • Quality & Reliability (AREA)
  • Microelectronics & Electronic Packaging (AREA)
  • Tourism & Hospitality (AREA)
  • Computer Hardware Design (AREA)
  • Game Theory and Decision Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • General Factory Administration (AREA)

Abstract

Data in disparate formats from different data sources are reformatted into a common data format and stored in database servers serving one or more data sources such that each database server contains only a portion of the composite database. A client server and graphical user interface are provided for allowing a client to perform simple search requests on one database server, browse requests on all database servers, or serve complex search requests on one or more database servers. The client server may reformat the resultant search data into one or more specific database formats for retrieval and manipulation by a specific database program or display the information for the client. The present invention has particular application to the semiconductor manufacturing field, for tracking data produced during the processes of semiconductor manufacturing.

Description

This application is a divisional of application Ser. No. 08/811,462 filed Mar. 3, 1997 U.S. Pat. No. 5,889,674, which is a continuation of application Ser. No. 08/223,348 filed Apr. 5, 1994, U.S. Pat. No. 5,625,816.
TECHNICAL FIELD
The present invention relates to providing engineering data related to the manufacture of semiconductor devices in a uniform format in a centralized database and accessing that database including a graphical user interface.
BACKGROUND ART
The manufacture of semiconductor devices requires a number of discrete process steps to create a packaged semiconductor circuit device from raw semiconductor material. The various processes, from the initial melt and refinement of the semiconductor material, the slicing of the semiconductor crystal into individual wafers, the fabrication stages (etching, doping, ion implanting or the like), to the packaging and final testing of the completed device, are so different form one another and specialized that the processes may be performed in different facilities in remote regions of the globe.
For example, the process of growing and refining a large semiconductor crystal (e.g., Si, GaAs or the like) may be performed by a foundry specializing in such crystal growth techniques. The resultant crystals may then be sold directly to a semiconductor manufacturer, either as large crystals, or as wafers, sliced from a large crystal.
The semiconductor manufacturer may then slice the semiconductor crystal into wafers, if the semiconductor material is not already in wafer format,. The semiconductor manufacturer then fabricates semiconductor circuit devices (e.g., microprocessor, DRAM, ASIC or the like) on individual wafers, usually forming a number of devices on each wafer. The individual fabrication (or "FAB") processes include photolithography, ion implantation, and other associated FAB processes known in the art. Typically, the resultant semiconductor device is tested on the wafer during and after the FAB process.
Once the semiconductor devices have been fabricated and tested on the wafer, the wafer is sliced up into individual semiconductor chips and packaged. The packaging process includes mounting and wire-bonding the individual chips to chip carriers (e.g., PLCCs, DIPs, CER-DIPs, surface mount carriers or the like) and final testing of the resultant packaged semiconductor device. This packaging process is fairly labor intensive, and thus it may be desirable to perform the mounting, wire-bonding, and final testing at an offshore facility where labor rates may be cheaper. Once completed, the packaged semiconductor device may again be tested, and then labeled and shipped to customers through a distribution system.
One problem which arises in this prior art manufacturing technique, is that the various processes take place at different discrete locations. Thus, it is difficult to track a semiconductor device through the fabrication process, from single crystal to finished product. Such tracking may be necessary for quality control purposes in order to determine the causes of production problems which may result in low yields or circuit defects.
In present fabrication facilities, individual fabrication machines or computer aided manufacturing systems (CAM systems) may provide data regarding operating conditions during the fabrication process. Some of these data are intrinsic data, for example, lot numbers, device model numbers or the like. Other data may be extrinsic data, such as production test data, production conditions, or the like. In the various processes, the various lot numbers may be changed, thus making it difficult for a production engineer to track down and solve difficulties in the production process.
For example, a semiconductor crystal or wafers may be assigned a manufacturer's lot number and shipped to a FAB facility. The FAB facility may in turn divide these wafers into different lots of 25 to 50 wafers, each assigned a new and different lot number. Each of these new lots of wafers may be used in the manufacture of a particular model semiconductor device. These lots may further comprise wafers commingled from other received lots of semiconductor wafers. During different process steps in the FAB facility, new lot numbers may be assigned to a wafer of group of wafers.
In the final assembly facility, the wafers are sliced up into chips, which may be assigned yet again new lot numbers. Through the production process testing and manufacturing steps are performed, generating data for each semiconductor device. If a problem arises in the manufacture of the semiconductor, for example a low yield of usable semiconductor devices, a production engineer may wish to track the semiconductor devices to determine why the production problem existed, correct the problem if necessary, and intercept other semiconductor devices similarly affected before performing additional process steps or shipping the product to the consumer.
Some efforts have been made through CAM systems to set up shop floor control systems (e.g. WorkStream™ or the like) and gather data on semiconductor devices during manufacturing. However, in such a shop floor control system, the collection of engineering data has been a by-product of the need to manage the inventory in the factory and manage the factory itself.
Unfortunately, in the prior art, no such system existed for effectively tracking engineering data from the various facilities. Manually tracking engineering data is hampered by several problems. First, the multiple facilities, if provided with computerized data acquisition systems (e.g., CAM or the like) may utilize different systems within the facility, and each facility may have systems different from the other. Thus, the computer systems may be incompatible and not effectively interfaced with one another. In addition, the different systems generally collect data in different formats, and thus data from one system cannot readily be compared or merged with data from another system. Further, since different lot numbers may be assigned at different steps in the manufacturing process, it may be difficult for an engineer to effectively track a particular chip, group of chips, wafer, or group of wafers back though the process steps. Since many of these CAM processes utilize computer systems dedicated to the manufacturing process, the systems may be unsuitable or too engaged to be used for manually tracking the production process of a semiconductor device.
In addition to improving the production process, the ability to track production data for a semiconductor device may also be useful to a semiconductor manufacturer in enhancing the value of the semiconductor to the consumer. For many critical applications (e.g., military or the like), the consumer may require assurances that the quality control of the semiconductor device can be effectively traced at each step. Further, the consumer may require that each semiconductor be provided with its "lineage," including the data generated in the manufacture and testing of the semiconductor device.
DISCLOSURE OF THE INVENTION
A system for storing and retrieving data comprises a network for transmitting and receiving data and at least one input system for inputting data in at least a first format. A reformatter receives the data and reformats the data into a predetermined standard format. A database coupled to the network stores the reformatted data, A loader loads the reformatted data into the database. At least one client workstation is provided, coupled to the network, for receiving database search requests. A front end server, coupled to the network, receives the database search requests and processes the search requests, querying the database, receiving reformatted data from the database, and outputting the reformatted data.
It is an object of the present invention to provide a global database of manufacturing data which may be readily accessed by a reliability engineer to provide product performance history for a particular manufactured product.
It is a further object of the present invention to provide a standardized data format for reformatting disparate types and forms of data into a common format which may be stored in a global database.
It is a further object of the present invention to provide a method and system for tracking a manufactured product or group of manufactured products through a manufacturing process comprising a series of manufacturing steps performed at different physical locations.
BRIEF DESCRIPTION OF DRAWINGS
FIG. 1 is a block diagram of the database system of the present invention.
FIG. 2 is a block diagram of the software structure and data flow between client and database servers of the present invention.
FIG. 3 is a sample product performance history generated for a sample lot of semiconductors using the database system of the present invention.
FIG. 4 is a diagram showing the relationship between the sections of the physical data model shown in FIGS. 4A, 4B, 4C, 4D, 4E, 4F, 4G, 4H, 4I, 4J, 4K, 4L, 4M, 4N, 4O, 4P and 4Q.
FIGS. 4A, 4B, 4E and 4F are a block diagram of the upper left hand corner of the physical data model of the present invention.
FIGS. 4I, 4J, 4M and 4N are a block diagram of the upper right hand corner of the physical data model of the present invention.
FIGS. 4K, 4L, 4P and 4Q area block diagram of the lower right hand corner of the physical data model of the present invention.
FIGS. 4C, 4D, 4G and 4H are a block diagram of the lower left hand corner of the physical data model of the present invention.
FIG. 5 is a block diagram illustrating the relationship between the data distributor and database servers within the distributed database of the present invention.
FIG. 6 is a block diagram of the architecture of the data distributor of FIG. 5.
FIG. 7 is a block diagram showing the architecture of data archiver of the present invention.
BEST MODE FOR CARRYING OUT THE INVENTION
In FIG. 1, the database system of the present invention is composed of various distributed elements connected together by a common network designated as worldnet network 111. Worldnet network 111 may comprise, for example, any of many known computer system networks which may be accessed via telephone link, microwave relay, satellite link or the like. As the name implies, worldnet network may provide a data link between system elements located throughout the world. Alternatively, worldnet network may comprise a network more limited in scope, including a local area network (LAN) for use within one plant location, without departing from the spirit and scope of the invention. In the preferred embodiment, worldnet network comprises a global communications network which allows systems elements to be located at various locations throughout the world.
Raw data 101 is generated at or within a particular plant facility. As discussed previously, semiconductor circuit manufacturing may be performed in several steps, including crystal growth, wafer sawing, so-called FAB or fabrication, testing, packaging and the like. Raw data 101 may comprise raw data produced from any one or a combination of these steps. Further, raw data 101 may comprise test data from testing performed before, during or after any one of these process steps. For the sake of illustration, only one group of raw data 101 is shown. However, other groups of raw data 101 and associated reformatter servers 102 may be provided for data generated from each process step or groups of steps.
Raw data 101 may comprise, for example, data generated from a WorkStream™ CAM system. This data may include manually keyed data generated by production employees or production engineers and entered at the shop floor into a WorkStream™ system. The data may also include data automatically loaded by the WorkStream™ system during the manufacturing process from the manufacturing equipment. These data may include, for example, temperature and pressure data describing the manufacturing process during, e.g., an etching operation. Such data is referred to as extrinsic data. So-called intrinsic data (e.g., lot number, date, time, machine number or the like) may also be manually or automatically entered into the WorkStream™ system.
Raw data 101 may be in one of a number of formats. Typically, the format of the data has been previously determined when the CAM or data acquisition system has been installed. Thus, the data format has already been determined in accordance with previously determined needs. Since the needs of the process engineers at each process step differ, it is generally the case that raw data 101 may be in one of a number of different formats. Similarly, since a number of data sources or manufacturers of data acquisition systems may differ, it is generally more often the case that raw data 101 may be in one of a number of different formats.
Reformatter server 102 is provided to reformat raw data 101 into a standardized data format known as Data Input Standard or DIS. Raw data 101 is fed to a reformatter server which reformats this data into DIS format, which will be discussed below in conjunction with FIGS. 4A-4D. Raw data 101 may be loaded into reformatter server 102 by means of data tape or disk, or through a local area network (LAN) at the data source. Each data source may be provided with a reformatter server, or in the alternative, a reformatter server may serve a number of data sources. In addition, reformatter server 102 may be fed with raw data 101 through worldnet network 111, although generally the cost of doing so may be somewhat prohibitive.
Reformatter server 102 may comprise a software program run on a computer or computer system. For example, reformatter server 102 may comprise a UNIX™ based computer system or a DOS based computer or computer network. In the preferred embodiment, the reformatter server may comprises a software program run on a general purpose UNIX™ based computer coupled to worldnet 111.
If the semiconductor crystals or wafers are purchased from an outside foundry, production data from that foundry may be provided (via contract arrangement with that foundry) in the DIS format or as raw data for input into the database system of the present invention. Similarly, data for other purchased components may be entered into the database system. This outside data may be provided on tape or disc and may be loaded in the DIS format into a database server 104 via loader 104. Alternatively, an outside supplier may be able to download such data electronically via a commercial network (e.g., Compuserve™) or via a telephone modem, private network or the like, or by access granted by the manufacture through worldnet network 111.
If the outside data is not in the DIS format, a reformatter server 102 may be provided or adapted to reformat the outside data into the DIS format for inclusion into the database system. If the data in electronic format cannot be obtained from the supplier or foundry, selected production data for the components (e.g., source, lot number, or other intrinsic or extrinsic data) may be manually keyed into the database system of the present invention.
As discussed above, raw data 101 may comprise data from a WorkStream™ CAM system generated at one manufacturing facility, such as a so-called FAB facility. At the FAB facility, a reformatter server 102 may be provided, interfaced with the WorkStream™ CAM system by means of a local area network (LAN) or the like. Periodically, raw data 101 is fed to reformatter server 102 which reformats the data into DIS format to produce DIS data 103. Once reformatted, the data in DIS format may then be available through worldnet network 111.
Once raw data 101 has been reformatted into DIS data 103 by reformatter server 102, the DIS data is loaded, via loader 104 into local database server 105 to produce database 106.
A plurality of database servers 105, 107 may be provided. For the purposes of illustration, local database server 105 represents a database server for a particular client location, whereas database server 107 represents all other database servers within the database system. Typically, each data source (e.g., manufacturing plant or testing facility) may be provided with one or more database servers 107. Thus, the entirety of the database 106 may be provided, not in any one database server, but rather spread out through a number of database servers logically joined and connected through worldnet network 111. In the preferred embodiment, each manufacturing facility may have several database servers 107.
For example, each department within a manufacturing facility may be provided with its own local database server 105. Thus, a particular department within a processing facility may supply (and pay for) its own portion of the database system. Overall costs of the database system may be paid for by each department using a subscription system similar to that used in on-line subscription systems (e.g., Compuserve™ or the like). In a similar manner, the present invention may also be applied to a commercial database systems where each subscriber provides its own portion of an overall database.
In the preferred embodiment, loader 104 may comprise a software program run on the same computer or computer system as database server 105. Preferably, database server 105 is a UNIX™ based server connected to worldnet network 111. Alternatively, one centralized loader 104 may be provided to load data into any portion of database 106 in database servers 105, 107 as determined by the content of DIS data 103. However, in the preferred embodiment, a number of loaders 104 are used, each optimized to load data into certain regions of database 106 depending on data type.
Since the primary purpose of the WorkStream™ system is to manage and control the manufacturing operation, raw data 101 is loaded only periodically via reformatter server 102. The period between the loading of the data may be determined generally by the engineering needs for that data. For example, so-called structural information, such as product lines (e.g., model designations or the like) may change only on a yearly basis. Other data, such as intrinsic and extrinsic data, may change on a daily or hourly basis as individual semiconductor devices pass through various process steps. Thus, the range for the time period between successive reformatting and loading of raw data may vary from an hourly to a yearly basis.
Distributing database 106 over a number of database servers 105, 107 on worldnet network 111 provides a number of advantages over prior art centralized databases. For example, as discussed above, the task of reformatting and loading raw data 101 can be more easily performed by a series of decentralized reformatter servers 107 and loaders 104 located in proximity to each source of raw data 101. Further, since reformatting and loading is performed locally, the amount of data flow through the worldnet network 111 may be greatly reduced. In addition, the plurality of database servers 105, 107 provides for system redundancy, such that if one database server is disabled, database 106 is not entirely disabled. Finally, since most database search or trace requests will be directed towards data contained in a local database server 105, the speed and response time of database 106 are improved.
Access to database 106 is provided through one of a number of client servers located on worldnet network 111. The term "client," as used in this application, refers to an end user of the database system (e.g., production engineer or the like). The client server may take the form of a graphical user interface (GUI) provided in an IBM™ compatible personal computer (PC) 109, an Apple™ MacIntosh™ computer 110 or UNIX™ Workstation 108 coupled to worldnet network 111. Collectively, client servers 108, 109, and 110 and local database server 105 may be referred to as "front-end" servers, and reformatter server 102 and loader 104 may be referred to as "backend" servers.
Client servers 108, 109, 110 are provided with a graphical user interface (GUI) program which allows the client to access database 106. Access to database 106 may take one of several forms. As discussed above, database 106 is decentralized into a number of database servers 105, 107. A production engineer or client within a particular facility, for example, the FAB facility, may have direct on-line access to that portion of database 106 contained within a database server, for example, local database server 105, located within that facility.
Most requests by a client will be related to that portion of the database 106 contained within that client's local database server. Thus, for example, a production engineer in a FAB facility may be most interested in data generated within that facility. Since that portion of database 106 is located within the local database server 105, information requests entered into client server 108, 109 or 110 may be quickly and easily handled.
The next type of data request that may be entered by a client into a client server 108, 109 or 110 is the so-called "browse" request. Such requests are not detailed data search requests, but nevertheless may require data from one of a number of database servers 105, 107 containing database 106. These browse requests are made by the client from client server 108, 109, or 110 and transmitted through worldnet network 111. Worldnet network 111 may access any one of database servers 105, 107 and request browse data. Examples of browse data include specific requests concerning lot numbers or data from a specific lot number or the like.
Other request may be much more complex. For example, a production engineer attempting to troubleshoot a particular production problem, may enter a complex data analysis request. Such a request for example, may comprise a complete genealogy from a particular chip, the results of which are shown in FIG. 3. Other requests may include, e.g., a search request for all lot numbers of chips processed by a particular machine or plant during a particular time period. For example, if a production engineer determined that a particular fabrication process has malfunctioned for a particular time period, the engineer may wish to trace all products which were processed during that time period and intercept those products before further processing is performed or the product is shipped to customers.
These complex search requests may require a relatively large amount of time to complete and thus may be entered as off-line requests to be performed as background jobs. Through the GUI in client server 108, 109, or 110, the client enters the search request using logical field operators as is well known in the art. Front end server 112, coupled to worldnet 111, receives and processes these complex requests. Database servers 105, 107 may operate using, for example, Oracle™ database library software, which provides an operating system and search software for a database server 105, 107. A client's local database server 105 then processes the search request, requesting information from other database servers 107 as necessary. Through the GUI in client server 108, 109, or 110, the client may be notified when the search request has been complete.
FIG. 3 shows an example of a result of a complex search request, in this instance, a genealogy of a semiconductor device. The GUI of the present invention allows the user to view this genealogy in graphical form on a CRT screen, or print the genealogy on a suitably equipped printer. FIG. 3 shows the series of process steps followed by a lot of semiconductor devices through various process steps. The semiconductor devices begin as raw semiconductor wafer material, here shown with the sample lot number "ROOT" in step 381. Steps 382-384 show the fabrication steps in the processing of the wafer, whereas step 385 shows the initial testing stage of the devices. Assembly steps 386-390 show the various steps taken in the assembly process. Not all of the original semiconductor devices are assembled in the same steps. Different devices may be assembled in different machines, different plants, or into different chip carriers. The final step 391 shows the manufacturing lot number assigned to the finished device. Throughout the manufacturing process, the lot numbers assigned to the semiconductors may change at different steps. The genealogy shown in FIG. 3 allows a production engineer to make further inquiries, if necessary, regarding manufacturing conditions or the like, with respect to a particular lot number or step in the process.
The GUI of the present invention provides the client with a variety of options with regard to the format of retrieved data from a complex search request. The GUI or the present invention may allow the client to view of browse the produced data, or may reformat that data into one of a number of formats corresponding to commercially available database programs (e.g., Lotus 1-2-3™, Paradox™, Excel™, RS1™, SAS™, or the like). Thus, engineers within a particular production facility or department may download information from database 106 and reformat this information into other database programs to meet pre-existing program or project needs.
FIG. 2 is a block diagram of the software structure and data flow between client and database servers of the present invention. Client server 251 may comprise, for example, PC 109 of FIG. 1. However client server 251 may also be substituted by client servers 108 or 110 shown in FIG. 1 without departing from the spirit or scope of the invention. Client server 251 contains a package of software programs which cooperate to provide a graphical user interface (GUI) for client requests. PC-NFS, a product of SUN Microsystems, comprises a software package which allows a DOS based PC to operate as a UNIX™ workstation. The OpenInterface™ Windows™ library, a product of Microsoft™ corporation, provides a standardized set of GUI interface routines. The ORACLE™ database library provides the data search and retrieval routines for accessing database 106. Custom written C-code provides a GUI incorporating elements of OpenInterface™ and ORACLE™. TCP/IP is a network protocol recognition software which allows the client server to run on an Ethernet™ system.
The front end server 112 may comprise a software program operating in a general purpose UNIX™ based computer coupled to worldnet 111. Database servers 253 in FIG. 2 represent collectively all database servers 105, 107 in the database 106. Browse requests entered into client server 251 are applied directly to database servers 253, bypassing front end server 112. Since the browse requests are directed towards specific fields of data and do not require large amounts of data to be transferred, these requests can be quickly handled by database servers 253 and transferred to client server 251 through worldnet 111 (not shown).
Front end server 112 may comprise a large, general purpose UNIX™ based computer, or alternately may comprise the same computer as local database server 105. Complex database requests and data analysis are processed by front-end server 112. Complex database requests generally ask for data from more than one portion of the process and may require accessing data from more than one region of database 106. Thus, complex requests may be entered into client server 251 and processed by front end server 112 as a so-called "background" job. Once the complex request has been entered into client server 251, front end server 112 processes the request, freeing client server 251 for further browsing or other tasks. As discussed above, client server 251 may comprise any of client servers 108, 109, or 110 (i.e., UNIX, DOS-PC or MAC). As such, the computer housing the software for client server 251 may not be dedicated to the client server task, but may also be used for other tasks commonly assigned to such PCs or workstations.
Front end server 112 may generate a query status file, which is periodically updated with the status of a complex search request. This file may be accessed by the client through client server 251 to determine the status of his complex request. For example, the client may wish to determine whether the complex request has been completed, or at what stage the complex request has reached (i.e., percent completed). Further, in some instances, a client may inadvertently issue a complex request which causes the front end server to "hang." Such a request, for example, may ask for an incompatible combination of data operators (i.e., searching a numerical field for a text operand). The client may then issue commands through client server 251 to front end server 112 to terminate the complex request.
In addition, the front end server may be interfaced with, or provide an E-mail type system to notify clients of completed search requests or to allow communication between different clients in the system. Further, the front end server may "deliver" the completed search result in a desired format (e.g., compatible with a particular print format or in a format compatible with a commercial database program) to a location determined by the client. In addition, the front end server may (if selected by the client in making the complex request) provide a log of the process of the complex request, for example, noting any errors or abnormalities in the processing of the search request. For example, if some requested data is unavailable due to a database serving being down or inaccessible, the front end server may note that unavailability of that data and continue the complex request.
To enter a complex request, the client server creates a query request file using information entered by the client through the GUI. The query request file includes the name of query definition file which contains the logical search request. The query request file also includes and the destination environment and node (i.e., format and file location). Front end server 112 parses the query request file and scans the query definition to determine which database servers 106 are being referenced. Front end server 112 then partitions the main query definition file into "child" files each of which references one database server 106. Front end server 112 may then run a request for each child definition file using one of two methods.
In the first method, which is the preferred embodiment of the present invention, a search request is generated and run against the database. The results are copied out to a series of temporary ASCII files. These row-wise ASCII files are then processed to do any further aggregation as required as well as a final transpose. the transposed data file is then delivered to the destination environment.
The second and alternative method of the present invention generates the search request and feeds it into a dynamic search processor program which is responsible for dynamically processing the search request, transposing the data into an internal version of the final data table, and performing any required replication of aggregation. This second technique, while possibly quicker that the preferred embodiment, requires more computer resources and code to process.
FIG. 4 is a diagram showing the relationship between the sections of the physical data model shown in FIGS. 4A, 4B, 4C and 4D. A detailed description of each of the elements of the data model shown in FIGS. 4A-4D is detailed in the Appendix attached hereto.
In FIG. 4A, the core table LOT is shown which contains the basic batch tracking entity. The LOT GENEALOGY TREE table tracks the various splits and submerges of lot numbers and enables the lot tracing capability. Data is added to this table on demand by a client request. For example, if a client requests a lot trace, either forward or backward from a particular point in the manufacturing process, a request goes from the client to application software designed in accordance with the present invention in database server 105. The software runs a routine designed in accordance with the present invention against the two tables and from that summarizes and proves a list of all nodes in the genealogy trees and all of the links between the nodes as shown in FIG. 3. This information is essentially transient, created on demand and purged periodically. The LOT tables contain the core information for the relationship between the lot as an entity and its history in terms of various transactions that have happened to the lot as it splits and merges in the production process.
Other tables are fairly static. For example, the PRODUCT and PRODUCT ATTR (attribute) tables contain model numbers and attributes of various products, which as described above, may change, for example, on a yearly basis.
In FIGS. 4A-D, most of the tables are interconnected with a number of lines, each with an arrow of one of a number of different shapes. These lines and arrows represent relationships between the entities. Each entity comprises a data table within data model 400. The arrows and lines represent the relationship between these entities. A single arrow head indicates that there is a one element in that data table or entity corresponding to the other entity or data table. Two arrow heads indicate that there are a number of elements in a data table which correspond to the entity or data table at the other end of the connecting line. A circle, or zero, indicates that there are no elements in a data table corresponding to the data table at the other end of the connecting line. A line with only a zero at its end indicates that there is no entity relationship between two tables, and thus, for the sake of clarity, such lines are not shown. A zero combined with either a single or double arrow head indicates that there may be zero or one (single head) or more (double head) data elements corresponding to the connected entity.
For example, considering the LOT and LOT GENEALOGY tables shown in FIG. 4A, for every record or entry in the LOT GENEALOGY table, there is one associated entry (i.e., lot number) in the LOT table, as indicated by the single arrow head on the connecting line between the tables. Conversely, for every lot number in the LOT table, there may be a number of entries in the LOT GENEALOGY table (if a lot genealogy was performed as discussed above) or no entries (if no lot genealogy was performed) as shown by the two arrow heads and circle on the connecting line between the tables.
Similarly, the WAFER TO LOT table describes the relationship between the wafers and the lots. Wafers may be tracked individually and a unique identifier may be assigned to each wafer. A given wafer may belong to one or more lots, depending on what stage in processing the wafer is in. Since a lot may be made up of a number of wafers, each entry in the LOT table may correspond to a number (or none) of WAFER TO LOT entries. The WAFER table contains entries of each wafer number. For each WAFER TO LOT entry there may be a number of WAFER entries. The UNIT TO LOT and UNIT tables describe a similar relationship between the UNITs (i.e., individual chips sawed from the wafers) and the LOTS and WAFERS. For example, each WAFER entry may correspond to a number (or none) of corresponding UNITS entries.
The data model 400 of the present invention is flexible to accommodate changes in the process steps. For example, another row of data may be added to a table without changing the overall structure of the model.
In order to facilitate operation of the distributed database, a data distributor software application may be provided to distribute any source database table from a database server (e.g., 105) to any number of other target or destination database servers (e.g., 107) throughout worldnet network 111. The entire contents of a database table or a subset of that table may be replicated from a local database server (e.g., 105) to any number of remote database servers (e.g., 107). The data distributor software application may facilitate the operation of several function of the distributed database system, particularly for manipulating and outputting data into report formats for clients.
For example, the client servers 108, 109, 110, 111 and loaders 104 may require timely access to a subset of the distributed database. For example, a lot genealogy for front to back lot traceability (as shown in FIG. 3) may require data elements from a plurality of database servers 105, 107 in the distributed database. Similarly, lot-based engineering summary data, which may be provided to improve communications between different manufacturing locations may require data elements from several database servers 105, 107. Standard worldwide database table joins may not provide the necessary performance characteristics required by some of these applications.
FIG. 5 is a block diagram illustrating the relationship between data distributor 509 and database servers 505, 506, 507, and 509 within the distributed database of the present invention. The use of data distributor 509 improves application performance by reducing the requirement for data access across remote sites by subsetting the remote data and replicating it locally. Further, data distributor serves to reduce network traffic during an application's run time and increases control over the timing of network transfers, for the better overall utilization of network resources. Data distributor 509 also serves to provide a redundant data source, and thus eliminate some points of system failure. If one portion of the distributed database is down (e.g., for maintenance, repair, or for data loading) client application programs may still be run if the necessary data has been replicated by data distributor 509.
FIG. 6 is a block diagram of the architecture of data distributor 509 of FIG. 5. Loader 604 represents any loader 501-504 within the distributed database. Similarly, local table 605 represents any local database server 505, 506, 507, 509 within the distributed database. Coupled to local table 605 is a shadow table 606, which may shadow the contents of local table 605. Local table 605 and Shadow table 606 are coupled to data distributor 609, which in turn is coupled to a remote table 607. Remote table 607 may represent any other database server within the distributed database system.
Data distributor 609 is designed to dynamically learn which data should be replicated, and to which destinations such data should be replicated to. Data distributor 609 is integrated into the client server query software and system data dictionary so as to learn which data should be replicated and to which remote databases the data should be replicated to. There are associated system costs involved with data replication. Data replication requires additional disk space, increases network traffic over worldnet 111, and requires additional CPU time. Thus, a balance must be struck between what data is needed frequently and associated data costs. Full replication of all data from each database within the distributed database to other databases would provide maximum client access to all data. However, such an approach would be unduly cost prohibitive. The data distributor of the present invention provides a balance between data cost and accessibility. Limited types of inquiries, such as lot summary and traceability data across sites, which may be used often by clients, may be selected for use with data distributor 609. Data supporting these inquiries may then be replicated so as to provide data redundance and reduce client inquiry dwell time. Data distributor 609 determines which data from the data model shown in FIG. 4, and which related data elements should be transferred in response to a transfer request. If the integrity constraints of the data model shown in FIG. 4 are changed, data distributor 609 automatically "learns" to retrieve the correctly related data. In addition, data distributor 609 may be programmed to learn which data to replicate based upon other criteria, such as frequency of requests for particular data elements of the frequency of particular data queries (e.g., lot genealogy or the like).
Elements 604, 605, and 606 may be collectively referred to as the local source node, where the table requiring replication resides. Shadow table 606 is created to mirror source table (local table) 605 with additional data distributor application attributes. Database triggers on the source (local) table 605 capture and post all inserts, updates, and deletes (i.e., incremental changes) to the shadow table 606. The main program of data distributor 609 then executes to replicate a data configuration to predefined remote nodes, shown here as remote table (database) 608. An incremental run of database distributor 609 will replicate appropriate rows within shadow table 606. A full run of database distributor 609 will replicate all designated rows from source (local) table 605.
The data designator delete application program 607 will execute to clean up shadow table 606 after rows have been replicated successively. Remote table 608 comprises one or more destination table objects in a remote database server. More than one remote database server may be targeted, however, for the sake of illustration, only one remote table 608 is shown here. Changes from the local source node (604, 605, 606) may be transferred directly via database distributor 609 to the remote target table 608. Thus, data maintained at multiple sites throughout the distributed database is updated whenever incremental changes occur, or new data is entered.
Data distributor 609 has the ability to provide both incremental and full refreshes of database tables to remote site databases. replicating incremental changes dramatically reduces the overall volume of data transfers. Full refresh capability is provided to restore lost data, as well as for system initialization. Once a database has be suitably replicated using a full refresh, subsequent incremental refreshes should keep all replicated data current. The distributor mechanism of data distributor 609 comprehends the table dependencies shown in FIGS. 4A-D and distributes only those related rows from dependent tables.
The distributed database system of the present invention may receive a large amount of data from various sources on a daily basis. The amount of space available (on a disk drive or the like) may quickly be filled. Thus, in order to prevent the database from overrunning the capabilities of individual database servers, a database archiver (DA) is provided.
The database archiver is a software application which archives data from a local database based upon customizable options. The database archiver also provides for client requestable de-archival of data. De-archived data may be available to all clients throughout the distributed database in a transparent fashion, either through normal inquiries, or as updated by data distributor 609. In the preferred embodiment, archived data should be available to a client within twenty four hours after a request.
FIG. 7 is a block diagram showing the architecture of data archiver of the present invention. Archiver 710 and recovery 713 are shown as separate elements in FIG. 7, however, the two may be combined into one application. Loader 704 and associated local table (database) 705 may comprise any local loader and database, for example, as shown in FIG. 5. For the purposes of illustration, only one loader 704 and local table (database) 705 are shown here.
Archiver 710 may archive data from local table 705 based upon one or more predetermined criteria. Lot level archives are triggered based upon the retention days of the data and the lot complete data (which is added to the LOT table). Non-lot based levels may be triggered based upon the retention days of the data and a defined level date. A lot complete data is defined as wither the date a lot of finished product ships from one area type to another (e.g., fabrication to packaging and final test) or the date at which the lot is moved out of a manufacturing step with a zero quantity. One a lot complete trigger has occurred, the data retention clock may be triggered. Thus, for example, data relating to a particular lot of semiconductor devices may be archived 60 days after the lot has left the fabrication step.
Archived data may be written out by archiver 710 into individual data files, one per lot, per level, shown as archive file 711 in FIG. 7. In this manner, the archived files may be reloaded into a database using the same loader 704 used to originally load the data. Archive file 711 is stored to and retrieved from a long-term secondary storage media 712, such as a magnetic tape or optical drive. The schema version (e.g., software version, database format and the like) is stored with the archived data such that later changes to the schema can be handled when retrieving archived data.
To retrieve archived data, a client may initiate a de-archive request from a lot status screen in the client graphical user interface run on client server 108, 109, 110, 112. Data level de-archive requests are then entered in a de-archival queue. Within twenty-four hours, a job will run which scans the de-archive queue to determined which data to return to the database. The de-archival program determines the current schema version, and build the appropriate loader control files necessary to reload the data. De-archived data may remain in the database for a defined period of time (e.g., 30 days) depending on the type of data (level). The client may be notified by electronic mail when the requested data has been de-archived.
Although described above in terms of semiconductor manufacturing (the preferred embodiment) the present invention may also be applied to other process steps which generate large amounts of disparate data, without departing from the spirit and scope of the invention. Further, the database distributor and archiver of the present invention may be similarly applied to other types of distributed databases. Similarly, although the WorkStream™ CAM system is discussed here for the purposes of illustration, other data acquisition systems, databases, data acquisition systems, or data sources may be used without departing from the spirit and scope of the invention.
Further, other types of computers than those disclosed above may be used as client server interfaces without departing from the spirit or scope of the invention. Further, access to SAPPHiRE database 106 may also be achieved through a terminal connected directly to one of database servers 105, 107. Finally, although a graphical user interface (GUI) is disclosed as the preferred embodiment for the client server, other types of interfaces may also be used without departing from the spirit and scope of the present invention
It will be readily seen by one of ordinary skill in the art that the present invention fulfills all of the objects set forth above. After reading the foregoing specification, one of ordinary skill will be able to effect various changes, substitutions of equivalents and various other aspects of the invention as broadly disclosed herein. It is therefore intended that the protection granted hereon be limited only by the definition contained in the appended claims and equivalents thereof.

Claims (29)

What is claimed is:
1. A system for storing and retrieving data having a network including data in a predetermined format where the data is reformatted by a reformatter to produce reformatted data, the network coupled to a database wherein the reformatted data is loaded thereto via a loader, the network coupled to at least one client workstation and a front end server for receiving and processing database search requests, comprising at least one data archiver, coupled to said database, archiving at least a portion of the data stored in said database according to a predetermined archiving algorithm, and transferring archived data to an archive storage media.
2. A system of claim 1, further comprising at least one data distributor, coupled to said database and said network, for shadowing at least a portion of the data stored in said database according to a predetermined algorithm, and for transferring shadowed data over said network.
3. In a system of claim 2, wherein said shadowed data is received and stored by another database.
4. A system of claim 1, wherein said at least one data archiver stores schema data on said archive storage media accompanying said archived data.
5. A system of claim 4, further comprising at least one data de-archiver, coupled to said database, said at least one client workstation, and said archive storage media, for receiving de-archive requests from said at least one client workstation, and for retrieving at least a portion of the archived data and corresponding schema data stored on said archive storage media and transferring the archived data and the schema data to said loader.
6. A system of claim 5, wherein said loader receives said archived data and said schema data and reloads said archived data into said database.
7. A database system for storing and retrieving data having a network including data in a predetermined format where the data is reformatted by a reformatter to produce reformatted data, the network coupled to a plurality of database servers, each containing at least a portion of the data comprising a database, wherein the reformatted data is loaded thereto via a loader, at least one of said plurality of database servers arranged to receive said database search request, searches for the data in the at least one or more of said plurality of database servers and produce the data responsive to a database search request, the network coupled to at least one client workstation receiving the database search request, comprising at least one data archiver, coupled to said database, for archiving at least a portion of the data stored in said database according to a predetermined archiving algorithm, and transferring archived data to an archive storage media.
8. A database system of claim 7, further comprising a front end server, coupled to said at least one client workstation and said network, for receiving said database search request, partitioning said database search request according to the location of requested data and transmitting said partitioned search request to the at least one or more of said plurality of database servers.
9. A database system of claim 8, wherein said front end server is configured to receive resultant data responsive to said partitioned database search request from at least one of said plurality of database servers, reformat said resultant data into one of a predetermined number of predetermined data formats to produce reformatted resultant data and transmit said reformatted resultant data to said client server.
10. A database system of claim 7, further comprising at least one data distributor, coupled to at least one of said plurality of database servers and said communications network, for shadowing at least a portion of the data stored in said at least one of said plurality of database servers according to a predetermined algorithm, and for transferring shadowed data over said communications network.
11. A database system of claim 10, wherein said shadowed data is received and stored by another of said plurality of database servers.
12. A database system of claim 7, further comprising at least one data archiver, coupled to at least one of said plurality of database servers, for archiving at least a portion of the data stored in said at least one of said plurality of database servers according to a predetermined archiving algorithm, and for transferring archived data to an archive storage media.
13. A database system of claim 12, wherein said at least one data archiver stores schema data on said archive storage media accompanying said archived data.
14. A database system of claim 13, further comprising at least one data de-archiver, coupled to at least one of said plurality of database servers, said at least one client server, and said archive storage media, for receiving de-archive requests from said at least one client server, and for retrieving at least a portion of the archived data and corresponding schema data stored on said archive storage media, and transferring the archived data and the schema data to said at least one loader.
15. A database system of claim 14, wherein said loader receives said archived data and said schema data and reloads said archived data into said at least one of said plurality of database servers.
16. A method used in the manufacturing of a semiconductor device, comprising the steps of:
(a) collecting process data having a first prescribed format representing processing of a semiconductor material to form a semiconductor circuit, and collecting test data of a second prescribed format representing testing of the semiconductor circuit;
(b) reformatting said process data and said test data into a predetermined data format comprising at least one of the first prescribed format, the second prescribed format and another prescribed format to produce reformatted data; and
(c) loading said reformatted data into at least one database server to produce a database containing said reformatted data in the predetermined format.
17. The method of claim 16, further comprising the step of querying said database to produce a record of the production and testing of said semiconductor circuit.
18. The method of claim 17, further comprising the step of receiving said database search request, partitioning said database search request according to the location of requested data and transmitting said partitioned search request to the at least one or more of said plurality of database servers.
19. The method of claim 18, wherein said receiving step further comprises the steps of receiving resultant data responsive to said partitioned database search request from at least one of said plurality of database servers, reformatting said resultant data into one of a predetermined number of predetermined data formats to produce reformatted resultant data and transmitting said reformatted resultant data to said client server.
20. The method of claim 17, further comprising the step of shadowing at least a portion of the data stored in said at least one of said plurality of database servers according to a predetermined algorithm, and transferring shadowed data over said communications network.
21. The method of claim 20, wherein said shadowing step further comprises the step of receiving and storing the shadowed data by another of said plurality of database servers.
22. The method of claim 17, further comprising the step of archiving at least a portion of the data stored in said at least one of said plurality of database servers according to a prescribed archiving algorithm, and transferring archived data to an archive storage media.
23. The method of claim 22, wherein said archiving step further comprises the step of storing schema data on said archive storage media accompanying said archived data.
24. The method of claim 23, father comprising the steps of receiving de-archive requests from said at least one client server, retrieving at least a portion of the archived data and corresponding schema data stored on said archive storage media and transferring the archived data and the schema data to said at least one loader.
25. The method of claim 24, further comprising the steps of receiving said archived data and said schema data and reloading said archived data into said at least one of said plurality of database servers.
26. A method used in the manufacturing of a semiconductor device, comprising the steps of:
(a) collecting process data of a prescribed format representing processing of a semiconductor material to form a semiconductor circuit, and collecting test data of the prescribed format representing testing of the semiconductor circuit;
(b) reformatting said process data and said test data into a predetermined data format to produce reformatted data; and
(c) loading said reformatted data into at least one database server to produce a database containing said reformatted data in the predetermined format.
27. A method used in the manufacturing of a semiconductor device, comprising the steps of:
(a) collecting process data of a first prescribed format representing processing of a semiconductor material to form a semiconductor circuit, and collecting test data of a second prescribed format representing testing of the semiconductor circuit;
(b) reformatting said process data and said test data into a predetermined data format to produce reformatted data; and
(c) loading said reformatted data into at least one database server to produce a database containing said reformatted data in the predetermined format.
28. A system for use in the manufacturing of a semiconductor device, comprising:
means for collecting process data having a prescribed format representing the processing a semiconductor material to form a semiconductor circuit, and for collecting test data of the prescribed format representing the testing of the semiconductor circuit;
means for reformatting said process data and said test data into a predetermined data format to produce reformatted data; and
means for loading said reformatted data into at least one database server to produce a database containing said reformatted data in the predetermined format.
29. A system for use in the manufacturing of a semiconductor device, comprising:
means for collecting process data having a first prescribed format representing processing of a semiconductor material to form a semiconductor circuit, and for collecting test data having a second prescribed format representing testing of the semiconductor circuit;
means for reformatting said process data and said test data into a reformatted data format to produce reformatted data; and
means for loading said reformatted data into at least one database server to produce a database containing said data in the reformatted format.
US09/195,195 1994-04-05 1998-11-18 Method and system for generating product performance history Expired - Lifetime US6148307A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US09/195,195 US6148307A (en) 1994-04-05 1998-11-18 Method and system for generating product performance history

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US08/223,348 US5625816A (en) 1994-04-05 1994-04-05 Method and system for generating product performance history
US08/811,462 US5889674A (en) 1994-04-05 1997-03-03 Method and system for generating product performance history
US09/195,195 US6148307A (en) 1994-04-05 1998-11-18 Method and system for generating product performance history

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US08/811,462 Division US5889674A (en) 1994-04-05 1997-03-03 Method and system for generating product performance history

Publications (1)

Publication Number Publication Date
US6148307A true US6148307A (en) 2000-11-14

Family

ID=22836129

Family Applications (3)

Application Number Title Priority Date Filing Date
US08/223,348 Expired - Fee Related US5625816A (en) 1994-04-05 1994-04-05 Method and system for generating product performance history
US08/811,462 Expired - Lifetime US5889674A (en) 1994-04-05 1997-03-03 Method and system for generating product performance history
US09/195,195 Expired - Lifetime US6148307A (en) 1994-04-05 1998-11-18 Method and system for generating product performance history

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US08/223,348 Expired - Fee Related US5625816A (en) 1994-04-05 1994-04-05 Method and system for generating product performance history
US08/811,462 Expired - Lifetime US5889674A (en) 1994-04-05 1997-03-03 Method and system for generating product performance history

Country Status (1)

Country Link
US (3) US5625816A (en)

Cited By (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010047222A1 (en) * 2000-04-25 2001-11-29 Oren Wiesler Reticle management system
US20020083052A1 (en) * 2000-02-16 2002-06-27 Joerg Heuer Method for querying a database
US20020091881A1 (en) * 2001-01-10 2002-07-11 International Business Machines Corporation Managing a failure to access a database in a computer system
US6427092B1 (en) * 1997-03-24 2002-07-30 Micron Technology, Inc. Method for continuous, non lot-based integrated circuit manufacturing
US6459949B1 (en) * 1998-10-21 2002-10-01 Advanced Micro Devices, Inc. System and method for corrective action tracking in semiconductor processing
US20030001111A1 (en) * 2001-06-29 2003-01-02 Samsung Electronics Co., Ltd. Apparatus for monitoring ion-implantation input parameter in semiconductor fabricating devices and monitoring method thereof
US6535874B2 (en) * 1997-09-09 2003-03-18 International Business Machines Corporation Technique for providing a universal query for multiple different databases
US6609083B2 (en) * 2001-06-01 2003-08-19 Hewlett-Packard Development Company, L.P. Adaptive performance data measurement and collections
US20030195754A1 (en) * 2002-04-10 2003-10-16 Ford John E. Product deviation request tracking system
US20040015518A1 (en) * 2002-07-18 2004-01-22 Alex Lee System and method for monitoring material on shop floors
US20040024551A1 (en) * 1997-02-26 2004-02-05 Beffa Raymond J. Method in an integrated circuit (IC) manufacturing process for identifying and redirecting IC's mis-processed during their manufacture
US6775630B2 (en) * 2001-05-21 2004-08-10 Lsi Logic Corporation Web-based interface with defect database to view and update failure events
US6792431B2 (en) 2001-05-07 2004-09-14 Anadarko Petroleum Corporation Method, system, and product for data integration through a dynamic common model
US20040187029A1 (en) * 2003-03-21 2004-09-23 Ting David M. T. System and method for data and request filtering
US6801617B1 (en) * 1999-09-16 2004-10-05 Mci, Inc. Method and apparatus for providing data to switching elements in a communications system
US20040205176A1 (en) * 2003-03-21 2004-10-14 Ting David M.T. System and method for automated login
US20050119776A1 (en) * 2003-09-30 2005-06-02 Pentax Corporation Process control system
US20050138075A1 (en) * 2003-12-23 2005-06-23 Texas Instruments Incorporated Method for collecting data from semiconductor equipment
US20050203653A1 (en) * 2004-03-09 2005-09-15 Pentax Corporation Process management system and production management system
US20050251277A1 (en) * 2004-05-05 2005-11-10 Taiwan Semiconductor Manufacturing Co., Ltd. Method and system for problem case packaging
US20060143244A1 (en) * 2004-12-28 2006-06-29 Taiwan Semiconductor Manufacturing Co., Ltd. Semiconductor data archiving management systems and methods
US7103618B1 (en) * 1999-01-19 2006-09-05 Ncr Corporation Data warehouse applications for networks of self-service machines
US7111006B2 (en) * 2000-04-17 2006-09-19 Circadence Corporation System and method for providing distributed database services
US7120513B1 (en) 1997-06-06 2006-10-10 Micron Technology, Inc. Method for using data regarding manufacturing procedures integrated circuits (ICS) have undergone, such as repairs, to select procedures the ICS will undergo, such as additional repairs
JP2007521907A (en) * 2004-02-09 2007-08-09 スマート・メディカル・システムズ・リミテッド Endoscope assembly
US20080056207A1 (en) * 2006-09-05 2008-03-06 Anders Eriksson Name-address management and routing in communication networks
US20080082190A1 (en) * 2006-09-29 2008-04-03 Sutirtha Bhattacharya Software architecture for engineering analysis framework for semiconductor manufacturing
US7398549B2 (en) 2001-05-18 2008-07-08 Imprivata, Inc. Biometric authentication with security against eavesdropping
US7580924B1 (en) * 2005-07-28 2009-08-25 Xilinx, Inc. Method and system for collection, analysis, and display of semiconductor manufacturing information
US20090254535A1 (en) * 2008-04-02 2009-10-08 International Business Machines Corporation Search engine to improve product recall traceability activities
US20090327809A1 (en) * 2008-06-26 2009-12-31 Microsoft Corporation Domain-specific guidance service for software development
US7682847B2 (en) 1997-01-17 2010-03-23 Micron Technology, Inc. Method for sorting integrated circuit devices
US7739305B1 (en) * 2005-07-28 2010-06-15 Xilinx, Inc. Network appliance for data collection and processing from multiple locations and data schema therefor
US7950021B2 (en) 2006-03-29 2011-05-24 Imprivata, Inc. Methods and systems for providing responses to software commands
US8050793B1 (en) * 2006-04-04 2011-11-01 Advanced Micro Devices, Inc. Method and apparatus for linking reticle manufacturing data

Families Citing this family (119)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5625816A (en) * 1994-04-05 1997-04-29 Advanced Micro Devices, Inc. Method and system for generating product performance history
DE29512330U1 (en) * 1995-07-31 1995-09-28 Siemens AG, 80333 München Product data storage facility
US5716856A (en) * 1995-08-22 1998-02-10 Advanced Micro Devices, Inc. Arrangement and method for detecting sequential processing effects in manufacturing using predetermined sequences within runs
US5926817A (en) * 1995-12-29 1999-07-20 Mci Communications Corporation Graphical user interface-based, client-server system and method for decision making applications
AU2457797A (en) * 1996-03-25 1997-10-17 Glenayre Electronics, Inc System and method for integrating planning and operations information
US6119130A (en) * 1996-03-28 2000-09-12 Oracle Corporation Method and apparatus for providing schema evolution without recompilation
US5859972A (en) * 1996-05-10 1999-01-12 The Board Of Trustees Of The University Of Illinois Multiple server repository and multiple server remote application virtual client computer
US5884310A (en) * 1996-06-14 1999-03-16 Electronic Data Systems Corporation Distributed data integration method and system
US5781902A (en) * 1996-07-12 1998-07-14 Microsoft Corporation Method, computer program product, and system for extending the capabilities of an existing process to store and display foreign data
US5940820A (en) * 1996-09-24 1999-08-17 Fujitsu Limited GUI apparatus for generating an object-oriented database application
US6078845A (en) * 1996-11-25 2000-06-20 Schlumberger Technologies, Inc. Apparatus for carrying semiconductor devices
US5927512A (en) * 1997-01-17 1999-07-27 Micron Technology, Inc. Method for sorting integrated circuit devices
US5844803A (en) * 1997-02-17 1998-12-01 Micron Technology, Inc. Method of sorting a group of integrated circuit devices for those devices requiring special testing
US5918191A (en) * 1997-03-11 1999-06-29 Certified Measurements, Inc. System and method for managing data for an equipment calibration laboratory
TW331650B (en) * 1997-05-26 1998-05-11 Taiwan Semiconductor Mfg Co Ltd Integrated defect yield management system for semiconductor manufacturing
US5907492A (en) * 1997-06-06 1999-05-25 Micron Technology, Inc. Method for using data regarding manufacturing procedures integrated circuits (IC's) have undergone, such as repairs, to select procedures the IC's will undergo, such as additional repairs
US6269279B1 (en) * 1997-06-20 2001-07-31 Tokyo Electron Limited Control system
US6366663B1 (en) 1997-07-21 2002-04-02 Mci Communications Corporation System for achieving local number portability
JPH1165644A (en) * 1997-08-12 1999-03-09 Handotai Sentan Technol:Kk Method for classifying data and method for managing and data base and data storage medium
US6222533B1 (en) 1997-08-25 2001-04-24 I2 Technologies, Inc. System and process having a universal adapter framework and providing a global user interface and global messaging bus
US5995945A (en) * 1997-08-25 1999-11-30 I2 Technologies, Inc. System and process for inter-domain planning analysis and optimization using model agents as partial replicas of remote domains
US5926809A (en) * 1997-08-29 1999-07-20 Advanced Micro Devices, Inc. Two-tier query methodology for a database
US6148335A (en) * 1997-11-25 2000-11-14 International Business Machines Corporation Performance/capacity management framework over many servers
US6088028A (en) * 1997-12-16 2000-07-11 At&T Corp. Method for enabling rapid modification of a display controlled by a computer program
EP0932195A1 (en) * 1997-12-30 1999-07-28 International Business Machines Corporation Method and system for semiconductor wafer fabrication process real-time in-situ supervision
EP0932194A1 (en) 1997-12-30 1999-07-28 International Business Machines Corporation Method and system for semiconductor wafer fabrication process real-time in-situ interactive supervision
US6049624A (en) * 1998-02-20 2000-04-11 Micron Technology, Inc. Non-lot based method for assembling integrated circuit devices
US6128628A (en) * 1998-02-27 2000-10-03 Mci Communication Corporation Meta data processing for converting performance data into a generic format
US6301477B1 (en) * 1998-04-02 2001-10-09 Lucent Technologies Inc. Method for creating and modifying similar and dissimilar databases for use in GSM wireless network configurations for telecommunication systems
US6108669A (en) * 1998-04-02 2000-08-22 Lucent Technologies, Inc. Method and apparatus for creating and modifying databases derived from a database warehouse for a telecommunication system
KR100315912B1 (en) * 1998-04-27 2002-02-19 윤종용 Automation system using file server and method for controlling the same
US6256549B1 (en) 1998-05-13 2001-07-03 Cirrus Logic, Inc. Integrated manufacturing solutions
JPH11353384A (en) * 1998-06-10 1999-12-24 Nec Corp Method and device for evaluating environmental load
WO2000000348A1 (en) 1998-06-29 2000-01-06 Recording Industry Association Of America Security marking system and method for minimizing pirating of data on data media
PE20001250A1 (en) * 1998-11-16 2000-11-21 Detroit Diesel Corp METHOD AND SYSTEM FOR THE CONTROL OF RETURNED MATERIAL
US6240427B1 (en) * 1999-01-05 2001-05-29 Advanced Micro Devices, Inc. Method and apparatus for archiving and deleting large data sets
US6078933A (en) * 1999-01-05 2000-06-20 Advanced Micro Devices, Inc. Method and apparatus for parallel processing for archiving and retrieval of data
US20070162420A1 (en) * 2004-01-21 2007-07-12 Oracle International Corporation Techniques for automatically discovering a database device on a network
US8321457B2 (en) 2000-09-08 2012-11-27 Oracle International Corporation Techniques for automatically developing a web site
US7249356B1 (en) * 1999-04-29 2007-07-24 Fisher-Rosemount Systems, Inc. Methods and structure for batch processing event history processing and viewing
JP2000315221A (en) * 1999-04-30 2000-11-14 Matsushita Electric Ind Co Ltd Database for designing integrated circuit device and designing method for integrated circuit device
US6381556B1 (en) * 1999-08-02 2002-04-30 Ciena Corporation Data analyzer system and method for manufacturing control environment
US6873997B1 (en) * 1999-08-04 2005-03-29 Agile Software Corporation Data management system and method for automatically propagating information to disparate information systems from a central location
US6947903B1 (en) * 1999-08-06 2005-09-20 Elcommerce.Com.Inc. Method and system for monitoring a supply-chain
US6438219B1 (en) 1999-08-31 2002-08-20 Worldcom, Inc. System, method and computer program product for achieving local number portability costing support
US6473502B1 (en) 1999-08-31 2002-10-29 Worldcom, Inc. System, method and computer program product for achieving local number portability costing and network management support
US6473503B1 (en) 1999-08-31 2002-10-29 Worldcom, Inc. System, method and computer program product for achieving local number portability network management support
US7092948B1 (en) 1999-09-09 2006-08-15 The Regents Of The University Of California Method and system of integrating information from multiple sources
US6266679B1 (en) * 1999-10-12 2001-07-24 Amd. Inc. Method and apparatus for hierarchical storage of data for efficient archiving and retrieval of data
CA2400341A1 (en) * 1999-10-27 2001-05-03 Fjord-Tech Industrie Inc. System and method for remotely following up or assessing a project
US6871112B1 (en) 2000-01-07 2005-03-22 Advanced Micro Devices, Inc. Method for requesting trace data reports from FDC semiconductor fabrication processes
US6615096B1 (en) * 2000-01-31 2003-09-02 Ncr Corporation Method using statistically analyzed product test data to control component manufacturing process
US6490590B1 (en) 2000-02-14 2002-12-03 Ncr Corporation Method of generating a logical data model, physical data model, extraction routines and load routines
US6606582B1 (en) * 2000-03-27 2003-08-12 Seh America, Inc. Universal system, method and computer program product for collecting and processing process data including particle measurement data
US7292905B1 (en) 2000-03-31 2007-11-06 Ncr Corp. Method and system for identifying manufacturing anomalies in a manufacturing system
US7216092B1 (en) 2000-04-14 2007-05-08 Deluxe Corporation Intelligent personalization system and method
US7016865B1 (en) 2000-04-14 2006-03-21 Deluxe Corporation Personalization format converter system and method
JP2001306582A (en) * 2000-04-20 2001-11-02 Ge Plastics Japan Ltd Retrieval system for molded product information
US6303398B1 (en) 2000-05-04 2001-10-16 Advanced Micro Devices, Inc. Method and system of managing wafers in a semiconductor device production facility
US6832122B1 (en) * 2000-07-06 2004-12-14 Siemens Electronics Assembly Systems, Inc. System and method for comparing electronics manufacturing data
JP2002032607A (en) * 2000-07-19 2002-01-31 Fujitsu Ltd Product information mediation system
US7870107B2 (en) * 2000-08-04 2011-01-11 Agile Software Corporation Data management system and method for propagating product manufacturing information to disparate information systems
US7177822B2 (en) * 2000-08-08 2007-02-13 Daimlerchrysler Corporation Common database system for sales and marketing process
US20020023127A1 (en) * 2000-08-15 2002-02-21 Sabeti Roya Rezvani Asynchronous hyperlink object
US20020091680A1 (en) * 2000-08-28 2002-07-11 Chirstos Hatzis Knowledge pattern integration system
US6950880B1 (en) * 2000-08-31 2005-09-27 Ncr Corporation System and method for standardizing component characteristic data submitted by a seller for use by a buyer
US6795830B1 (en) * 2000-09-08 2004-09-21 Oracle International Corporation Techniques for providing off-host storage for a database application
US6993657B1 (en) 2000-09-08 2006-01-31 Oracle International Corporation Techniques for managing database systems with a community server
US6716589B2 (en) 2000-11-20 2004-04-06 Alphabeta Ab Discordant helix stabilization for prevention of amyloid formation
US6901340B1 (en) * 2001-04-02 2005-05-31 Advanced Micro Devices, Inc. Method and apparatus for distinguishing between sources of process variation
US20020161594A1 (en) * 2001-04-27 2002-10-31 Bryan Helen Elizabeth Method and system for providing remote quality assurance audits
TW526437B (en) * 2001-08-08 2003-04-01 Macronix Int Co Ltd Photolithography rework analysis method and system
WO2003016609A2 (en) * 2001-08-21 2003-02-27 Sara Lee Corporation Systems and methods for manufacturing
JP2003122818A (en) * 2001-10-12 2003-04-25 Ricoh Co Ltd Information sharing system
US7401148B2 (en) * 2001-11-16 2008-07-15 At&T Mobility Ii Llc System for customer access to messaging and configuration data
US7317697B2 (en) * 2001-11-16 2008-01-08 At&T Mobility Ii Llc System for handling file attachments
US7549096B2 (en) 2001-11-16 2009-06-16 At&T Mobility Ii Llc Methods and systems for tracking and playing back errors in a communications network
US7617328B2 (en) 2001-11-16 2009-11-10 At&T Mobility Ii Llc System for translation and communication of messaging protocols into a common protocol
US7454195B2 (en) 2001-11-16 2008-11-18 At&T Mobility Ii, Llc System for the centralized storage of wireless customer information
US20030095555A1 (en) * 2001-11-16 2003-05-22 Mcnamara Justin System for the validation and routing of messages
US7657253B2 (en) 2001-11-16 2010-02-02 At&T Mobility Ii Llc System and method for providing message notification
US7793334B2 (en) * 2001-11-16 2010-09-07 At&T Mobility Ii Llc System and method for password protecting a distribution list
US20030109271A1 (en) * 2001-11-16 2003-06-12 Lewis John Ervin Telecommunications system messaging infrastructure
US7487262B2 (en) * 2001-11-16 2009-02-03 At & T Mobility Ii, Llc Methods and systems for routing messages through a communications network based on message content
US8660537B2 (en) * 2001-11-16 2014-02-25 At&T Mobility Ii Llc System for the storage and retrieval of messages
US6773932B2 (en) 2001-11-30 2004-08-10 Seh America, Inc. System and method for collecting, storing, and displaying process data including particle measurement data
US7170557B2 (en) * 2002-03-26 2007-01-30 Eastman Kodak Company Modular digital imaging system
AU2003224841A1 (en) * 2002-04-12 2003-10-27 Johnson & Johnson Vision Care, Inc. Method and system for recording data monitored during the manufacture of molded ophthalmic lenses
US20040011689A1 (en) * 2002-07-18 2004-01-22 Witold Bauer Sterilization container filter system
US7668702B2 (en) * 2002-07-19 2010-02-23 Applied Materials, Inc. Method, system and medium for controlling manufacturing process using adaptive models based on empirical data
US6845280B1 (en) 2002-11-26 2005-01-18 Advanced Micro Devices, Inc. Work in progress management program interface
US6839601B1 (en) 2002-11-26 2005-01-04 Advanced Micro Devices, Inc. Fabrication architecture including enterprise resource planning integration
US6954711B2 (en) * 2003-05-19 2005-10-11 Applied Materials, Inc. Test substrate reclamation method and apparatus
US7474933B2 (en) * 2003-07-14 2009-01-06 Esilicon Corporation System and method for automating integration of semiconductor work in process updates
US20050027487A1 (en) * 2003-07-15 2005-02-03 Supriya Iyer Product defect analysis and resolution system
US7198964B1 (en) 2004-02-03 2007-04-03 Advanced Micro Devices, Inc. Method and apparatus for detecting faults using principal component analysis parameter groupings
US20050251774A1 (en) * 2004-05-07 2005-11-10 Shah Gaurav R Circuit design property storage and manipulation
US7725905B1 (en) 2004-05-10 2010-05-25 Globalfoundries Inc. Media accelerator interface API
US8725748B1 (en) * 2004-08-27 2014-05-13 Advanced Micro Devices, Inc. Method and system for storing and retrieving semiconductor tester information
US7266417B2 (en) * 2004-09-03 2007-09-04 Taiwan Semiconductor Manufacturing Company, Ltd. System and method for semiconductor manufacturing automation
US7734606B2 (en) * 2004-09-15 2010-06-08 Graematter, Inc. System and method for regulatory intelligence
CN101040290A (en) * 2004-10-15 2007-09-19 应用材料股份有限公司 Die-level traceability mechanism for semiconductor assembly and test facility
DE102005038086A1 (en) * 2005-08-11 2006-10-05 Siltronic Ag Semiconductor wafer, is provided with work test certificate e.g. certificate of compliance, in digital form on data medium, where certificate includes data for distinctive identity such as explicit number, which characterizes wafer
US7657390B2 (en) * 2005-11-02 2010-02-02 Applied Materials, Inc. Reclaiming substrates having defects and contaminants
US7487003B1 (en) * 2006-03-09 2009-02-03 Rockwell Automation Technologies, Inc. Automatic tracking of a lot of items through virtual sublots
US7194328B1 (en) 2006-04-04 2007-03-20 Advanced Micro Devices, Inc. Method and apparatus for tracking reticle history
TW200802024A (en) * 2006-06-30 2008-01-01 Powerchip Semiconductor Corp Data tracking method and system applied in semiconductor manufacturing
US7793292B2 (en) * 2006-09-13 2010-09-07 Fisher-Rosemount Systems, Inc. Compact batch viewing techniques for use in batch processes
US8321402B2 (en) * 2006-12-14 2012-11-27 Sap Ag Generic application interface for searching
US9582558B2 (en) * 2008-06-02 2017-02-28 Sybase, Inc. Method and system for data definition language (DDL) replication
JP2010056367A (en) * 2008-08-29 2010-03-11 Panasonic Corp Semiconductor manufacturing apparatus
WO2010038019A2 (en) * 2008-09-30 2010-04-08 Clearpace Software Limited System and method for data storage
EP2447889A1 (en) * 2010-10-29 2012-05-02 Siemens Aktiengesellschaft Method for modeling a defect management in a manufacturing process and for handling the defect during the production process based on said modeled defect management
US9927788B2 (en) 2011-05-19 2018-03-27 Fisher-Rosemount Systems, Inc. Software lockout coordination between a process control system and an asset management system
US9063998B2 (en) 2012-10-18 2015-06-23 Oracle International Corporation Associated information propagation system
US9317323B2 (en) * 2012-12-26 2016-04-19 Microsoft Technology Licensing, Llc Dynamic execution log in a distributed system
US10438259B1 (en) 2013-12-09 2019-10-08 Amazon Technologies, Inc. Propagating and presenting user specific information
US10410170B1 (en) 2014-06-18 2019-09-10 Amazon Technologies, Inc. Propagating and expiring presentation information
US11321310B2 (en) 2018-05-11 2022-05-03 Visa International Service Association System, method, and apparatus for generating analytics with structured query files

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5036479A (en) * 1989-04-20 1991-07-30 Trw Inc. Modular automated avionics test system
US5150308A (en) * 1986-09-12 1992-09-22 Digital Equipment Corporation Parameter and rule creation and modification mechanism for use by a procedure for synthesis of logic circuit designs
US5261094A (en) * 1991-04-08 1993-11-09 International Business Machines Corporation Asynchronous replication of data changes by distributed update requests
US5325290A (en) * 1989-08-14 1994-06-28 Compucom Communications Corp. Billing system with data indexing
US5333183A (en) * 1992-03-13 1994-07-26 Moscom Corporation Universal MDR data record collection and reporting system
US5438614A (en) * 1994-05-25 1995-08-01 U.S. Robotics, Inc. Modem management techniques
US5442545A (en) * 1991-03-18 1995-08-15 Fujitsu Limited System for automatically managing information about electronic equipment having printed-circuit boards
US5537325A (en) * 1991-10-29 1996-07-16 Komatsu Electronic Metals Co., Ltd. Apparatus for and method of manufacturing semiconductor wafer
US5625816A (en) * 1994-04-05 1997-04-29 Advanced Micro Devices, Inc. Method and system for generating product performance history
US5706457A (en) * 1995-06-07 1998-01-06 Hughes Electronics Image display and archiving system and method
US5890163A (en) * 1996-09-26 1999-03-30 Compaq Computer Corp Sharing an electronic mail message with a party not named as a recipient of the message
US5920317A (en) * 1996-06-11 1999-07-06 Vmi Technologies Incorporated System and method for storing and displaying ultrasound images

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5150308A (en) * 1986-09-12 1992-09-22 Digital Equipment Corporation Parameter and rule creation and modification mechanism for use by a procedure for synthesis of logic circuit designs
US5036479A (en) * 1989-04-20 1991-07-30 Trw Inc. Modular automated avionics test system
US5325290A (en) * 1989-08-14 1994-06-28 Compucom Communications Corp. Billing system with data indexing
US5442545A (en) * 1991-03-18 1995-08-15 Fujitsu Limited System for automatically managing information about electronic equipment having printed-circuit boards
US5261094A (en) * 1991-04-08 1993-11-09 International Business Machines Corporation Asynchronous replication of data changes by distributed update requests
US5537325A (en) * 1991-10-29 1996-07-16 Komatsu Electronic Metals Co., Ltd. Apparatus for and method of manufacturing semiconductor wafer
US5333183A (en) * 1992-03-13 1994-07-26 Moscom Corporation Universal MDR data record collection and reporting system
US5625816A (en) * 1994-04-05 1997-04-29 Advanced Micro Devices, Inc. Method and system for generating product performance history
US5438614A (en) * 1994-05-25 1995-08-01 U.S. Robotics, Inc. Modem management techniques
US5706457A (en) * 1995-06-07 1998-01-06 Hughes Electronics Image display and archiving system and method
US5920317A (en) * 1996-06-11 1999-07-06 Vmi Technologies Incorporated System and method for storing and displaying ultrasound images
US5890163A (en) * 1996-09-26 1999-03-30 Compaq Computer Corp Sharing an electronic mail message with a party not named as a recipient of the message

Cited By (54)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7682847B2 (en) 1997-01-17 2010-03-23 Micron Technology, Inc. Method for sorting integrated circuit devices
US7875821B2 (en) 1997-01-17 2011-01-25 Micron Technology, Inc. Method for sorting integrated circuit devices
US20040024551A1 (en) * 1997-02-26 2004-02-05 Beffa Raymond J. Method in an integrated circuit (IC) manufacturing process for identifying and redirecting IC's mis-processed during their manufacture
US7885782B2 (en) 1997-02-26 2011-02-08 Micron Technology, Inc. Method in an integrated circuit (IC) manufacturing process for identifying and redirecting ICs mis-processed during their manufacture
US6944567B2 (en) 1997-02-26 2005-09-13 Micron Technology, Inc. Method in an integrated circuit (IC) manufacturing process for identifying and redirecting ICs mis-processed during their manufacture
US8600540B2 (en) 1997-03-24 2013-12-03 Micron Technology, Inc. Methods for non-lot-based manufacturing of articles
US7555358B2 (en) 1997-03-24 2009-06-30 Micron Technology, Inc. Process and method for continuous, non lot-based integrated circuit manufacturing
US8315730B2 (en) 1997-03-24 2012-11-20 Micron Technology, Inc. Methods for non lot-based integrated circuit manufacturing
US7738988B2 (en) 1997-03-24 2010-06-15 Micron Technology, Inc. Process and method for continuous, non lot-based integrated circuit manufacturing
US6427092B1 (en) * 1997-03-24 2002-07-30 Micron Technology, Inc. Method for continuous, non lot-based integrated circuit manufacturing
US7120513B1 (en) 1997-06-06 2006-10-10 Micron Technology, Inc. Method for using data regarding manufacturing procedures integrated circuits (ICS) have undergone, such as repairs, to select procedures the ICS will undergo, such as additional repairs
US6535874B2 (en) * 1997-09-09 2003-03-18 International Business Machines Corporation Technique for providing a universal query for multiple different databases
US6459949B1 (en) * 1998-10-21 2002-10-01 Advanced Micro Devices, Inc. System and method for corrective action tracking in semiconductor processing
US7103618B1 (en) * 1999-01-19 2006-09-05 Ncr Corporation Data warehouse applications for networks of self-service machines
US6801617B1 (en) * 1999-09-16 2004-10-05 Mci, Inc. Method and apparatus for providing data to switching elements in a communications system
US20020083052A1 (en) * 2000-02-16 2002-06-27 Joerg Heuer Method for querying a database
US6941299B2 (en) * 2000-02-16 2005-09-06 Siemens Aktiengesellschaft Method for querying a database
US7111006B2 (en) * 2000-04-17 2006-09-19 Circadence Corporation System and method for providing distributed database services
US20010047222A1 (en) * 2000-04-25 2001-11-29 Oren Wiesler Reticle management system
US7058627B2 (en) * 2000-04-25 2006-06-06 Brooks Automation, Inc. Reticle management system
US20020091881A1 (en) * 2001-01-10 2002-07-11 International Business Machines Corporation Managing a failure to access a database in a computer system
US6792431B2 (en) 2001-05-07 2004-09-14 Anadarko Petroleum Corporation Method, system, and product for data integration through a dynamic common model
US20040230605A1 (en) * 2001-05-07 2004-11-18 Aderbad Tamboli Method, system, and product for data integration through a dynamic common model
US7257594B2 (en) 2001-05-07 2007-08-14 Petris Technology Corporation Method, system, and product for data integration through a dynamic common model
US7398549B2 (en) 2001-05-18 2008-07-08 Imprivata, Inc. Biometric authentication with security against eavesdropping
US6775630B2 (en) * 2001-05-21 2004-08-10 Lsi Logic Corporation Web-based interface with defect database to view and update failure events
US6609083B2 (en) * 2001-06-01 2003-08-19 Hewlett-Packard Development Company, L.P. Adaptive performance data measurement and collections
US7041990B2 (en) * 2001-06-29 2006-05-09 Samsung Electronics Co., Ltd. Apparatus for monitoring ion-implantation input parameter in semiconductor fabricating devices and monitoring method thereof
US20030001111A1 (en) * 2001-06-29 2003-01-02 Samsung Electronics Co., Ltd. Apparatus for monitoring ion-implantation input parameter in semiconductor fabricating devices and monitoring method thereof
US20030195754A1 (en) * 2002-04-10 2003-10-16 Ford John E. Product deviation request tracking system
US20040015518A1 (en) * 2002-07-18 2004-01-22 Alex Lee System and method for monitoring material on shop floors
US20040187029A1 (en) * 2003-03-21 2004-09-23 Ting David M. T. System and method for data and request filtering
US20040205176A1 (en) * 2003-03-21 2004-10-14 Ting David M.T. System and method for automated login
US10505930B2 (en) 2003-03-21 2019-12-10 Imprivata, Inc. System and method for data and request filtering
US7660880B2 (en) 2003-03-21 2010-02-09 Imprivata, Inc. System and method for automated login
US20050119776A1 (en) * 2003-09-30 2005-06-02 Pentax Corporation Process control system
US20050138075A1 (en) * 2003-12-23 2005-06-23 Texas Instruments Incorporated Method for collecting data from semiconductor equipment
US8112400B2 (en) * 2003-12-23 2012-02-07 Texas Instruments Incorporated Method for collecting data from semiconductor equipment
JP2007521907A (en) * 2004-02-09 2007-08-09 スマート・メディカル・システムズ・リミテッド Endoscope assembly
US7054699B2 (en) 2004-03-09 2006-05-30 Pentax Corporation Process management system and production management system
US20050203653A1 (en) * 2004-03-09 2005-09-15 Pentax Corporation Process management system and production management system
FR2868574A1 (en) * 2004-03-09 2005-10-07 Pentax Corp PROCESS MANAGEMENT SYSTEM AND PRODUCTION MANAGEMENT SYSTEM
US7647132B2 (en) * 2004-05-05 2010-01-12 Taiwan Semiconductor Manufacturing Company, Ltd. Method and system for problem case packaging
US20050251277A1 (en) * 2004-05-05 2005-11-10 Taiwan Semiconductor Manufacturing Co., Ltd. Method and system for problem case packaging
US20060143244A1 (en) * 2004-12-28 2006-06-29 Taiwan Semiconductor Manufacturing Co., Ltd. Semiconductor data archiving management systems and methods
US7580924B1 (en) * 2005-07-28 2009-08-25 Xilinx, Inc. Method and system for collection, analysis, and display of semiconductor manufacturing information
US7739305B1 (en) * 2005-07-28 2010-06-15 Xilinx, Inc. Network appliance for data collection and processing from multiple locations and data schema therefor
US7950021B2 (en) 2006-03-29 2011-05-24 Imprivata, Inc. Methods and systems for providing responses to software commands
US8050793B1 (en) * 2006-04-04 2011-11-01 Advanced Micro Devices, Inc. Method and apparatus for linking reticle manufacturing data
US20080056207A1 (en) * 2006-09-05 2008-03-06 Anders Eriksson Name-address management and routing in communication networks
US9264355B2 (en) * 2006-09-05 2016-02-16 Telefonaktiebolaget L M Ericsson (Publ) Name-address management and routing in communication networks
US20080082190A1 (en) * 2006-09-29 2008-04-03 Sutirtha Bhattacharya Software architecture for engineering analysis framework for semiconductor manufacturing
US20090254535A1 (en) * 2008-04-02 2009-10-08 International Business Machines Corporation Search engine to improve product recall traceability activities
US20090327809A1 (en) * 2008-06-26 2009-12-31 Microsoft Corporation Domain-specific guidance service for software development

Also Published As

Publication number Publication date
US5625816A (en) 1997-04-29
US5889674A (en) 1999-03-30

Similar Documents

Publication Publication Date Title
US6148307A (en) Method and system for generating product performance history
US7143079B2 (en) Integrated composite data base system
US5758150A (en) System and method for database synchronization
US6226650B1 (en) Database synchronization and organization system and method
CA2796448C (en) Method and system for deployed operations support
CA2121483C (en) Open office directory database views
US6879984B2 (en) Analytical database system that models data to speed up and simplify data analysis
US5606693A (en) Distributed database management over a network
US8161085B2 (en) Automatic and dynamic provisioning of databases
US7672930B2 (en) System and methods for facilitating a linear grid database with data organization by dimension
US20050203946A1 (en) Method for data maintenance in a network of partially replicated database systems
SE513182C2 (en) Procedure and system for auditing data in a distributed computer system
US6289355B1 (en) Fast log apply
SG183996A1 (en) Database management system
AU4105899A (en) Factory software mangement system
WO2004049231A1 (en) Fabrication architecture including enterprise resource planning integration
US5926809A (en) Two-tier query methodology for a database
WO2001093104A2 (en) System and method for retrieving data from a database using a data management system
US20040085363A1 (en) System and method for enabling access to a data source through a graphical interface
US6871113B1 (en) Real time dispatcher application program interface
US6846684B1 (en) Integrated enterprise resource planning and manufacturing system
US6845280B1 (en) Work in progress management program interface
US7613534B1 (en) Web based semiconductor ordering architecture
JPS63186339A (en) Remote resources maintenance system
Leesley et al. Databases for computer-aided process plant design

Legal Events

Date Code Title Description
STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS

Free format text: AFFIRMATION OF PATENT ASSIGNMENT;ASSIGNOR:ADVANCED MICRO DEVICES, INC.;REEL/FRAME:023119/0083

Effective date: 20090630

FPAY Fee payment

Year of fee payment: 12

AS Assignment

Owner name: GLOBALFOUNDRIES U.S. INC., NEW YORK

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION;REEL/FRAME:056987/0001

Effective date: 20201117