EP0474366B1 - Graphics display system including a video random access memory with a split serial register and a run counter - Google Patents

Graphics display system including a video random access memory with a split serial register and a run counter Download PDF

Info

Publication number
EP0474366B1
EP0474366B1 EP19910307222 EP91307222A EP0474366B1 EP 0474366 B1 EP0474366 B1 EP 0474366B1 EP 19910307222 EP19910307222 EP 19910307222 EP 91307222 A EP91307222 A EP 91307222A EP 0474366 B1 EP0474366 B1 EP 0474366B1
Authority
EP
European Patent Office
Prior art keywords
data
register
random access
access memory
tile
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
EP19910307222
Other languages
German (de)
French (fr)
Other versions
EP0474366A2 (en
EP0474366A3 (en
Inventor
Andre J. Guillemaud
Anthony M. Balistreri
Karl M. Guttag
Richard D. Simpson
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Texas Instruments Inc
Original Assignee
Texas Instruments 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
Priority claimed from US07/563,469 external-priority patent/US5517609A/en
Application filed by Texas Instruments Inc filed Critical Texas Instruments Inc
Publication of EP0474366A2 publication Critical patent/EP0474366A2/en
Publication of EP0474366A3 publication Critical patent/EP0474366A3/en
Application granted granted Critical
Publication of EP0474366B1 publication Critical patent/EP0474366B1/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/36Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
    • G09G5/39Control of the bit-mapped memory
    • G09G5/395Arrangements specially adapted for transferring the contents of the bit-mapped memory to the screen

Definitions

  • the present invention pertains to graphics display and processing systems for producing a graphics display generally and particularly using a semiconductor memory in the form of a random access memory with a split serial register arrangement.
  • time required for accessing a row is approximately twice as long as the time required for accessing a column.
  • page mode it is desirable to access a row and hold it while several of the columns are accessed along that row. This is referred to as "page mode" operation. If all of the columns across the array are accessed during a single row access, time saved may be as much as 50-70 percent. Such time saving may be achieved during memory write or during memory read operations. For any specific system design there may be trade-offs between memory write time and memory read time to achieve operating efficiency.
  • Suppliers of devices which may be used in such applications prefer to manufacture devices that include several optional features so that designers and users will apply each type of device in many different applications. This enables one device design effort to result in large manufacturing runs and low costs per device.
  • line oriented operation the graphics processor generates and stores data in sequential order as it will appear line-by-line on the display.
  • Storage of data in the video random access memory and read out from storage to the display are accomplished in serial order bit-by-bit and line-by-line. Read out from the split serial register to the display is timed to correlate with the display sweep signal.
  • Prior video random access memory device designs have features which are very desirable and are in wide spread use in line oriented systems.
  • a tile oriented display is divided into a grid of equal size and shape areas, called tiles.
  • the size and shape of the tiles are factors which are among the factors to be chosen by the system designer or user. For instance, the tiles may be squares or rectangles. If rectangles, they may be oriented with the long dimension either laying horizontally or standing vertically.
  • currently available video random access memory devices lack sufficient flexibility for efficient use in some possible system applications. More specifically, the data representing a single tile must be stored in different rows of the storage cells of the random access memory array.
  • the start point address of a data access run can be defined by information loaded into the start point register
  • the access run of the data readout ended at the midpoint of the split serial register when reading from the low-half or at the very end of the split serial register when reading from the high-half. This aspect of operating with a split serial register is a significant problem or limitation for some graphics processing systems designs.
  • the end point for an access run in the low-half of the split serial register would be at bit 255 and the end point for an access run in the high-half of the split serial register would be at bit 511. Since typical useful access runs for a graphics processing system often vary from eight bits to 128 bits, the forcing of access runs to end either at bit 255 or at bit 511, unnecessarily slows the operating speed of the graphics processing system.
  • US-A-4 825 411 discloses a dual-port memory including a memory array comprising a plurality of memory elements, one of which is accessed at random by a row and column address input so as to enable writing in or reading out of data. At least two serial access memories are provided which are capable of receiving parallel input of all or a portion of the data of a selected row or column of the memory array. A switching circuit switches the respective serial access memories to be in operational states of receiving parallel inputs independently or to be in operational states of outputting their serial outputs successively.
  • Such a dual-port memory is used, for example, for storing picture data to be input to a cathode-ray tube with said picture being randomly accessed or with said picture data stored in a particular row or column being serially accessed.
  • the present invention provides a graphics display system comprising:
  • a graphics display and processing system including a video random access memory with a split serial register having low and high halves of a plurality of storage elements, an access start point address register, and an arrangement for stopping an access run at the end of a desired run length.
  • a method and apparatus define both start and stop points of a data access operation, i.e., the specific run length, for a split serial register of a graphics processing system.
  • the address of the access start point in the split register is loaded into the access start point address register.
  • a run length is loaded into a run length counter. Together that information determines the start and stop point addresses for each access operation of the split serial register.
  • the graphics processing system is able to start and stop read access operations at selected storage elements in the split serial register.
  • the graphics display and processing system operates at a faster speed.
  • the graphics display and processing system has a random access memory arranged with a novel split register and a multiplexer for transferring data from the memory array to the split register. Data stored in either a low half or a high half of the memory array column addresses may be selectively transferred through the multiplexer to either a low half or a high half of the split register addresses.
  • An advantage of this arrangement is that system designers have greater flexibility, or more options, in a tile oriented operation, in deciding where within the memory array to store specific bits of information to be displayed, particularly in a tile oriented operation.
  • a tile of data is mapped into the storage elements along a single row of the random access memory array. Thereafter the data from the storage elements of the random access memory are transferred into the split register and transmitted in line-by-line sequence to a raster scan display.
  • FIG. 1 there is shown a block diagram of a data processing system 100 including a graphics display arrangement for presenting information.
  • a more complete description of the arrangement and operation of the system of Figure 1 can be found in a patent application U.S. serial No. 821,641, filed January 23, 1986.
  • the data processing system 100 includes a host processing system 102, a graphics processor 103, such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor, a video random access memory 105, a data register 107, a video palette 108, a digital to video converter 110, and a video display 112.
  • a graphics processor 103 such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor
  • a video random access memory 105 such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor
  • a video random access memory 105 such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor
  • a data register 107 such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor
  • a data register 107 such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor
  • Host processing system 102 provides the major computational capacity for the data processing system 100. Included in the host processing system 102 are a processor, an input device, a long term storage device, a read only memory, a random access memory and assorted peripheral devices that form a computer system. Arrangement and operation of the host processing system are considered to be conventional. As a result of its processing functions, the host processing system 102 determines the information content of the graphic display to be presented on a screen for the user.
  • Graphics processor 103 provides the major portion of data manipulation for producing the particular graphics display to be presented on the screen.
  • the graphics processor 103 is bidirectionally coupled to the host processing system 102 by way of a host bus 101. In the arrangement of Figure 1, graphics processor 103 operates independently from the host processing system 102. The graphics processor 103, however, is responsive to requests from the host processing system 102.
  • Graphics processor 103 also communicates with memory 105 and the video palette 108 by way of a memory bus 104. Data to be stored in the video random access memory 105 is controlled by the graphics processor 103.
  • the graphics processor may be controlled either in part or wholly by a program stored in the video random access memory 105 or in a read only memory 114. Read only memory 114 may store various types of graphic image data.
  • the graphics processor 103 controls data stored within the video palette 108 and by way of a video control bus 116 the operation of the digital to video converter 110. Through the digital to video converter, the graphics processor 103 can control the line length and the number of lines per frame of the video graphic image. Significantly, the graphics processor 103 determines and controls where graphic display information is stored in the video random access memory 105. Subsequently, during readout from the video random access memory 105, the graphics processor determines the readout sequence from the video random access memory and the split serial register 107, the addresses to be accessed, and control information required to produce the desired graphic image on the display 112.
  • Video random access memory 105 stores the bit mapped graphics data which define the graphics image to be presented to the user. Control of the transfer of the data from the video random access memory 105 through the data register 107, the video palette 108, and the digital to video converter 110 to the display 112 is provided by the graphics processor 103. Video data output from the video random access memory 105 is transferred by way of a video output bus 118 to the data register 107 where it is assembled into a display bit stream.
  • the data register 107 may be a shift register.
  • Storage elements of the data register 107 may be fabricated of either dynamic or static electronic circuits. Alternative choices of storage elements include any bistable electronic, magnetic, optical, or optoelectronic device with sufficient operating speed.
  • the video random access memory 105 there is a bank of several separate random access memory integrated circuits.
  • Storage cells of the video random access memory 105 may be fabricated as either dynamic or static electronic circuits. For a single readout access operation, only one bit of data is readout from a selected storage element of each of the integrated circuits. Thus a group of bits, including one bit from each of the several separate integrated circuits, are read out at once.
  • the data register 107 assembles the display bit stream for transmission by way of a lead 120 to the video palette 108.
  • the video random access memory 105 as an electronic circuit, the invention may also be carried out by a memory fabricated as any bistable electronic, magnetic, optical or optoelectronic device with sufficient speed.
  • the video palette 108 Under control of information from the graphics processor 103, the video palette 108, such as a Texas Instruments TMS34070 Video Palette, converts the data received from the data register 107 into video level signals on a bus 125. This conversion is accomplished through a look-up table.
  • the video level signal output from the video palette 108 may include color, saturation, and brightness information.
  • Digital to video converter 110 receives the digital video signals from the video palette 108 and, under control of signals received by way of the video control bus 116, converts the digital video signals into analog levels which are applied to the video display 112 via an output line 127.
  • the number of pixels per horizontal line and the number of lines per display are determined by the graphics processor 103.
  • the synchronization, retrace, and blanking signals are controlled by the graphics processor 103. Altogether, this group of signals specify the desired video output to the video display 112.
  • Video display 112 produces the specified video image for viewing by the user.
  • the first technique specifies video data in terms of color, hue, brightness, and saturation for each pixel.
  • For the second technique color levels of red, blue and green are specified for each pixel.
  • the video palette 108, the digital to video converter 110, and the video display are designed and fabricated to be compatible with the selected technique.
  • FIG. 2 there is shown a block diagram layout of an integrated circuit video random access memory 105. Included within the memory 105 are four arrays of memory cells 105-1, 105-2, 105-3, 105-4. The cells are arranged in rows and columns. For random access, row and column addresses are applied to the integrated circuit by way of address leads and an address bus. For random access, row and column addresses are decoded respectively by row and column decoders. Data is written from a data bus through the column decoders and sense amplifiers to the selected cells of the memory arrays. For serial readout, the data is read from a selected row of the memory arrays, through transfer gates to the data registers.
  • a serial address counter applies a series of serial data register addresses to the serial data pointers, or decoder. In response to those addresses, sequences of data are transmitted from the serial data registers through a data bus to a serial output buffer. From there the data proceeds to the register 107, the video palette, the digital-to-video signal converter, and to the video display, as shown in Figure 1.
  • the various random access input and output circuits are replicated four times to complete the random access arrangement.
  • a group of common circuits controls the readout operation very effectively.
  • the group of circuits includes an initial tap register, a run count register, a run counter, a comparator, and a serial address counter which applies a series of addresses through another address bus to serial data pointers associated with each serial data register. Operation of these common circuits for serial readout are described at length hereinafter.
  • Video random access memory 105 is an exemplary memory including four memory arrays 105-1, 105-2, 105-3, and 105-4 of rows and columns of storage cells. Typically the four memory arrays are included on one semiconductor chip.
  • Information representing a single pixel for the display includes several bits of data. There is one bit, e.g., B0, stored in each of the arrays for one pixel. All of those bits for the one pixel are stored at the same row address and the same column address so that they can be either written into or read out from the whole memory in one access operation. In any specific design, there usually are as many memory arrays as there are bits in a pixel. If more than four bits are needed per pixel, either more arrays per chip or more chips may be provided.
  • the screen of the video display 112 of Figure 1 can be thought to be organized in either of two ways. Usually in the display, there are a large number of horizontal lines each including a large number of pixels. Another often used, but different, scheme divides the display into a number of tiles. Each tile includes some number of pixels in a contiguous area of the display. The tile areas for a display are uniform in size and therefore include some number of pixels across and some number of pixels in height. For purposes of subsequent discussion, the number of pixels across a tile equals the number of columns in a section of the video random access memory array 105-1 and the number of storage elements in a section of the split register 109-1.
  • the split register 109-1 may be either a shift register or a serial register.
  • split serial register 109-1 Information in one line across a tile is considered to be a segment of the tile. Since there is only one bit per pixel in the memory array 105-1, the number of bits in a segment of the tile in array 105-1 equals the number of columns used in the sections of the memory array and the number of storage elements used in the sections of the split serial register 109-1. The number of pixels in height equals the number of lines in the tile. For a subsequent illustrative example, a tile is thirty-two pixels across and eight pixels high in the display depicted in Figure 12, to be discussed subsequently.
  • the video random access memory array 105-1 is arranged so that the data, representing a tile of the display, is stored as sequential segments of the tile in a single row of the memory array 105-1. An entire tile of data is stored in the single row of the memory array 105-1. Row and column address information, together with the desired display, or pixel information, is generated by the graphics processor 103.
  • the addresses are applied through the bus 104 to an address register 106 for accessing the identified row and column storage locations in the random access memory array 105-1.
  • the display data, to be stored at each address also is applied through the bus 104 and a lead 111 to the random access memory array 105-1.
  • the graphics processor develops the random access address and display data for any tile, that data, in a departure from the prior art, is transmitted through bus 104 and is written into the random access memory 105-1 by making a single row access and thereafter accessing sequentially selected columns where data is to be stored. This enables a random access write-in operation to write in during a single row access as much as a whole tile of data. Since the accessing of a row operation takes approximately twice as long as accessing a column, considerable operational time is saved by making the single row access and performing the several column accesses while the row access remains effective.
  • the memory array 105-1 and the split serial register 109-1 are each divided by address into a low part and a high part. Such divisions greatly facilitate readout from the memory array 105-1 to the video display 112 of Figure 1. Readout from the memory array 105-1 occurs sequentially by line of the display. As the raster scans a line of the display, the appropriate data for each pixel in the sequence is applied to the beam for projection on the display screen.
  • the graphics processor 103 determines the order for addressing the storage cells of the memory array 105-1, the selection made by the multiplexer 130-1, and the order for reading data from the storage elements of the split serial register 109-1 to achieve the desired output sequence of information being forwarded to the video display 112.
  • Rows of the memory are addressed by part rows, e.g., low address half rows and high address half rows.
  • the multiplexer 130-1 determines whether the data read out of either the low-half or the high-half of the memory array is transmitted by bit line to either the low-half or the high-half addresses of the split serial register 109-1. Once the data is stored in the split serial register 109-1, one or more bits of data or segments of tiles can be transmitted from the split serial register 109-1 out to the video display 112.
  • Additional control circuitry which is common to the several memory arrays, is provided for determining the specific portion of data to be transmitted from the split serial register 109-1.
  • the data from the split serial register 109-1 can be read out from a separate tap at each storage element.
  • the taps are represented by a gate circuit 132 which receives a separate output from each storage element of the split serial register 109-1.
  • a counter decoder 135 determines which one of the split serial register storage element outputs is transmitted to the video display 112 during any time slot determined by a readout clock signal CLOCK .
  • the graphics processor 103 loads the address of that initial pixel data into an initial tap, or start point, register 137.
  • the initial tap register 137 loads the initial pixel data address into the counter decoder 135 for enabling the gate circuit 132 to transmit the data from the correct split serial register storage element. Loading of the initial pixel data address may be in parallel to the counter decoder 135.
  • Data read out thereafter generally proceeds sequentially along the storage elements of the split serial register 109-1, however, unlike the prior art, it does not necessarily proceed continuously.
  • One such circumstance arises when the display system is tile oriented and the data representing a tile is stored along a single row of the memory array 105-1, as previously described herein. Then for efficiency, the sequential addressing for reading out the data from the split serial register 109-1 should be interrupted before the end of half the register.
  • interruptions are made by the graphics processor 103 loading a number, or run count, into a run count register 140 for determining the number of sequential addresses of the split serial register 109-1 that are accessed before the interruption, i.e., before the counter decoder 135 and gate circuit 132 jump to a new initial, or start, tap address for subsequent readout.
  • a convenient run length is equal to the number of pixels in a segment.
  • the number in the count register 140 and a run count from a run counter 142 are compared by the comparator 145. When they do not match, the current sequence of addresses continues as the run counter is incremented by the signal CLOCK for each readout operation.
  • the comparator 145 When the two counts do agree, e.g., at the end of a segment, the comparator 145 produces a signal for resetting the run counter 142 and for loading the new initial tap address into the initial tap register 137. As a result, the counter decoder 135 enables the gate circuit 132 to jump to the new initial tap address of the split serial register 109-1 and thereby interrupt the sequential addressing.
  • a tile oriented system it is advantageous for a tile oriented system to run through a sequence of addresses equal to the number of addresses needed for reading out all of the pixels in a segment of a tile from one half of the split serial register 109-1 and then transfer to the other half of the split serial register to read out the pixels in a segment from another tile. Since the tiles typically end before the end of a half of the register, it is advantageous to interrupt the readout operation at the end of the tile rather than at the end of half of the register. A more detailed description of this operation is to be described hereinafter in reference to Figures 5 through 12.
  • FIG 4 there is shown the physical arrangements of the storage cells and bit lines of the memory array 105-1 and of the storage elements of the associated split serial register 109-1.
  • the memory array 105-1 and the split serial register 109-1 both are divided into parts by addresses, a low-half L of the memory array addresses including half of the storage cells and a high-half H of the memory array addresses including the remaining storage cells.
  • the low-half designators L0...L127 are shown below the high-half designators H0...H127 so that, at a glance, the two halves will stand out from each other in Figure 4.
  • the storage cells L of the low-half addresses of the memory array 105-1 are interleaved with the storage cells H of the high-half addresses of the memory array.
  • the storage elements L of the low-half addresses of the split serial register 109-1 are interleaved with the storage elements H of the high-half addresses of the split serial register 109-1.
  • Such interleaving of the storage cells of the two parts of the memory columns and of the storage elements of the two parts of the split serial register 109-1 provides a significant advantage when the memory array 105-1 and the split serial register 109-1 are fabricated as an integrated circuit.
  • the total length and complexity of the bit lines, which are arranged for coupling the storage cells of the memory array 105-1 through the multiplexer 130-1 to the storage elements of the split serial register 109-1 are substantially reduced with respect to the bit line layout, which otherwise is required when the lower and upper halves of the memory array 105-1 and split serial register 109-1 are divided by whole physical sections rather than by the interleaving of the columns and register elements, as shown in Figure 4.
  • Figure 4 additionally illustrates a schematic for a section 130-1.1 of the multiplexer 130-1 which can be used for transferring data from one cell in either half of the addresses of the memory array 105-1 to a storage element in either half of the addresses of the split serial register 109-1.
  • the illustrated section 130-1.1 of the multiplexer 130-1 couples one column address of the high-half or one column address of the low-half of the memory array 105-1 to associated high or low half storage elements of the split serial register 109-1.
  • the complete multiplexer 130-1 uses one of such multiplexer sections 130-1.1 for every pair of bit lines.
  • FIG. 5 there is shown a truth table that describes the logical operation of the section 130-1.1 of the multiplexer 130-1 shown in Figure 4.
  • a one-out-of-four code received from the graphics processor by way of a path 160 of Figure 3, is applied to the control terminals H-H, L-L, L-H and H-L of the illustrative switching devices.
  • one gate of the multiplexer section 130-1.1 is enabled. The other three gates remain disabled.
  • Input control signals are designated low-half-to-low-half, L-L; low-half-to-high-half, L-H; high-half-to-low-half, H-L; and high-half-to-high-half, H-H.
  • Inputs are from the high-half H or low-half L of the memory array, and outputs go to the high-half H or low-half L of the split serial register.
  • multiplexer operations represented by the truth table of Figure 5 is not dependent upon the interleaving of the storage elements in the memory array or in the split serial register, as shown in Figure 4.
  • the described multiplexer operations may be used for coupling the column addresses of other arrangements of split memory arrays to the addresses of the split serial register.
  • the graphics processor 103 of Figures 1 and 3 generates all of the information for the graphic display. Each bit of the data can be generated at any time and in any order. The processor 103 knows which bit is being generated at any time and where that bit is preassigned, or mapped, for storage in the random access memory 105. When randomly writing the bits into the random access memory 105, the order of writing the bits is unimportant except for efficiency considerations, but each bit must be stored in a storage element at its own preassigned, or bit mapped, location in the random access memory.
  • FIG. 6 there is shown a Cartesian coordinate map representing the storage locations in the random access memory array 105-1 presented in Figures 3 and 4. It is noted that the low-half and the high-half of the array are divided in the center rather than by interleaving the columns. This array is shown divided in the center for the purpose of illustrating the concept by a simplified drawing. Our preference in practice, however, is to interleave memory storage elements and the column leads by address, as shown in Figure 4. The interleaved arrangement can handle the high-half, low-half transfer operations in accordance with the subsequent discussion just as well as the illustrated random access memory array 105-1 of Figure 6.
  • the grid of Figure 6 is an 8 x 8 array of squares, each square of which represents the information to be presented as an eighth of a tile to be presented on the graphic display.
  • squares represent segments of data. Each segment is numbered so that the reader can follow numerically identified segments from storage in the memory array through the multiplexer and split serial register to the display, as subsequently discussed. The numbers in the squares identify the information as segments of the tiles.
  • Each segment of data is stored in a section of a row of the memory.
  • Data represented by each one of the numbered squares, or segments includes thirty-two bits of data (i.e., 32 columns x 1 row) which are stored as shown in the memory array 105-1.
  • a tile of the display image is represented by all of the bits stored in the memory cells along a single row of the random access memory array 105-1, e.g., row 1. It was noted previously that relating to the display of Figure 12, the tiles are thirty-two bits wide by eight bits high and are oriented in vertical columns in the display, as discussed subsequently with respect to Figure 12.
  • the graphics processor creates the information for the display image by tiles and stores that information into the memory array.
  • all of the data included in each row of the memory array is equivalent to a full tile.
  • the graphics processor 103 creates all of the data making up a single tile, the graphics processor only accesses a single selected row in the memory array 105-1 one time. While that selected row is accessed, the columns are accessed one at a time until all of the new data, related to the one tile, is stored in the accessed row of the random access memory.
  • the graphics processor 103 writes, or stores, all of the data contained in one tile while accessing only one row of the memory array, considerable system operating efficiency is achieved.
  • Each row access generally takes as much as twice the time needed for each column access.
  • the worst case occurs when only a single column is accessed for each row access.
  • Our arrangement can achieve as much as a seventy percent reduction in operating time with respect to the worst case for writing randomly into the random access memory.
  • the system can commence reading that data from the random access memory for transfer to the split serial register 109-1, the data register 107 and on to the video display 112.
  • data is stored in the memory by segment.
  • the video display uses a well-known raster scanning technique for presenting the graphic information on a display screen or cathode ray tube.
  • the graphics processor 103 scans the random access memory 105 for transferring data to the display. Data from the memory array is transferred through the multiplexer, the split serial register, the data register 107, and the color palette, and is coordinated with the raster beam as it sweeps across one horizontal line after another projecting the graphics information onto the screen at predetermined locations.
  • the sequential order of readout of data from the memory array is fixed by the hardware and firmware of the graphics display system.
  • the first data for display is segment 1, then segment 2, etc., until finally segment 64.
  • data from one half row of the addresses of the data register 107 are being read out to the display 112
  • data from another half row of addresses can be transferred from the memory array 105 to the idle half of the split serial register 109-1.
  • the information sent from the split serial register may be -and often is- less than an entire half register for every half register of data transferred thereto from the memory.
  • Data register 107 is arranged to receive in parallel, the sequential data streams from each of the arrays 105-1, 105-2, 105-3, and 105-4 by way of the output leads 118-1, 118-2, 118-3, and 118-4 of Figure 3.
  • the data register 107 takes in the plural parallel streams of input data, and shifts them out in one interleaved sequence. All of the bits for each pixel are grouped together in the output stream of data. Thus all of the data describing each pixel is applied to the video palette at once.
  • the video palette translates the pixel data into the desired form for application to the digital to video converter. From the digital to video converter, the video signals are applied to the display. At the finish of each line of the screen, the raster retraces, or returns, to the beginning side of the screen, typically, one or more lines lower. During retrace, graphic information is blanked from the beam. Once the retrace is completed, the raster commences sweeping across another line of the screen and projects the graphic display information. Because the raster beam sweeps across the entire screen and then retraces, the data read from the memory array must be presented to the beam modulator of the video display 112 in the proper sequential order for each complete sweep across the screen.
  • Figure 7 there is shown a table representing the operation of sequentially reading the stored data, as presented in Figure 7, from the random access memory of Figures 3 and 4.
  • the leftmost column shows the time slots for reading segments of data from the memory array 105-1.
  • the column labeled the LOW HALF of the register shows which groups of bits, or parts of tiles, are read out of the memory array and into the low-half of the split serial register 107-1 of Figure 4 in preparation for transfer of selected segments to the video display 112 during odd numbered time slots of the readout operation.
  • the column labeled HIGH HALF of the register shows the groups of bits that are read out of the memory array and into the high-half of the addresses of the split serial register 107-1 in preparation for transfer of other selected segments to the display during even numbered time slots.
  • the column labeled MULTIPLEXER presents an indication of the control signal information for operating the multiplexer 130-1 for the transfer of data into the split serial register 107-1 before it is sent to the video display.
  • the letters designate, respectively, the low-half L or high-half H of the addresses of the memory array 105-1 and the split serial register 107-1 and thus designate the multiplexer control signalling used in Figure 4.
  • the initial tap address, to be stored in the initial tap register 137, is the address of the first bit of segment 1. Thirty-two is stored into the run count register 140 so that the sequential read is interrupted when 32 bits are read out from the split serial register. Segments 9, 17 and 25 are not forwarded during time slot 1. Refer now to Figures 6 and 8 for the next step of the sequential readout. While the segments 1, 9, 17, and 25 are residing in the low-half of the register, data from the low-half L of the second row of the memory array 105-1 is transferred through the multiplexer to the high-half H of the split serial register 107-1. The multiplexer 130-1 is set for a low-half L to high-half H transfer (control signal L-H).
  • Bits of segments 2, 10, 18 and 26 are transferred into the high-half of the split serial register 107-1.
  • time slot 2 the 32 bits representing the segment 2 are forwarded to the display device. This is accomplished by storing the appropriate start address and run count while the segments are being transferred into the split serial register.
  • the number 2 is encircled to indicate that the segment 2 is so forwarded to the display in sequence following segment 1.
  • Figures 7-11 for each of the time slots only one segment number is encircled to indicate which tile segment is forwarded in the sequence going to the display. An appropriate start address and run count are stored and used for each time slot.
  • Figures 10 and 11 show additional examples of the data from rows 1 and 2 of the memory being transferred through the multiplexer to the split serial register for sending segments 57 and 58 to the display.
  • FIG 8 there is shown a time line for the sequence of tile segments being forwarded out of the split serial register 107-1 of Figure 3 to the display.
  • the tile segments can be transmitted to the video display 112 of Figure 1 in sequential order 1, 2, 3, . . . 64, as shown in Figure 12.
  • FIG. 13 there is shown a graphic representation of the stored data, from the memory array 105-1, as an image created by the tile segment information presented in raster scan sequence on the video display 112.
  • the numbered segments of the data are presented to the video display in sequential order 1, 2, . . . 64.
  • Each scan of the raster includes eight segments of the data, one segment for each of eight tiles per scan.
  • Each tile is in a separate column on the screen and may be identified by the number in the top row of its column. Thus the tiles are numbered 1, 2 . . . 8. It is noted that all of the data for each tile of the display screen is mapped from a different row of the memory array 105 of Figure 6.
  • Figure 14 shows an alternative arrangement of the serial readout circuits and of the serial readout control circuits for a system using a split shift register. It is noted that features which are the same as the features of Figure 3 are designated with the same numerical identifier. Other numerical identifiers are used with respect to different features.
  • control signals on the leads 160 cause the data from either the low-half or the high-half of the memory to be transferred to either the low-half or the high-half of the split shift register.
  • the split shift register is arranged at every stage with a tap for outputting data.
  • a tap address register 175 is loaded with the address of the tap from which the first bit of a data sequence and subsequent data is to be outputted.
  • the tap address is loaded into the register decoder 192.
  • the register decoder 192 stores the tap address for the duration of the current serial readout operation.
  • a decoded signal is applied to the gate 132-1 to identify and enable the selected tap for reading out data from the associated shift register stage.
  • a shift clock signal applied to the split shift register 191-1 and the run counter 142, shifts data along the stages of the shift register 191-1 and increments the count in the run counter 142.
  • a new bit of data is stored in the shift register stage associated with the selected tap. That new bit is read out through the gate 132-1 and the lead 118-1 for transmission to the video display, not shown.
  • the comparator 145 continuously compares the count in the run counter 142 with the run count value stored in the run count register 140. Whenever they do not match, the comparator produces a low output signal. When they match, however, the comparator produces a high output signal. This high output signal is the signal which resets the run counter 142 to zero and enables the tap address register 175 to send a new tap address to the register decoder 192.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Controls And Circuits For Display Device (AREA)
  • Image Input (AREA)

Description

    RELATED CASES
  • This application contains subject matter disclosed in EP-A-0 410 743, EP-A-0 474 366, US-A-5 270 973, and in the U.S. Patent Nos. 4,281,401, 4,639,890, and 4,747,081.
  • BACKGROUND OF INVENTION Field of Invention
  • The present invention pertains to graphics display and processing systems for producing a graphics display generally and particularly using a semiconductor memory in the form of a random access memory with a split serial register arrangement.
  • Description of the Related Art
  • In a typical random access memory, the time required for accessing a row is approximately twice as long as the time required for accessing a column. For speedy overall operation, it is desirable to access a row and hold it while several of the columns are accessed along that row. This is referred to as "page mode" operation. If all of the columns across the array are accessed during a single row access, time saved may be as much as 50-70 percent. Such time saving may be achieved during memory write or during memory read operations. For any specific system design there may be trade-offs between memory write time and memory read time to achieve operating efficiency.
  • For computer graphics system applications, further trade-offs can be made between memory read and write times and the capability and speed of a microprocessor used for generating the data to be presented on a video screen. Other factors to be considered include the width and height of the display, the size of the video random access memory and whether the system is line oriented or tile oriented. Final choices among the several trade-offs is a matter left for the system designer or user.
  • Suppliers of devices which may be used in such applications prefer to manufacture devices that include several optional features so that designers and users will apply each type of device in many different applications. This enables one device design effort to result in large manufacturing runs and low costs per device.
  • In furtherance of the aforementioned design strategy, integrated circuit manufacturers have been improving the designs of video random access memory integrated circuit devices by adding features which increase the flexibility and speed of operation of those devices. Some of the features which have been added to random access memory designs include the addition of split serial registers to improve access to and from the memory array and selectable taps for readout from the split serial registers. These features enable the user to closely pack data into the video random access memory and to thereby avoid wasting memory space.
  • As previously mentioned, there are two modes of operation, i.e., line oriented and tile oriented. In line oriented operation, the graphics processor generates and stores data in sequential order as it will appear line-by-line on the display. Storage of data in the video random access memory and read out from storage to the display are accomplished in serial order bit-by-bit and line-by-line. Read out from the split serial register to the display is timed to correlate with the display sweep signal. Prior video random access memory device designs have features which are very desirable and are in wide spread use in line oriented systems.
  • Prior video random access memory device designs are much less flexible and useful with respect to tile oriented systems. Typically, a tile oriented display is divided into a grid of equal size and shape areas, called tiles. The size and shape of the tiles are factors which are among the factors to be chosen by the system designer or user. For instance, the tiles may be squares or rectangles. If rectangles, they may be oriented with the long dimension either laying horizontally or standing vertically. For some tile sizes and orientations, currently available video random access memory devices lack sufficient flexibility for efficient use in some possible system applications. More specifically, the data representing a single tile must be stored in different rows of the storage cells of the random access memory array.
  • Prior to the advent of split serial registers, graphics processing systems transferred an entire row of data bits from a dynamic random access memory into a long data register for readout. From the data register, the entire row of data bits was read out in serial sequence. We now know that this operation was significantly limiting the speed of some graphics processing systems because output of the data register was a serial bit stream read out under control of a serial clock. During the long readout operation, no new data could be transferred into the data register from the dynamic random access memory because the new data would corrupt the data existing in the data register before that existing data could be read out.
  • With the advent of the use of a split serial register in graphics processing systems, it became possible to define a high-half and a low-half of the split serial register through reference to the most significant bit in each half of a counter used for addressing the split serial register. Then, while accessing data from one half of the split serial register, the other half can be reloaded from the random access memory. Also during the loading of half of the split serial register, the address, within that half of the split serial register from which serial accessing will begin, is loaded into a start point address register. While the start point address of a data access run can be defined by information loaded into the start point register, the access run of the data readout ended at the midpoint of the split serial register when reading from the low-half or at the very end of the split serial register when reading from the high-half. This aspect of operating with a split serial register is a significant problem or limitation for some graphics processing systems designs.
  • For example, for a split serial register storing 512 bits, the end point for an access run in the low-half of the split serial register would be at bit 255 and the end point for an access run in the high-half of the split serial register would be at bit 511. Since typical useful access runs for a graphics processing system often vary from eight bits to 128 bits, the forcing of access runs to end either at bit 255 or at bit 511, unnecessarily slows the operating speed of the graphics processing system.
  • US-A-4 825 411 discloses a dual-port memory including a memory array comprising a plurality of memory elements, one of which is accessed at random by a row and column address input so as to enable writing in or reading out of data. At least two serial access memories are provided which are capable of receiving parallel input of all or a portion of the data of a selected row or column of the memory array. A switching circuit switches the respective serial access memories to be in operational states of receiving parallel inputs independently or to be in operational states of outputting their serial outputs successively. Such a dual-port memory is used, for example, for storing picture data to be input to a cathode-ray tube with said picture being randomly accessed or with said picture data stored in a particular row or column being serially accessed.
  • The present invention provides a graphics display system comprising:
    • a display device for displaying lines of pixels;
    • a random access memory system arranged for storing data to be displayed; and
    • access circuits for writing data from the data processor into the random access memory system and for serially reading out data to be displayed by the display device, characterized in that:
    • a data processor is provided to produce data to be displayed in tiles having a height, each tile including a number of segments of pixels equal to the number of lines of pixels in the height of the tiles;
    • the random access memory system is arranged to store a whole tile of data in a selected single row of storage cells, the single row of storage cells including storage cells for storing only pixel data to be displayed as all of the segments of a single tile in the display device; and
    • the access circuits are arranged to write the single tile of data from the data processor into the selected single row of the random access memory system and to read out serially pixel data from the single row to be displayed by the display device as the tile, wherein each segment of the tile is displayed on a separate line of the display device.
  • The above-mentioned and other problems are solved in the embodiment of the invention illustrated in the accompanying drawings by a graphics display and processing system including a video random access memory with a split serial register having low and high halves of a plurality of storage elements, an access start point address register, and an arrangement for stopping an access run at the end of a desired run length.
  • A method and apparatus define both start and stop points of a data access operation, i.e., the specific run length, for a split serial register of a graphics processing system. The address of the access start point in the split register is loaded into the access start point address register. A run length is loaded into a run length counter. Together that information determines the start and stop point addresses for each access operation of the split serial register.
  • There is an operational advantage for the graphics processing system being able to start and stop read access operations at selected storage elements in the split serial register. The graphics display and processing system operates at a faster speed.
  • The graphics display and processing system has a random access memory arranged with a novel split register and a multiplexer for transferring data from the memory array to the split register. Data stored in either a low half or a high half of the memory array column addresses may be selectively transferred through the multiplexer to either a low half or a high half of the split register addresses.
  • An advantage of this arrangement is that system designers have greater flexibility, or more options, in a tile oriented operation, in deciding where within the memory array to store specific bits of information to be displayed, particularly in a tile oriented operation. A tile of data is mapped into the storage elements along a single row of the random access memory array. Thereafter the data from the storage elements of the random access memory are transferred into the split register and transmitted in line-by-line sequence to a raster scan display.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • A more complete understanding of the invention may be gained by reading the following detailed description with reference to the drawing wherein:
    • Figure 1 is a block diagram of part of a graphics processing system;
    • Figure 2 is a block diagram of circuits on a video random access memory integrated circuit chip;
    • Figure 3 is a block diagram of a random access memory system arranged with a multiplexer between a memory array and a split serial register;
    • Figure 4 is a schematic diagram of an illustrative multiplexer for coupling either a low-half or a high-half of the memory array addresses to either a low-half or a high-half of the split serial register addresses;
    • Figure 5 is a truth table for defining the operation of the multiplexer of Figure 3;
    • Figure 6 is a map showing where tile data may be stored in the memory array for defining a screen of information in an exemplary tile oriented system operation;
    • Figure 7 is a table showing a sequence for transferring data from the memory cells of the random access memory array and storing it in the storage elements of the split serial register;
    • Figures 8 through 11 are block diagrams of a selected row of memory, a multiplexer, a split serial register and control circuits in four different operating conditions;
    • Figure 12 is a time line showing a sequence for moving data from the split serial register to the display; and
    • Figure 13 is a map showing where tile information is presented on a display screen.
    • Figure 14 is a block diagram of a random access memory system arranged with a multiplexer between a memory array and a split shift register.
    DETAILED DESCRIPTION
  • Referring now to Figure 1, there is shown a block diagram of a data processing system 100 including a graphics display arrangement for presenting information. A more complete description of the arrangement and operation of the system of Figure 1 can be found in a patent application U.S. serial No. 821,641, filed January 23, 1986.
  • The data processing system 100 includes a host processing system 102, a graphics processor 103, such as a Texas Instruments Incorporated TMS34010 or TMS34020 Graphics System Processor, a video random access memory 105, a data register 107, a video palette 108, a digital to video converter 110, and a video display 112.
  • Host processing system 102 provides the major computational capacity for the data processing system 100. Included in the host processing system 102 are a processor, an input device, a long term storage device, a read only memory, a random access memory and assorted peripheral devices that form a computer system. Arrangement and operation of the host processing system are considered to be conventional. As a result of its processing functions, the host processing system 102 determines the information content of the graphic display to be presented on a screen for the user.
  • Graphics processor 103 provides the major portion of data manipulation for producing the particular graphics display to be presented on the screen. The graphics processor 103 is bidirectionally coupled to the host processing system 102 by way of a host bus 101. In the arrangement of Figure 1, graphics processor 103 operates independently from the host processing system 102. The graphics processor 103, however, is responsive to requests from the host processing system 102. Graphics processor 103 also communicates with memory 105 and the video palette 108 by way of a memory bus 104. Data to be stored in the video random access memory 105 is controlled by the graphics processor 103. The graphics processor, in turn, may be controlled either in part or wholly by a program stored in the video random access memory 105 or in a read only memory 114. Read only memory 114 may store various types of graphic image data.
  • Additionally the graphics processor 103 controls data stored within the video palette 108 and by way of a video control bus 116 the operation of the digital to video converter 110. Through the digital to video converter, the graphics processor 103 can control the line length and the number of lines per frame of the video graphic image. Significantly, the graphics processor 103 determines and controls where graphic display information is stored in the video random access memory 105. Subsequently, during readout from the video random access memory 105, the graphics processor determines the readout sequence from the video random access memory and the split serial register 107, the addresses to be accessed, and control information required to produce the desired graphic image on the display 112.
  • Video random access memory 105 stores the bit mapped graphics data which define the graphics image to be presented to the user. Control of the transfer of the data from the video random access memory 105 through the data register 107, the video palette 108, and the digital to video converter 110 to the display 112 is provided by the graphics processor 103. Video data output from the video random access memory 105 is transferred by way of a video output bus 118 to the data register 107 where it is assembled into a display bit stream. The data register 107 may be a shift register.
  • Storage elements of the data register 107 may be fabricated of either dynamic or static electronic circuits. Alternative choices of storage elements include any bistable electronic, magnetic, optical, or optoelectronic device with sufficient operating speed.
  • In accordance with a typical arrangement of the video random access memory 105, there is a bank of several separate random access memory integrated circuits. Storage cells of the video random access memory 105 may be fabricated as either dynamic or static electronic circuits. For a single readout access operation, only one bit of data is readout from a selected storage element of each of the integrated circuits. Thus a group of bits, including one bit from each of the several separate integrated circuits, are read out at once. The data register 107 assembles the display bit stream for transmission by way of a lead 120 to the video palette 108. Although the foregoing describes the video random access memory 105 as an electronic circuit, the invention may also be carried out by a memory fabricated as any bistable electronic, magnetic, optical or optoelectronic device with sufficient speed.
  • Under control of information from the graphics processor 103, the video palette 108, such as a Texas Instruments TMS34070 Video Palette, converts the data received from the data register 107 into video level signals on a bus 125. This conversion is accomplished through a look-up table. The video level signal output from the video palette 108 may include color, saturation, and brightness information.
  • Digital to video converter 110 receives the digital video signals from the video palette 108 and, under control of signals received by way of the video control bus 116, converts the digital video signals into analog levels which are applied to the video display 112 via an output line 127. The number of pixels per horizontal line and the number of lines per display are determined by the graphics processor 103. Also, the synchronization, retrace, and blanking signals are controlled by the graphics processor 103. Altogether, this group of signals specify the desired video output to the video display 112.
  • Video display 112 produces the specified video image for viewing by the user. There are two techniques which are used widely. The first technique specifies video data in terms of color, hue, brightness, and saturation for each pixel. For the second technique, color levels of red, blue and green are specified for each pixel. The video palette 108, the digital to video converter 110, and the video display are designed and fabricated to be compatible with the selected technique.
  • Referring now to Figure 2, there is shown a block diagram layout of an integrated circuit video random access memory 105. Included within the memory 105 are four arrays of memory cells 105-1, 105-2, 105-3, 105-4. The cells are arranged in rows and columns. For random access, row and column addresses are applied to the integrated circuit by way of address leads and an address bus. For random access, row and column addresses are decoded respectively by row and column decoders. Data is written from a data bus through the column decoders and sense amplifiers to the selected cells of the memory arrays. For serial readout, the data is read from a selected row of the memory arrays, through transfer gates to the data registers. A serial address counter applies a series of serial data register addresses to the serial data pointers, or decoder. In response to those addresses, sequences of data are transmitted from the serial data registers through a data bus to a serial output buffer. From there the data proceeds to the register 107, the video palette, the digital-to-video signal converter, and to the video display, as shown in Figure 1.
  • The various random access input and output circuits are replicated four times to complete the random access arrangement.
  • For serial output operation, a group of common circuits controls the readout operation very effectively. The group of circuits includes an initial tap register, a run count register, a run counter, a comparator, and a serial address counter which applies a series of addresses through another address bus to serial data pointers associated with each serial data register. Operation of these common circuits for serial readout are described at length hereinafter.
  • Referring now to Figure 3, there is shown a more detailed block diagram of the graphics processor 103, the video random access memory 105-1, a split register 109-1, some control circuitry, and interconnecting busses and leads. Video random access memory 105 is an exemplary memory including four memory arrays 105-1, 105-2, 105-3, and 105-4 of rows and columns of storage cells. Typically the four memory arrays are included on one semiconductor chip. Information representing a single pixel for the display includes several bits of data. There is one bit, e.g., B0, stored in each of the arrays for one pixel. All of those bits for the one pixel are stored at the same row address and the same column address so that they can be either written into or read out from the whole memory in one access operation. In any specific design, there usually are as many memory arrays as there are bits in a pixel. If more than four bits are needed per pixel, either more arrays per chip or more chips may be provided.
  • Although the four video random access memory arrays 105-1, 105-2, 105-3, and 105-4 are shown ganged together in Figure 3, only one of them, 105-1, will be discussed hereinafter for purposes of simplifying both the drawing and the description without compromising any generality. It is to be understood that what is shown and said about the one memory array 105-1 and associated multiplexer 130-1, split register 109-1 and control circuits also applies to the other memory arrays and associated circuits which are ganged together from one or more semiconductor chips.
  • The screen of the video display 112 of Figure 1 can be thought to be organized in either of two ways. Usually in the display, there are a large number of horizontal lines each including a large number of pixels. Another often used, but different, scheme divides the display into a number of tiles. Each tile includes some number of pixels in a contiguous area of the display. The tile areas for a display are uniform in size and therefore include some number of pixels across and some number of pixels in height. For purposes of subsequent discussion, the number of pixels across a tile equals the number of columns in a section of the video random access memory array 105-1 and the number of storage elements in a section of the split register 109-1. The split register 109-1 may be either a shift register or a serial register. Hereinafter the split register will be described as split serial register 109-1. Information in one line across a tile is considered to be a segment of the tile. Since there is only one bit per pixel in the memory array 105-1, the number of bits in a segment of the tile in array 105-1 equals the number of columns used in the sections of the memory array and the number of storage elements used in the sections of the split serial register 109-1. The number of pixels in height equals the number of lines in the tile. For a subsequent illustrative example, a tile is thirty-two pixels across and eight pixels high in the display depicted in Figure 12, to be discussed subsequently.
  • The video random access memory array 105-1 is arranged so that the data, representing a tile of the display, is stored as sequential segments of the tile in a single row of the memory array 105-1. An entire tile of data is stored in the single row of the memory array 105-1. Row and column address information, together with the desired display, or pixel information, is generated by the graphics processor 103.
  • For random access writing, the addresses are applied through the bus 104 to an address register 106 for accessing the identified row and column storage locations in the random access memory array 105-1. The display data, to be stored at each address, also is applied through the bus 104 and a lead 111 to the random access memory array 105-1. When the graphics processor develops the random access address and display data for any tile, that data, in a departure from the prior art, is transmitted through bus 104 and is written into the random access memory 105-1 by making a single row access and thereafter accessing sequentially selected columns where data is to be stored. This enables a random access write-in operation to write in during a single row access as much as a whole tile of data. Since the accessing of a row operation takes approximately twice as long as accessing a column, considerable operational time is saved by making the single row access and performing the several column accesses while the row access remains effective.
  • The memory array 105-1 and the split serial register 109-1 are each divided by address into a low part and a high part. Such divisions greatly facilitate readout from the memory array 105-1 to the video display 112 of Figure 1. Readout from the memory array 105-1 occurs sequentially by line of the display. As the raster scans a line of the display, the appropriate data for each pixel in the sequence is applied to the beam for projection on the display screen. The graphics processor 103 determines the order for addressing the storage cells of the memory array 105-1, the selection made by the multiplexer 130-1, and the order for reading data from the storage elements of the split serial register 109-1 to achieve the desired output sequence of information being forwarded to the video display 112.
  • Rows of the memory are addressed by part rows, e.g., low address half rows and high address half rows. Under control of the graphics processor 103, the multiplexer 130-1 determines whether the data read out of either the low-half or the high-half of the memory array is transmitted by bit line to either the low-half or the high-half addresses of the split serial register 109-1. Once the data is stored in the split serial register 109-1, one or more bits of data or segments of tiles can be transmitted from the split serial register 109-1 out to the video display 112.
  • Additional control circuitry, which is common to the several memory arrays, is provided for determining the specific portion of data to be transmitted from the split serial register 109-1. The data from the split serial register 109-1 can be read out from a separate tap at each storage element. Conceptually, the taps are represented by a gate circuit 132 which receives a separate output from each storage element of the split serial register 109-1. A counter decoder 135 determines which one of the split serial register storage element outputs is transmitted to the video display 112 during any time slot determined by a readout clock signal CLOCK .
  • Since the initial pixel data to be transmitted may be in any split serial register 109-1 location, the graphics processor 103 loads the address of that initial pixel data into an initial tap, or start point, register 137. Upon receipt of a reset signal from a comparator 145, the initial tap register 137 loads the initial pixel data address into the counter decoder 135 for enabling the gate circuit 132 to transmit the data from the correct split serial register storage element. Loading of the initial pixel data address may be in parallel to the counter decoder 135.
  • Data read out thereafter generally proceeds sequentially along the storage elements of the split serial register 109-1, however, unlike the prior art, it does not necessarily proceed continuously. We have found that in some circumstances, it is advantageous to read data from only a portion of one half of the split serial register 109-1.One such circumstance arises when the display system is tile oriented and the data representing a tile is stored along a single row of the memory array 105-1, as previously described herein. Then for efficiency, the sequential addressing for reading out the data from the split serial register 109-1 should be interrupted before the end of half the register. In a departure from the prior art, interruptions are made by the graphics processor 103 loading a number, or run count, into a run count register 140 for determining the number of sequential addresses of the split serial register 109-1 that are accessed before the interruption, i.e., before the counter decoder 135 and gate circuit 132 jump to a new initial, or start, tap address for subsequent readout. A convenient run length is equal to the number of pixels in a segment. The number in the count register 140 and a run count from a run counter 142 are compared by the comparator 145. When they do not match, the current sequence of addresses continues as the run counter is incremented by the signal CLOCK for each readout operation. When the two counts do agree, e.g., at the end of a segment, the comparator 145 produces a signal for resetting the run counter 142 and for loading the new initial tap address into the initial tap register 137. As a result, the counter decoder 135 enables the gate circuit 132 to jump to the new initial tap address of the split serial register 109-1 and thereby interrupt the sequential addressing.
  • It is advantageous for a tile oriented system to run through a sequence of addresses equal to the number of addresses needed for reading out all of the pixels in a segment of a tile from one half of the split serial register 109-1 and then transfer to the other half of the split serial register to read out the pixels in a segment from another tile. Since the tiles typically end before the end of a half of the register, it is advantageous to interrupt the readout operation at the end of the tile rather than at the end of half of the register. A more detailed description of this operation is to be described hereinafter in reference to Figures 5 through 12.
  • Referring now to Figure 4, there is shown the physical arrangements of the storage cells and bit lines of the memory array 105-1 and of the storage elements of the associated split serial register 109-1. The memory array 105-1 and the split serial register 109-1 both are divided into parts by addresses, a low-half L of the memory array addresses including half of the storage cells and a high-half H of the memory array addresses including the remaining storage cells. The low-half designators L0...L127 are shown below the high-half designators H0...H127 so that, at a glance, the two halves will stand out from each other in Figure 4.
  • In a departure from prior memory arrays, the storage cells L of the low-half addresses of the memory array 105-1 are interleaved with the storage cells H of the high-half addresses of the memory array. Similarly, in a departure from prior random access memory system arrangements, the storage elements L of the low-half addresses of the split serial register 109-1 are interleaved with the storage elements H of the high-half addresses of the split serial register 109-1.
  • Such interleaving of the storage cells of the two parts of the memory columns and of the storage elements of the two parts of the split serial register 109-1 provides a significant advantage when the memory array 105-1 and the split serial register 109-1 are fabricated as an integrated circuit. By interleaving, the total length and complexity of the bit lines, which are arranged for coupling the storage cells of the memory array 105-1 through the multiplexer 130-1 to the storage elements of the split serial register 109-1, are substantially reduced with respect to the bit line layout, which otherwise is required when the lower and upper halves of the memory array 105-1 and split serial register 109-1 are divided by whole physical sections rather than by the interleaving of the columns and register elements, as shown in Figure 4.
  • Figure 4 additionally illustrates a schematic for a section 130-1.1 of the multiplexer 130-1 which can be used for transferring data from one cell in either half of the addresses of the memory array 105-1 to a storage element in either half of the addresses of the split serial register 109-1. The illustrated section 130-1.1 of the multiplexer 130-1 couples one column address of the high-half or one column address of the low-half of the memory array 105-1 to associated high or low half storage elements of the split serial register 109-1. The complete multiplexer 130-1 uses one of such multiplexer sections 130-1.1 for every pair of bit lines.
  • Referring now to Figure 5, there is shown a truth table that describes the logical operation of the section 130-1.1 of the multiplexer 130-1 shown in Figure 4. A one-out-of-four code, received from the graphics processor by way of a path 160 of Figure 3, is applied to the control terminals H-H, L-L, L-H and H-L of the illustrative switching devices. In response to the one-out-of-four code, one gate of the multiplexer section 130-1.1 is enabled. The other three gates remain disabled. Input control signals are designated low-half-to-low-half, L-L; low-half-to-high-half, L-H; high-half-to-low-half, H-L; and high-half-to-high-half, H-H. Inputs are from the high-half H or low-half L of the memory array, and outputs go to the high-half H or low-half L of the split serial register.
  • It is noted that the multiplexer operations represented by the truth table of Figure 5 is not dependent upon the interleaving of the storage elements in the memory array or in the split serial register, as shown in Figure 4. The described multiplexer operations may be used for coupling the column addresses of other arrangements of split memory arrays to the addresses of the split serial register.
  • The graphics processor 103 of Figures 1 and 3 generates all of the information for the graphic display. Each bit of the data can be generated at any time and in any order. The processor 103 knows which bit is being generated at any time and where that bit is preassigned, or mapped, for storage in the random access memory 105. When randomly writing the bits into the random access memory 105, the order of writing the bits is unimportant except for efficiency considerations, but each bit must be stored in a storage element at its own preassigned, or bit mapped, location in the random access memory.
  • For efficient, speedy random writing of data into the memory array, it is effective to access for writing by tiles rather than by individual pixels. All changed information for one or more tiles is generated and written quickly. All stored information for other unchanged tiles need only be refreshed, not written again. By so writing only into tiles where information has changed, all of the writing can be accomplished very efficiently.
  • Referring now to Figure 6, there is shown a Cartesian coordinate map representing the storage locations in the random access memory array 105-1 presented in Figures 3 and 4. It is noted that the low-half and the high-half of the array are divided in the center rather than by interleaving the columns. This array is shown divided in the center for the purpose of illustrating the concept by a simplified drawing. Our preference in practice, however, is to interleave memory storage elements and the column leads by address, as shown in Figure 4. The interleaved arrangement can handle the high-half, low-half transfer operations in accordance with the subsequent discussion just as well as the illustrated random access memory array 105-1 of Figure 6.
  • The grid of Figure 6 is an 8 x 8 array of squares, each square of which represents the information to be presented as an eighth of a tile to be presented on the graphic display. In Figure 6 and subsequently in Figures 7-12, squares represent segments of data. Each segment is numbered so that the reader can follow numerically identified segments from storage in the memory array through the multiplexer and split serial register to the display, as subsequently discussed. The numbers in the squares identify the information as segments of the tiles. Each segment of data is stored in a section of a row of the memory. Data represented by each one of the numbered squares, or segments, includes thirty-two bits of data (i.e., 32 columns x 1 row) which are stored as shown in the memory array 105-1. A tile of the display image is represented by all of the bits stored in the memory cells along a single row of the random access memory array 105-1, e.g., row 1. It was noted previously that relating to the display of Figure 12, the tiles are thirty-two bits wide by eight bits high and are oriented in vertical columns in the display, as discussed subsequently with respect to Figure 12.
  • Recall that data can be written into the storage cells of the random access memory array 105-1 in any sequential order but each bit must be stored in its preassigned location. For the purpose of enhancing the overall speed of operation of the display system, the graphics processor creates the information for the display image by tiles and stores that information into the memory array. In Figure 6, all of the data included in each row of the memory array is equivalent to a full tile. As the graphics processor 103 creates all of the data making up a single tile, the graphics processor only accesses a single selected row in the memory array 105-1 one time. While that selected row is accessed, the columns are accessed one at a time until all of the new data, related to the one tile, is stored in the accessed row of the random access memory. Because the graphics processor 103 writes, or stores, all of the data contained in one tile while accessing only one row of the memory array, considerable system operating efficiency is achieved. Each row access generally takes as much as twice the time needed for each column access. For efficient operation, the worst case occurs when only a single column is accessed for each row access. Our arrangement can achieve as much as a seventy percent reduction in operating time with respect to the worst case for writing randomly into the random access memory.
  • After a complete display screen of data is stored in the random access memory 105 of Figure 1, the system can commence reading that data from the random access memory for transfer to the split serial register 109-1, the data register 107 and on to the video display 112. As shown in Figure 6, data is stored in the memory by segment. The video display uses a well-known raster scanning technique for presenting the graphic information on a display screen or cathode ray tube. Meanwhile, the graphics processor 103 scans the random access memory 105 for transferring data to the display. Data from the memory array is transferred through the multiplexer, the split serial register, the data register 107, and the color palette, and is coordinated with the raster beam as it sweeps across one horizontal line after another projecting the graphics information onto the screen at predetermined locations. The sequential order of readout of data from the memory array is fixed by the hardware and firmware of the graphics display system. The first data for display is segment 1, then segment 2, etc., until finally segment 64. While the data from one half row of the addresses of the data register 107 are being read out to the display 112, data from another half row of addresses can be transferred from the memory array 105 to the idle half of the split serial register 109-1. The information sent from the split serial register may be -and often is- less than an entire half register for every half register of data transferred thereto from the memory.
  • From the split serial register, the data is sent to the video palette by way of the data register 107 of Figure 1. Data register 107 is arranged to receive in parallel, the sequential data streams from each of the arrays 105-1, 105-2, 105-3, and 105-4 by way of the output leads 118-1, 118-2, 118-3, and 118-4 of Figure 3. In operation, the data register 107 takes in the plural parallel streams of input data, and shifts them out in one interleaved sequence. All of the bits for each pixel are grouped together in the output stream of data. Thus all of the data describing each pixel is applied to the video palette at once.
  • The video palette translates the pixel data into the desired form for application to the digital to video converter. From the digital to video converter, the video signals are applied to the display. At the finish of each line of the screen, the raster retraces, or returns, to the beginning side of the screen, typically, one or more lines lower. During retrace, graphic information is blanked from the beam. Once the retrace is completed, the raster commences sweeping across another line of the screen and projects the graphic display information. Because the raster beam sweeps across the entire screen and then retraces, the data read from the memory array must be presented to the beam modulator of the video display 112 in the proper sequential order for each complete sweep across the screen.
  • The operation of reading data from the memory and transferring it through the multiplexer, the serial shift register and the gate to the data register may be better understood by carefully reading the following description of Figures 7-13.
  • Referring now to Figure 7, there is shown a table representing the operation of sequentially reading the stored data, as presented in Figure 7, from the random access memory of Figures 3 and 4. In Figure 7, the leftmost column shows the time slots for reading segments of data from the memory array 105-1. The column labeled the LOW HALF of the register shows which groups of bits, or parts of tiles, are read out of the memory array and into the low-half of the split serial register 107-1 of Figure 4 in preparation for transfer of selected segments to the video display 112 during odd numbered time slots of the readout operation. Likewise, the column labeled HIGH HALF of the register shows the groups of bits that are read out of the memory array and into the high-half of the addresses of the split serial register 107-1 in preparation for transfer of other selected segments to the display during even numbered time slots. The column labeled MULTIPLEXER presents an indication of the control signal information for operating the multiplexer 130-1 for the transfer of data into the split serial register 107-1 before it is sent to the video display. In the columns labeled RAM and REGISTER, the letters designate, respectively, the low-half L or high-half H of the addresses of the memory array 105-1 and the split serial register 107-1 and thus designate the multiplexer control signalling used in Figure 4.
  • As shown in Figures 7 and 8, during read time slot 0, data from the low-half L of the first row of the memory array 105-1 is read out through the multiplexer to the low-half L of the split serial register 107-1. The multiplexer 130-1 is set for a low-half L to low-half L transfer (control signal L-L). There are thirty-two bits in each of the segments, or squares, 1, 9, 17 and 25. Those numbers are underscored to indicate that they are segments of tile 1. While that data is residing in the split serial register 107-1 during time slot 1, only the thirty-two bits representing segment 1 are forwarded to the video display 112. The numeral 1, representing the tile segment 1, is enclosed in a circle to indicate that segment is to be forwarded to the video display. The initial tap address, to be stored in the initial tap register 137, is the address of the first bit of segment 1. Thirty-two is stored into the run count register 140 so that the sequential read is interrupted when 32 bits are read out from the split serial register. Segments 9, 17 and 25 are not forwarded during time slot 1. Refer now to Figures 6 and 8 for the next step of the sequential readout. While the segments 1, 9, 17, and 25 are residing in the low-half of the register, data from the low-half L of the second row of the memory array 105-1 is transferred through the multiplexer to the high-half H of the split serial register 107-1. The multiplexer 130-1 is set for a low-half L to high-half H transfer (control signal L-H). Bits of segments 2, 10, 18 and 26 are transferred into the high-half of the split serial register 107-1. During time slot 2, the 32 bits representing the segment 2 are forwarded to the display device. This is accomplished by storing the appropriate start address and run count while the segments are being transferred into the split serial register. The number 2 is encircled to indicate that the segment 2 is so forwarded to the display in sequence following segment 1. In Figures 7-11 for each of the time slots only one segment number is encircled to indicate which tile segment is forwarded in the sequence going to the display. An appropriate start address and run count are stored and used for each time slot.
  • Figures 10 and 11 show additional examples of the data from rows 1 and 2 of the memory being transferred through the multiplexer to the split serial register for sending segments 57 and 58 to the display.
  • Referring now to Figure 8, there is shown a time line for the sequence of tile segments being forwarded out of the split serial register 107-1 of Figure 3 to the display. By forwarding the data stored in sequential rows of the low-half of the random access memory alternately to the low-half and the high-half of the split serial register, followed similarly by data stored in the high half of the random access memory, the tile segments can be transmitted to the video display 112 of Figure 1 in sequential order 1, 2, 3, . . . 64, as shown in Figure 12.
  • Referring now to Figure 13, there is shown a graphic representation of the stored data, from the memory array 105-1, as an image created by the tile segment information presented in raster scan sequence on the video display 112. The numbered segments of the data are presented to the video display in sequential order 1, 2, . . . 64. Each scan of the raster includes eight segments of the data, one segment for each of eight tiles per scan. There are eight tiles in a complete screen of the display. Each tile is in a separate column on the screen and may be identified by the number in the top row of its column. Thus the tiles are numbered 1, 2 . . . 8. It is noted that all of the data for each tile of the display screen is mapped from a different row of the memory array 105 of Figure 6.
  • Figure 14 shows an alternative arrangement of the serial readout circuits and of the serial readout control circuits for a system using a split shift register. It is noted that features which are the same as the features of Figure 3 are designated with the same numerical identifier. Other numerical identifiers are used with respect to different features.
  • When data is to be read out serially from the array of memory cells, control signals on the leads 160 cause the data from either the low-half or the high-half of the memory to be transferred to either the low-half or the high-half of the split shift register. The split shift register is arranged at every stage with a tap for outputting data. A tap address register 175 is loaded with the address of the tap from which the first bit of a data sequence and subsequent data is to be outputted. When a signal is applied from the comparator 145 to the tap address register 175, the tap address is loaded into the register decoder 192. The register decoder 192 stores the tap address for the duration of the current serial readout operation. A decoded signal is applied to the gate 132-1 to identify and enable the selected tap for reading out data from the associated shift register stage.
  • A shift clock signal, applied to the split shift register 191-1 and the run counter 142, shifts data along the stages of the shift register 191-1 and increments the count in the run counter 142. During each clock cycle, a new bit of data is stored in the shift register stage associated with the selected tap. That new bit is read out through the gate 132-1 and the lead 118-1 for transmission to the video display, not shown.
  • The comparator 145 continuously compares the count in the run counter 142 with the run count value stored in the run count register 140. Whenever they do not match, the comparator produces a low output signal. When they match, however, the comparator produces a high output signal. This high output signal is the signal which resets the run counter 142 to zero and enables the tap address register 175 to send a new tap address to the register decoder 192.
  • The foregoing description presents the arrangement and operation of an illustrative example of the invention. This exemplary arrangement and other arrangements, made obvious in view thereof, are considered to be within the scope of the appended claims.

Claims (7)

  1. A graphics display system comprising:
    a display device (112) for displaying lines of pixels;
    a random access memory system (105) arranged for storing data to be displayed; and
    access circuits (104) for writing data from the data processor (103) into the random access memory system (105) and for serially reading out data to be displayed by the display device (112), characterized in that:
    a data processor (103) is provided to produce data to be displayed in tiles having a height, each tile including a number of segments of pixels equal to the number of lines of pixels in the height of the tiles;
    the random access memory system (105) is arranged to store a whole tile of data in a selected single row of storage cells, the single row of storage cells including storage cells for storing only pixel data to be displayed as all of the segments of a single tile in the display device (112); and
    the access circuits (104) are arranged to write the single tile of data from the data processor (103) into the selected single row of the random access memory system (105) and to read out serially pixel data from the single row to be displayed by the display device (112) as the tile, wherein each segment of the tile is displayed on a separate line of the display device (112).
  2. A graphics display system, in accordance with claim 1, further comprising:
    a plurality of column lines, coupled to the storage cells, including low half and high half column lines associated with respective storage cells;
    the access circuits including
    a split register (109), each half of the split register (109) being arranged for receiving data simultaneously from half of the plurality of column lines associated with the storage cells of the random access memory system (105); and
    a multiplexer (130) arranged for transferring data from either a low half or a high half of the storage cells through the column lines to either a low half or a high half of the split register (109).
  3. A graphics display system, in accordance with claim 2, wherein the access circuits include a circuit for reading data from the split register (109) to the display device (112) in a line-by-line sequence for the display device (112).
  4. A graphics display system, in accordance with any preceding claim, wherein the display device (112) is a raster scan display device (112); and the circuit for reading data from the random access memory (105) to the display device (112) is a serial readout circuit for transferring data from the random access memory (105) to the raster scan display device (112).
  5. A graphics display system, in accordance with any preceding claim, wherein the random access memory (105) has the storage cells arranged in rows and columns;
    the access circuits include an address register for selecting addressable row and column storage cells to store the tile data, and a bus (104) for transmitting storage cell addresses and the tile data, respectively, to the address register and the random access memory (105), the random access memory (105) being arranged for storing the whole tile of the tile data in a single addressable row of the storage cells; and
    the split register (109) includes storage elements and is arranged for receiving data concurrently from a half of the storage cells in the single addressable row; and the split register (109) is accessed to serially read out data one bit at a time.
  6. A graphics display system, in accordance with any preceding claim, wherein the split register (109) is a split serial register.
  7. A graphics display system, in accordance with any one of claims 1 to 5, wherein the split register (109) is a split shift register.
EP19910307222 1990-08-06 1991-08-06 Graphics display system including a video random access memory with a split serial register and a run counter Expired - Lifetime EP0474366B1 (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US56347290A 1990-08-06 1990-08-06
US07/563,469 US5517609A (en) 1990-08-06 1990-08-06 Graphics display system using tiles of data
US563469 1990-08-06
US563472 1990-08-06

Publications (3)

Publication Number Publication Date
EP0474366A2 EP0474366A2 (en) 1992-03-11
EP0474366A3 EP0474366A3 (en) 1992-11-19
EP0474366B1 true EP0474366B1 (en) 1996-07-03

Family

ID=27073299

Family Applications (1)

Application Number Title Priority Date Filing Date
EP19910307222 Expired - Lifetime EP0474366B1 (en) 1990-08-06 1991-08-06 Graphics display system including a video random access memory with a split serial register and a run counter

Country Status (3)

Country Link
EP (1) EP0474366B1 (en)
JP (1) JPH06102842A (en)
DE (1) DE69120616T2 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3435205B2 (en) * 1994-03-16 2003-08-11 株式会社東芝 Semiconductor storage device
US5694143A (en) 1994-06-02 1997-12-02 Accelerix Limited Single chip frame buffer and graphics accelerator
WO1995035572A1 (en) 1994-06-20 1995-12-28 Neomagic Corporation Graphics controller integrated circuit without memory interface
CN101751908B (en) * 2008-11-28 2011-12-14 旭曜科技股份有限公司 Frame memory access method and the display drive thereof

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS634493A (en) * 1986-06-24 1988-01-09 Mitsubishi Electric Corp Dual port memory
US5001672A (en) * 1989-05-16 1991-03-19 International Business Machines Corporation Video ram with external select of active serial access register

Also Published As

Publication number Publication date
DE69120616D1 (en) 1996-08-08
EP0474366A2 (en) 1992-03-11
JPH06102842A (en) 1994-04-15
EP0474366A3 (en) 1992-11-19
DE69120616T2 (en) 1996-11-28

Similar Documents

Publication Publication Date Title
US4979738A (en) Constant spatial data mass RAM video display system
EP0201210B1 (en) Video display system
US4991110A (en) Graphics processor with staggered memory timing
EP0098868B1 (en) Apparatus for controling a color display
JP3385135B2 (en) On-screen display device
US4628467A (en) Video display control system
EP0185294A2 (en) Display apparatus
EP0279693B1 (en) Multi-plane video ram
US5517609A (en) Graphics display system using tiles of data
EP0398510B1 (en) Video random access memory
JPS5830590B2 (en) Character graphic color display system
JPS5937512B2 (en) raster display device
CA1220293A (en) Raster scan digital display system
US5270973A (en) Video random access memory having a split register and a multiplexer
GB2137857A (en) Computer Graphics System
CN1953040B (en) Image display system and control method therefor
EP0215984B1 (en) Graphic display apparatus with combined bit buffer and character graphics store
US5311468A (en) Random access memory with a serial register arranged for quick access of a second bit from an arbitrary address
EP0474366B1 (en) Graphics display system including a video random access memory with a split serial register and a run counter
US5818433A (en) Grapics memory apparatus and method
JPS6073575A (en) Data display
US5119331A (en) Segmented flash write
JPH06167958A (en) Memory device
US7050064B2 (en) Method and apparatus for displaying higher color resolution on a hand-held LCD device
KR100297716B1 (en) Semiconductor memory device having high flexibility in column

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A2

Designated state(s): DE FR GB IT NL

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): DE FR GB IT NL

17P Request for examination filed

Effective date: 19930223

17Q First examination report despatched

Effective date: 19940915

GRAH Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOS IGRA

GRAH Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOS IGRA

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB IT NL

REF Corresponds to:

Ref document number: 69120616

Country of ref document: DE

Date of ref document: 19960808

ITF It: translation for a ep patent filed

Owner name: BARZANO' E ZANARDO ROMA S.P.A.

ET Fr: translation filed
PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed
REG Reference to a national code

Ref country code: GB

Ref legal event code: IF02

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20060706

Year of fee payment: 16

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: NL

Payment date: 20060710

Year of fee payment: 16

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20060803

Year of fee payment: 16

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: IT

Payment date: 20060831

Year of fee payment: 16

Ref country code: DE

Payment date: 20060831

Year of fee payment: 16

GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 20070806

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: NL

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20080301

NLV4 Nl: lapsed or anulled due to non-payment of the annual fee

Effective date: 20080301

REG Reference to a national code

Ref country code: FR

Ref legal event code: ST

Effective date: 20080430

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20080301

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20070831

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20070806

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IT

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20070806