WO1994010633A1 - Rasterizer for a pattern generation apparatus - Google Patents

Rasterizer for a pattern generation apparatus Download PDF

Info

Publication number
WO1994010633A1
WO1994010633A1 PCT/US1993/010137 US9310137W WO9410633A1 WO 1994010633 A1 WO1994010633 A1 WO 1994010633A1 US 9310137 W US9310137 W US 9310137W WO 9410633 A1 WO9410633 A1 WO 9410633A1
Authority
WO
WIPO (PCT)
Prior art keywords
pixel
sub
geometry
rasterizer
pixels
Prior art date
Application number
PCT/US1993/010137
Other languages
French (fr)
Inventor
Robin L. Teitzel
Matthew J. Jolley
James B. Campbell
Richard K. George
John Wipfli
Original Assignee
Etec Systems, 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 Etec Systems, Inc. filed Critical Etec Systems, Inc.
Priority to EP93924401A priority Critical patent/EP0664033B1/en
Priority to AU54102/94A priority patent/AU5410294A/en
Priority to JP51119194A priority patent/JP3331339B2/en
Priority to KR1019950701739A priority patent/KR100310279B1/en
Priority to DE69331547T priority patent/DE69331547T2/en
Publication of WO1994010633A1 publication Critical patent/WO1994010633A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • GPHYSICS
    • G03PHOTOGRAPHY; CINEMATOGRAPHY; ANALOGOUS TECHNIQUES USING WAVES OTHER THAN OPTICAL WAVES; ELECTROGRAPHY; HOLOGRAPHY
    • G03FPHOTOMECHANICAL PRODUCTION OF TEXTURED OR PATTERNED SURFACES, e.g. FOR PRINTING, FOR PROCESSING OF SEMICONDUCTOR DEVICES; MATERIALS THEREFOR; ORIGINALS THEREFOR; APPARATUS SPECIALLY ADAPTED THEREFOR
    • G03F7/00Photomechanical, e.g. photolithographic, production of textured or patterned surfaces, e.g. printing surfaces; Materials therefor, e.g. comprising photoresists; Apparatus specially adapted therefor
    • G03F7/70Microphotolithographic exposure; Apparatus therefor
    • G03F7/70383Direct write, i.e. pattern is written directly without the use of a mask by one or multiple beams
    • G03F7/704Scanned exposure beam, e.g. raster-, rotary- and vector scanning
    • GPHYSICS
    • G03PHOTOGRAPHY; CINEMATOGRAPHY; ANALOGOUS TECHNIQUES USING WAVES OTHER THAN OPTICAL WAVES; ELECTROGRAPHY; HOLOGRAPHY
    • G03FPHOTOMECHANICAL PRODUCTION OF TEXTURED OR PATTERNED SURFACES, e.g. FOR PRINTING, FOR PROCESSING OF SEMICONDUCTOR DEVICES; MATERIALS THEREFOR; ORIGINALS THEREFOR; APPARATUS SPECIALLY ADAPTED THEREFOR
    • G03F7/00Photomechanical, e.g. photolithographic, production of textured or patterned surfaces, e.g. printing surfaces; Materials therefor, e.g. comprising photoresists; Apparatus specially adapted therefor
    • G03F7/70Microphotolithographic exposure; Apparatus therefor
    • G03F7/70483Information management; Active and passive control; Testing; Wafer monitoring, e.g. pattern monitoring
    • G03F7/70491Information management, e.g. software; Active and passive control, e.g. details of controlling exposure processes or exposure tool monitoring processes
    • G03F7/70508Data handling in all parts of the microlithographic apparatus, e.g. handling pattern data for addressable masks or data transfer to or from different components within the exposure apparatus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/20Drawing from basic elements, e.g. lines or circles
    • G06T11/203Drawing of straight lines or curves

Definitions

  • This invention relates to the field of converting digital data representing figures or objects into a pixel format for printing on a pattern generation system.
  • resist sensitive to radiant particle energy is exposed in predetermined patterns to define circuit features.
  • the energy is passed through masks which contains the patterns, thereby selectively exposing a photoresist on a semiconductor body.
  • the resist is on a mask substrate and the direction of the radiant energy itself is controlled to define patterns in the resist.
  • the selective exposure can be done as part of the making a mask (or reticle) or to directly "write" onto the resist film covering a semiconductor wafer.
  • sources of radiant energy have been used, including ultraviolet light, visible light, coherent light, x-rays and electron beam (E-Beam).
  • circuit patterns are written onto a workpiece by directing laser beams and moving a workpiece relative to the laser beams.
  • a single laser beam is split into eight (8) beams to form a brush.
  • the beams pass through Acousto-Optical Modulator (AOMs).
  • the AOMs receive electric signals defining the circuit patterns.
  • the AOMs are used to control the intensity of the beams as they write onto the workpiece.
  • a steering mirror is used for directing the plurality of beams through a zoom lens arrangement and towards a rotating polygonal mirror.
  • the steering mirror is used to adjust and align the beams in response to movement of the workpiece.
  • the zoom lens arrangement is for adjusting the size and placement of the beams.
  • the rotating polygonal mirror has a plurality of facets and is used to scan the beams onto the workpiece. Through successive scans, a stripe (one pass of the stage) is printed on the workpiece. The stripes comprise the different portions of the integrated circuit pattern. All stripes of a circuit are then printed on a workpiece. Thus, the circuit pattern is written onto the workpiece.
  • the electric signals which are received by the AOM's are generated by a rasterizer.
  • rasterized it is meant to convert the pattern into a collection of pixel values.
  • the pixel values represent the electrical signals which are sent to the AOMs.
  • a rasterizer is described in U.S. Patent No 4, 806,921, entitled “Rasterizer for Pattern Generator” which is assigned to the assignee of the present invention.
  • a method for improved control of modulation of radiant energy beams is found in U.S. Patent No. 4,956,650 entitled “Pattern Generation System” which is assigned to the assignee of the present invention. This allows for correction of non-linearities in the turn on /turn off of the beams.
  • Rasterization is conceptually similar to creating a bit-mapped image of the circuit pattern.
  • the bit-mapped image contains a plurality of pixel values. Each pixel value corresponds to an electrical signal sent to the AOMs.
  • the address grid is finer than the pixel grid.
  • a file 101 containing geometric instructions and placement instructions is provided to rasterizer 102.
  • the file 101 may be in one of many commercially known writing formats, e.g. the MEBES ® format or the ALF format.
  • the rasterizer 102 creates a bit-mapped image 103 of the circuit pattern.
  • the bit-mapped image 103 is then provided to the AOMs 104.
  • the AOMs 104 control the exposure of the laser beams onto the workpiece, which effectively controls the printing operation.
  • a rasterizer for generating pixel values for a pattern generation apparatus is disclosed.
  • the pixel values drive the printing mechanism of the pattern generation apparatus.
  • the rasterizer receives a file defining the pattern to be printed, fractures the pattern into sub frames, rasterizes each sub frame and then coordinates the provision of the pixels, to the pattern generation apparatus.
  • the rasterizer of the present invention is comprised primarily of a host processing means for fracturing and translating said file into one or more sub frames; geometry engines for pasteurizing each sub frame; beam boards for storing and delivering pixels to a pattern generation system; a serial bus for coupling the host processor means to the geometry engines and beam boards and a pixel bus for coupling each of the geometry engines to the beam boards.
  • the host processor sends different sub frames to different geometry engines over the serial bus.
  • the geometry engines rasterizes subframes into pixels in parallel.
  • the geometry engines transmits the pixels to the beam boards in packets over the pixel bus.
  • Each beam board interfaces to a single writing element of the pattern generation apparatus, e.g. a beam.
  • the host processor also controls the transmission of pixel packets from the geometry engines to the beam boards and pixel values from the beam boards to the pattern generation apparatus.
  • Figure 1 illustrates the overall flow for the generation of pixel intensities for a pattern generation apparatus.
  • Figure 2a illustrates the beam organization at a final image plane as utilized by the currently preferred embodiment of the present invention after the introduction of time delay.
  • Figure 2b illustrates the beam organization before a time delay being introduced.
  • Figure 2c illustrates the beam organization after a time delay being introduced.
  • Figure 2d illustrates the angle of printing resulting from the stage and beam motion of the currently preferred embodiment of the present invention.
  • Figure 2e illustrates a misaligned printing image resulting from rotation of the pattern to be generated.
  • Figure 2f illustrates the corrected printing image after the introduction of a pixel time delay as may be utilized in the currently preferred embodiment of the present invention.
  • Figure 3a illustrates a writing grid as utilized by the currently preferred embodiment of the present invention.
  • Figure 3b illustrates the printing strategy on a mask as utilized by the currently preferred embodiment of the present invention.
  • Figure 3c illustrates the dovetail feature of the printing strategy as performed by the currently preferred embodiment of the present invention.
  • Figure 4 illustrates the geometric coordinates and frame as utilized by the currently preferred embodiment of the present invention.
  • Figure 5 is a block diagram illustrations of the rasterizer of the currently preferred embodiment of the present invention.
  • Figure 6 is a block diagram illustration of a geometry engine as may be utilized in the currently preferred embodiment of the present invention.
  • Figure 7a illustrates two subpixel maps as may be utilized by the currently preferred embodiment of the present invention.
  • Figure 7b is an illustration of full sub-pixel map as known in the prior art.
  • Figure 7c is an illustration sampled sub-pixel map as may be utilized in the preferred embodiment of the present invention.
  • Figure 8 is a block diagram illustration of a beam board as may be utilized in the currently preferred embodiment of the present invention.
  • Figure 9 is a block diagram illustration of a Pixel Bus as may be utilized in the currently preferred embodiment of the present invention.
  • Figure 10 is a flow diagram of the pixel bus transfer protocol as may be utilized in the currently preferred embodiment of the present invention.
  • a method and apparatus for generating pixel values for use in a pattern generating apparatus is described.
  • Such a laser pattern generation apparatus is particularly suitable for use in the photolithographic fabrication of integrated circuits.
  • numerous and specific details are set of such as pixel sizes, print strategies, etc. in order to provide a though understanding of the present invention.
  • the present invention maybe practiced with out such specific details.
  • certain protocol and timing aspects are not set forth in detail in order to not unnecessarily obscure the present invention.
  • a pattern generation apparatus as may be used with the present invention is described in co-pending application entitled "Improved Laser Pattern Generation Apparatus", serial number not yet assigned which assigned to the assignee of the present application.
  • the initial laser beam is split into 32 beams which are modulated to create the image on the workpiece.
  • Figure 2a illustrates the effective beam organization at the final image plane after timing delays are introduced.
  • the beams are organized into two groups of 16 beams, 201 and 202 respectively.
  • Each of the beams within a group is separated by a fixed predetermined distance in the stripe axis, namely a 2X pixel spacing (.533 micrometers).
  • beam diameter is approximately 0.4 microns.
  • the beams must be separated by more than one or two microns and yet print as if they are separated by .533 micrometers.
  • a pixel unit is .2666 micrometers or (25*32/3 nanometers in width). Between the two groups a 3X pixel spacing in the stripe axis is included (.8 micrometers). This spacing in the stripe axis between the two sections is referred to as a diastemal split.
  • the diastemal split plays a role in generating the proper error averaging during the successive passes in the printing processes.
  • n clocks (or pixel period).
  • n is equal to six (6). This delays the data until the beam is in the correct position. The delay corresponds to the distance between the beams in the scan direction.
  • the effective brush is a straight line.
  • Figure 2b illustrates beam organization before introduction of a time delay.
  • the beams comprising the brush are printed at the angle 0 (theta) 210. Note that the spacings between the pixels 211 and the diastemal split are with respect to
  • the stage motion and the beam motion create an angled line with respect to the stage motion.
  • a first sweep 262 creates an angled line with respect to a beam motion axis 263.
  • the angle is the arctan(32/4096) or the arctan (91/128) which is 7.812mRadians. Note that the angle of printing limits the printing to one direction. Otherwise a "herringbone" pattern would result.
  • the whole pattern is printed with this angle.
  • the starting positions of the adjacent passes are offset so that the first sweeps all align without a zig-zag.
  • the whole printed image is rotated by this angle.
  • the object is to print on an angle.
  • the axis of stage motion is set at a slight angle to the axis of polygon spin.
  • the delays introduced to set theta to 18.434 degrees result in a brush that is exactly aligned to the polygon axis.
  • the scan footprint appears as a parallelogram as indicated in Figure 2e. This is the method used in the laser pattern generation as described in U.S. patent No. 4,796,038.
  • the error in alignment of the ends of the parallelograms is 1 /2 of a pixel for wider brush of a thirty-two (32) beam system. This is large compared to an acceptable error budget.
  • every pixel is delayed by a slight amount to create an angled brush, so that the printed area is a rectangle instead of a parallelogram.
  • the maximum delay is approximately 20nS*l/2 or 10 nS.
  • the increment of delay between beams is .312 nanoseconds. Note that this is a second delay added in addition to the beam delay discussed above with respect to beam organization. The final result would be as illustrated in Figure 2f .
  • the desired address grid is a multiple of 25nM.
  • the address grid chosen is 25nM/3 or 8.3333nM.
  • Each pixel unit represents 32 address grid units.
  • beam intensity variation gray scaling
  • gray scales were primarily achieved through successive physical stage passes over the workpiece. At most one intermediate gray scale value was introduced directly by beam intensity.
  • gray scales are achieved through 17 levels of intensity variation of the beams in the brush and optionally through successive physical stage passes.
  • the intensity values are generated by a rasterizer that is coupled to the pattern generation apparatus.
  • one pass is done according to a normal grid and one pass is done according to an interstitial grid.
  • the interstitial grid is offset from the normal grid by half a pixel in both the stripe and scan axes.
  • four passes are done as two physical stage passes.
  • For each group of beams and each pass the data is written on a different polygon facet.
  • the data during the four passes print different pixels. Since the beam diameter is larger than the pixel spacing, the averaging is still accomplished amongst neighboring pixels. This averaging technique forces every other pixel to be printed on a different facet of a rotating mirror.
  • FIG. 3a A pixel grid as utilized in the currently preferred embodiment is illustrated in Figure 3a.
  • pixels labeled A and B are printed on one stage pass and pixels labeled C and D are printed on one stage pass.
  • the pixels labeled A and B are printed on a normal grid, whereas the pixels labeled C and D are printed on the interstitial grid.
  • the printing system will print frames along the scan axis across the reticle as the workpiece moves along the stripe axis.
  • a frame is a printing unit that is described in more detail below.
  • Figure 3b illustrates the general print strategy for printing an array of integrated circuits on a reticle or wafer.
  • stripes are printed across the surface of the substrate along a stripe axis.
  • reticles and wafers are comprised of a plurality of die. Each die on the reticle or wafer will have the same circuit pattern.
  • each identical stripe for each row of die is printed at one time. This is illustrated in Figure 3b where a stripe 301 for each of the various row of die on the substrate is printed.
  • each stripe is printed by the printing of frames along a scan axis. This will become more apparent with respect to Figure 4.
  • Figure 3c illustrates another aspect of the print strategy called dovetailing.
  • Dovetailing is a technique whereby the scan lines formed by the individual beams are alternately offset in the scan direction. This effectively averages the errors in the butt joint over the distance of the offset.
  • beams Al, A2 and A3 are offset from the beams BI, B2 and B3.
  • the beams retain the same offset.
  • the offset is 32 pixels.
  • Butt joint errors are further reduced by printing the interstitial grid at a scan offset with respect to the normal grid. In this way a region with butt joints is averaged with a region without butt joints.
  • Figure 4 illustrates the geometric coordinates and printing units as utilized in the currently preferred embodiment for the present invention.
  • a scan axis 401 and a stripe axis 402 are illustrated.
  • a stripe is printed across the substrate.
  • a first unit is called a frame e.g. frame 403.
  • the frame 403 is an area that is 1,024 pixels wide by 4,096 pixels tall.
  • a pixel corresponds to what is printed by any of the plurality of beams.
  • a pixel in the currently preferred embodiment is .26666 micrometers in width and will have 17 levels of gray.
  • a frame is comprised of four sub frames, e.g.
  • sub frame 404 A sub frame is 1,024 pixels wide by 1,024 pixels tall. Frames and sub frames are comprised of a plurality of scanlines e.g. scanline 405. A scan line is one sweep of a brush. A sweep of the brush occurs for the height of the frame. Since the brush is 32 pixels wide, a scan line is 32 by 4,096 pixels.
  • FIG. 5 is a block diagram of the rasterizer of the currently preferred embodiment.
  • a host computer 501 interfaces with external computer system 502 for receiving data defining a circuit pattern and to the pattern generation apparatus 503 for receiving print control information.
  • the data received from the external computer system 502 is typically a file containing instructions on placement and files of geometry descriptions. Such a file may be in one of the well known formats such as MEBES® or ALF®.
  • Many well known commercially available application programs may be used for generating such files, e.g. DRACULA, available from CADENCE of San Jose, California, or CATS available from Transcription Enterprises Limited, of Los Gatos, California.
  • Computing means on the host computer 501 would then fracture and translate the geometry description for rasterization by geometry engines 504-511.
  • the host computer 501 of the currently preferred embodiment is a SPARCSTATTON 10 workstation, available from SUN Microsystems of Mountain View, California.
  • SPARCSTATTON 10 workstation available from SUN Microsystems of Mountain View, California.
  • other commercially available or proprietary computer systems having the same operating characteristics could be utilized without departing from the spirit and scope of the present invention.
  • the geometry engines 504-511 are coupled to host computer 501 through a serial bus 515. It is through the serial bus 515 that the geometry engines 504-511 receive geometry descriptions.
  • geometry engines 504-511 are illustrated. However in the currently preferred embodiment there are 24 geometry engines.
  • the geometry engines 504- 511 translate the geometry description into a gray scale pixel map of a sub- frame. Each pixel value represents the desired beam intensity at the corresponding location.
  • pixel packets are transmitted to a plurality of beam boards. In Figure 5 only two beam boards, i.e. beam boards 512-513 are illustrated but in the currently preferred embodiment there are 32 beam boards.
  • Each of the beam boards provides pixel data to one of the laser beams in the pattern generation apparatus.
  • Each beam board is coupled to each of the geometry engines through a pixel bus 514. Although not illustrated, each beam board is further coupled to the serial bus 515 for communication with host computer 501.
  • the beam boards collect and store the pixel data from the geometry engines. The beam boards coordinate the provision of pixel data to the pattern generation apparatus.
  • a feature of the rasterizer architecture is its scalability. For example, if the rasterizer is to be used with a pattern generation apparatus with more or less then 32 beams is required, greater or fewer beam boards may be utilized. Further, the number of geometry engines utilized can be increased or decreased depending on the desired pixel rendering performance.
  • the geometry data for printing is compiled on the host computer in preparation for translation by the geometry engines.
  • the host computer transforms and fractures the geometry data and placement instructions received from the external computer system into sub-frames for each geometry engine.
  • the geometry data generated by the host computer may be in either compressed or uncompressed data forms. The compressed form of the data better utilizes the data path bandwidth as the data moves from the host to each geometry engine.
  • the two basic geometry types handled are rectangles and trapezoids.
  • the trapezoids are further broken into two categories, 45 degree slopes and non 45 degree slopes.
  • the data is sorted into geometry lists. By sorting lists a small amount of data compression is achieved. Rectangles are all grouped together as are trapezoids with identical slopes. Additional compression is achieved where a group of geometries repeated with only a change in the sub-frame origin.
  • the sub-frame origin is manipulated in a variety of ways. For random placements the origin can simply be offset one time or by a list of row and column values. In a filled array pattern the row, column or both axes can be iterated upon with an offset added on each iteration.
  • the third method is called a bit map.
  • the origin information for the bit map is specified by a list of row and column values. A bit map then specifies which row and column crossing points are used as the origin offsets.
  • geometry data objects include: A list of rectangles
  • a complete sub-frame can be described in a minimum amount of space.
  • Objects are concatenated to form compound objects.
  • geometry primitives are interpreted by the geometry engine as if it were an instruction.
  • any compound object can be called like a subroutine provided it is terminated with a return instruction.
  • a hierarchical structure can then be built by called subroutines.
  • Data objects can then be reused in different sub-frames with the same geometries.
  • the hierarchical geometry data is described by nested subroutines. Each subroutine is considered to be a geometry object. A geometry object is placed into the print image by offsetting the origin and invoking the object . Origin offsets are relative to the previously established offset and are nested as deeply as required. Each geometry object at the lowest level of hierarchy is defined by a set of primitive geometry objects to form a desired pattern. The next level of hierarchy defines objects which set the
  • UBSTITUTE SHEET desired origin offsets for the placement of patterns previously described.
  • An object can be placed multiple times by calling the object repeatedly or by using the object in an iterate, grid or bit mapped placement instruction. The levels of hierarchy continue as needed to describe the desired printing pattern.
  • Each data packet is comprised of a header and data objects.
  • the header contains the control information needed to route and identify the packet.
  • the header also identifies the size of the data packet.
  • the remainder of the packet is comprised of data objects.
  • the host computer controls the sending of pixel data by the geometry engines and the beam boards through pass lists.
  • the pass list describes the sub-frames to be rasterized, the offset for the sub frame, and the order in which sub-frames are sent to the beam boards.
  • the pass list describes the order in which scan lines are transferred to the pattern generation apparatus.
  • the geometry engines perform the rasterization of geometry primitive.
  • each geometry engine rasterizes a different sub-frame.
  • Up to 64 geometry engines may be utilized, all working on different sub-frames.
  • Each of the geometry engines are identically configured. The general movement of data through the geometry begins with the geometries from the host computer and completes with the transfer of the rasterized information to the Beam Boards.
  • FIG. 6 illustrates the geometry engine in block diagram form.
  • a control processor 601 interfaces with a serial bus and the other components of the geometry engine.
  • the control processor used is the TMS 320C30 available from Texas Instruments. However, it would be apparent to one skilled in the art to use other commercially available processor products.
  • the geometry data and commands from the host computer are transferred to the geometry engines in serial packets via the serial bus.
  • the control processor 601 is coupled to the serial bus through an internal serial port.
  • the control processor 601 utilizes an on-chip Direct Memory Access (DMA) channel (not illustrated) to move each word of the packet into RAM as a temporary storage area (not illustrated).
  • DMA Direct Memory Access
  • the packet is checked and acknowledged in accordance to the serial bus protocol. After the packet is processed the data is placed into a geometry pass memory 602
  • the geometry primitives are processed in the control processor 601 by a command interpreter.
  • Each geometry primitive is an interpreter command.
  • the additional instructions of the interpreter include push /pop of the offset stack, branch, halt, call and return.
  • the rendering processors 605 performs the y-axis coordinate offset.
  • the data at this point consists of bounding coordinates, slopes and offsets.
  • the geometry engine contains eight (8) rendering processors 605.
  • the rendering processors 605 are Application Specific Integrated Circuit (ASIC) chips. Each rendering processor is responsible for rendering 2 pixels at a time.
  • the rendering processor 605 contains such elements as a Data Differential Analyzer (DDA) , a 45 degree accelerator and pixel cache. Such elements are described in greater detail below with respect to Geometry Engine performance.
  • DDA Data Differential Analyzer
  • the rendering processors 605 are further coupled to static RAMs 606 (which contain the pixel maps) and a pixel bus interface 607.
  • the pixel maps 606 each define a sampled sub-pixel map. The currently preferred method of performing pixel intensity calculations with pixel maps is described in more detail below. However, other known methods of obtaining pixel intensity values could be utilized.
  • the pixel bus interface 607 is for the control of sending pixel intensity values to the beam boards.
  • the pixel values are inserted into packets and transferred to the beam boards via the pixel bus.
  • a sub-frame is divided into 32 pixel packets of 1024 pixels each for transfer.
  • the packet address are sent with a sub-frame. This address specifies where in the Beam Board memory to store it. This address is provided by the host computer 501 (see Figure 5). The details of transferring pixel packets is described in more detail with respect to the pixel bus.
  • ROM memory 603. is used by the processor 601 for storing control instructions for initializing the processor 601.
  • the initialization consists of loading a control program into program memory 608.
  • the rendering components 605 determine a pixel intensity value by tallying the contributions of the geometric primitives at the pixel location being rendered.
  • a sub-pixel grid allows the correct intensity to be calculated when overlapping geometries occur.
  • a geometry is generated on the sub-pixel map using known on/off pixel type algorithms (e.g. Bresenham DDA Algorithm).
  • a pixel is then formed from a group of sub-pixels.
  • a sub-pixel grid consists of 32 sub-pixels on a side. For each pixel there are 1024 sub-pixels. Since there are two physical stage passes 1/2 the dose is deposited at a time. To minimize storage requirements the grid used and stored on each pass is 16 sub
  • the address is offset in the X and Y directions by a one sub-pixel space, to force sampling of the odd addresses.
  • the stage is positioned such that the pixel is placed in the correct location.
  • a pixel 701 is illustrated. Assume a line 702 through the pixel 701 is used to indicate a portion of the pixel 701 below the line which should be "on”. Thus, the sub pixels 703-711 would be "on”. The pixel intensity value would be 9/16. This is the exact intensity value for the pixel.
  • a sample pixel 720 has sampled sub pixels 721-724 as it's sample points. Note that no two of the sub pixels 721-724 have the same X or Y sub pixel address.
  • Selection of the sampled sub-pixel map to be used for a particular geometry is determined by exhaustive search.
  • the selected pattern is slightly more optimum for 45 degree edges.
  • Rectangles take two clock cycles to do an edge. If all the pixels are to be filled by all the rendering processors, then a one cycle write can be performed. Otherwise a two cycle read-modify-write cycle is done. A rectangle can be applied to a pixel map in one cycle.
  • Normally 45 degree angled trapezoids would be done by the DDA engine. This is slow in comparison to the rectangles, about nine times slower. Since a large number of 45 degree angled trapezoids geometries are expected in the patterns to be generated, a 45 degree accelerator has been added.
  • the DDA is used to step by one pixel. The bottom and top edges of the trapezoid are formed as rectangles. Left and right edges (the 45 degree lines) are formed by picking the 45 degree line and illuminating all the pixels to the right (or left). Since there are 16 sub-pixels per side, there are a total of 32 different 45 degree slopes.
  • angles close to 45 degrees can also be processed with 45 degree accelerator. Angles of 44 degrees to 46 degrees can be done. Since Fracturing Algorithms can make small errors the resulting Angle may not be exactly 45 degrees. So the DDA is run with correct angle and stepping up 1 pixel at a time, but the edges are formed with the 45 degree accelerator hardware. The resulting errors are acceptably small. Thus near 45 degree lines can be rendered as fast as a rectangle.
  • a pixel cache is implemented.
  • the cache stores 8 pixels on the rendering processor 605.
  • the cache algorithm is one in which the first 4 used pixels on a row are kept in cache.
  • the processor 601 fractures any trapezoid larger than 17 microns to one that is less so that all trapezoids can be rendered as fast as possible.
  • the beam board serves as a buffer between the geometry engines and the pattern generation apparatus.
  • the board interfaces to the pixel bus and maintains a buffer to drive the print generation apparatus on demand as signaled by a print clock from the pattern generation apparatus.
  • the pixel data comes from the Geometry Engines in the form of packets. Each packet is 1024 pixels in length. Each pixel is a five bit gray ⁇ scale level. Associated with each pixel packet is a 17 bit address. The address identifies a page of frame buffer memory for storage of the packet.
  • FIG 8 is a block diagram of a beam board as utilized in the currently preferred embodiment.
  • a control processor 801 controls the operation of the beam board.
  • a TMS320c31 processor available from Texas Instruments Corporation of Houston, Texas, is utilized.
  • the control processor 801 communicates with the host computer and controls the movement and storage of pixel data.
  • the control processor 801 receives pixel packet addresses for the packets from the Pixel Bus through address assembly register 810 and manages the storage of the pixel packet into frame buffer memory 805.
  • Pixel packets are received by the beam boards, stored in Input FIFO 802a and 802b.
  • Each FIFO is four packets deep and eight pixels wide.
  • Associated with each FIFO is a Frame Buffer packet destination address register.
  • Each pixel packet has a packet address which is transferred to the packet destination address register.
  • the packet address transferred with each packet generates an interrupt to the control processor 801 signaling the processing of a packet waiting in the input FIFO 802.
  • the packet address is the physical address for insertion of the packets pixel data into frame buffer, 805.
  • the data from the input FIFO 802 is directly piped to the frame buffer 805.
  • the frame buffer 805 is a 1, 4, or 16 meg- word block of memory for the storage of pixels where a word is 8 pixels wide. In the currently preferred embodiment, this memory is not directly addressable by the processor.
  • the frame buffer 805 is organized into pages which are flagged, e.g. semaphored, to prevent data from being overwritten.
  • the transfer from the input FIFO 802 to the frame buffer 805 is controlled by the destination address register which when loaded with a Frame Buffer pixel packet destination address causes a packet to be transferred from the input FIFO 802 into the frame buffer 805.
  • a processor interrupt is generated when the address register is empty.
  • the output FIFO 803 receives data packets from the frame buffer 805 and holds the data for transfer to the AOM driver of the pattern re ⁇
  • the output FIFO 803 is four packets deep and eight pixels wide. Associated with the output FIFO 803 is a Frame Buffer address register which when loaded with a Frame Buffer pixel packet source address causes a packet to be transferred from the Frame Buffer 805 into the output FIFO 803. A processor interrupt is generated when the address register is empty. This register is double buffered for pipelining.
  • the output FIFO 803 is emptied as print clocks are received.
  • the data is reduced from 8 pixels wide to one pixel wide through a MUX 806.
  • the pixel is then translated from linear to non-linear values through a look up table, then timing is compensated, and translated to a voltage level.
  • This voltage level is then used to modulate 200MHz sine wave, the result is amplified to 1 watt. This is accomplished through an output control, compensation and modulation unit 807. This signal is then delivered to the AOM of the pattern generation apparatus.
  • the frame buffer allocation table 804 is a block of memory directly addressable by the control processor 801.
  • the table 804 keeps track of the pages in the frame buffer 805 that are in-use and prevents a new pixel packet from over writing data which has not been printed.
  • the table 804 contains two bits per pixel packet page in the frame buffer for a minimum table size of 8K words. One of the two bits is used as write protection and other is used as an in-use semaphore.
  • the destination address When there is data in the input FIFO 802 the destination address must be verified against the allocation table 804. First the semaphore bit is checked to see if the page is available. If the page is not available the input transfer process stops and waits for that page to empty. If the page is available the write protection bit is checked. If the page is write enabled then the address of the page is handed off to the queue for the input transfer address register. If the page is read only, an error is flagged and a message is passed back to the host computer with information regarding the fault.
  • the input transfer address register interrupts the processor after the register empties signaling to the processor that the hardware is ready to accept a new address. When this interrupt occurs the next address from the queue of addresses is loaded into the register. After the next address is written the previous address is marked in the table 804 as in-use.
  • a pixel packet does not transfer successfully a flag is set to indicate that a bad packet is in the FIFO.
  • the control processor 801 automatically signals the geometry engine to re-send the packet.
  • the bad packet is then transferred into an area in the frame buffer 805 where it can then be examined to determine why transfer was unsuccessful.
  • a Beam board pass list describes the order in which the pixel data must be transferred from the frame buffer to the pattern generation apparatus.
  • the pass list is sent from the host computer over the serial bus and stored in memory on the beam board for later execution.
  • the basic unit for pass list information is a 32 bit value or one word. Each word in the pass list is either an instruction, instruction with data or an instruction followed by data.
  • the pass list is processed in the control processor 801 by a software interpreter.
  • Each data object is an interpreter instruction much like a processor executes assembly code.
  • the interpreter includes a call/return mechanism for a hierarchical structure in the pass lists. This hierarchical structure can then be used to describe the pass information for printing an individual die at the lowest level. The higher level of the structure then calls each die in the order desired for a given pass.
  • the pass list consists of a starting address and the number of transfers beginning at that address.
  • the process of traversing the pass list consists of generating an address, validating the address against the allocation table, and then handing the address off to the queue for the output transfer address register.
  • the process of validating the address consists of checking the in-use semaphore to determine if the data is present in the frame buffer.
  • the transfer address register interrupts the processor when the FIFO is less than half full and the address register is empty. When the interrupt occurs the next transfer address is loaded from the queue of processed addresses. After the next address is written the previous address is marked as free.
  • the geometry engines are coupled to beam boards through a pixel bus.
  • the pixel bus serves two main functions. The first function is to transfer data from the geometry engines to the beam boards at a high aggregate rate of transfer. In the currently preferred embodiment the maxim transfer rate is over 2 giga-pixels per second.
  • the second function is to distribute pixel packets from one geometry engine to 32 different beam boards. This is because each geometry engine rasterizes a sub- frame. Portions of the sub-frame are printed using each of the plurality of laser beams in the "brush".
  • the pixel bus of the currently preferred embodiment is illustrated in Figure 9.
  • the pixel bus is comprised of four (4) sub-buses 901-904.
  • the geometry engines are organized into 4 groups 905-908. Each geometry engine in a group couples to the same sub-bus.
  • each beam board 910-941 is coupled to each of the sub-buses 901- 904.
  • each geometry engines coupled to each sub-bus and each beam board only coupled to one sub-bus could be utilized to satisfy the pixel bus requirements, e.g. each geometry engines coupled to each sub-bus and each beam board only coupled to one sub-bus.
  • the configuration of the currently preferred embodiment utilizes the fewest number of component parts.
  • the geometry engines transfers pixel packets across the pixel bus.
  • a pixel packet is 1024 pixels long by 16 pixels wide.
  • a rasterized sub- frame would comprise 64 packets.
  • An entire sub-frame of pixels is transmitted a packet at a time. The first group of pixels starts in the lower left corner of the sub-frame and extends for a width of 16 pixels to the top left corner of the sub-frame (packet 0). The successive grouping of pixels continues across the sub-frame in the same manner.
  • each sub-bus is comprised of the following lines:
  • Serial Address Lines PADR
  • Address Bits Valid line PAV_N
  • 80 pixel data lines comprising 16 pixels with 5 bits of data per pixel (PIX(l:0)b(5:0))
  • a receive now signal from the controlling beam board to the other beam boards in a group of 16 beam boards (BBRN_N)
  • GEADR is the address of the next geometry engine allowed to transmit on the bus.
  • the geometry engines within a group pass control of a sub-bus from the current geometry engine to the next geometry engine to transfer.
  • the host processor determines the order in which the geometry engines transfer data to the beam boards.
  • a geometry engine initiates transfer by asserting BBUSY_N and PADR on the bus, box 1001. This has the effect of gaining access to the bus.
  • the geometry engine asserts beam board request signal PRQ_N, sets bit 0 of PADR to a valid value and asserts the pixel packet data on the bus, box 1002.
  • each Beam Board asserts BBRN a wire "AND" signal.
  • BBRN a wire "AND" signal.
  • PACK_N acknowledgment signal
  • the geometry engine de-asserts, PVAL_N, PRQ_N and PIXxxby, box 1006.
  • the beam board de-asserts, PACK_N, box 1007.
  • PERR_N is asserted, box 1008.
  • the sequence will be repeated if either an error has been detected or more packets are to be sent, box 1009. When no more packets or no error has been detected PADR and BBUSY_N are all de-asserted, box 1010.
  • the serial bus provides a means of communication from the host computer to the geometry engines and the beam boards. Besides geometry information, the serial bus is used to transfer set-up, diagnostic and status information.
  • the serial bus is architected into four (4) identical sub-bus structures.
  • the host computer maintains a separate serial coupling to each of the sub-bus structures.
  • Each sub-bus structure operates at a transfer rate of 750 kilobytes per second (resulting in an aggregate transfer rate of 3 mega bytes per second).
  • the serial bus operates in a master-slave model, where the host computer is the master and the geometry engines and beam boards are the slaves.
  • the slaves do not directly communicate with each other and they do not transmit data to the master without permission.
  • the slaves notify the master when they have data to transmit.
  • the master acknowledges each of the slaves for transmission by sending their address and allowing them on the bus.
  • the serial bus is implemented in physical, data link, transport and application layers.
  • the physical layer is based on the TMS320C30 serial channel where the master slave relationship described above is implemented.
  • the data link layer of the serial bus implementation provides the means of transferring data to and from the geometry engines and beam boards with guaranteed message delivery and data accuracy.
  • the data link layer is responsible for the control of the physical serial hardware and understands the means for addressing an individual slave, the transferring of information, and checking the data for errors. At this level the data portion of a transfer is divided into packets requiring only the creation of the packet header and error checking information.
  • the transport layer ties the application layer and the data link layer. This layer is responsible for the assembly and disassembly of the data as it passes from master to slave and slave to master.
  • the application layer relates to the means which utilize the serial bus, rather than any implementation of the serial bus itself. Such means were described with respect to the host computer, geometry engines and beam boards.

Abstract

A rasterizer for generating pixel values for a pattern generation apparatus (503). The pixel value drives the printing mechanism (104) of the pattern generation apparatus. The rasterizer receives a file defining the pattern to be printed, fractures the pattern into sub frames, rasterizes each sub frame and then coordinates the provision of the shaded pixel values to the pattern generation apparatus. The rasterizer of the present invention is comprised primarily of a host processing means (501) for fracturing and translating the file into one or more subframes of pixels; geometry engines (505-508) for rasterizing each sub frame; beam board (512-513) for providing the pixel shading values to a pattern generation system; a serial bus for coupling the host processor means for geometry engines and beam boards and a pixel bus (514) for coupling each of the geometry engines to each of the beam boards.

Description

RASTERIZER FOR A PATTERN GENERATION APPARATUS
BACKGROUND OF THE IN VENTION
1. Field Of The Invention
This invention relates to the field of converting digital data representing figures or objects into a pixel format for printing on a pattern generation system.
2. Prior Art
In the photolithographic fabrication of integrated circuits, resist sensitive to radiant particle energy is exposed in predetermined patterns to define circuit features. In some cases, the energy is passed through masks which contains the patterns, thereby selectively exposing a photoresist on a semiconductor body. In other instances, the resist is on a mask substrate and the direction of the radiant energy itself is controlled to define patterns in the resist. The selective exposure can be done as part of the making a mask (or reticle) or to directly "write" onto the resist film covering a semiconductor wafer. Several sources of radiant energy have been used, including ultraviolet light, visible light, coherent light, x-rays and electron beam (E-Beam).
A system for photolithographic fabrication of integrated circuits is described in U.S. Patent No. 4,796,038 entitled "Laser Pattern Generation Apparatus" which is assigned to the assignee of the present invention. In U.S. Patent No. 4,796,038 circuit patterns are written onto a workpiece by directing laser beams and moving a workpiece relative to the laser beams. A single laser beam is split into eight (8) beams to form a brush. The beams pass through Acousto-Optical Modulator (AOMs). The AOMs receive electric signals defining the circuit patterns. The AOMs are used to control the intensity of the beams as they write onto the workpiece. A steering mirror is used for directing the plurality of beams through a zoom lens arrangement and towards a rotating polygonal mirror. The steering mirror is used to adjust and align the beams in response to movement of the workpiece. The zoom lens arrangement is for adjusting the size and placement of the beams. The rotating polygonal mirror has a plurality of facets and is used to scan the beams onto the workpiece. Through successive scans, a stripe (one pass of the stage) is printed on the workpiece. The stripes comprise the different portions of the integrated circuit pattern. All stripes of a circuit are then printed on a workpiece. Thus, the circuit pattern is written onto the workpiece.
Commercially available systems embodying the laser pattern generation apparatus of U.S. Patent No. 4, 796,038 include the CORE 2100, 2500 and WAFER WRITE-60000 Systems available from ETEC Systems, Inc. of Beaverton, Oregon.
As noted above, the electric signals which are received by the AOM's are generated by a rasterizer. By rasterized it is meant to convert the pattern into a collection of pixel values. The pixel values represent the electrical signals which are sent to the AOMs. Such a rasterizer is described in U.S. Patent No 4, 806,921, entitled "Rasterizer for Pattern Generator" which is assigned to the assignee of the present invention. A method for improved control of modulation of radiant energy beams is found in U.S. Patent No. 4,956,650 entitled "Pattern Generation System" which is assigned to the assignee of the present invention. This allows for correction of non-linearities in the turn on /turn off of the beams.
Rasterization is conceptually similar to creating a bit-mapped image of the circuit pattern. The bit-mapped image contains a plurality of pixel values. Each pixel value corresponds to an electrical signal sent to the AOMs. In order to obtain the fine detail needed for printing integrated circuits, the address grid is finer than the pixel grid.
The flow for providing the electrical signals to the AOMs is described with reference to Figure 1. Referring to Figure 1, a file 101 containing geometric instructions and placement instructions is provided to rasterizer 102. The file 101 may be in one of many commercially known writing formats, e.g. the MEBES® format or the ALF format. The rasterizer 102 creates a bit-mapped image 103 of the circuit pattern. Thus, the bit-mapped image of the pattern is printed many times on the wafer. The bit-mapped image 103 is then provided to the AOMs 104. The AOMs 104 control the exposure of the laser beams onto the workpiece, which effectively controls the printing operation.
Known rasterizers, are limited in their rendering speed, 2 bit intensities and their flexibility. Thus, it is an object of the present invention to provide a rasterizer which can supply multiple pixel intensities at an increased speed and which will allow scalability. SUMMARY OF THE INVENTION
A rasterizer for generating pixel values for a pattern generation apparatus is disclosed. The pixel values drive the printing mechanism of the pattern generation apparatus. The rasterizer receives a file defining the pattern to be printed, fractures the pattern into sub frames, rasterizes each sub frame and then coordinates the provision of the pixels, to the pattern generation apparatus. The rasterizer of the present invention is comprised primarily of a host processing means for fracturing and translating said file into one or more sub frames; geometry engines for pasteurizing each sub frame; beam boards for storing and delivering pixels to a pattern generation system; a serial bus for coupling the host processor means to the geometry engines and beam boards and a pixel bus for coupling each of the geometry engines to the beam boards.
The host processor sends different sub frames to different geometry engines over the serial bus. The geometry engines rasterizes subframes into pixels in parallel. The geometry engines transmits the pixels to the beam boards in packets over the pixel bus. Each beam board interfaces to a single writing element of the pattern generation apparatus, e.g. a beam. The host processor also controls the transmission of pixel packets from the geometry engines to the beam boards and pixel values from the beam boards to the pattern generation apparatus. BRIEF DESCRIPTION OF THE FIGURES
Figure 1 illustrates the overall flow for the generation of pixel intensities for a pattern generation apparatus.
Figure 2a illustrates the beam organization at a final image plane as utilized by the currently preferred embodiment of the present invention after the introduction of time delay.
Figure 2b illustrates the beam organization before a time delay being introduced.
Figure 2c illustrates the beam organization after a time delay being introduced.
Figure 2d illustrates the angle of printing resulting from the stage and beam motion of the currently preferred embodiment of the present invention.
Figure 2e illustrates a misaligned printing image resulting from rotation of the pattern to be generated.
Figure 2f illustrates the corrected printing image after the introduction of a pixel time delay as may be utilized in the currently preferred embodiment of the present invention.
Figure 3a illustrates a writing grid as utilized by the currently preferred embodiment of the present invention.
Figure 3b illustrates the printing strategy on a mask as utilized by the currently preferred embodiment of the present invention.
Figure 3c illustrates the dovetail feature of the printing strategy as performed by the currently preferred embodiment of the present invention.
Figure 4 illustrates the geometric coordinates and frame as utilized by the currently preferred embodiment of the present invention.
Figure 5 is a block diagram illustrations of the rasterizer of the currently preferred embodiment of the present invention.
Figure 6 is a block diagram illustration of a geometry engine as may be utilized in the currently preferred embodiment of the present invention.
Figure 7a illustrates two subpixel maps as may be utilized by the currently preferred embodiment of the present invention.
Figure 7b is an illustration of full sub-pixel map as known in the prior art.
Figure 7c is an illustration sampled sub-pixel map as may be utilized in the preferred embodiment of the present invention. Figure 8 is a block diagram illustration of a beam board as may be utilized in the currently preferred embodiment of the present invention.
Figure 9 is a block diagram illustration of a Pixel Bus as may be utilized in the currently preferred embodiment of the present invention.
Figure 10 is a flow diagram of the pixel bus transfer protocol as may be utilized in the currently preferred embodiment of the present invention.
DETAILED DESCRIPΗON OF THE PREFERRED EMBODIMENT
A method and apparatus for generating pixel values for use in a pattern generating apparatus is described. Such a laser pattern generation apparatus is particularly suitable for use in the photolithographic fabrication of integrated circuits. In the following description, numerous and specific details are set of such as pixel sizes, print strategies, etc. in order to provide a though understanding of the present invention. However, it would be apparent to one skilled in the art that the present invention maybe practiced with out such specific details. In other instances, certain protocol and timing aspects are not set forth in detail in order to not unnecessarily obscure the present invention.
Aspects of the present invention is disclosed in disclosure document number 311534 and 309875 filed pursuant to the document disclosure program of the United States Patent and Trademark Office.
A pattern generation apparatus as may be used with the present invention is described in co-pending application entitled "Improved Laser Pattern Generation Apparatus", serial number not yet assigned which assigned to the assignee of the present application.
Prior to describing the print generation apparatus, it is instructive to describe the beam organization, the error averaging techniques employed and the overall print strategy.
Beam Organization
As noted above the initial laser beam is split into 32 beams which are modulated to create the image on the workpiece. Figure 2a illustrates the effective beam organization at the final image plane after timing delays are introduced. Referring to Figure 2a, the beams are organized into two groups of 16 beams, 201 and 202 respectively. Each of the beams within a group is separated by a fixed predetermined distance in the stripe axis, namely a 2X pixel spacing (.533 micrometers). In the currently preferred embodiment beam diameter is approximately 0.4 microns. To properly modulate the beams, the beams must be separated by more than one or two microns and yet print as if they are separated by .533 micrometers. In the currently preferred embodiment a pixel unit is .2666 micrometers or (25*32/3 nanometers in width). Between the two groups a 3X pixel spacing in the stripe axis is included (.8 micrometers). This spacing in the stripe axis between the two sections is referred to as a diastemal split. The diastemal split plays a role in generating the proper error averaging during the successive passes in the printing processes.
As the workpiece moves in a direction perpendicular to the brush, to achieve the desired pattern, the data to each the beams in the brush is delayed by n clocks, (or pixel period). In the currently preferred embodiment n is equal to six (6). This delays the data until the beam is in the correct position. The delay corresponds to the distance between the beams in the scan direction. The effective brush is a straight line.
Figure 2b illustrates beam organization before introduction of a time delay. Referring to Figure 2b, without a time delay, the beams comprising the brush are printed at the angle 0 (theta) 210. Note that the spacings between the pixels 211 and the diastemal split are with respect to
T the stripe axis.
Referring now to Figure 2c, the printing of the beams after the delay is illustrated. Assuming beam 220 is printed first and the stage is moving from left to right, the remainder of the beams 221-233 are timed so the resulting printed image is a straight line.
Angle of Printing
As the printing process occurs, the stage motion and the beam motion create an angled line with respect to the stage motion. This is illustrated in Figure 2d. From Figure 2d it is shown that the stage motion 260 is perpendicular to beam motion 261. A first sweep 262 creates an angled line with respect to a beam motion axis 263. The angle is the arctan(32/4096) or the arctan (91/128) which is 7.812mRadians. Note that the angle of printing limits the printing to one direction. Otherwise a "herringbone" pattern would result.
The whole pattern is printed with this angle. The starting positions of the adjacent passes are offset so that the first sweeps all align without a zig-zag. Next, the whole printed image is rotated by this angle. In this way, the whole pattern is rotated. The object is to print on an angle. To accomplish this the axis of stage motion is set at a slight angle to the axis of polygon spin. The delays introduced to set theta to 18.434 degrees result in a brush that is exactly aligned to the polygon axis. Thus the scan footprint appears as a parallelogram as indicated in Figure 2e. This is the method used in the laser pattern generation as described in U.S. patent No. 4,796,038. The error in alignment of the ends of the parallelograms is 1 /2 of a pixel for wider brush of a thirty-two (32) beam system. This is large compared to an acceptable error budget. To compensate, every pixel is delayed by a slight amount to create an angled brush, so that the printed area is a rectangle instead of a parallelogram. With a print clock period of 20ns, the maximum delay is approximately 20nS*l/2 or 10 nS. The increment of delay between beams is .312 nanoseconds. Note that this is a second delay added in addition to the beam delay discussed above with respect to beam organization. The final result would be as illustrated in Figure 2f .
Print Strategy and Error Averaging
It has been determined that by making the pixel address grid small enough, any grid snap errors that would occur would be negligible (this also has the effect of eliminating the need for a Zoom Lens Assembly). The desired address grid is a multiple of 25nM. The address grid chosen is 25nM/3 or 8.3333nM. Each pixel unit represents 32 address grid units. To accomplish this, beam intensity variation (gray scaling) for edge placement is utilized. In prior systems, gray scales were primarily achieved through successive physical stage passes over the workpiece. At most one intermediate gray scale value was introduced directly by beam intensity.
In the currently preferred embodiment of the present invention, gray scales are achieved through 17 levels of intensity variation of the beams in the brush and optionally through successive physical stage passes. The intensity values are generated by a rasterizer that is coupled to the pattern generation apparatus.
To increase the resolution and to improve the averaging, one pass is done according to a normal grid and one pass is done according to an interstitial grid. During each pass the two groups of 16 beams interleave each other. The interstitial grid is offset from the normal grid by half a pixel in both the stripe and scan axes. Effectively, four passes are done as two physical stage passes. For each group of beams and each pass the data is written on a different polygon facet. However, instead of printing the same data four times, the data during the four passes print different pixels. Since the beam diameter is larger than the pixel spacing, the averaging is still accomplished amongst neighboring pixels. This averaging technique forces every other pixel to be printed on a different facet of a rotating mirror.
A pixel grid as utilized in the currently preferred embodiment is illustrated in Figure 3a. Referring to Figure 3a, pixels labeled A and B are printed on one stage pass and pixels labeled C and D are printed on one stage pass. The pixels labeled A and B are printed on a normal grid, whereas the pixels labeled C and D are printed on the interstitial grid.
Generally, the printing system will print frames along the scan axis across the reticle as the workpiece moves along the stripe axis. A frame is a printing unit that is described in more detail below. By analogy, visualize a brush stroke going up and down across a horizontally moving surface to create a stripe. When a stripe is completed, the next stripe to be printed strategy is at the location on the reticle is just below the completed stripe. This strategy is acceptable for printing reticles, with data which is different stripe to stripe.
For printing masks or wafers which contain multiple die with the same data, a different strategy is employed. Figure 3b illustrates the general print strategy for printing an array of integrated circuits on a reticle or wafer. Referring to Figure 3b, stripes are printed across the surface of the substrate along a stripe axis. It should be noted that reticles and wafers are comprised of a plurality of die. Each die on the reticle or wafer will have the same circuit pattern. Thus, in order to avoid the recalculation and reloading of data for each row of die, each identical stripe for each row of die is printed at one time. This is illustrated in Figure 3b where a stripe 301 for each of the various row of die on the substrate is printed. As mentioned above, each stripe is printed by the printing of frames along a scan axis. This will become more apparent with respect to Figure 4.
Figure 3c illustrates another aspect of the print strategy called dovetailing. When two passes are printed next to each other there are small errors in the relative placement of the ends of the scan lines known as butting errors. Dovetailing is a technique whereby the scan lines formed by the individual beams are alternately offset in the scan direction. This effectively averages the errors in the butt joint over the distance of the offset.
Referring to Figure 3c, a portion of the beam brush is illustrated. During a first pass, beams Al, A2 and A3 are offset from the beams BI, B2 and B3. During a pass m that a butts pass n, the beams retain the same offset. In the currently preferred embodiment the offset is 32 pixels. Thus it can be seen that the resulting printing from the beams is interleaved.
Butt joint errors are further reduced by printing the interstitial grid at a scan offset with respect to the normal grid. In this way a region with butt joints is averaged with a region without butt joints.
Figure 4 illustrates the geometric coordinates and printing units as utilized in the currently preferred embodiment for the present invention. Referring to Figure 4 a scan axis 401 and a stripe axis 402 are illustrated. As noted with reference to Figure 3b, a stripe is printed across the substrate. For the purposes of generating accurate pixel data, a stripe is broken down into various subparts. A first unit is called a frame e.g. frame 403. The frame 403 is an area that is 1,024 pixels wide by 4,096 pixels tall. A pixel corresponds to what is printed by any of the plurality of beams. A pixel in the currently preferred embodiment is .26666 micrometers in width and will have 17 levels of gray. A frame is comprised of four sub frames, e.g. sub frame 404. A sub frame is 1,024 pixels wide by 1,024 pixels tall. Frames and sub frames are comprised of a plurality of scanlines e.g. scanline 405. A scan line is one sweep of a brush. A sweep of the brush occurs for the height of the frame. Since the brush is 32 pixels wide, a scan line is 32 by 4,096 pixels.
OVERVIEW OF THE RASTERIZER OF THE CURRENTLY PREFERRED EMBODIMENT Figure 5 is a block diagram of the rasterizer of the currently preferred embodiment. A host computer 501 interfaces with external computer system 502 for receiving data defining a circuit pattern and to the pattern generation apparatus 503 for receiving print control information. The data received from the external computer system 502 is typically a file containing instructions on placement and files of geometry descriptions. Such a file may be in one of the well known formats such as MEBES® or ALF®. Many well known commercially available application programs may be used for generating such files, e.g. DRACULA, available from CADENCE of San Jose, California, or CATS available from Transcription Enterprises Limited, of Los Gatos, California. Computing means on the host computer 501 would then fracture and translate the geometry description for rasterization by geometry engines 504-511.
The host computer 501 of the currently preferred embodiment is a SPARCSTATTON 10 workstation, available from SUN Microsystems of Mountain View, California. However, other commercially available or proprietary computer systems having the same operating characteristics could be utilized without departing from the spirit and scope of the present invention.
The geometry engines 504-511 are coupled to host computer 501 through a serial bus 515. It is through the serial bus 515 that the geometry engines 504-511 receive geometry descriptions. In Figure 5 geometry engines 504-511 are illustrated. However in the currently preferred embodiment there are 24 geometry engines. The geometry engines 504- 511 translate the geometry description into a gray scale pixel map of a sub- frame. Each pixel value represents the desired beam intensity at the corresponding location. When a geometry engine has completed a sub- frame, pixel packets are transmitted to a plurality of beam boards. In Figure 5 only two beam boards, i.e. beam boards 512-513 are illustrated but in the currently preferred embodiment there are 32 beam boards.
Each of the beam boards provides pixel data to one of the laser beams in the pattern generation apparatus. Each beam board is coupled to each of the geometry engines through a pixel bus 514. Although not illustrated, each beam board is further coupled to the serial bus 515 for communication with host computer 501. The beam boards collect and store the pixel data from the geometry engines. The beam boards coordinate the provision of pixel data to the pattern generation apparatus.
A feature of the rasterizer architecture is its scalability. For example, if the rasterizer is to be used with a pattern generation apparatus with more or less then 32 beams is required, greater or fewer beam boards may be utilized. Further, the number of geometry engines utilized can be increased or decreased depending on the desired pixel rendering performance.
Each of the components of the rasterizer is now described in greater detail.
The Host Computer
The geometry data for printing is compiled on the host computer in preparation for translation by the geometry engines. Generally, the host computer transforms and fractures the geometry data and placement instructions received from the external computer system into sub-frames for each geometry engine. The geometry data generated by the host computer may be in either compressed or uncompressed data forms. The compressed form of the data better utilizes the data path bandwidth as the data moves from the host to each geometry engine.
The two basic geometry types handled are rectangles and trapezoids. The trapezoids are further broken into two categories, 45 degree slopes and non 45 degree slopes. The data is sorted into geometry lists. By sorting lists a small amount of data compression is achieved. Rectangles are all grouped together as are trapezoids with identical slopes. Additional compression is achieved where a group of geometries repeated with only a change in the sub-frame origin. The sub-frame origin is manipulated in a variety of ways. For random placements the origin can simply be offset one time or by a list of row and column values. In a filled array pattern the row, column or both axes can be iterated upon with an offset added on each iteration. The third method is called a bit map. The origin information for the bit map is specified by a list of row and column values. A bit map then specifies which row and column crossing points are used as the origin offsets.
For each grouping of geometry's, header information is appended to the data describing what that grouping is. Each grouping is then called a geometry data object. In the currently preferred embodiment, geometry data objects include: A list of rectangles
A list of discrete slope trapezoids
A list of trapezoids with identical slopes
A list of 45 degree trapezoids with identical slopes
A list of x-axis placements
A list of y-axis placements
A list of x and y-axis placements
A bit mapped instruction with lists of row and column placements.
An x-axis iteration specifying pitch
A y-axis iteration specifying pitch
By utilizing the above geometry object forms, a complete sub-frame can be described in a minimum amount of space. Objects are concatenated to form compound objects. As will be described below, geometry primitives are interpreted by the geometry engine as if it were an instruction. Thus, any compound object can be called like a subroutine provided it is terminated with a return instruction. A hierarchical structure can then be built by called subroutines. Data objects can then be reused in different sub-frames with the same geometries.
The hierarchical geometry data is described by nested subroutines. Each subroutine is considered to be a geometry object. A geometry object is placed into the print image by offsetting the origin and invoking the object . Origin offsets are relative to the previously established offset and are nested as deeply as required. Each geometry object at the lowest level of hierarchy is defined by a set of primitive geometry objects to form a desired pattern. The next level of hierarchy defines objects which set the
UBSTITUTE SHEET desired origin offsets for the placement of patterns previously described. An object can be placed multiple times by calling the object repeatedly or by using the object in an iterate, grid or bit mapped placement instruction. The levels of hierarchy continue as needed to describe the desired printing pattern.
The data objects are then inserted into one or more data packets for routing to the appropriate geometry engine. Each data packet is comprised of a header and data objects. The header contains the control information needed to route and identify the packet. The header also identifies the size of the data packet. The remainder of the packet is comprised of data objects.
The host computer controls the sending of pixel data by the geometry engines and the beam boards through pass lists. For the geometry engine, the pass list describes the sub-frames to be rasterized, the offset for the sub frame, and the order in which sub-frames are sent to the beam boards. For the beam boards, the pass list describes the order in which scan lines are transferred to the pattern generation apparatus.
Geometry Engine
The geometry engines perform the rasterization of geometry primitive.
In the currently preferred embodiment each geometry engine rasterizes a different sub-frame. Up to 64 geometry engines may be utilized, all working on different sub-frames. Each of the geometry engines are identically configured. The general movement of data through the geometry begins with the geometries from the host computer and completes with the transfer of the rasterized information to the Beam Boards.
Figure 6 illustrates the geometry engine in block diagram form. A control processor 601, interfaces with a serial bus and the other components of the geometry engine. The control processor used is the TMS 320C30 available from Texas Instruments. However, it would be apparent to one skilled in the art to use other commercially available processor products.
The geometry data and commands from the host computer are transferred to the geometry engines in serial packets via the serial bus. The control processor 601 is coupled to the serial bus through an internal serial port. The control processor 601 utilizes an on-chip Direct Memory Access (DMA) channel (not illustrated) to move each word of the packet into RAM as a temporary storage area (not illustrated). The packet is checked and acknowledged in accordance to the serial bus protocol. After the packet is processed the data is placed into a geometry pass memory 602
In the currently preferred embodiment, the geometry primitives are processed in the control processor 601 by a command interpreter. Each geometry primitive is an interpreter command. The additional instructions of the interpreter include push /pop of the offset stack, branch, halt, call and return.
BSTITUTE SHEET Each sub-frame geometry list is then executed. The compressed geometry data is expanded by the control processor 601 as it is moved to the geometry primitive FIFO 604. During the expansion step the x-axis coordinate is offset in each geometry. Rendering processors 605 receives geometry primitives from the FIFO 604.
The rendering processors 605 performs the y-axis coordinate offset. The data at this point consists of bounding coordinates, slopes and offsets.
In the currently preferred embodiment the geometry engine contains eight (8) rendering processors 605. The rendering processors 605 are Application Specific Integrated Circuit (ASIC) chips. Each rendering processor is responsible for rendering 2 pixels at a time. The rendering processor 605 contains such elements as a Data Differential Analyzer (DDA) , a 45 degree accelerator and pixel cache. Such elements are described in greater detail below with respect to Geometry Engine performance.
The rendering processors 605 are further coupled to static RAMs 606 (which contain the pixel maps) and a pixel bus interface 607. The pixel maps 606 each define a sampled sub-pixel map. The currently preferred method of performing pixel intensity calculations with pixel maps is described in more detail below. However, other known methods of obtaining pixel intensity values could be utilized.
The pixel bus interface 607 is for the control of sending pixel intensity values to the beam boards. The pixel values are inserted into packets and transferred to the beam boards via the pixel bus. A sub-frame is divided into 32 pixel packets of 1024 pixels each for transfer. The packet address are sent with a sub-frame. This address specifies where in the Beam Board memory to store it. This address is provided by the host computer 501 (see Figure 5). The details of transferring pixel packets is described in more detail with respect to the pixel bus.
Also coupled to the control processor 605 is a ROM memory 603. The ROM memory 603 is used by the processor 601 for storing control instructions for initializing the processor 601. The initialization consists of loading a control program into program memory 608.
Determining Pixel Intensity Values
The rendering components 605 determine a pixel intensity value by tallying the contributions of the geometric primitives at the pixel location being rendered.
A sub-pixel grid allows the correct intensity to be calculated when overlapping geometries occur. A geometry is generated on the sub-pixel map using known on/off pixel type algorithms (e.g. Bresenham DDA Algorithm). A pixel is then formed from a group of sub-pixels. In the currently preferred embodiment, a sub-pixel grid consists of 32 sub-pixels on a side. For each pixel there are 1024 sub-pixels. Since there are two physical stage passes 1/2 the dose is deposited at a time. To minimize storage requirements the grid used and stored on each pass is 16 sub
STITUTE SHEET pixels on a side for a total of 256 sub-pixels. Two different grids are used; one for odd pixels and one for even pixels. Such grids are as illustrated in Figure 7a. During the second interstitial pass the address is offset in the X and Y directions by a one sub-pixel space, to force sampling of the odd addresses. The stage is positioned such that the pixel is placed in the correct location.
In order to minimize the amount of storage required for pixels, a technique which samples the full sub-pixel approach is utilized. One requirement for a sample is that there is only one sub-pixel for each X or Y sub-pixel address. This allows correct edge placement of rectangles. So no matter how over lapped, or ordered the answer is correct and the same. Second, a good sample would have a random spread of the sampled points, so that the error in any arbitrary line would be "small". Figures 7b and 7c illustrate a full sub-pixel and a good sample, respectively, for the simple case of 4 sub-pixels per side.
Referring to Figure 7b, a pixel 701 is illustrated. Assume a line 702 through the pixel 701 is used to indicate a portion of the pixel 701 below the line which should be "on". Thus, the sub pixels 703-711 would be "on". The pixel intensity value would be 9/16. This is the exact intensity value for the pixel.
Referring to Figure 7c, a sample of the full sub-pixel approach is illustrated. A sample pixel 720 has sampled sub pixels 721-724 as it's sample points. Note that no two of the sub pixels 721-724 have the same X or Y sub pixel address. Here, a line 725 corresponds to the line 702 of Figure 7a. However in this case only sampled sub pixels 722 and 724 would be "on". This results in an intensity value of 2/4 = 1/2. As the "exact" intensity value is 9/16 an error of 1/16 occurs.
In the case of arbitrary lines, the sampled approach trades off accuracy for reduced storage requirements. For the case of horizontal lines and vertical lines, no error occurs. Since the primary concern is placement accuracy of horizontal and vertical lines, this is an acceptable tradeoff. This tradeoff translates into lower cost and higher performance.
Techniques for determining the set of good sampled sub-pixel maps is known in the art. The problem simply stated is the identification of the combination of entries on a grid where there is one and only one entry in every row and one and only one entry in every column.
Selection of the sampled sub-pixel map to be used for a particular geometry is determined by exhaustive search. The selected pattern is slightly more optimum for 45 degree edges.
When determining the final pixel intensity value, contributions from overlapping geometry primitives must be considered. Thus, the intensity values derived from each geometry primitive are tallied to generate the final intensity value for a pixel.
Rendering Performance Of A Geometry Engine
Rectangles take two clock cycles to do an edge. If all the pixels are to be filled by all the rendering processors, then a one cycle write can be performed. Otherwise a two cycle read-modify-write cycle is done. A rectangle can be applied to a pixel map in one cycle.
Normally 45 degree angled trapezoids would be done by the DDA engine. This is slow in comparison to the rectangles, about nine times slower. Since a large number of 45 degree angled trapezoids geometries are expected in the patterns to be generated, a 45 degree accelerator has been added. The DDA is used to step by one pixel. The bottom and top edges of the trapezoid are formed as rectangles. Left and right edges (the 45 degree lines) are formed by picking the 45 degree line and illuminating all the pixels to the right (or left). Since there are 16 sub-pixels per side, there are a total of 32 different 45 degree slopes.
Note that angles close to 45 degrees can also be processed with 45 degree accelerator. Angles of 44 degrees to 46 degrees can be done. Since Fracturing Algorithms can make small errors the resulting Angle may not be exactly 45 degrees. So the DDA is run with correct angle and stepping up 1 pixel at a time, but the edges are formed with the 45 degree accelerator hardware. The resulting errors are acceptably small. Thus near 45 degree lines can be rendered as fast as a rectangle.
To reduce the time for rendering a trapezoid with non-45 degree lines, a pixel cache is implemented. The cache stores 8 pixels on the rendering processor 605. Thus a geometry engine can render up to a 17 micron wide object in one clock cycle per memory access instead of two clock cycles. The cache algorithm is one in which the first 4 used pixels on a row are kept in cache. Thus only objects wider than the cache are slowed down. Thus at least the first 17 microns of an object can be rendered at a faster rate. To best exploit the pixel cache, the processor 601 fractures any trapezoid larger than 17 microns to one that is less so that all trapezoids can be rendered as fast as possible.
Beam Boards
The beam board serves as a buffer between the geometry engines and the pattern generation apparatus. In the currently preferred embodiment, there is one beam board for each beam of the pattern generation apparatus. The board interfaces to the pixel bus and maintains a buffer to drive the print generation apparatus on demand as signaled by a print clock from the pattern generation apparatus.
The pixel data comes from the Geometry Engines in the form of packets. Each packet is 1024 pixels in length. Each pixel is a five bit gray¬ scale level. Associated with each pixel packet is a 17 bit address. The address identifies a page of frame buffer memory for storage of the packet.
Figure 8 is a block diagram of a beam board as utilized in the currently preferred embodiment. Referring to Figure 8, a control processor 801 controls the operation of the beam board. In the currently preferred embodiment a TMS320c31 processor available from Texas Instruments Corporation of Houston, Texas, is utilized. The control processor 801 communicates with the host computer and controls the movement and storage of pixel data. The control processor 801 receives pixel packet addresses for the packets from the Pixel Bus through address assembly register 810 and manages the storage of the pixel packet into frame buffer memory 805.
Pixel packets are received by the beam boards, stored in Input FIFO 802a and 802b. Each FIFO is four packets deep and eight pixels wide. Associated with each FIFO is a Frame Buffer packet destination address register. Each pixel packet has a packet address which is transferred to the packet destination address register. The packet address transferred with each packet generates an interrupt to the control processor 801 signaling the processing of a packet waiting in the input FIFO 802. The packet address is the physical address for insertion of the packets pixel data into frame buffer, 805. The data from the input FIFO 802 is directly piped to the frame buffer 805.
The frame buffer 805 is a 1, 4, or 16 meg- word block of memory for the storage of pixels where a word is 8 pixels wide. In the currently preferred embodiment, this memory is not directly addressable by the processor. The frame buffer 805 is organized into pages which are flagged, e.g. semaphored, to prevent data from being overwritten.
The transfer from the input FIFO 802 to the frame buffer 805 is controlled by the destination address register which when loaded with a Frame Buffer pixel packet destination address causes a packet to be transferred from the input FIFO 802 into the frame buffer 805. A processor interrupt is generated when the address register is empty.
The output FIFO 803 receives data packets from the frame buffer 805 and holds the data for transfer to the AOM driver of the pattern re¬
generation apparatus. The output FIFO 803 is four packets deep and eight pixels wide. Associated with the output FIFO 803 is a Frame Buffer address register which when loaded with a Frame Buffer pixel packet source address causes a packet to be transferred from the Frame Buffer 805 into the output FIFO 803. A processor interrupt is generated when the address register is empty. This register is double buffered for pipelining.
The output FIFO 803 is emptied as print clocks are received. The data is reduced from 8 pixels wide to one pixel wide through a MUX 806. The pixel is then translated from linear to non-linear values through a look up table, then timing is compensated, and translated to a voltage level. This voltage level is then used to modulate 200MHz sine wave, the result is amplified to 1 watt. This is accomplished through an output control, compensation and modulation unit 807. This signal is then delivered to the AOM of the pattern generation apparatus.
The frame buffer allocation table 804 is a block of memory directly addressable by the control processor 801. The table 804 keeps track of the pages in the frame buffer 805 that are in-use and prevents a new pixel packet from over writing data which has not been printed. The table 804 contains two bits per pixel packet page in the frame buffer for a minimum table size of 8K words. One of the two bits is used as write protection and other is used as an in-use semaphore.
When there is data in the input FIFO 802 the destination address must be verified against the allocation table 804. First the semaphore bit is checked to see if the page is available. If the page is not available the input transfer process stops and waits for that page to empty. If the page is available the write protection bit is checked. If the page is write enabled then the address of the page is handed off to the queue for the input transfer address register. If the page is read only, an error is flagged and a message is passed back to the host computer with information regarding the fault.
The input transfer address register interrupts the processor after the register empties signaling to the processor that the hardware is ready to accept a new address. When this interrupt occurs the next address from the queue of addresses is loaded into the register. After the next address is written the previous address is marked in the table 804 as in-use.
If a pixel packet does not transfer successfully a flag is set to indicate that a bad packet is in the FIFO. The control processor 801 automatically signals the geometry engine to re-send the packet. The bad packet is then transferred into an area in the frame buffer 805 where it can then be examined to determine why transfer was unsuccessful.
Beam Board Pass List
A Beam board pass list describes the order in which the pixel data must be transferred from the frame buffer to the pattern generation apparatus. The pass list is sent from the host computer over the serial bus and stored in memory on the beam board for later execution. The basic unit for pass list information is a 32 bit value or one word. Each word in the pass list is either an instruction, instruction with data or an instruction followed by data. The pass list is processed in the control processor 801 by a software interpreter. Each data object is an interpreter instruction much like a processor executes assembly code. The interpreter includes a call/return mechanism for a hierarchical structure in the pass lists. This hierarchical structure can then be used to describe the pass information for printing an individual die at the lowest level. The higher level of the structure then calls each die in the order desired for a given pass.
The pass list consists of a starting address and the number of transfers beginning at that address. The process of traversing the pass list consists of generating an address, validating the address against the allocation table, and then handing the address off to the queue for the output transfer address register. The process of validating the address consists of checking the in-use semaphore to determine if the data is present in the frame buffer.
The transfer address register interrupts the processor when the FIFO is less than half full and the address register is empty. When the interrupt occurs the next transfer address is loaded from the queue of processed addresses. After the next address is written the previous address is marked as free.
Pixel Bus
The geometry engines are coupled to beam boards through a pixel bus. The pixel bus serves two main functions. The first function is to transfer data from the geometry engines to the beam boards at a high aggregate rate of transfer. In the currently preferred embodiment the maxim transfer rate is over 2 giga-pixels per second. The second function is to distribute pixel packets from one geometry engine to 32 different beam boards. This is because each geometry engine rasterizes a sub- frame. Portions of the sub-frame are printed using each of the plurality of laser beams in the "brush".
The pixel bus of the currently preferred embodiment is illustrated in Figure 9. Referring to Figure 9, the pixel bus is comprised of four (4) sub-buses 901-904. The geometry engines are organized into 4 groups 905-908. Each geometry engine in a group couples to the same sub-bus. Finally, each beam board 910-941 is coupled to each of the sub-buses 901- 904.
Other configurations could be utilized to satisfy the pixel bus requirements, e.g. each geometry engines coupled to each sub-bus and each beam board only coupled to one sub-bus. However, the configuration of the currently preferred embodiment utilizes the fewest number of component parts.
The geometry engines transfers pixel packets across the pixel bus. A pixel packet is 1024 pixels long by 16 pixels wide. A rasterized sub- frame would comprise 64 packets. An entire sub-frame of pixels is transmitted a packet at a time. The first group of pixels starts in the lower left corner of the sub-frame and extends for a width of 16 pixels to the top left corner of the sub-frame (packet 0). The successive grouping of pixels continues across the sub-frame in the same manner.
In the currently preferred embodiment, each sub-bus is comprised of the following lines:
1. Serial Address Lines (PADR) 2. Address Bits Valid line ( PAV_N) 3. 80 pixel data lines, comprising 16 pixels with 5 bits of data per pixel (PIX(l:0)b(5:0))
4. 16 parity bits for each pixel data group (PPAR(15:0)) 5. Request to Transfer Data line (PRQ_N) 6. Acknowledgment to Transfer Data line (PACK_N) 7. Pixel Data Valid line (PVAL_N) 8. Bus busy signal to transfer control between geometry engines (BBUSY_N) 9. A fault indication from Beam Boards indicating a bad transmission (PERR_N)
10. A receive now signal from the controlling beam board to the other beam boards in a group of 16 beam boards (BBRN_N)
11. A check on the input FIFOs of the beam boards that is asserted with an input FIFO is full (FULL_N)
12. GEADR is the address of the next geometry engine allowed to transmit on the bus.
The geometry engines within a group pass control of a sub-bus from the current geometry engine to the next geometry engine to transfer. The host processor determines the order in which the geometry engines transfer data to the beam boards.
Only the geometry engine which currently owns the pixel bus is allowed to drive the geometry engine address bus. The other geometry
B TITUTE SHEET engines monitor the bus during this time.
The protocol for transfer of packets across the pixel bus is described with reference to Figure 10. A geometry engine initiates transfer by asserting BBUSY_N and PADR on the bus, box 1001. This has the effect of gaining access to the bus. Next, the geometry engine asserts beam board request signal PRQ_N, sets bit 0 of PADR to a valid value and asserts the pixel packet data on the bus, box 1002.
At this point the beam board must respond. The beam board waits until it is ready to receive, box 1003. Each Beam Board asserts BBRN a wire "AND" signal. When all 16 Beam Boards of a group (A1-B8 or A9- B15) have asserted BBRN then the signal is logical 1, thus all boards are ready to receive. When ready, the beam board Al (or A9) asserts acknowledgment signal PACK_N, box 1004 and all Beam Boards in a group de-assert BBRN.
When the geometry engine detects PACK_N and signals asserted, pixel data is asserted on PVAL_N so that 1024 pixels are transmitted every 30 nanoseconds, box 1005.
When the entire sub-frame has been transmitted, the geometry engine de-asserts, PVAL_N, PRQ_N and PIXxxby, box 1006. In response, the beam board de-asserts, PACK_N, box 1007.
If the beam board detects an error in one of the received pixel packets, PERR_N is asserted, box 1008. The sequence will be repeated if either an error has been detected or more packets are to be sent, box 1009. When no more packets or no error has been detected PADR and BBUSY_N are all de-asserted, box 1010.
Serial Bus
The serial bus provides a means of communication from the host computer to the geometry engines and the beam boards. Besides geometry information, the serial bus is used to transfer set-up, diagnostic and status information. The serial bus is architected into four (4) identical sub-bus structures. The host computer maintains a separate serial coupling to each of the sub-bus structures. Each sub-bus structure operates at a transfer rate of 750 kilobytes per second (resulting in an aggregate transfer rate of 3 mega bytes per second).
In the currently preferred embodiment, the serial bus operates in a master-slave model, where the host computer is the master and the geometry engines and beam boards are the slaves. The slaves do not directly communicate with each other and they do not transmit data to the master without permission. The slaves notify the master when they have data to transmit. The master acknowledges each of the slaves for transmission by sending their address and allowing them on the bus.
The serial bus is implemented in physical, data link, transport and application layers. The physical layer is based on the TMS320C30 serial channel where the master slave relationship described above is implemented. The data link layer of the serial bus implementation provides the means of transferring data to and from the geometry engines and beam boards with guaranteed message delivery and data accuracy. The data link layer is responsible for the control of the physical serial hardware and understands the means for addressing an individual slave, the transferring of information, and checking the data for errors. At this level the data portion of a transfer is divided into packets requiring only the creation of the packet header and error checking information.
The transport layer ties the application layer and the data link layer. This layer is responsible for the assembly and disassembly of the data as it passes from master to slave and slave to master.
The application layer relates to the means which utilize the serial bus, rather than any implementation of the serial bus itself. Such means were described with respect to the host computer, geometry engines and beam boards.
Thus, a method and apparatus for generating pixel values from a file containing geometric primitives, is described.

Claims

CLAIMSWe Claim:
1. A rasterizer for generating pixel intensity /values from a file having a plurality of geometric primitives describing a pattern, said rasterizer comprised of: a) a host processing means for fracturing and translating said file into one or more sub frames of pixels; b) a plurality of geometry engines, each of said plurality of geometry engines for generating pixel values of a sub frame; c) a plurality of interface modules for providing said pixel values to a pattern generation system; d) a first coupling means for coupling said host processor means to each of said plurality of geometry engines and each of said plurality of interface modules; and e) a second coupling means for coupling each of said plurality of geometry engines to each of said plurality of interface modules.
2. The rasterizer as recited in Claim 1 wherein each of said plurality of geometry engines is comprised of: a) a first control means for receiving a sub frame and determining that it is valid; b) a first storage means coupled to said first control means, said first storage means for storing geometry primitives; c) rasterizing means coupled to said first storage means, said rasterizing means for rendering a description of a geometry primitive into a plurality of pixel values; and d) routing means coupled to said rasterizing means, said routing means for controlling the sending of shaded pixel values to said plurality of interface modules.
3. The rasterizer as recited in Claim 2 wherein said rasterizing means is further comprised of a plurality of rendering processors, each of said rendering processors for rendering a predetermined number of pixels.
4. The rasterizer as recited in Claim 3 wherein each of said rendering processors is comprised of: a) a Digital Differential Analyzer; b) a pixel cache; and c) a forty-five degree trapezoid accelerator.
5. The rasterizer as recited in Claim 4 wherein said forty-five degree trapezoid accelerator will render trapezoids that are approximately forty- five degrees.
6. The rasterizer as recited in Claim 4 wherein said forty-five degree trapezoid accelerator will render trapezoids in a range from forty-four to forty-six degrees.
7. The rasterizer as recited in Claim 1 wherein each of said plurality of interface modules is comprised of: a) pixel storage means for storing pixel values; b) storage control means for controlling the storage of pixel values in said pixel storage means; c) output control means for controlling the output of pixel shading values to said pattern generation system; and d) connection means for connecting said output control means to said printing system.
8. The rasterizer as recited in Claim 1 wherein said first coupling means is a serial bus.
9. The rasterizer as recited in Claim 8 wherein said serial bus is further comprised of a plurlaity of sub-buses, each of said sub-buses for coupling one or more of said geometry engines and one or more of said interface modules with said host processor means.
10. The rasterizer as recited in Claim 1 wherein said second coupling means is a bus means.
11. The rasterizer as recited in Claim 10 wherein said bus means is comprised of a plurality of sub-buses, each of said sub-buses for coupling a predetermined group of said geometry engines with each of said interface modules.
12. A method for generating pixel shading values for a pattern generation system from a file having geometry primitives defining a pattern to be generated, said method comprising the steps of: a) receiving a file containing geometry primitives and placement commands; b) fracturing said file into a plurality of sub-frames, said sub- frames defining a portion of said pattern to be printed; c) rendering each sub-frame in a predetermined order, said rendering comprising the steps of:
- generating a sub pixel grid for a pixel;
- generating a set of sampled sub pixel grids, each of said sampled sub pixel grids having N sample sub pixels on said sub pixel grid;
- selecting one of said set of sampled sub pixel grids;
- mapping a line to said sub pixel grid;
- counting the number of sample sub pixels X in a pre¬ determined relationship to said line; and
- generating said pixel shading values as the value X/N d) storing said rendered pixel values for each sub-frame at a location corresponding to an individual printing means of said pattern generation system.
13. A method for determining the intensity value for a pixel comprising the steps of: a) generating a sub pixel grid for a pixel; b) generating a set of sampled sub pixel grids, each of said sampled sub pixel grids having N sample sub pixels on said sub pixel grid; c) selecting one of said set of sampled sub pixel grids; d) mapping a line to said sub pixel grid; e) counting the number of sample sub pixels X in a pre¬ determined relationship to said line; and f) generating said pixel shading values as the value X/N.
14. The method as recited in Claim 13 wherein said step of generating a set of sampled sub pixel grids is further comprised of the step of determining a combination of sub pixels where no two sample sub pixels are on the same row or are in the same column.
SUBSTITUTE SHE
PCT/US1993/010137 1992-11-02 1993-10-22 Rasterizer for a pattern generation apparatus WO1994010633A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
EP93924401A EP0664033B1 (en) 1992-11-02 1993-10-22 Rasterizer for a pattern generation apparatus
AU54102/94A AU5410294A (en) 1992-11-02 1993-10-22 Rasterizer for a pattern generation apparatus
JP51119194A JP3331339B2 (en) 1992-11-02 1993-10-22 Rasterizer for pattern generator
KR1019950701739A KR100310279B1 (en) 1992-11-02 1993-10-22 Rasterizer for Pattern Generator
DE69331547T DE69331547T2 (en) 1992-11-02 1993-10-22 IMAGE FORMATTING FOR A PATTERN GENERATION DEVICE

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US97029392A 1992-11-02 1992-11-02
US07/970,293 1992-11-02

Publications (1)

Publication Number Publication Date
WO1994010633A1 true WO1994010633A1 (en) 1994-05-11

Family

ID=25516715

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1993/010137 WO1994010633A1 (en) 1992-11-02 1993-10-22 Rasterizer for a pattern generation apparatus

Country Status (8)

Country Link
US (1) US5533170A (en)
EP (1) EP0664033B1 (en)
JP (1) JP3331339B2 (en)
KR (1) KR100310279B1 (en)
AU (1) AU5410294A (en)
CA (1) CA2148121A1 (en)
DE (1) DE69331547T2 (en)
WO (1) WO1994010633A1 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1996006395A1 (en) * 1994-08-25 1996-02-29 Wright Technologies Pty. Ltd. Data representation and access method
AU689633B2 (en) * 1994-08-25 1998-04-02 Wright Technologies NV Data representation and access method
WO2006027246A2 (en) * 2004-09-09 2006-03-16 Micronic Laser Systems Ab Healing algorithm
US7608844B2 (en) 2004-05-26 2009-10-27 Hitachi High-Technologies Corporation Charged particle beam drawing apparatus
US8779396B2 (en) 2011-12-27 2014-07-15 Canon Kabushiki Kaisha Drawing apparatus, and method of manufacturing article

Families Citing this family (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2887572B2 (en) * 1995-04-07 1999-04-26 富士ゼロックス株式会社 Image output device and image processing method
SE509062C2 (en) 1997-02-28 1998-11-30 Micronic Laser Systems Ab Data conversion method for a multi-beam laser printer for very complex microcolytographic designs
US6786420B1 (en) 1997-07-15 2004-09-07 Silverbrook Research Pty. Ltd. Data distribution mechanism in the form of ink dots on cards
US6618117B2 (en) 1997-07-12 2003-09-09 Silverbrook Research Pty Ltd Image sensing apparatus including a microcontroller
US20040119829A1 (en) 1997-07-15 2004-06-24 Silverbrook Research Pty Ltd Printhead assembly for a print on demand digital camera system
US7110024B1 (en) 1997-07-15 2006-09-19 Silverbrook Research Pty Ltd Digital camera system having motion deblurring means
US6690419B1 (en) 1997-07-15 2004-02-10 Silverbrook Research Pty Ltd Utilising eye detection methods for image processing in a digital image camera
US6624848B1 (en) 1997-07-15 2003-09-23 Silverbrook Research Pty Ltd Cascading image modification using multiple digital cameras incorporating image processing
US6879341B1 (en) 1997-07-15 2005-04-12 Silverbrook Research Pty Ltd Digital camera system containing a VLIW vector processor
SE9800665D0 (en) * 1998-03-02 1998-03-02 Micronic Laser Systems Ab Improved method for projection printing using a micromirror SLM
WO2000004494A1 (en) * 1998-07-17 2000-01-27 Intergraph Corporation Graphics processing system with multiple strip breakers
AUPP702098A0 (en) 1998-11-09 1998-12-03 Silverbrook Research Pty Ltd Image creation method and apparatus (ART73)
US6377265B1 (en) 1999-02-12 2002-04-23 Creative Technology, Ltd. Digital differential analyzer
AUPQ056099A0 (en) 1999-05-25 1999-06-17 Silverbrook Research Pty Ltd A method and apparatus (pprint01)
SE516914C2 (en) * 1999-09-09 2002-03-19 Micronic Laser Systems Ab Methods and grid for high performance pattern generation
SE516347C2 (en) * 1999-11-17 2001-12-17 Micronic Laser Systems Ab Laser scanning system and method for microlithographic writing
US6819450B1 (en) 2000-03-28 2004-11-16 Applied Materials, Inc. Enhanced edge resolution and critical dimension linearity in lithography
US6724002B2 (en) 2001-01-31 2004-04-20 Applied Materials, Inc. Multiple electron beam lithography system with multiple beam modulated laser illumination
US7034963B2 (en) * 2001-07-11 2006-04-25 Applied Materials, Inc. Method for adjusting edges of grayscale pixel-map images
US7420710B2 (en) * 2001-07-11 2008-09-02 Applied Materials, Inc. Optical proximity correction in raster scan printing based on grayscale manipulation of the bitmap
US6812474B2 (en) * 2001-07-13 2004-11-02 Applied Materials, Inc. Pattern generation method and apparatus using cached cells of hierarchical data
JP4324645B2 (en) * 2001-08-21 2009-09-02 株式会社オーク製作所 Multiple exposure drawing apparatus and multiple exposure drawing method
DE10297208T5 (en) * 2001-09-12 2005-01-05 Micronic Laser Systems Ab Improved method and apparatus using an SLM
US7302111B2 (en) * 2001-09-12 2007-11-27 Micronic Laser Systems A.B. Graphics engine for high precision lithography
US6618185B2 (en) 2001-11-28 2003-09-09 Micronic Laser Systems Ab Defective pixel compensation method
US7106490B2 (en) * 2001-12-14 2006-09-12 Micronic Laser Systems Ab Methods and systems for improved boundary contrast
SE0200864D0 (en) * 2002-03-21 2002-03-21 Micronic Laser Systems Ab Method and apparatus for printing large data flows
US7167185B1 (en) 2002-03-22 2007-01-23 Kla- Tencor Technologies Corporation Visualization of photomask databases
US7345782B2 (en) * 2002-05-13 2008-03-18 Texas Instruments Incorporated Efficient implementation of raster operations flow
CN1723384A (en) * 2003-01-15 2006-01-18 麦克罗尼克激光系统公司 Method to detect a defective element
US7529421B2 (en) 2004-07-01 2009-05-05 Applied Materials, Inc. Optical proximity correction in raster scan printing based on corner matching templates
US7407252B2 (en) 2004-07-01 2008-08-05 Applied Materials, Inc. Area based optical proximity correction in raster scan printing
US7425713B2 (en) * 2005-01-14 2008-09-16 Arradiance, Inc. Synchronous raster scanning lithographic system
US7965373B2 (en) * 2005-06-28 2011-06-21 Asml Netherlands B.V. Lithographic apparatus and device manufacturing method utilizing a datapath having a balanced calculation load
JP4617210B2 (en) * 2005-07-13 2011-01-19 日立ビアメカニクス株式会社 Drawing apparatus and exposure apparatus equipped with the same
JP4661854B2 (en) * 2007-11-09 2011-03-30 株式会社デンソー Inspection system and program
JP5134944B2 (en) * 2007-12-27 2013-01-30 株式会社ニューフレアテクノロジー Drawing apparatus and drawing method
JP2012511168A (en) * 2008-12-05 2012-05-17 マイクロニック マイデータ アーベー Image resampling with gradients in microlithographic printing
US8539395B2 (en) 2010-03-05 2013-09-17 Micronic Laser Systems Ab Method and apparatus for merging multiple geometrical pixel images and generating a single modulator pixel image
US8473877B2 (en) * 2011-09-06 2013-06-25 Taiwan Semiconductor Manufacturing Company, Ltd. Striping methodology for maskless lithography
US10169906B2 (en) 2013-03-29 2019-01-01 Advanced Micro Devices, Inc. Hybrid render with deferred primitive batch binning
US10957094B2 (en) * 2013-03-29 2021-03-23 Advanced Micro Devices, Inc. Hybrid render with preferred primitive batch binning and sorting
US20160284044A1 (en) * 2015-03-24 2016-09-29 Applied Materials, Inc. Low-latency high bandwidth data path
US10410831B2 (en) 2015-05-12 2019-09-10 Ims Nanofabrication Gmbh Multi-beam writing using inclined exposure stripes
US10325756B2 (en) 2016-06-13 2019-06-18 Ims Nanofabrication Gmbh Method for compensating pattern placement errors caused by variation of pattern exposure density in a multi-beam writer
US10325757B2 (en) * 2017-01-27 2019-06-18 Ims Nanofabrication Gmbh Advanced dose-level quantization of multibeam-writers
US10522329B2 (en) 2017-08-25 2019-12-31 Ims Nanofabrication Gmbh Dose-related feature reshaping in an exposure pattern to be exposed in a multi beam writing apparatus
US11569064B2 (en) 2017-09-18 2023-01-31 Ims Nanofabrication Gmbh Method for irradiating a target using restricted placement grids
US10651010B2 (en) 2018-01-09 2020-05-12 Ims Nanofabrication Gmbh Non-linear dose- and blur-dependent edge placement correction
US10840054B2 (en) 2018-01-30 2020-11-17 Ims Nanofabrication Gmbh Charged-particle source and method for cleaning a charged-particle source using back-sputtering
US11099482B2 (en) 2019-05-03 2021-08-24 Ims Nanofabrication Gmbh Adapting the duration of exposure slots in multi-beam writers
KR20210132599A (en) 2020-04-24 2021-11-04 아이엠에스 나노패브릭케이션 게엠베하 Charged­particle source

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4668995A (en) * 1985-04-12 1987-05-26 International Business Machines Corporation System for reproducing mixed images
US4949280A (en) * 1988-05-10 1990-08-14 Battelle Memorial Institute Parallel processor-based raster graphics system architecture
US4958303A (en) * 1988-05-12 1990-09-18 Digital Equipment Corporation Apparatus for exchanging pixel data among pixel processors

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4796038A (en) * 1985-07-24 1989-01-03 Ateq Corporation Laser pattern generation apparatus
IE852259L (en) * 1985-09-13 1987-03-13 Scottish & Newcastle Breweries A method and apparatus for constructing, storing and¹displaying characters
US4806921A (en) * 1985-10-04 1989-02-21 Ateq Corporation Rasterizer for pattern generator
US4956650A (en) * 1988-08-26 1990-09-11 Ateq Corporation Pattern generation system
US5103101A (en) * 1991-03-04 1992-04-07 Etec Systems, Inc. Multiphase printing for E-beam lithography

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4668995A (en) * 1985-04-12 1987-05-26 International Business Machines Corporation System for reproducing mixed images
US4949280A (en) * 1988-05-10 1990-08-14 Battelle Memorial Institute Parallel processor-based raster graphics system architecture
US4958303A (en) * 1988-05-12 1990-09-18 Digital Equipment Corporation Apparatus for exchanging pixel data among pixel processors

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP0664033A4 *

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1996006395A1 (en) * 1994-08-25 1996-02-29 Wright Technologies Pty. Ltd. Data representation and access method
AU689633B2 (en) * 1994-08-25 1998-04-02 Wright Technologies NV Data representation and access method
US7608844B2 (en) 2004-05-26 2009-10-27 Hitachi High-Technologies Corporation Charged particle beam drawing apparatus
WO2006027246A2 (en) * 2004-09-09 2006-03-16 Micronic Laser Systems Ab Healing algorithm
WO2006027246A3 (en) * 2004-09-09 2006-08-31 Micronic Laser Systems Ab Healing algorithm
US8779396B2 (en) 2011-12-27 2014-07-15 Canon Kabushiki Kaisha Drawing apparatus, and method of manufacturing article

Also Published As

Publication number Publication date
DE69331547T2 (en) 2003-04-24
KR100310279B1 (en) 2001-12-17
EP0664033A4 (en) 1995-11-08
EP0664033B1 (en) 2002-02-06
KR950704759A (en) 1995-11-20
JPH08505003A (en) 1996-05-28
AU5410294A (en) 1994-05-24
US5533170A (en) 1996-07-02
EP0664033A1 (en) 1995-07-26
CA2148121A1 (en) 1994-05-11
JP3331339B2 (en) 2002-10-07
DE69331547D1 (en) 2002-03-21

Similar Documents

Publication Publication Date Title
US5533170A (en) Rasterizer for a pattern generation apparatus
US7646919B2 (en) Graphics engine for high precision lithography
KR100748767B1 (en) Data path for high performance pattern generator
US7088468B1 (en) Data-conversion method for a multibeam laser writer for very complex microlithographic patterns
US4879605A (en) Rasterization system utilizing an overlay of bit-mapped low address resolution databases
EP0956516B1 (en) Method and apparatus for the production of a structure by focused laser radiation on a photosensitively coated substrate
EP0895652B1 (en) Method and apparatus for run-time correction of proximity effects in pattern generation
EP2359192B1 (en) Gradient-assisted image resampling for microlithography
WO1985001906A1 (en) Data handling system for a pattern generator
JP4324645B2 (en) Multiple exposure drawing apparatus and multiple exposure drawing method
US7167231B2 (en) Method and apparatus for printing large data flows
US6965387B2 (en) Real time data conversion for a digital display

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AT AU BB BG BR BY CA CH CZ DE DK ES FI GB HU JP KP KR KZ LK LU MG MN MW NL NO NZ PL PT RO RU SD SE SK UA UZ VN

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2148121

Country of ref document: CA

WWE Wipo information: entry into national phase

Ref document number: 1993924401

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1993924401

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWG Wipo information: grant in national office

Ref document number: 1993924401

Country of ref document: EP