WO1995012164A2 - Frame buffer system designed for windowing operations - Google Patents

Frame buffer system designed for windowing operations Download PDF

Info

Publication number
WO1995012164A2
WO1995012164A2 PCT/US1994/012307 US9412307W WO9512164A2 WO 1995012164 A2 WO1995012164 A2 WO 1995012164A2 US 9412307 W US9412307 W US 9412307W WO 9512164 A2 WO9512164 A2 WO 9512164A2
Authority
WO
WIPO (PCT)
Prior art keywords
die
data
frame buffer
circuitry
array
Prior art date
Application number
PCT/US1994/012307
Other languages
French (fr)
Other versions
WO1995012164A3 (en
Inventor
Curtis Priem
Shuen Chin Chang
Hai Duy Ho
Szu Cheng Sun
Original Assignee
Sun Microsystems, Inc.
Samsung Semiconductor, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sun Microsystems, Inc., Samsung Semiconductor, Inc. filed Critical Sun Microsystems, Inc.
Priority to EP94932066A priority Critical patent/EP0677190B1/en
Priority to JP7512813A priority patent/JPH08505255A/en
Priority to KR1019950702526A priority patent/KR100335474B1/en
Priority to DE69432512T priority patent/DE69432512T2/en
Publication of WO1995012164A2 publication Critical patent/WO1995012164A2/en
Publication of WO1995012164A3 publication Critical patent/WO1995012164A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/06Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
    • 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/02Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the way in which colour is displayed
    • G09G5/024Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the way in which colour is displayed using colour registers, e.g. to control background, foreground, surface filling
    • 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/02Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the way in which colour is displayed
    • G09G5/022Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the way in which colour is displayed using memory planes
    • 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/393Arrangements for updating the contents of the bit-mapped memory

Definitions

  • This invention relates to computer systems and, more particularly, to methods and apparatus for providing a frame buffer capable of receiving, manipulating and transferring data for display at a high rate of speed when used in a system displaying a plurality of applications simultaneously in windows on an output display device.
  • a problem which has been discovered by designers of graphics accelerator circuitry is that a great deal of the speed improvement which is accomplished by the graphics accelerator circuitry is negated by the frame buffer circuitry into which the output of the graphics accelerator is loaded for ultimate display on an output display device.
  • a frame buffer offers a sufficient amount of random access memory to store one frame of data to be displayed.
  • transferring the data to and from the frame buffer is very slow because of the manner in which the frame buffers are constructed.
  • Various improvements have been made to speed access in frame buffers. For example, two-ported VRAM has been substituted for DRAM so that information may be taken from the frame buffer while it is being loaded.
  • a flash mode has been devised for allowing an entire row of a display to be written with a single color.
  • an object of the present invention to provide a new design of frame buffer capable of rapidly handling the data transferred to it for display in a system which presents a plurality of applications in separate windows on an output display device.
  • the frame buffer including an array of memory cells for storing data indicating pixels to be displayed on the output display, address decoding apparatus for controlling access to the array, the address decoding apparatus including column address decoding apparatus for selecting groups of adjacent columns of the array, a plurality of apparatus for selectively writing to each of the columns of any of said groups of adjacent columns, a plurality of color value registers, latching apparatus for storing pixel data equivalent to a row of pixel data to be displayed on the output display, apparatus for writing pixel data from selected groups of adjacent columr - of the array to the latching apparatus, and apparatus for connecting either selected ones of the color value registers, the latches, or the data bus to the apparatus for selectively writing to each of the columns of
  • Figure 1 is a block diagram illustrating a computer system including the present invention.
  • FIG. 2 is a block diagram of a frame buffer designed in accordance with prior art
  • FIG. 3 is a block diagram of a frame buffer designed in accordance with the present invention.
  • Figure 4 is a diagram illustrating operational details of a portion of the frame buffer of Figure 3.
  • Figure 5 is a flow chart illustrating a method in accordance with the invention.
  • the manipulations performed are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. No such capability of a human operator is necessary or desirable in most cases in any of the operations described herein which form part of the present invention; the operations are machine operations.
  • Useful machines for performing the operations of the present invention include general purpose digital computers or other similar devices. In all cases the distinction between the method operations in operating a computer and the method of computation itself should be borne in mind.
  • the present invention relates to a method and apparatus for operating a computer in processing electrical or other (e.g. mechanical, chemical) physical signals to generate other desired physical signals.
  • the system 10 includes a central processor 11 which carries out the various instructions provided to the computer 10 for its operations.
  • the central processor 11 is joined to a bus 12 adapted to carry information to various components of the system 10.
  • main memory 13 which is typically constructed of dynamic random access memory arranged in a manner well known to those skilled in the prior art to store information being used by the central processor during the period in which power is provided to the system 10.
  • read only memory 14 which may include various memory devices (such as electrically programmable read only memory devices (EPROM or similar devices)) well known to those skilled in the art which are adapted to retain memory condition in the absence of power to the system 10.
  • the read only memory 14 typically stores various basic functions used by the processor 11 such as basic input/output processes and startup processes.
  • long term memory 16 Also connected to the bus 12 are various peripheral components such as long term memory 16.
  • long term memory 16 typically electro-mechanical hard disk drives
  • circuitry such as a frame buffer 17 to which data may be written that is to be transferred to an output device such as a monitor 18 for display.
  • the frame buffer may be considered to include in addition to the various memory planes necessary to store information, various circuitry well known to those skilled in the art for controlling the scan of information to the output display.
  • FIG. 2 illustrates a frame buffer 17 constructed in accordance with the prior art
  • a frame Duffer 17 includes a dynamic random access memory array designed to store information defining pixels on the output display.
  • data is written to or read from the frame buffer 17 on the conductors of the data bus 12.
  • the frame buffer 17 is written, all of the data conductors of the bus transfer the binary data to be stored as pixel information.
  • thirty-two bits of information may be written on the bus and appear at thirty-two input pins to the frame buffer memory. This data may define one or more pixels depending upon the number of bits required to define a pixel in the particular display mode.
  • each pixel displayed requires eight bits of data; and thirty-two bits of data on the data conductors of the bus are capable of defining four pixels in each individual access.
  • Writing pixel data one (or four) pixels at a time is a relatively slow method of filling the frame buffer with data to be written to the display. This is, however, the usual mode of writing pixel data to the display.
  • This normal mode is typically used in any process which varies the display on a pixel by pixel basis or to describe any graphical image which uses more than two colors in a window.
  • some prior art frame buffers also have apparatus which allows a mode of operation (referred to as "block mode") in which each of the data conductors controls access to four bits representing a pixel color value.
  • block mode allows data representing a color value to be written simultaneously to a plurality of individual pixel positions in the memory.
  • the information written to the array on the data conductors is control information used to enable writing to memory positions representing particular pixel positions and to ignore other pixel positions.
  • the prior art frame buffer 17 of Figure 2 has a plurality of data input conductors 23 and a four bit color register 19.
  • a four bit color value to be stored as pixel data in data positions in an array 20 of the frame buffer 17 is written into the color register 19.
  • Data transferred to the frame buffer 17 on the data conductors 23 indicates the positions of pixels which are to be written and of tiiose pixels which are not to be written. For example, if a data conductor 23 carries a zero value, then the pixel position controlled by that conductor is not written. If a data conductor 23 carries a one value, then the four bit color value from the color register 19 is written into the pixel position.
  • the foreground color is placed in the color register, and the foreground pixels are written to the row.
  • the background color is again placed in the color register, and die entire second row of the particular window is cleared.
  • the background color is again replaced in the color register with the foreground color, and the foreground pixels are written for the second row. This continues until all of the rows of the window have been written with both of the colors necessary to the display.
  • each access of the frame buffer requires both a row address strobe (RAS) cycle of 120 nanoseconds and a column address strobe (CAS) cycle of 20 nanoseconds. This is true for accessing the frame buffer to load die color register and for accessing die memory positions in the frame buffer.
  • RAS row address strobe
  • CAS column address strobe
  • a plurality of pixels may be read or written in the same row as long as no other operation intervenes with only a CAS cycle required for each group of d irty-two pixels.
  • the same RAS/CAS sequence is used for operations other than reading and writing to me memory cells, to load the color register with background color takes a first 120 nanoseconds, writing the background color takes another 120 nanoseconds, reloading d e color register with foreground color takes another 120 nanoseconds, and writing the foreground color takes another 120 nanoseconds.
  • the time necessary to reload the color register twice on each row and die requirement to write twice to each of the thirty-two bit positions in each row together slow the operation signif ⁇ candy. For example, if it is desired to write to an area of a window in order to change die data presented, it is first necessary to change the value in the color register to the back ground color for the area, then write the background, tiien change the value in the color register again, and finally write the foreground color.
  • One of the slowest operations performed in such a prior art frame buffer is the scrolling of data. In a scrolling operation rows of data are moved up or down on d e output display.
  • Another problem with the prior art frame buffers relates to the circuitry by which data is taken from the array and transferred to the output display circuitry.
  • the circuitry requires a shift register output stage sufficient to hold an entire row of pixels on the display.
  • a row of pixel data is transferred into this shift register circuitry and shifted out to die display on a pixel by pixel basis.
  • a shift register sufficient to hold an entire row of pixels takes a large amount of space on the frame buffer. This space is space which is then not available to accomplish other, often more useful, techniques.
  • FIG. 3 there is illustrated a detailed block diagram of a frame buffer 50 designed in accordance widi the present invention while Figure 5 illustrates a method in accordance with the invention.
  • Figure 3 illustrates a circuit board upon which reside die various components of a frame buffer 50.
  • the frame buffer 50 includes a plurality of memory cells 53 such as field effect transistor devices arranged to provide a dynamic random access memory array 52.
  • the arrangement of the cells 53 constituting the array 52 is developed in accordance witii principals well known to those skilled in die art It is adapted to provide a sufficient number of addressable memory cells 5 1 in the array 52 to describe d e number of pixels to be presented on an output display device in a particular mode of operation.
  • the array 52 may include a total of thirty-two planes (only the first is illustrated in detail in Figure 3), each plane including 256 rows, each row including 1024 memory devices; such an arrangement allows the storage of color data sufficient to display thirty-two bit color in a 512 X 512 pixel display on a color output display terminal.
  • the frame buffer 50 may display both diirty-two bit and sixteen bit color modes as well as otiier modes well known to those skilled in d e art, the frame buffer 50 is particularly adapted for use with pixels displaying color in eight bit color modes.
  • the frame buffer 50 includes row and column decode circuitry for decoding the addresses furnished by a controller such as a central processor and selecting individual memory cells in each plane of the array 52 to define die various pixels which may be represented on an output display device.
  • the address decoding circuitry includes row decoding circuitry 54 and column decoding circuitry 56 by which individual memory cells 53 representing bits of individual pixels may be selected for reading and writing.
  • data conductors 58 which may be connected to a data bus to provide data to be utilized in die array 52.
  • thirty-two data conductors 58 are provided aldiough tiiis number will vary with die particular computer system. The number thirty-two matches die number of bits which are transferred to indicate the color of a single pixel of die large?' number of bits expected to be used by the display system in the most accurate color mode of operation.
  • each group of diirty-two bits defines one or more color values to be displayed at one or more pixel positions on die output display.
  • the diirty-two bits carried by die data conductors 58 in normal -> ?, mode may define four pixel positions on the display.
  • the diirty-two bits of die data conductors 58 carry information defining a single pixel position on die display.
  • one of die data conductors 58 of die bus is connected through an input data buffer to all of eight multiplexors 62 in each plane of the array.
  • the embodiment illustrated in Figure 3 is particularly adapted to be used in a system utilizing eight bit color modes; and, to this end, d e system utilizes eight individual multiplexors 62 in each plane of the frame buffer 50 for selecting particular write input data.
  • Each of tiiese multiplexors 62 has its output connected to one of eight tri-state write drivers 73 which furnishes an output signal via a write enable switch such as a transmission gate 71 on a conductor 66 connected to every eighth column of d e particular plane of d e array.
  • Each of the multiplexors 62 selects the source of die data to be transferred to die array 52 in each plane depending on die mode of operation selected. Thus, in normal mode, d e data bit is selected direcdy from the data conductor 58 for tiiat plane of die array. The bit is transferred from one of die multiplexors 62 by one of the eight write drivers 73 to a particular selected column and written to die memory cell 53 at that column and d e selected row.
  • thirty-two bits may be written from the bus conductors 58 (one to each plane) as one diirty-two bit pixel, two sixteen bit pixels, or four eight bit pixels, depending on die color mode in which the system is operating.
  • a mode control circuit 68 is provided to designate the particular mode of operation in which the frame buffer is to operate.
  • four control signals DSF0-DSF3 are furnished along with write enable and output enable signals. The combination of these signals produces the particular output mode control signals in a manner well known to those skilled in die prior art
  • a particular address is transferred on d e address bus to select a particular row and column.
  • the row address is furnished to die row decode circuitry 54 by a row address latch 51 on the falling edge of a row address strobe signal.
  • the row address causes power to be furnished to all of die memory cells 53 joined to die particular row of die array in each of the selected planes.
  • die value of each memory cell in the row is sensed by a sense amplifier 63 for each column of die array.
  • the sense amplifiers 63 are turned on, and each sense amplifier 63 drives d e value sensed back to refresh the memory cell 53 in the selected row.
  • die column address is transferred from a latch 57 and applied to die appropriate switches 67 of the column decode circuitry 56 to select the appropriate columns in each plane to be written.
  • the column address is ten bits. Of these ten bits, die higher valued seven bits CA3-9 of the column address are used to select a group of eight adjacent columns.
  • the normal mode write control signal at each of the multiplexors 62 causes the data signal furnished on die single conductor 58 associated witii tiiat plane to be transferred from the data input buffer by each of the eight multiplexors 62.
  • One of d e signals produced by die multiplexors 62 is amplified by a single one of the write drive amplifiers 73 and transferred to die addressed memory cell 53 in iat plane of the array.
  • the lower three bits CAO-2 of die column address from die latch 57 select the particular one of d e eight write drive amplifiers 73 which transfers the data bit to a single one of die columns. Since each of die conductors 58 associated with each plane of the array 52 carries an individual bit for die memory cell at die selected row and column, die pixel value (or values) will be transferred to die appropriate column and row position in each plane of the array.
  • the row and column addresses are transferred to the decode circuitry 54 and 56.
  • a row address is selected on the falling edge of the RAS signal; and the entire row of memory cells in each selected plane of the array 52 is refreshed.
  • the higher valued seven bits CA3-9 of die column address are applied to the appropriate switches 67 of d e column decode circuitry 56 to select die eight adjacent columns in each plane which have been addressed and are to be read.
  • the condition of the memory cells 53 in each of tiiese eight columns of each selected plane are sensed by a second set of output sense amplifiers 75.
  • die frame buffer 50 carries out the typical normal read and write modes of operation.
  • the frame buffer 50 also includes at least a pair of color value registers CO and Cl which are utilized to store color values which may be used in color block modes of operation described hereinafter in which a plurality of storage positions may be written simultaneously.
  • Each plane of the array includes a one bit register CO and a one bit register Cl for storing one bit of a color value. Since each plane includes one bit for each register, each register CO and Cl includes a total of thirty-two bits in the preferred embodiment Thus an entire eight bit color value may be stored in die registers CO and Cl residing on eight planes, an entire sixteen bit color value may be stored in the registers CO and Cl residing on sixteen planes, and an entire thirty-two bit color value may be stored in die registers CO and Cl of thirty-two planes of the frame buffer 50. With a thirty-two bit color register such as is shown, the color pattern for a particular eight bit color value may be repeated four times in each color register (similarly a sixteen bit color may be repeated twice).
  • the color registers CO and Cl may be selectively addressed so that they may be loaded by data furnished on die conductors 58 of the data bus; as may be seen, switches are provided in each cell plane to allow loading of die registers CO and Cl widi color value data from die data conductors 58.
  • the details of die color block registers and their use are described in die U.S. patent application Serial No. entided Apparatus For Providing Fast Multi-Color Storage In A Frame Buffer. Priem et al, filed on even date herewith.
  • the color registers CO and Cl provide color values which the multiplexors 62 may select for writing to the cells of the memory array instead of die data furnished on d e conductors 58.
  • the selection by die multiplexors 62 of color values from the registers CO, Cl or of pixel data from the conductors 58 depends on die particular color mode of operation, a value indicated by control signals furnished by die central processor or by an associated graphical accelerating device.
  • the data conductors 58 When a color block mode of operation is indicated by die control signals, the data conductors 58, rather tiian carrying pixel data, carry enabling signals to indicate pixel positions in the array 52 to which the color values held in die registers CO and Cl are to be written. These color values are initially loaded from die data conductors 58 of each array plane of the frame buffer 50 in response to a load color register control signal. Since two color registers CO and Cl are provided in die preferred embodiment, a total of four color block modes of operation are possible. These modes are referred to as color 0 mode, color 1 mode, color 0&1 mode, and color 1&0 mode. As will be seen, substantial time is saved with any of tiiese modes of operation simply through die lack of a requirement to load the color value registers for writing to each row of die display.
  • the control data appearing on the conductors 58 is sent to a pixel mask register 55.
  • the bits of the pixel mask register 55 are used in the manner illustrated in Figure 4 in each of the array planes to control all of the drivers 73 controlling transfer of data to a particular pixel. Since the example considered involves eight bit color and assuming diat die first eight columns have been selected by the column address, the bits defining die first pixel lie in the first column in the selected row and die first eight planes of that column.
  • the first pixel PI in the pixel mask register 55 controls die appropriate drivers 73 controlling the first column and die first eight planes to transfer the color to tiiese bit positions in the array from the color value register CO. Consequentiy, with one row and eight columns selected, a total of thirty-two eight bit color pixels may be written simultaneously with the value stored in the color value register CO.
  • a frame buffer 30 for a display which is 1024 X 780 pixels and eight bits deep, may be cleared approximately thirty-two times faster than individual pixels may be written one by one to die frame buffer 50.
  • This mode is also useful for clipping since a color value may be written to pixel positions inside a window area while the pixel positions outside diat window area are not enabled.
  • Color 1 mode is similar to color 0 mode except d at if a one value is transferred on a particular data conductor 58, tiien the value in the color register Cl is written to the storage positions which define die pixel addressed for that conductor 58.
  • the value in the color register Cl is also transferred to all otiier storage positions at addresses enabled by one values transferred on die data conductors 58. On die otiier hand, no color value is written to the pixel positions to which a zero is transferred on die data conductors.
  • die two color registers CO and Cl may be loaded prior to manipulating any portion of a window and are always available, a series of pixels (e.g., thirty-two) may be written and clipped in two accesses without any need to reload color registers. Background color may be written in a first access and foreground color written in a second access without any need to reload a color register between accesses.
  • the provision of the two color value registers allows a number of new methods of writing data to d e frame buffer to be practiced in addition die color modes described.
  • block modes are provided by which an entire row of pixels may be written from the color registers in one color with clipping or in two colors unclipped. These modes are referred to as block 256, block 512 and block 1024 modes and are described in detail in die U.S. patent application Serial No. , entitled Multiple Block Mode Operations In A Frame
  • die value on each data conductor determines the color value which is written to thirty-two adjacent eight bit pixel positions. This is accomplished by die column address selecting one quarter of the total of columns (256) in each plane of die array simultaneously. Then each of the pixels connected to each of these columns receives the single color value in a color value register designated by die value carried on d e data conductor in the particular color mode. It will be seen that in block 256 mode a total of thirty-two times thirty-two eight bit pixels (1024 pixels) are affected at once by each write access. This is a typical number of pixels in a row of a modern computer color monitor. Thus, each access of eight bit pixels in block 256 mode may write all of die pixels in a 1024 pixel row. It will be appreciated diat this mode may be used to very rapidly clear an entire screen or to write a pattern which varies in thirty-two bit blocks on the screen.
  • a second additional mode is referred to as block 512 mode.
  • each data conductor affects the value of data written to thirty-two adjacent sixteen bit pixel positions.
  • the column address selects a total of half the columns in each plane simultaneously.
  • This mode requires the increase in number of selection conductors, multiplexors 62, and otiier components discussed above to sixteen.
  • This mode is used witii the block 16 mode in the same manner that block 256 mode is used with block 8 mode to rapidly write to an entire row witiiin a clipped window area of the display.
  • a tiiird additional mode is referred to as block 1024 mode. In block 1024 mode, all of die columns in each plane are selected simultaneously by the column address.
  • each data conductor affects the value of data written to thirty-two adjacent thirty-two bit pixel positions.
  • This mode is used with die block 32 mode in die same manner that block 256 mode is used widi block 8 mode to rapidly write to an entire row within a clipped window area of the display.
  • Each of these modes provides useful functions in die same manner as does block 256 mode but for configurations of frame buffers storing data describing sixteen bit and thirty-two bit pixels.
  • the frame buffer 50 of Figure 3 includes output circuitry by which pixel data is shifted to an output display device (not shown in the figure).
  • This includes a an array of transmission gates 77 which is utilized to shift data eight bits at a time from each plane of d e array to an output shift register 80.
  • the shift register 80 in each plane includes a total of sixty-four bit positions.
  • the register totals 256 bytes in the diirty-two planes of the preferred embodiment, a value equivalent to one- fourth of a row on a display having 1024 pixel positions in a row.
  • the data in the register 80 is then shifted a bit at a time from each plane by anotiier multiplexor 82 to a circuitry controlling die display of the pixel data on an output display device. It will be recognized diat this shift register is substantially smaller than diat typically used at the output of a frame buffer and consequently uses much less circuit board area.
  • the frame buffer 50 also includes circuitry designed to provide an extremely rapid scrolling operation.
  • the scrolling operation is described in detail in U.S. patent application Serial No. , entided METHOD AND APPARATUS FOR
  • die data is first read from die array and tiien written back to die array to a new row without being removed from the frame buffer 50.
  • a scroll mode signal is initiated by the controlling circuitry (central processor or graphics accelerator); and an address is furnished to die row and column decode circuitry to designate the particular data to be scrolled.
  • the scroll mode may cause a particular row to be selected at die falling edge of a RAS signal as in normal mode of operation and die memory cells of at row to be refreshed.
  • the higher order bits of the column address are used to select eight adjacent columns of d e address.
  • the mode signal at die array of transmission gates 77 of each plane causes die data in the memory cells of each of the eight columns selected to be transferred to a first eight bit latch shown as latch 0 in the figure.
  • a next sequential address causes the data in the memory cells of each of die next eight columns to be selected and to be transferred to a second eight bit latch shown as latch 1 in the figure. This continues for two more read operations which select two more sets of eight memory cells in each plane and place d e results read in third and fourth eight bit latches latch 2 and latch 3.
  • each latch 0-3 is connected so diat its individual bits may be selected by a multiplexor 81 to be furnished to die multiplexors 62.
  • one of the latches 0-3 is illustrated with each of its bit positions furnishing input to each of the eight individual multiplexors 62 of at memory plane. This allows four sequential write operations to four consecutive addresses, taking approximately 180 ns., to write the data being scrolled back to die new row positions in the array 52 to which the row is addressed.
  • the scroll mode control signal causes the higher bits of the column address to select die appropriate eight adjacent columns in each write operation. The scroll mode control signal then selects all of the columns using the drivers 73 and the write enable switches 71.
  • each write back operation used in scrolling the values in each of the individual bit latches 0-3 are then driven onto the array by overdriving die sense amplifiers 63 to establish the new values at the selected memory positions in the appropriate cells of the array.
  • the total time required to read and write back the data to scroll 128 pixels is only 180 ns. while a row requires 1440 ns., approximately one-85th of the time required to scroll in prior art arrangements.
  • An additional facility of the invention allows it to clip pixel data to fit windows in which that data is stored at the same time diat scrolling is taking place. It will have been noted diat during any period in which scrolling is occu ⁇ ing, the conductors 58 on the data bus are not being used for the scrolling. By sending enabling signals on the data conductors 58 to die write enable gates 71 of each array, clipping may be accomplished.
  • a first data conductor 58 carries a zero indicating d at a write is not to occur and d at signal is applied to disable die transmission gates 71 connected to all of the conductors 66 (one in each plane of the array 52) affecting the bits of a particular pixel, then die bits in the particular latch bit position will not be written. Thus an entire pixel may be clipped. If all of the data conductors controlling pixel positions outside a window carry zero values, then the entire area outside a window may be clipped while the scrolling is occurring.

Abstract

A frame buffer (17) designed to be coupled to a data bus (12) and to an output display (18) in a computer system (Figure 1), the frame buffer (Frame 3) including an array of memory cells (52) for storing data indicating pixels to be displayed on the output display, address decoding apparatus (54 and 56) for controlling access to the array, the address decoding apparatus including column address decoding apparatus (56) for selecting groups of adjacent columns of the array, a plurality of apparatus for selectively writing to each of the columns of any of said groups of adjacent columns, a plurality of color value registers (C0 and C1), latching apparatus (57) for storing pixel data equivalent to a row of pixel data to be displayed on the output display, apparatus for writing pixel data from selected groups of adjacent columns of the array to the latching apparatus, and apparatus (58) for connecting either selected ones of the color value registers, the latches, or the data bus to the apparatus for selectively writing to each of the columns of any of said groups of adjacent columns.

Description

FRAME BUFFER SYSTEM DESIGNED FOR WINDOWING OPERATIONS
BACKGROUND OF THE INVENTION
Field Of The Invention
This invention relates to computer systems and, more particularly, to methods and apparatus for providing a frame buffer capable of receiving, manipulating and transferring data for display at a high rate of speed when used in a system displaying a plurality of applications simultaneously in windows on an output display device.
History Of The Prior Art
One of the significant problems involved in increasing the ability of desktop computers has been in finding ways to increase the rate at which information is transferred to an output display device. The various forms of data presentation which are presently available require that copious amounts of data be transferred. For example, if a computer output display monitor is operating in a color mode in which 1024 X 780 pixels are displayed on the screen and the mode is one in which thirty-two bits are used to define each pixel, then a total of over twenty-five millions bits of information must be transferred to the screen with each frame that is displayed. Typically, sixty frames are displayed each second so that over one and one-half billion bits must be transferred each second. This requires a very substantial amount of processing power. In general, the transfer of this data to the display slows the overall operation of the computer.
In order to speed the process of transferring data to the display, various accelerating circuitry has been devised. This circuitry is adapted to relieve the central processor of the computer of the need to accomplish many of the functions necessary to the transfer of data to the display. Essentially, these accelerators take over various operations which the central processor would normally be required to accomplish. For example, block transfers of data from one position on the screen to another require that each line of data on the screen being transferred be read and rewritten to a new line. Storing information within window areas of a display requires that data available for each window portion be clipped to fit within that window portion and not overwrite other portions of the display. Many other functions require the generation of various vectors when an image within a window on the display is cleared or moved. All of these operations require a substantial portion of the time available to a central processing unit. These repetitive sorts of functions may be accomplished by a graphics accelerator and relieve the central processor of the burden. In general, it has been found that if operations which handle a great number of pixels at once are mechanized by a graphics accelerator, then the greatest increase in display speed may be attained. This, of course, speeds the operations involved in graphical display.
A problem which has been discovered by designers of graphics accelerator circuitry is that a great deal of the speed improvement which is accomplished by the graphics accelerator circuitry is negated by the frame buffer circuitry into which the output of the graphics accelerator is loaded for ultimate display on an output display device. Typically, a frame buffer offers a sufficient amount of random access memory to store one frame of data to be displayed. However, transferring the data to and from the frame buffer is very slow because of the manner in which the frame buffers are constructed. Various improvements have been made to speed access in frame buffers. For example, two-ported VRAM has been substituted for DRAM so that information may be taken from the frame buffer while it is being loaded. A flash mode has been devised for allowing an entire row of a display to be written with a single color. This mode is useful when the entire display is being cleared but cannot provide clipping to limited areas and so is not useful when windows are displayed on the screen of an output display. Since the design of prior art frame buffers has produced a substantial bottle neck to rapid display of data in modern windowing systems, a new design of frame buffers allowing substantially increased display speed is desirable.
Summary Of The Invention
It is, therefore, an object of the present invention to provide a new design of frame buffer capable of rapidly handling the data transferred to it for display in a system which presents a plurality of applications in separate windows on an output display device.
It is another more specific object of the present invention to provide a new design of frame buffer capable of speeding the display of data by factors which are the order die magnitude of the prior art frame buffers. These and other objects of the present invention are realized in a frame buffer designed to be coupled to a data bus and to an output display in a computer system, the frame buffer including an array of memory cells for storing data indicating pixels to be displayed on the output display, address decoding apparatus for controlling access to the array, the address decoding apparatus including column address decoding apparatus for selecting groups of adjacent columns of the array, a plurality of apparatus for selectively writing to each of the columns of any of said groups of adjacent columns, a plurality of color value registers, latching apparatus for storing pixel data equivalent to a row of pixel data to be displayed on the output display, apparatus for writing pixel data from selected groups of adjacent columr - of the array to the latching apparatus, and apparatus for connecting either selected ones of the color value registers, the latches, or the data bus to the apparatus for selectively writing to each of the columns of any of said groups of adjacent columns.
These and other objects and features of die invention will be better understood by reference to the detailed description which follows taken together with the drawings in which like elements are referred to by like designations throughout the several views.
Brief Description Of The Drawings
Figure 1 is a block diagram illustrating a computer system including the present invention.
Figure 2 is a block diagram of a frame buffer designed in accordance with prior art
Figure 3 is a block diagram of a frame buffer designed in accordance with the present invention.
Figure 4 is a diagram illustrating operational details of a portion of the frame buffer of Figure 3.
Figure 5 is a flow chart illustrating a method in accordance with the invention.
Notation And Nomenclature
Some portions of the detailed descriptions which follow are presented in terms of symbolic representations of operations on data bits within a computer memory. These descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. The operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities.
Further, the manipulations performed are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. No such capability of a human operator is necessary or desirable in most cases in any of the operations described herein which form part of the present invention; the operations are machine operations. Useful machines for performing the operations of the present invention include general purpose digital computers or other similar devices. In all cases the distinction between the method operations in operating a computer and the method of computation itself should be borne in mind. The present invention relates to a method and apparatus for operating a computer in processing electrical or other (e.g. mechanical, chemical) physical signals to generate other desired physical signals.
Detailed Description Of The Invention
Referring now to Figure 1, there is illustrated a computer system 10. The system 10 includes a central processor 11 which carries out the various instructions provided to the computer 10 for its operations. The central processor 11 is joined to a bus 12 adapted to carry information to various components of the system 10. Joined to the bus 12 is main memory 13 which is typically constructed of dynamic random access memory arranged in a manner well known to those skilled in the prior art to store information being used by the central processor during the period in which power is provided to the system 10. Also joined to the bus 12 is read only memory 14 which may include various memory devices (such as electrically programmable read only memory devices (EPROM or similar devices)) well known to those skilled in the art which are adapted to retain memory condition in the absence of power to the system 10. The read only memory 14 typically stores various basic functions used by the processor 11 such as basic input/output processes and startup processes.
Also connected to the bus 12 are various peripheral components such as long term memory 16. The construction and operation of long term memory 16 (typically electro-mechanical hard disk drives) are well known to those skilled in the art. Also joined to die bus 12 is circuitry such as a frame buffer 17 to which data may be written that is to be transferred to an output device such as a monitor 18 for display. For the purposes of the present explanation, the frame buffer may be considered to include in addition to the various memory planes necessary to store information, various circuitry well known to those skilled in the art for controlling the scan of information to the output display.
Figure 2 illustrates a frame buffer 17 constructed in accordance with the prior art Typically, such a frame Duffer 17 includes a dynamic random access memory array designed to store information defining pixels on the output display. When the random access memory of a frame buffer 17 is accessed in its normal mode of operation, data is written to or read from the frame buffer 17 on the conductors of the data bus 12. When the frame buffer 17 is written, all of the data conductors of the bus transfer the binary data to be stored as pixel information. In a typical computer system having a thirty-two bit bus, thirty-two bits of information may be written on the bus and appear at thirty-two input pins to the frame buffer memory. This data may define one or more pixels depending upon the number of bits required to define a pixel in the particular display mode. For example, in an eight bit color mode of operation, each pixel displayed requires eight bits of data; and thirty-two bits of data on the data conductors of the bus are capable of defining four pixels in each individual access. Writing pixel data one (or four) pixels at a time is a relatively slow method of filling the frame buffer with data to be written to the display. This is, however, the usual mode of writing pixel data to the display. This normal mode is typically used in any process which varies the display on a pixel by pixel basis or to describe any graphical image which uses more than two colors in a window.
There are many operations which affect the display, however, which manipulate very large numbers of pixels and do not require that pixels be individually varied. These operations include, for example, clearing me entire display or a window of the display and similar operations. Because filling the frame buffer is so slow when each pixel is individually described on the data conductors, some prior art frame buffers also have apparatus which allows a mode of operation (referred to as "block mode") in which each of the data conductors controls access to four bits representing a pixel color value. This block mode allows data representing a color value to be written simultaneously to a plurality of individual pixel positions in the memory. In this block mode, the information written to the array on the data conductors is control information used to enable writing to memory positions representing particular pixel positions and to ignore other pixel positions.
The prior art frame buffer 17 of Figure 2 has a plurality of data input conductors 23 and a four bit color register 19. A four bit color value to be stored as pixel data in data positions in an array 20 of the frame buffer 17 is written into the color register 19. Data transferred to the frame buffer 17 on the data conductors 23 indicates the positions of pixels which are to be written and of tiiose pixels which are not to be written. For example, if a data conductor 23 carries a zero value, then the pixel position controlled by that conductor is not written. If a data conductor 23 carries a one value, then the four bit color value from the color register 19 is written into the pixel position. In this way, selected ones of a number of individual pixels may be written at once using the color value stored in the color register 19. This is a very useful manipulation if it is desired to accomplish manipulation of large areas using the same color. For example, with a thirty-two bit bus, one may rapidly clear a window by writing a background color to ti e entire window of a display in accesses of thirty-two pixels at a time. This mode also allows pixel data to be clipped to fit within a window since it allows control signals to write a color within a window and disable the writing of the color to pixel positions outside the window.
One problem with this prior art block mode of operation is that it can only be used with the outdated four bit color mode of operation. A greater problem is that prior art frame buffers are only capable of dealing with one color at a time although more than one pixel may be written simultaneously with that color using the block mode. On the other hand, the graphical accelerating devices and software which furnish pixel information to the frame buffer 17 typically manipulate two colors at once. Thus, while an entire screen may be cleared rapidly using this block mode, more advanced manipulations slow down the system operation. For example, when any information pattern is written to the frame buffer, a first background color must be placed in the color register; and the entire first row of the particular window must be cleared by writing the background color. Then the foreground color is placed in the color register, and the foreground pixels are written to the row. Then the background color is again placed in the color register, and die entire second row of the particular window is cleared. The background color is again replaced in the color register with the foreground color, and the foreground pixels are written for the second row. This continues until all of the rows of the window have been written with both of the colors necessary to the display.
In prior art frame buffers, each access of the frame buffer requires both a row address strobe (RAS) cycle of 120 nanoseconds and a column address strobe (CAS) cycle of 20 nanoseconds. This is true for accessing the frame buffer to load die color register and for accessing die memory positions in the frame buffer. Once the row address strobe has been furnished, a single column address cycle may overlap the row address strobe signal so that a total of 120 ns. is required for any particular operation. When a memory position is accessed, die row address is furnished on d e falling edge of the RAS cycle; and data is written or read on die falling edge of die CAS cycle. Once a RAS signal has been initiated, a plurality of pixels may be read or written in the same row as long as no other operation intervenes with only a CAS cycle required for each group of d irty-two pixels. However, since the same RAS/CAS sequence is used for operations other than reading and writing to me memory cells, to load the color register with background color takes a first 120 nanoseconds, writing the background color takes another 120 nanoseconds, reloading d e color register with foreground color takes another 120 nanoseconds, and writing the foreground color takes another 120 nanoseconds.
The time necessary to reload the color register twice on each row and die requirement to write twice to each of the thirty-two bit positions in each row together slow the operation signifϊcandy. For example, if it is desired to write to an area of a window in order to change die data presented, it is first necessary to change the value in the color register to the back ground color for the area, then write the background, tiien change the value in the color register again, and finally write the foreground color. One of the slowest operations performed in such a prior art frame buffer is the scrolling of data. In a scrolling operation rows of data are moved up or down on d e output display. Since the data describing die pixels which are displayed on an output display device is stored in a frame buffer, scrolling requires that the pixel data in the frame buffer describing a row of the display be read from the frame buffer by the central processor and written back to another position in the frame buffer. In a typical personal computer, thirty-two bits of data (one pixel in thirty- two bit color or four pixels in eight bit color) are read from die frame buffer simultaneously in an operation tiiat typically requires 140 nanoseconds; typically an extra 20 ns. is required to read when data must be taken off of the frame buffer chip. This is followed by an access to write the data back to the appropriate positions in the frame buffer, an access which again requires 120 nanoseconds. This pattern of reading and writing is continued until an entire row has been read and rewritten. Since a typical screen may hold rows of 1024 pixels, 140 nanoseconds plus 120 nanoseconds times 1024 pixels is required to scroll a single row of thirty-two bit color pixels on the display or one-fourth that time for eight bit pixels. Each line of text takes up approximately twelve rows of pixels so scrolling a line of text takes a very long time.
Another problem with the prior art frame buffers relates to the circuitry by which data is taken from the array and transferred to the output display circuitry. Typically, the circuitry requires a shift register output stage sufficient to hold an entire row of pixels on the display. A row of pixel data is transferred into this shift register circuitry and shifted out to die display on a pixel by pixel basis. A shift register sufficient to hold an entire row of pixels takes a large amount of space on the frame buffer. This space is space which is then not available to accomplish other, often more useful, techniques.
In addition to these problems of prior art frame buffers, a number of other problems exist which tend to slow the operation of displaying data.
Referring now to Figure 3, there is illustrated a detailed block diagram of a frame buffer 50 designed in accordance widi the present invention while Figure 5 illustrates a method in accordance with the invention. Figure 3 illustrates a circuit board upon which reside die various components of a frame buffer 50. The frame buffer 50 includes a plurality of memory cells 53 such as field effect transistor devices arranged to provide a dynamic random access memory array 52. The arrangement of the cells 53 constituting the array 52 is developed in accordance witii principals well known to those skilled in die art It is adapted to provide a sufficient number of addressable memory cells 51 in the array 52 to describe d e number of pixels to be presented on an output display device in a particular mode of operation. For example, the array 52 may include a total of thirty-two planes (only the first is illustrated in detail in Figure 3), each plane including 256 rows, each row including 1024 memory devices; such an arrangement allows the storage of color data sufficient to display thirty-two bit color in a 512 X 512 pixel display on a color output display terminal. Ald ough the frame buffer 50 may display both diirty-two bit and sixteen bit color modes as well as otiier modes well known to those skilled in d e art, the frame buffer 50 is particularly adapted for use with pixels displaying color in eight bit color modes.
In addition to die array 52, the frame buffer 50 includes row and column decode circuitry for decoding the addresses furnished by a controller such as a central processor and selecting individual memory cells in each plane of the array 52 to define die various pixels which may be represented on an output display device. The address decoding circuitry includes row decoding circuitry 54 and column decoding circuitry 56 by which individual memory cells 53 representing bits of individual pixels may be selected for reading and writing. Also included as a part of die frame buffer 50 are data conductors 58 which may be connected to a data bus to provide data to be utilized in die array 52. Typically, thirty-two data conductors 58 are provided aldiough tiiis number will vary with die particular computer system. The number thirty-two matches die number of bits which are transferred to indicate the color of a single pixel of die large?' number of bits expected to be used by the display system in the most accurate color mode of operation.
When data is written to die frame buffer 50 on the conductors 58 of die data bus in the normal mode of operation, each group of diirty-two bits defines one or more color values to be displayed at one or more pixel positions on die output display. Thus, when an output display is displaying data in an eight bit color mode, the diirty-two bits carried by die data conductors 58 in normal -> ?, mode may define four pixel positions on the display. On the other hand, whi display is displaying data in a diirty-two bit color mode, the diirty-two bits of die data conductors 58 carry information defining a single pixel position on die display. As may be seen, one of die data conductors 58 of die bus is connected through an input data buffer to all of eight multiplexors 62 in each plane of the array. The embodiment illustrated in Figure 3 is particularly adapted to be used in a system utilizing eight bit color modes; and, to this end, d e system utilizes eight individual multiplexors 62 in each plane of the frame buffer 50 for selecting particular write input data. Each of tiiese multiplexors 62 has its output connected to one of eight tri-state write drivers 73 which furnishes an output signal via a write enable switch such as a transmission gate 71 on a conductor 66 connected to every eighth column of d e particular plane of d e array. Each of the multiplexors 62 selects the source of die data to be transferred to die array 52 in each plane depending on die mode of operation selected. Thus, in normal mode, d e data bit is selected direcdy from the data conductor 58 for tiiat plane of die array. The bit is transferred from one of die multiplexors 62 by one of the eight write drivers 73 to a particular selected column and written to die memory cell 53 at that column and d e selected row. Since a bit may be written in each of thirty-two planes of the array, thirty-two bits may be written from the bus conductors 58 (one to each plane) as one diirty-two bit pixel, two sixteen bit pixels, or four eight bit pixels, depending on die color mode in which the system is operating.
As is shown in Figure 3, a mode control circuit 68 is provided to designate the particular mode of operation in which the frame buffer is to operate. To accomplish mode selection, four control signals DSF0-DSF3 are furnished along with write enable and output enable signals. The combination of these signals produces the particular output mode control signals in a manner well known to those skilled in die prior art
In a normal mode write operation as practiced in die prior art, a particular address is transferred on d e address bus to select a particular row and column. The row address is furnished to die row decode circuitry 54 by a row address latch 51 on the falling edge of a row address strobe signal. The row address causes power to be furnished to all of die memory cells 53 joined to die particular row of die array in each of the selected planes. Once power has been furnished to die appropriate row of die array, die value of each memory cell in the row is sensed by a sense amplifier 63 for each column of die array. The sense amplifiers 63 are turned on, and each sense amplifier 63 drives d e value sensed back to refresh the memory cell 53 in the selected row. At the falling edge of die CAS signal, die column address is transferred from a latch 57 and applied to die appropriate switches 67 of the column decode circuitry 56 to select the appropriate columns in each plane to be written. In embodiment of the frame buffer 50 illustrated, the column address is ten bits. Of these ten bits, die higher valued seven bits CA3-9 of the column address are used to select a group of eight adjacent columns. The normal mode write control signal at each of the multiplexors 62 causes the data signal furnished on die single conductor 58 associated witii tiiat plane to be transferred from the data input buffer by each of the eight multiplexors 62. One of d e signals produced by die multiplexors 62 is amplified by a single one of the write drive amplifiers 73 and transferred to die addressed memory cell 53 in iat plane of the array. The lower three bits CAO-2 of die column address from die latch 57 select the particular one of d e eight write drive amplifiers 73 which transfers the data bit to a single one of die columns. Since each of die conductors 58 associated with each plane of the array 52 carries an individual bit for die memory cell at die selected row and column, die pixel value (or values) will be transferred to die appropriate column and row position in each plane of the array.
In a similar manner, when a particular pixel value is to be read from the array 52 in the normal mode of operation, the row and column addresses are transferred to the decode circuitry 54 and 56. A row address is selected on the falling edge of the RAS signal; and the entire row of memory cells in each selected plane of the array 52 is refreshed. At die falling edge of d e CAS signal, the higher valued seven bits CA3-9 of die column address are applied to the appropriate switches 67 of d e column decode circuitry 56 to select die eight adjacent columns in each plane which have been addressed and are to be read. The condition of the memory cells 53 in each of tiiese eight columns of each selected plane are sensed by a second set of output sense amplifiers 75. The output of a particular one of the columns is selected by a multiplexor 79 in each plane which is controlled by die normal mode read signal and die value of die lower tiiree bits CAO-2 of the column address. This causes the condition of a particular memory cell 53 to be transferred to a particular one of the conductors 58 of die data bus associated witii d at plane of die array 52. Thus, as has been illustrated, die frame buffer 50 carries out the typical normal read and write modes of operation. The frame buffer 50 also includes at least a pair of color value registers CO and Cl which are utilized to store color values which may be used in color block modes of operation described hereinafter in which a plurality of storage positions may be written simultaneously. Each plane of the array includes a one bit register CO and a one bit register Cl for storing one bit of a color value. Since each plane includes one bit for each register, each register CO and Cl includes a total of thirty-two bits in the preferred embodiment Thus an entire eight bit color value may be stored in die registers CO and Cl residing on eight planes, an entire sixteen bit color value may be stored in the registers CO and Cl residing on sixteen planes, and an entire thirty-two bit color value may be stored in die registers CO and Cl of thirty-two planes of the frame buffer 50. With a thirty-two bit color register such as is shown, the color pattern for a particular eight bit color value may be repeated four times in each color register (similarly a sixteen bit color may be repeated twice). The color registers CO and Cl may be selectively addressed so that they may be loaded by data furnished on die conductors 58 of the data bus; as may be seen, switches are provided in each cell plane to allow loading of die registers CO and Cl widi color value data from die data conductors 58. The details of die color block registers and their use are described in die U.S. patent application Serial No. entided Apparatus For Providing Fast Multi-Color Storage In A Frame Buffer. Priem et al, filed on even date herewith.
The color registers CO and Cl provide color values which the multiplexors 62 may select for writing to the cells of the memory array instead of die data furnished on d e conductors 58. The selection by die multiplexors 62 of color values from the registers CO, Cl or of pixel data from the conductors 58 depends on die particular color mode of operation, a value indicated by control signals furnished by die central processor or by an associated graphical accelerating device.
When a color block mode of operation is indicated by die control signals, the data conductors 58, rather tiian carrying pixel data, carry enabling signals to indicate pixel positions in the array 52 to which the color values held in die registers CO and Cl are to be written. These color values are initially loaded from die data conductors 58 of each array plane of the frame buffer 50 in response to a load color register control signal. Since two color registers CO and Cl are provided in die preferred embodiment, a total of four color block modes of operation are possible. These modes are referred to as color 0 mode, color 1 mode, color 0&1 mode, and color 1&0 mode. As will be seen, substantial time is saved with any of tiiese modes of operation simply through die lack of a requirement to load the color value registers for writing to each row of die display.
In the color 0 mode of operation, if a control signal value of one is transferred on a particular data conductor 58, ? ' ^n the value in the color register CO is written to the storage positions controlled b; lat conductor 58. The value in the color register CO is also transferred to all other storage positions by data conductors 58 which transfer a control signal with a one value. On die oti er hand, no color value is written to the pixel positions controlled by a data conductor 58 on which a zero control value is transferred. Thus, thirty-two different pixel positions may be affected in a single simultaneous transfer; those positions which receive a one value are enabled to receive d e value in the color register CO while those which receive a zero value remain unchanged.
The manner in which this is accomplished will be illustrated in a case of eight bit color. Presuming that the color value register CO has been loaded witii a color value pattern of eight bits which is repeated four times in the thirty-two bits provided in diat register and diat die color value register Cl has been loaded with anodier color value pattern of eight bits which is repeated four times in the thirty- two bits provided in diat register, then a row and eight columns are selected by d e address on the address bus tiirough d e row and column address decode circuitry 54 and 56 in the manner described above. Assuming diat color block mode 0 is selected, all eight of the multiplexors 62 of each plane select die register CO as the source of color data for the array. Then the particular write drivers 73 are enabled in accordance witii d e enabling signals appearing on the conductors 58 of die data bus.
The control data appearing on the conductors 58 is sent to a pixel mask register 55. The bits of the pixel mask register 55 are used in the manner illustrated in Figure 4 in each of the array planes to control all of the drivers 73 controlling transfer of data to a particular pixel. Since the example considered involves eight bit color and assuming diat die first eight columns have been selected by the column address, the bits defining die first pixel lie in the first column in the selected row and die first eight planes of that column. The first pixel PI in the pixel mask register 55 controls die appropriate drivers 73 controlling the first column and die first eight planes to transfer the color to tiiese bit positions in the array from the color value register CO. Consequentiy, with one row and eight columns selected, a total of thirty-two eight bit color pixels may be written simultaneously with the value stored in the color value register CO.
This is a fast mode of operation similar to the four bit block mode used in prior art frame buffers and may be used to clear the screen very rapidly or to otherwise provide a single color to the window area. For example, a frame buffer 30 for a display which is 1024 X 780 pixels and eight bits deep, may be cleared approximately thirty-two times faster than individual pixels may be written one by one to die frame buffer 50. This mode is also useful for clipping since a color value may be written to pixel positions inside a window area while the pixel positions outside diat window area are not enabled.
Color 1 mode is similar to color 0 mode except d at if a one value is transferred on a particular data conductor 58, tiien the value in the color register Cl is written to the storage positions which define die pixel addressed for that conductor 58. The value in the color register Cl is also transferred to all otiier storage positions at addresses enabled by one values transferred on die data conductors 58. On die otiier hand, no color value is written to the pixel positions to which a zero is transferred on die data conductors.
As may be seen, since die two color registers CO and Cl may be loaded prior to manipulating any portion of a window and are always available, a series of pixels (e.g., thirty-two) may be written and clipped in two accesses without any need to reload color registers. Background color may be written in a first access and foreground color written in a second access without any need to reload a color register between accesses.
However, even faster writing is possible using the color modes 0&1 and 1&0 in those portions of the display in which clipping is unnecessary. As is pointed out in the co-pending patent application referred to above, most operations involved in writing to the display utilize two colors. Typically, a rendering chip (graphics accelerator) or the central processing unit provides a control signal indicating where clipping is necessary. In the absence of this signal, use of the modes 0&1 and 1&0 allow two colors to be written simultaneously to die frame buffer. In these modes a zero value on a data conductor 58 indicates diat a color value is to be written to the controlled pixels from one color value register while a one value on a data conductor 58 indicates diat a color value is to be written to die controlled pixels from the other color value register.
This is accomplished by combining the control value transferred on die data conductor 58 for each plane and stored in the pixel mask register 55 with d e color mode control signal to select the particular color register from which the color value is transferred by each of the multiplexors 62. For example, when in color mode 0&1 or 1&0, a zero in a bit position in the pixel mask register 55 causes a multiplexor 62 to select the color value stored in one color value register while a one in a bit position in the pixel mask register 55 causes a multiplexor 62 to select die color value stored in the other color value register. Then, the color mode control signals indicating mode 0&1 or 1&0 control all of die pixels selected to be written by the drivers 73 to die array. This allows two separate colors representing botii foreground and background to be written simultaneously to ti ose portions of a window area which do not require clipping.
The provision of the two color value registers allows a number of new methods of writing data to d e frame buffer to be practiced in addition die color modes described. For example, in addition to writing in groups of thirty-two pixels at once using the color registers CO and Cl, block modes are provided by which an entire row of pixels may be written from the color registers in one color with clipping or in two colors unclipped. These modes are referred to as block 256, block 512 and block 1024 modes and are described in detail in die U.S. patent application Serial No. , entitled Multiple Block Mode Operations In A Frame
Buffer System Designed For Windowing Operations. Priem et al, filed on even date herewith.
In block 256 mode, die value on each data conductor determines the color value which is written to thirty-two adjacent eight bit pixel positions. This is accomplished by die column address selecting one quarter of the total of columns (256) in each plane of die array simultaneously. Then each of the pixels connected to each of these columns receives the single color value in a color value register designated by die value carried on d e data conductor in the particular color mode. It will be seen that in block 256 mode a total of thirty-two times thirty-two eight bit pixels (1024 pixels) are affected at once by each write access. This is a typical number of pixels in a row of a modern computer color monitor. Thus, each access of eight bit pixels in block 256 mode may write all of die pixels in a 1024 pixel row. It will be appreciated diat this mode may be used to very rapidly clear an entire screen or to write a pattern which varies in thirty-two bit blocks on the screen.
However, in any case in which two colors are written to the frame buffer in the same access using the block 256 mode, the data conductors are not available to provide clipping signals. For tiiis reason, it is necessary to utilize the color 0 and color 1 modes at d e boundaries of a window in order to accomplish clipping of the window. These single color modes may be used at die window crossings at each side of each row containing a window to write a background color to the window edge on a first access and then to write a foreground color to the window edge on a second access. In a similar manner, because the granularity of the access is so large with the block 256 mode, it often must be used witii d e otiier modes to clip to a window edge. That is, since each control bit affects thirty-two pixels, block 256 mode can only select pixels to write and not write in adjacent groups of thirty-two pixels. Consequentiy, the block 256 mode must be used with block 8 mode to clip to an exact window edge.
A second additional mode is referred to as block 512 mode. In block 512 mode each data conductor affects the value of data written to thirty-two adjacent sixteen bit pixel positions. In this mode, the column address selects a total of half the columns in each plane simultaneously. This mode requires the increase in number of selection conductors, multiplexors 62, and otiier components discussed above to sixteen. This mode is used witii the block 16 mode in the same manner that block 256 mode is used with block 8 mode to rapidly write to an entire row witiiin a clipped window area of the display. A tiiird additional mode is referred to as block 1024 mode. In block 1024 mode, all of die columns in each plane are selected simultaneously by the column address. This mode requires the increase in number of selection conductors, multiplexors 62, and otiier components discussed above to thirty-two. In block 1024 mode, each data conductor affects the value of data written to thirty-two adjacent thirty-two bit pixel positions. This mode is used with die block 32 mode in die same manner that block 256 mode is used widi block 8 mode to rapidly write to an entire row within a clipped window area of the display. Each of these modes provides useful functions in die same manner as does block 256 mode but for configurations of frame buffers storing data describing sixteen bit and thirty-two bit pixels. In addition to die color values registers CO and Cl which provide fast operation, the frame buffer 50 of Figure 3 includes output circuitry by which pixel data is shifted to an output display device (not shown in the figure). This includes a an array of transmission gates 77 which is utilized to shift data eight bits at a time from each plane of d e array to an output shift register 80. The shift register 80 in each plane includes a total of sixty-four bit positions. Thus, the register totals 256 bytes in the diirty-two planes of the preferred embodiment, a value equivalent to one- fourth of a row on a display having 1024 pixel positions in a row. The data in the register 80 is then shifted a bit at a time from each plane by anotiier multiplexor 82 to a circuitry controlling die display of the pixel data on an output display device. It will be recognized diat this shift register is substantially smaller than diat typically used at the output of a frame buffer and consequently uses much less circuit board area.
The frame buffer 50 also includes circuitry designed to provide an extremely rapid scrolling operation. The scrolling operation is described in detail in U.S. patent application Serial No. , entided METHOD AND APPARATUS FOR
INCREASING THE RATE OF SCROLLING IN A FRAME BUFFER SYSTEM DESIGNED FOR WINDOWING OPERATIONS. Priem et al, filed on even date herewith. That scrolling operation is described, in general, at this point in order to explain the use of the various circuitry of die frame buffer.
In the scrolling operation, die data is first read from die array and tiien written back to die array to a new row without being removed from the frame buffer 50. In order to accomplish this, a scroll mode signal is initiated by the controlling circuitry (central processor or graphics accelerator); and an address is furnished to die row and column decode circuitry to designate the particular data to be scrolled. The scroll mode may cause a particular row to be selected at die falling edge of a RAS signal as in normal mode of operation and die memory cells of at row to be refreshed. The higher order bits of the column address are used to select eight adjacent columns of d e address. The mode signal at die array of transmission gates 77 of each plane causes die data in the memory cells of each of the eight columns selected to be transferred to a first eight bit latch shown as latch 0 in the figure. A next sequential address causes the data in the memory cells of each of die next eight columns to be selected and to be transferred to a second eight bit latch shown as latch 1 in the figure. This continues for two more read operations which select two more sets of eight memory cells in each plane and place d e results read in third and fourth eight bit latches latch 2 and latch 3.
Thus, in a set of four read operations taking only 180 ns (one RAS CAS of 120 ns. followed by tiiree CAS cycles of 20 ns. each), a total of thirty-two bits in each of thirty-two planes is read and stored in the Latches 0-3. This means that in four individual accesses requiring in total a single RAS signal and a four CAS signals taking 180 ns., a total of 128 eight bit pixels, may be stored in the latches 0-3. Thus, an entire row of pixels on a display 1024 pixels wide may be accessed and stored in a total period of eight times 180 ns. or 1440 ns.
As is shown in Figure 3, each latch 0-3 is connected so diat its individual bits may be selected by a multiplexor 81 to be furnished to die multiplexors 62. In the figure, one of the latches 0-3 is illustrated with each of its bit positions furnishing input to each of the eight individual multiplexors 62 of at memory plane. This allows four sequential write operations to four consecutive addresses, taking approximately 180 ns., to write the data being scrolled back to die new row positions in the array 52 to which the row is addressed. As witii die scroll read operation, the scroll mode control signal causes the higher bits of the column address to select die appropriate eight adjacent columns in each write operation. The scroll mode control signal then selects all of the columns using the drivers 73 and the write enable switches 71. In each write back operation used in scrolling, the values in each of the individual bit latches 0-3 are then driven onto the array by overdriving die sense amplifiers 63 to establish the new values at the selected memory positions in the appropriate cells of the array. Thus, the total time required to read and write back the data to scroll 128 pixels is only 180 ns. while a row requires 1440 ns., approximately one-85th of the time required to scroll in prior art arrangements.
An additional facility of the invention allows it to clip pixel data to fit windows in which that data is stored at the same time diat scrolling is taking place. It will have been noted diat during any period in which scrolling is occuπing, the conductors 58 on the data bus are not being used for the scrolling. By sending enabling signals on the data conductors 58 to die write enable gates 71 of each array, clipping may be accomplished. For example, if a first data conductor 58 carries a zero indicating d at a write is not to occur and d at signal is applied to disable die transmission gates 71 connected to all of the conductors 66 (one in each plane of the array 52) affecting the bits of a particular pixel, then die bits in the particular latch bit position will not be written. Thus an entire pixel may be clipped. If all of the data conductors controlling pixel positions outside a window carry zero values, then the entire area outside a window may be clipped while the scrolling is occurring.
Aldiough the present invention has been described in terms of a preferred embodiment it will be appreciated diat various modifications and alterations might be made by tiiose skilled in the art without departing from the spirit and scope of the invention. The invention should therefore be measured in terms of die claims which follow.

Claims

What Is Claimed Is:
Claim 1. A computer system comprising
a central processing unit
main memory,
a busing system including a data bus,
an output display, and
a frame buffer joining the busing system to the output display, the frame buffer comprising
an array of memory cells for storing data indicating pixels to be displayed on die output display,
access circuitry for selecting memory cells in the array,
first and second color value registers,
a plurality of latches,
circuitry for writing pixel data from the array to the latches, and
circuitry for writing pixel data selectively from the color value registers or from the latches to a plurality of storage positions in the array simultaneously.
Claim 2. A computer system as claimed in Claim 1 in which the circuitry for writing pixel data selectively from die color value registers or from the latches to a plurality of storage positions in the array simultaneously comprises
a plurality of multiplexors connected to each of the color registers and to the latches, and a source of control signals for causing the multiplexors to select pixel data from die color registers or from the latches.
Claim 3. A computer system as claimed in Claim 2 in which the source of control signals for causing the multiplexors to select pixel data from the color registers or from the latches comprises circuitry for transferring control signals on the data bus.
Claim 4. A computer system as claimed in Claim 1 further comprising circuitry for causing the multiplexors to select pixel data from die data bus.
Claim 5. A computer system as claimed in Claim 1 further comprising a shift register providing a number of storage positions substantially less than die number of pixels in a row of a display, and
circuitry for writing pixel data to die shift register from the array for presentation on an output display.
Claim 6. A computer system as claimed in Claim 1 in which the array of memory cells is arranged in a plurality of planes, and further comprising circuitry for selecting any of the plurality of planes for accessing.
Claim 7. A frame buffer designed to be coupled to a data bus and to an output display in a computer system, the frame buffer comprising
an array of memory cells for storing data indicating pixels to be displayed on die output display,
access circuitry for selecting memory cells in the array, first and second color value registers,
latching circuitry for storing pixel data equivalent to a plurality of pixels in a row of pixel data to be displayed on d e output display,
circuitry for writing pixel data from die array to the latching circuitry, and
circuitry for writing pixel data selectively from the color value registers or from the latching circuitry to a plurality of storage positions in the array simultaneously.
Claim 8. A frame buffer as claimed in Claim 7 in which the circuitry for writing pixel data selectively from die color value registers or from the latching circuitry to a plurality of storage positions in the array simultaneously comprises
a plurality of multiplexors connected to each of die color registers and to the latching circuitry, and
a source of control signals for causing the multiplexors to select pixel data from die color registers or from the latching circuitry.
Claim 9. A frame buffer as claimed in Claim 8 in which die source of control signals for causing the multiplexors to select pixel data from the color registers or from the latching circuitry comprises circuitry for transferring control signals on the data bus.
Claim 10. A frame buffer as claimed in Claim 7 further comprising circuitry for causing die multiplexors to select pixel data from the data bus.
Claim 11. A frame buffer as claimed in Claim 7 further comprising a shift register providing a number of storage positions substantially less tiian the number of pixels in a row of an output display, and circuitry for writing pixel data to die shift register from the array for presentation on an output display.
Claim 12. A frame buffer as claimed in Claim 7 in which the array of memory cells is arranged in a plurality of planes, and further comprising circuitry for selecting any of the plurality of planes for accessing.
Claim 13. A frame buffer designed to be coupled to a data bus and to an output display in a computer system, the frame buffer comprising
an array of memory cells for storing data indicating pixels to be displayed on die output display,
address decoding circuitry for controlling access to die array, die address decoding circuitry including column address decoding circuitry for selecting groups of adjacent columns of d e array,
a plurality of circuits for selectively writing to each of the columns of any of said groups of adjacent columns,
a plurality of color value registers,
latching circuitry for storing pixel data equivalent to a substantial portion of a row of pixel data to be displayed on die output display,
circuitry for writing pixel data from selected groups of adjacent columns of die array to d e latching circuitry, and
circuitry for connecting eitiier selected ones of die color value registers, the latching circuitry, or the data bus to ones of die circuits for selectively writing to each of the columns of any of said groups of adjacent columns.
Claim 14. A frame buffer as claimed in Claim 13 in which the circuitry for connecting eitiier selected ones of die color value registers, die latching circuitry, or the data bus to ones of die circuits for selectively writing to each of the columns of any of said groups of adjacent columns comprises a plurality of multiplexors.
Claim 15. A frame buffer as claimed in Claim 14 in which the circuitry for connecting either selected ones of the color value registers, the latching circuits, or the data bus to ones of die circuits for selectively writing to each of the columns of any of said groups of adjacent columns comprises circuitry for transferring control signals on the data bus, and
a register for storing control signals transferred on die data bus.
Claim 16. A frame buffer as claimed in Claim 13 further comprising a shift register providing a number of storage positions substantially less than die number of pixels in a row of an output display, and
circuitry for writing pixel data to the shift register from the array for presentation on an output display.
Claim 17. A metiiod for selecting data to be transferred to a frame buffer comprising the steps of:
storing data in a color value register to indicate a color value of pixels to be stored in a row of the frame buffer,
storing data in a plurality of latches to indicate a value of a plurality of pixels stored in a row of die frame buffer;
storing data in a pixel mask register to indicate pixels to which color values are to be written from a color value register for storage in the frame buffer;
providing data defining pixel values on die conductors of a data bus to indicate a color value of at least one pixel to be stored in die frame buffer; and providing a plurality of control signals to select for any operation of storing in the frame buffer from among the data in the color value register, the plurality of latches, and die conductors of the data bus die data to be stored in the frame buffer.
Claim 18. A method for selecting data to be transferred to a frame buffer as claimed in Claim 17 in which die step of providing control signals comprises
furnishing at least tiiree independent control signals to select different modes of operation.
Claim 19. A metiiod for selecting data to be transferred to a frame buffer as claimed in Claim 18 in which the step of providing a plurality of control signals to select for any operation of storing in the frame buffer from among the data in the color value register, the plurality of latches, and the conductors of d e data bus d e data to be stored in the frame buffer comprises the additional step of:
utilizing the data stored in the pixel mask register as additional control signals to indicate pixels to which color values are to be written from the color value register for storage in the frame buffer.
Claim 20. A method for selecting data to be transferred to a frame buffer as claimed in Claim 17 further comprising causing a plurality of multiplexors to select pixel data from among die data in the color value register, the plurality of latches, and d e conductors of d e data bus the data to be stored in die frame buffer.
PCT/US1994/012307 1993-10-29 1994-10-27 Frame buffer system designed for windowing operations WO1995012164A2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
EP94932066A EP0677190B1 (en) 1993-10-29 1994-10-27 Frame buffer system designed for windowing operations
JP7512813A JPH08505255A (en) 1993-10-29 1994-10-27 Frame buffer system for window operation
KR1019950702526A KR100335474B1 (en) 1993-10-29 1994-10-27 Frame Buffer System Designed by Window Influence
DE69432512T DE69432512T2 (en) 1993-10-29 1994-10-27 GRID BUFFER SYSTEM DESIGNED FOR WINDOW ENVIRONMENTAL OPERATIONS

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14533593A 1993-10-29 1993-10-29
US08/145,335 1993-10-29

Publications (2)

Publication Number Publication Date
WO1995012164A2 true WO1995012164A2 (en) 1995-05-04
WO1995012164A3 WO1995012164A3 (en) 1995-05-26

Family

ID=22512623

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1994/012307 WO1995012164A2 (en) 1993-10-29 1994-10-27 Frame buffer system designed for windowing operations

Country Status (6)

Country Link
US (1) US5528751A (en)
EP (1) EP0677190B1 (en)
JP (1) JPH08505255A (en)
KR (1) KR100335474B1 (en)
DE (1) DE69432512T2 (en)
WO (1) WO1995012164A2 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0680651A1 (en) * 1993-10-29 1995-11-08 Sun Microsystems, Inc. Pipeline read write operations in a high speed frame buffer system
EP2026323A3 (en) * 2007-08-14 2009-12-02 Seiko Epson Corporation Image processing circuit, display device, and printing device
EP2026324A3 (en) * 2007-08-14 2009-12-02 Seiko Epson Corporation Image processing circuit, display device, and printing device
US8159440B2 (en) 2003-06-30 2012-04-17 Advanced Micro Devices, Inc. Controller driver and display apparatus using the same

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH08505244A (en) * 1993-10-29 1996-06-04 サン・マイクロシステムズ・インコーポレーテッド Method and apparatus for increasing scroll rate in a frame buffer system designed for windowing
US5764963A (en) * 1995-07-07 1998-06-09 Rambus, Inc. Method and apparatus for performing maskable multiple color block writes
US6230235B1 (en) 1996-08-08 2001-05-08 Apache Systems, Inc. Address lookup DRAM aging
US6104658A (en) * 1996-08-08 2000-08-15 Neomagic Corporation Distributed DRAM refreshing
US5781200A (en) * 1996-08-08 1998-07-14 Ulsi Systems Tile memory mapping for increased throughput in a dual bank access DRAM
KR100300972B1 (en) * 1997-09-19 2001-09-03 윤종용 Texture mapping system and texture cache access method
US6542796B1 (en) * 2000-11-18 2003-04-01 Honeywell International Inc. Methods and apparatus for integrating, organizing, and accessing flight planning and other data on multifunction cockpit displays
TW514863B (en) * 2001-12-14 2002-12-21 Chi Mei Electronics Corp Overdrive system and method of liquid crystal display
CN100350448C (en) * 2001-12-27 2007-11-21 奇美电子股份有限公司 Overload drive system of liquid crystal display and its method
US7313764B1 (en) * 2003-03-06 2007-12-25 Apple Inc. Method and apparatus to accelerate scrolling for buffered windows
US7573491B2 (en) * 2004-04-02 2009-08-11 David Hartkop Method for formatting images for angle-specific viewing in a scanning aperture display device
EP1622111A1 (en) * 2004-07-28 2006-02-01 Deutsche Thomson-Brandt Gmbh Line driver circuit for active matrix display device
TWI416500B (en) * 2009-12-28 2013-11-21 Inventec Besta Co Ltd Display system and speeding method thereof

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4648077A (en) * 1985-01-22 1987-03-03 Texas Instruments Incorporated Video serial accessed memory with midline load
US4823302A (en) * 1987-01-30 1989-04-18 Rca Licensing Corporation Block oriented random access memory able to perform a data read, a data write and a data refresh operation in one block-access time
US5046023A (en) * 1987-10-06 1991-09-03 Hitachi, Ltd. Graphic processing system having bus connection control capable of high-speed parallel drawing processing in a frame buffer and a system memory

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4769637A (en) * 1985-11-26 1988-09-06 Digital Equipment Corporation Video display control circuit arrangement
US5170157A (en) * 1986-05-20 1992-12-08 Takatoshi Ishii Memory device for an image display apparatus having a serial port and independently operable data registers
JPS63204595A (en) * 1987-02-20 1988-08-24 Fujitsu Ltd Multi-plane video ram constituting system
US4807189A (en) * 1987-08-05 1989-02-21 Texas Instruments Incorporated Read/write memory having a multiple column select mode
US5305078A (en) * 1992-01-21 1994-04-19 Exfo Electro-Optical Engineering Inc. Measurement of attenuation of optical fibers using transmitted wavelength and power information
US5282177A (en) * 1992-04-08 1994-01-25 Micron Technology, Inc. Multiple register block write method and circuit for video DRAMs

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4648077A (en) * 1985-01-22 1987-03-03 Texas Instruments Incorporated Video serial accessed memory with midline load
US4823302A (en) * 1987-01-30 1989-04-18 Rca Licensing Corporation Block oriented random access memory able to perform a data read, a data write and a data refresh operation in one block-access time
US5046023A (en) * 1987-10-06 1991-09-03 Hitachi, Ltd. Graphic processing system having bus connection control capable of high-speed parallel drawing processing in a frame buffer and a system memory

Non-Patent Citations (1)

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

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0680651A1 (en) * 1993-10-29 1995-11-08 Sun Microsystems, Inc. Pipeline read write operations in a high speed frame buffer system
EP0680651A4 (en) * 1993-10-29 1996-11-13 Sun Microsystems Inc Pipeline read write operations in a high speed frame buffer system.
US8159440B2 (en) 2003-06-30 2012-04-17 Advanced Micro Devices, Inc. Controller driver and display apparatus using the same
EP2026323A3 (en) * 2007-08-14 2009-12-02 Seiko Epson Corporation Image processing circuit, display device, and printing device
EP2026324A3 (en) * 2007-08-14 2009-12-02 Seiko Epson Corporation Image processing circuit, display device, and printing device
CN101369343B (en) * 2007-08-14 2011-07-27 精工爱普生株式会社 Image processing circuit, display device and printing device
US8326083B2 (en) 2007-08-14 2012-12-04 Seiko Epson Corporation Image processing circuit, display device, and printing device

Also Published As

Publication number Publication date
EP0677190A4 (en) 1996-07-24
DE69432512T2 (en) 2004-04-22
KR100335474B1 (en) 2002-09-26
WO1995012164A3 (en) 1995-05-26
US5528751A (en) 1996-06-18
DE69432512D1 (en) 2003-05-22
KR950704741A (en) 1995-11-20
EP0677190A1 (en) 1995-10-18
JPH08505255A (en) 1996-06-04
EP0677190B1 (en) 2003-04-16

Similar Documents

Publication Publication Date Title
KR970005392B1 (en) Read/write memory having a multiple column select mode
US5528751A (en) Frame buffer system designed for windowing operations
US5442748A (en) Architecture of output switching circuitry for frame buffer
KR100279039B1 (en) Improved memory structure, device, system and how to use it
US5142276A (en) Method and apparatus for arranging access of vram to provide accelerated writing of vertical lines to an output display
JPH0677398B2 (en) Storage device
US5504855A (en) Method and apparatus for providing fast multi-color storage in a frame buffer
US5539430A (en) Pipelined read write operations in a high speed frame buffer system
US5805133A (en) Method and apparatus for increasing the rate of scrolling in a frame buffer system designed for windowing operations
US5654742A (en) Method and apparatus for providing operations affecting a frame buffer without a row address strobe cycle
US5533187A (en) Multiple block mode operations in a frame buffer system designed for windowing operations
JPH1092172A (en) Semiconductor memory device having data reading/ writing function
KR970000273B1 (en) Apparatus for processing korean alphabet on p.c.
KR100281250B1 (en) Memory architecture and devices, system and method utilizing the same

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 1994932066

Country of ref document: EP

AK Designated states

Kind code of ref document: A2

Designated state(s): JP KR

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

AK Designated states

Kind code of ref document: A3

Designated state(s): JP KR

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWP Wipo information: published in national office

Ref document number: 1994932066

Country of ref document: EP

WWG Wipo information: grant in national office

Ref document number: 1994932066

Country of ref document: EP