[go: up one dir, main page]

JP5310079B2 - Image drawing device - Google Patents

Image drawing device Download PDF

Info

Publication number
JP5310079B2
JP5310079B2 JP2009040328A JP2009040328A JP5310079B2 JP 5310079 B2 JP5310079 B2 JP 5310079B2 JP 2009040328 A JP2009040328 A JP 2009040328A JP 2009040328 A JP2009040328 A JP 2009040328A JP 5310079 B2 JP5310079 B2 JP 5310079B2
Authority
JP
Japan
Prior art keywords
cache
texture
texels
texel
coordinate
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2009040328A
Other languages
Japanese (ja)
Other versions
JP2010198156A (en
Inventor
雅之 中村
誠 安達
幸治 西河
元信 間宮
明宏 川原
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fujitsu Semiconductor Ltd
Original Assignee
Fujitsu Semiconductor Ltd
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 Fujitsu Semiconductor Ltd filed Critical Fujitsu Semiconductor Ltd
Priority to JP2009040328A priority Critical patent/JP5310079B2/en
Publication of JP2010198156A publication Critical patent/JP2010198156A/en
Application granted granted Critical
Publication of JP5310079B2 publication Critical patent/JP5310079B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Controls And Circuits For Display Device (AREA)
  • Image Input (AREA)
  • Image Generation (AREA)

Description

本発明は、画像描画装置に関する。   The present invention relates to an image drawing apparatus.

従来、コンピュータグラフィックスなどの画像描画装置では、描画対象の物体にテクスチャを貼り付けるように描画することで、より写実的な描画を行う。
図1は、テクスチャの描画処理のイメージを説明する図である。
2. Description of the Related Art Conventionally, an image drawing apparatus such as computer graphics performs more realistic drawing by drawing so that a texture is pasted on an object to be drawn.
FIG. 1 is a diagram for explaining an image of a texture drawing process.

描画対象には、表示装置の座標系が設定される。表示装置の表示単位は画素で、表示装置座標で画素の位置を示すように設定される。一方、テクスチャは、描画対象に貼り付ける画像データであり、画像データを構成する基本単位をテクセルという。テクセルは、テクスチャにローカルに設定されたテクセル座標によって指定される。図1の場合は、x−y座標が表示装置座標であり、例えば、x、yが整数値のときに画素の左下端の位置を示すように設定される。一方、u−v座標は、テクセル座標であり、テクスチャにローカルに設定された座標系で、例えば、u、vが整数値のときにテクセルの左下端の位置を示すように設定される。テクスチャは、拡大、縮小、回転などの操作を受けた後、描画対象に貼り付けられる。テクスチャを描画対象に貼り付ける場合には、テクセル座標を表示装置座標に変換して、テクセルのデータを画素に転写することによって行われる。   The coordinate system of the display device is set as the drawing target. The display unit of the display device is a pixel, and is set so as to indicate the position of the pixel in display device coordinates. On the other hand, texture is image data to be pasted on a drawing target, and a basic unit constituting the image data is called a texel. The texel is specified by the texel coordinates set locally in the texture. In the case of FIG. 1, the xy coordinates are display device coordinates, and are set to indicate the position of the lower left corner of the pixel when x and y are integer values, for example. On the other hand, the uv coordinate is a texel coordinate, and is set to indicate the position of the lower left corner of the texel when u and v are integer values, for example, in a coordinate system set locally in the texture. The texture is pasted on the drawing target after being subjected to operations such as enlargement, reduction, and rotation. When the texture is pasted on the drawing target, the texel coordinates are converted into display device coordinates, and the texel data is transferred to the pixels.

図2は、画像描画装置のブロック構成図である。
CPU11から発行された描画コマンドは、コマンド解釈部14により解釈され、頂点処理部15において、描画の基本単位である三角形の頂点の座標が生成される。ラスタライザー16では、頂点座標が指定された三角形を表示装置に表示するために、対応する部分のテクスチャのデータの取得を行う。ラスタライザー16では、テクセル座標が生成され、キャッシュ内テクセル有無判定部17、テクセル座標−メモリアドレス変換部18、テクセル座標−キャッシュマッピングアドレス変換部19に渡される。キャッシュ内テクセル有無判定部17は、キャッシュ22内に、テクセル座標で指定されたテクセルが存在するか否かを判定する。テクセル座標−メモリアドレス変換部18では、テクセル座標で示されるテクセルの情報が格納されているメモリ21内のアドレスを計算する。テクセル座標−キャッシュマッピングアドレス変換部19では、テクセル座標から、このテクセル座標で示されるテクセルが格納されているキャッシュ22内のアドレスを計算する。アドレス出力部20は、キャッシュ内テクセル有無判定部17の判定結果が、キャッシュ22内に該当するテクセルが存在しないという判定であった場合に、テクセル座標−メモリアドレス変換部18からのメモリアドレスをメモリ21に出力し、テクセルを読み出させる。また、キャッシュ内テクセル有無判定部17からは、当該テクセルがキャッシュ22に無い場合には書き込み指示、当該テクセルがキャッシュ22にある場合には読み出し指示が出力され、キャッシュ22に与えられる。テクセル座標−キャッシュマッピングアドレス変換部19からのアドレスは、キャッシュ22に与えられて、当該テクセルの読出しに使われる。このように、キャッシュ22に、必要なテクセルがある場合には、キャッシュ22からテクセルを読出し、無い場合には、メモリ21からキャッシュ22にテクセルを転送した後、キャッシュ22からテクセルを読み出すようにする。
FIG. 2 is a block diagram of the image drawing apparatus.
The drawing command issued from the CPU 11 is interpreted by the command interpretation unit 14, and the vertex processing unit 15 generates the coordinates of the triangle vertices that are the basic unit of drawing. The rasterizer 16 acquires the texture data of the corresponding portion in order to display the triangle with the vertex coordinates designated on the display device. In the rasterizer 16, texel coordinates are generated and passed to the cache texel presence / absence determination unit 17, the texel coordinate-memory address conversion unit 18, and the texel coordinate-cache mapping address conversion unit 19. The in-cache texel presence / absence determining unit 17 determines whether or not the texel designated by the texel coordinates exists in the cache 22. The texel coordinate-memory address conversion unit 18 calculates an address in the memory 21 in which texel information indicated by the texel coordinates is stored. The texel coordinate-cache mapping address conversion unit 19 calculates an address in the cache 22 in which the texel indicated by the texel coordinate is stored from the texel coordinate. The address output unit 20 stores the memory address from the texel coordinate-memory address conversion unit 18 when the determination result of the in-cache texel presence / absence determination unit 17 indicates that there is no corresponding texel in the cache 22. 21 to output the texel. In addition, the cache texel presence / absence determination unit 17 outputs a write instruction when the texel is not in the cache 22, and a read instruction when the texel is in the cache 22, and gives it to the cache 22. The address from the texel coordinate-cache mapping address conversion unit 19 is given to the cache 22 and used for reading the texel. As described above, when there is a necessary texel in the cache 22, the texel is read from the cache 22, and when there is no texel, the texel is transferred from the memory 21 to the cache 22 and then read out from the cache 22. .

読み出されたテクセルは、ピクセル処理部23に渡され、ピクセル処理部23において、貼り付けるべき表示装置座標が計算され、ピクセルデータとして使用される。ピクセルデータと表示装置座標は、メモリアドレス変換部24に渡され、表示メモリへの書き込みアドレスと、書き込みデータが生成される。表示メモリ12の生成された書き込みアドレスに書き込みデータが書き込まれ、表示装置13によって表示される。   The read texel is transferred to the pixel processing unit 23, where the display device coordinates to be pasted are calculated and used as pixel data. The pixel data and display device coordinates are transferred to the memory address conversion unit 24, and a write address and write data to the display memory are generated. Write data is written to the generated write address of the display memory 12 and displayed by the display device 13.

テクスチャは、容量の大きいメモリに格納され、必要なときに取り出し使用される。容量の大きいメモリ21は、画像描画装置の集積回路10とは分離されている。メモリ21と集積回路10との通信は、集積回路10の内部動作よりも遅い速度であるため、メモリ21と集積回路10との通信を減らすことが望まれる。そのために集積回路10内にテクスチャを保持するためのキャッシュ22を設ける。このときキャッシュ22の容量は、メモリの容量に比べ小さい容量となる。キャッシュのマッピング方式は、フルアソシアティブマッピングがもっともキャッシュ効率がよいが、コストが高いためダイレクトマッピングもしくは、その中間的なNウェイセットアソシアティブマッピングが使用される。   Textures are stored in a large memory and are retrieved and used when needed. The large capacity memory 21 is separated from the integrated circuit 10 of the image drawing apparatus. Since the communication between the memory 21 and the integrated circuit 10 is slower than the internal operation of the integrated circuit 10, it is desired to reduce the communication between the memory 21 and the integrated circuit 10. For this purpose, a cache 22 for holding the texture is provided in the integrated circuit 10. At this time, the capacity of the cache 22 is smaller than the capacity of the memory. As a cache mapping method, full associative mapping is most efficient in cache, but direct mapping or intermediate N-way set associative mapping is used because of high cost.

図3は、2ウェイセットアソシエイティブマッピングを説明する図である。
一般に、Nウェイセットアソシエイティブマッピングでは、キャッシュをN個のウェイに分割するが、ここでは、2ウェイセットアソシエイティブマッピングについて説明する。図3では、キャッシュにウェイ0とウェイ1が設けられている。FIFO方式のキャッシュの場合、外部メモリからデータを転送するときには、2つのウェイを交互に利用する。1回目の転送では、ウェイ0にデータを転送し、2回目の転送では、ウェイ1にデータを転送する。3回目の転送では、FIFO方式であるので、古いほうのデータであるウェイ0のデータを上書きするよう、データをウェイ0に転送する。4回目の転送では、ウェイ1にデータを転送する。
FIG. 3 is a diagram illustrating 2-way set associative mapping.
In general, in N-way set associative mapping, a cache is divided into N ways. Here, 2-way set associative mapping will be described. In FIG. 3, way 0 and way 1 are provided in the cache. In the case of a FIFO cache, two ways are used alternately when transferring data from an external memory. In the first transfer, data is transferred to way 0, and in the second transfer, data is transferred to way 1. Since the third transfer is based on the FIFO method, the data is transferred to way 0 so as to overwrite the data of way 0 which is the older data. In the fourth transfer, data is transferred to way 1.

テクスチャ内のテクセル位置を表すテクセル座標をマッピングのためのキャッシュマッピングアドレスに変換する。変換はテクセル座標がマッピング位置を示す方法(例えば、特許文献1参照)が低コストであり使用されている。なお、画像描画装置を使用するときは、予めテクセル座標をメモリアドレスに変換し、テクスチャをメモリに格納する。   The texel coordinates representing the texel position in the texture are converted into a cache mapping address for mapping. For conversion, a method in which texel coordinates indicate a mapping position (for example, see Patent Document 1) is low-cost and used. When the image drawing apparatus is used, texel coordinates are converted into memory addresses in advance, and textures are stored in the memory.

図4は、u座標方向4テクセルとv座標方向4テクセルの計16テクセルをマッピング可能なダイレクトマッピングのキャッシュの例を示す図である。
テクスチャを1ワード1テクセルのキャッシュへマッピングする例である。図4の場合、ワード0からワード15の16ワードが格納可能となっている。1ワード1テクセルなので、16テクセルの格納が可能である。図4の上の図は、テクスチャがテクセルからなっている様子を示しており、テクセル0からテクセル15までが、16x16のブロックに示されている。この16x16のブロックのテクセルを、16ワードのキャッシュに、テクセル番号が0から順に、格納する。この16x16のブロックに含まれていないテクセルをキャッシュに格納する場合には、所望のテクセルを含む16x16ブロックを指定して、16テクセル分キャッシュに読み込む。すなわち、図4上に記載されているように、テクスチャをテクセル0〜15の16x16ブロックに分割し、このブロック単位で、キャッシュに読み込むようにする。
FIG. 4 is a diagram illustrating an example of a direct mapping cache capable of mapping a total of 16 texels of 4 texels in the u coordinate direction and 4 texels in the v coordinate direction.
It is an example which maps a texture to the cache of 1 word 1 texel. In the case of FIG. 4, 16 words from word 0 to word 15 can be stored. Since one word is one texel, 16 texels can be stored. The upper diagram in FIG. 4 shows the texture made of texels, and texel 0 to texel 15 are shown in a 16 × 16 block. The texels of this 16x16 block are stored in a 16-word cache in order from texel number 0. When storing texels not included in the 16x16 block in the cache, the 16x16 block including the desired texel is designated and read into the cache for 16 texels. That is, as described in FIG. 4, the texture is divided into 16 × 16 blocks of texels 0 to 15 and read into the cache in units of these blocks.

図5は、図4の例におけるテクセル座標からキャッシュマッピングアドレスへの変換回路の回路図である。
図5の回路では、テクセル座標uとvの下位2ビット分の2本の信号線を使用する。テクセル座標uの最下位の信号線の信号は、キャッシュマッピングアドレスの最下位ビットであるアドレス[0]とする。テクセル座標uの2番目の信号線の信号は、キャッシュマッピングアドレスの下から2番目のビットであるアドレス[1]とする。テクセル座標vの最下位の信号線の信号は、キャッシュマッピングアドレスの下から3番目のアドレス[2]とする。テクセル座標vの2番目の信号線の信号は、キャッシュマッピングアドレスの下から4番目のアドレス[3]とする。
FIG. 5 is a circuit diagram of a conversion circuit from texel coordinates to a cache mapping address in the example of FIG.
In the circuit of FIG. 5, two signal lines for the lower 2 bits of the texel coordinates u and v are used. The signal on the lowest signal line of the texel coordinate u is address [0] which is the least significant bit of the cache mapping address. The signal on the second signal line at the texel coordinate u is address [1], which is the second bit from the bottom of the cache mapping address. The signal of the lowest signal line of the texel coordinate v is the third address [2] from the bottom of the cache mapping address. The signal on the second signal line of the texel coordinate v is the fourth address [3] from the bottom of the cache mapping address.

図6は、図5の回路の動作を図示したものである。
キャッシュメモリが、テクセル座標(0,0)〜(3,3)の矩形を格納するとする。その場合の順番は、
テクセル座標(0,0)をアドレス0に格納
テクセル座標(1,0)をアドレス1に格納
テクセル座標(2,0)をアドレス2に格納
テクセル座標(3,0)をアドレス3に格納
・・・
テクセル座標(3,3)をアドレス15に格納
となり、これを式で表すと、
アドレス=v*4+uとなる。
FIG. 6 illustrates the operation of the circuit of FIG.
Assume that the cache memory stores rectangles having texel coordinates (0,0) to (3,3). In that case, the order is
Store texel coordinate (0,0) at address 0 Store texel coordinate (1,0) at address 1 Store texel coordinate (2,0) at address 2 Store texel coordinate (3,0) at address 3・
The texel coordinates (3, 3) are stored at address 15, and this is expressed by an equation:
Address = v * 4 + u.

この式の意味は、テクセル座標vのビットを2ビット分高位にシフトし、uと加算するということである。したがって、キャッシュマッピングアドレスは、上位2ビットがvで、下位2ビットがuとなる4ビットの値となる。   The meaning of this expression is that the bit of the texel coordinate v is shifted to the high order by 2 bits and added to u. Therefore, the cache mapping address is a 4-bit value in which the upper 2 bits are v and the lower 2 bits are u.

また、特許文献2には、ピクセル座標をメモリ座標に変換する技術が開示されている。   Patent Document 2 discloses a technique for converting pixel coordinates into memory coordinates.

特表2002−504251号公報Japanese translation of PCT publication No. 2002-504251 特開平3−292575号公報JP-A-3-292575

図7は、従来の問題点を説明する図である。
今、取得したいテクスチャが横方向の一直線上にあるとする。この場合、(1)のブロックをキャッシュへ読み込んで、テクスチャ0〜3をピクセル処理部に送り、次に、(2)のブロック、その次に(3)のブロックをキャッシュへ読み込み、テクスチャ0〜3をピクセル処理部に送る。したがって、使用するのは、常にテクスチャ0〜3のみであり、キャッシュのワード0〜3しか使われない。
FIG. 7 is a diagram for explaining a conventional problem.
Assume that the texture to be acquired is on a straight line in the horizontal direction. In this case, the block of (1) is read into the cache, the textures 0 to 3 are sent to the pixel processing unit, the block of (2) and then the block of (3) are read into the cache, and the textures 0 to 0 are read. 3 is sent to the pixel processing unit. Therefore, only the textures 0 to 3 are always used, and only the cache words 0 to 3 are used.

すなわち、実際描画する場合に必要とするテクセルはテクスチャ内に一直線上にあり、メモリから取得しキャッシュへマッピングした場合、キャッシュの一部分しか使用されず、(1)のブロックから、(2)、(3)のブロックというように頻繁に上書きが発生し、描画速度が遅いという問題を生じていた。   That is, the texels required for actual drawing are in a straight line in the texture. When the texels are acquired from the memory and mapped to the cache, only a part of the cache is used. From the block (1), (2), ( As in the block 3), overwriting frequently occurred and the drawing speed was slow.

本発明の課題は、キャッシュ効率を向上させ描画速度の速い画像描画装置を提供することである。   An object of the present invention is to provide an image drawing apparatus that improves cache efficiency and has a high drawing speed.

本発明の画像描画装置は、複数のテクセルからなるテクスチャを貼り付けることにより画像を描画する画像描画装置において、テクスチャを格納するメモリと、貼り付けに使用されるテクスチャを、複数のテクスチャ領域に分割してキャッシュマッピングアドレスを割り当て、格納するキャッシュと、分割されたテクスチャ領域の境界に隣接するテクスチャ領域は、異なるキャッシュマッピングアドレスが割り当てられたテクスチャ領域となるように、テクセル座標をキャッシュマッピングアドレスに変換する変換回路と、該キャッシュからテクセルを取得し表示装置の座標系で描画を行う描画回路とを備える。   The image drawing apparatus of the present invention is an image drawing apparatus that draws an image by pasting a texture composed of a plurality of texels. The cache mapping address is assigned and stored, and the texture area adjacent to the boundary of the divided texture area is converted to the cache mapping address so that the texture area is assigned with a different cache mapping address. And a drawing circuit that obtains texels from the cache and performs drawing in the coordinate system of the display device.

本発明によれば、キャッシュ効率を向上させ描画速度の速い画像描画装置を提供することができる。   ADVANTAGE OF THE INVENTION According to this invention, cache efficiency can be improved and the image drawing apparatus with a high drawing speed can be provided.

テクスチャの描画処理のイメージを説明する図である。It is a figure explaining the image of the drawing process of a texture. 画像描画装置のブロック構成図である。It is a block block diagram of an image drawing apparatus. 2ウェイセットアソシエイティブマッピングを説明する図である。It is a figure explaining 2 way set associative mapping. u座標方向4テクセルとv座標方向4テクセルの計16テクセルをマッピング可能なダイレクトマッピングのキャッシュの例を示す図である。It is a figure which shows the example of the cache of the direct mapping which can map a total of 16 texels of u coordinate direction 4 texels and v coordinate direction 4 texels. 図4の例におけるテクセル座標からキャッシュマッピングアドレスへの変換回路の回路図である。FIG. 5 is a circuit diagram of a conversion circuit from texel coordinates to a cache mapping address in the example of FIG. 4. 図5の回路の動作を示す図である。It is a figure which shows operation | movement of the circuit of FIG. 従来の問題点を説明する図である。It is a figure explaining the conventional problem. 本発明のテクセル座標とキャッシュマッピングアドレスの変換を示した図である。It is the figure which showed conversion of the texel coordinate and cache mapping address of this invention. 本発明の実施形態のキャッシュマッピングアドレス変換の回路図である。It is a circuit diagram of cache mapping address conversion of an embodiment of the present invention. 本発明の他の実施形態を説明する図である。It is a figure explaining other embodiment of this invention. 図10の実施形態のキャッシュマッピングアドレス変換の回路図である。FIG. 11 is a circuit diagram of cache mapping address conversion in the embodiment of FIG. 10.

本発明の画像描画装置は、テクスチャをマッピングするメモリと、複数の領域に分割されたキャッシュと、テクセル座標をキャッシュマッピングアドレスへ変換時に複数に分割されたキャッシュ領域の境界(左右の接辺のある部分)は必ず異なる領域となる変換回路とキャッシュからテクセルを取得し画像描画を行う回路を特徴とするものである。   The image drawing apparatus of the present invention includes a memory for mapping texture, a cache divided into a plurality of areas, and a boundary between cache areas divided into a plurality of areas when converting texel coordinates to a cache mapping address (with left and right tangents). (Part) is characterized by a conversion circuit that is always a different area and a circuit that obtains a texel from a cache and draws an image.

図8は、本発明のテクセル座標とキャッシュマッピングアドレスの変換を示した図である。
図8では、u座標方向4テクセルとv座標方向4テクセルの計16テクセルをマッピング可能なダイレクトマッピングのキャッシュの例を示している。テクスチャ内の数値はキャッシュのマッピング位置を示している。テクスチャを複数の領域に分割するためキャッシュマッピングの0,1,2,3をグループA、4,5,6,7をグループB、8,9,10,11をグループC、12,13,14,15をグループDと定義する。テクセルのキャッシュマッピングは、グループAの境界(接辺)にグループB,C,Dのいずれかを配置することとする。グループBの境界(接辺)にグループA,C,Dのいずれかを配置することとする。グループCの境界(接辺)にグループA,B,Dのいずれかを配置することとする。グループDの境界(接辺)にグループA,B,Cのいずれかを配置することとする。図8は、この条件に一致するように配置した例である。
FIG. 8 is a diagram showing conversion of texel coordinates and cache mapping addresses according to the present invention.
FIG. 8 shows an example of a direct mapping cache capable of mapping a total of 16 texels of 4 texels in the u coordinate direction and 4 texels in the v coordinate direction. The numerical value in the texture indicates the cache mapping position. In order to divide the texture into a plurality of areas, 0, 1, 2, and 3 of the cache mapping are group A, 4, 5, 6, and 7 are group B, 8, 9, 10, and 11 are groups C, 12, 13, and 14, respectively. , 15 is defined as group D. In the texel cache mapping, any one of groups B, C, and D is arranged at the boundary (tangent side) of group A. One of the groups A, C, and D is arranged at the boundary (tangent side) of the group B. One of the groups A, B, and D is arranged on the boundary (tangent side) of the group C. One of groups A, B, and C is arranged at the boundary (tangent side) of group D. FIG. 8 shows an example in which these are arranged so as to meet this condition.

図8のように、取得したいテクスチャが、横方向の一直線であるとする。キャッシュにテクスチャを読み込む場合、16x16のブロック単位で読み込むのではなく、取得したいテクスチャを直接読み込むようにする。取得したい直線上には、テクスチャ0〜3、テクスチャ8〜11が配列され、以後、この繰り返しとなる例が示されている。16x16のブロックのテクスチャ0〜15に、キャッシュのワード0〜15が割り当てられているが、このブロックを読み込むのではなく、テクスチャ0〜3とその左隣のテクスチャ8〜11を読み込むようにする。このようにしても、テクスチャ0〜3が割り当てられるキャッシュのアドレス位置は、ワード0〜3であり、テクスチャ8〜11には、ワード8〜11が割り当てられるので、キャッシュ内で、同じワードに2つのデータを書き込むようなことは起こらない。従来の場合は、横方向の直線を読み込もうとした場合、16x16のブロックごとに、同じワードがテクスチャに割り当てられていた。したがって、図7のように、ワード0〜3が不要に上書きされないように、テクスチャ0〜3を順次、前の処理が終わってから読み込む必要があった。しかし、図8のように、テクスチャに割り振るキャッシュのワードを隣り合う16x16ブロックの間で切り替えることにより、ブロックをまたいで、テクスチャを読み込むことが出来るようになる。これにより、キャッシュの格納領域もより使用率が高まる。図8では、2つの16x16ブロックごとに、同じキャッシュアドレスの割り当てが繰り返されるようになっているが、3つのブロックごと、あるいは、4つのブロックにわたって、隣接するテクスチャグループが異なるようにすることにより、よりキャッシュの使用率が高まると共に、メモリからテクスチャを読み込みキャッシュへ上書きを行う頻度を少なくすることが出来る。   As shown in FIG. 8, it is assumed that the texture to be acquired is a straight line in the horizontal direction. When the texture is read into the cache, the texture to be acquired is directly read instead of being read in units of 16 × 16 blocks. Textures 0 to 3 and textures 8 to 11 are arranged on the straight line to be acquired, and thereafter, an example in which this is repeated is shown. The cache words 0 to 15 are assigned to the textures 0 to 15 of the 16 × 16 block, but instead of reading this block, the textures 0 to 3 and the textures 8 to 11 adjacent to the left are read. Even in this case, the address positions of the cache to which the textures 0 to 3 are assigned are the words 0 to 3, and the words 8 to 11 are assigned to the textures 8 to 11, so that the same word is set to 2 in the cache. There is no such thing as writing one piece of data. In the conventional case, when trying to read a horizontal straight line, the same word is assigned to the texture for each 16 × 16 block. Therefore, as shown in FIG. 7, it is necessary to sequentially read the textures 0 to 3 after the previous processing is finished so that the words 0 to 3 are not overwritten unnecessarily. However, as shown in FIG. 8, by switching the cache word allocated to the texture between adjacent 16 × 16 blocks, the texture can be read across the blocks. This further increases the usage rate of the cache storage area. In FIG. 8, the same cache address assignment is repeated every two 16 × 16 blocks, but by making adjacent texture groups different every three blocks or across four blocks, As the cache usage rate increases, the texture is read from the memory and overwritten in the cache can be reduced.

図8は、u座標方向4テクセルとv座標方向4テクセルの計16テクセルをマッピング可能なダイレクトマッピングのキャッシュの例を示したものであるがキャッシュの容量によってu座標方向、v座標方向ともにテクセル数を増やすことが可能である。   FIG. 8 shows an example of a direct mapping cache capable of mapping a total of 16 texels of 4 texels in the u coordinate direction and 4 texels in the v coordinate direction, but the number of texels in both the u coordinate direction and the v coordinate direction depending on the capacity of the cache. Can be increased.

また、テクスチャ内の数値は1テクセルに割り当てているが、キャッシュ容量が大きい場合、テクスチャ内の数値は複数テクセルに割り当てることもできる。例えば、キャッシュマッピング位置0には4テクセルマッピングするということが可能である。   The numerical value in the texture is assigned to one texel. However, if the cache capacity is large, the numerical value in the texture can be assigned to a plurality of texels. For example, it is possible to map 4 texels at the cache mapping position 0.

更に、上記実施形態は、ダイレクトマッピングの例であるが、Nウェイセットアソシアティブにおいても1つのウェイ内ではダイレクトマッピングであるため、上記実施形態を適用可能である。   Furthermore, although the said embodiment is an example of direct mapping, since it is direct mapping within one way also in N way set associative, the said embodiment is applicable.

図9は、本発明の実施形態のキャッシュマッピングアドレス変換の回路図である。
図9の回路においては、図8のキャッシュマッピングを実現する。テクセル座標uは、下位3ビット、すなわち、最下位ビットu[0]、下から2番目のビットu[1]、下から3番目のビットu[2]を使用する。テクセル座標vは、下位2ビット、すなわち、最下位ビットv[0]、下から2番目のビットv[1]を使用する。u[0]と、u[1]は、そのまま、キャッシュマッピングアドレスの下位2ビット、すなわち、アドレス[0]、アドレス[1]とする。すなわち、テクセルが横方向に4つ並んでいる場合には、連続したキャッシュマッピングアドレスとする意味である。テクセル座標v[0]は、そのまま、キャッシュマッピングアドレスの3ビット目、アドレス[2]とする。これは、テクセルが、2列上下に並んでいる場合には、そのままマッピングする意味である。テクセル座標uの3ビット目、u[2]と、テクセル座標vの2ビット目、v[1]は、XOR回路30に入力される。これは、テクセル座標vが1変化する、すなわち、テクセル座標vが0、1の場合と、2、3の場合とで、キャッシュマッピングアドレスのアドレス[3]を切り替える意味である。同様に、テクセル座標u[2]が変化する、すなわち、テクセル座標が、8個変化するごとに、キャッシュマッピングアドレス[3]を切り替える意味である。すなわち、u[2]が同じ場合には、v[1]が1変化する、すなわち、上に4つ行くと、アドレス[3]が元に戻る、すなわち、キャッシュマッピングのアドレスが元に戻ることを意味する。テクセル座標u[3]が変化すると、すなわち、横に8個進むと、キャッシュマッピングアドレスが元に戻ることを意味する。
以上により、図8のテクセル座標−キャッシュマッピングアドレス変換が実現される。
FIG. 9 is a circuit diagram of cache mapping address conversion according to the embodiment of this invention.
In the circuit of FIG. 9, the cache mapping of FIG. 8 is realized. The texel coordinate u uses the lower 3 bits, that is, the least significant bit u [0], the second bit u [1] from the bottom, and the third bit u [2] from the bottom. The texel coordinate v uses the lower 2 bits, that is, the least significant bit v [0] and the second bit v [1] from the bottom. u [0] and u [1] are directly used as the lower 2 bits of the cache mapping address, that is, address [0] and address [1]. That is, when four texels are arranged in the horizontal direction, this means that consecutive cache mapping addresses are used. The texel coordinate v [0] is directly used as the third bit of the cache mapping address, address [2]. This means that when texels are arranged in two rows, the mapping is performed as it is. The third bit u [2] of the texel coordinate u and the second bit v [1] of the texel coordinate v are input to the XOR circuit 30. This means that the texel coordinate v changes by 1, that is, the address [3] of the cache mapping address is switched between when the texel coordinate v is 0, 1 and when it is 2, 3. Similarly, this means that the cache mapping address [3] is switched every time the texel coordinates u [2] change, that is, every eight texel coordinates change. That is, when u [2] is the same, v [1] changes by 1, that is, when going upwards, the address [3] is restored, that is, the address of the cache mapping is restored. Means. This means that when the texel coordinate u [3] changes, that is, when the texel coordinate u [3] advances by eight, the cache mapping address is restored.
Thus, the texel coordinate-cache mapping address conversion of FIG. 8 is realized.

図10は、本発明の他の実施形態を説明する図である。
他の実施形態として、以下のようなものが考えられる。すなわち、テクスチャを複数の領域に分割するためキャッシュマッピングの0,1をグループA、2,3をグループB、4,5をグループC、6,7をグループD、8,9をグループE、10,11をグループF、12,13をグループG、14,15をグループHと定義する。テクセルのキャッシュマッピングは、グループAの境界(接辺)にグループB,C,D,E,F,G,Hのいずれかを配置することとする。グループBの境界(接辺)にグループA,C,D,E,F,G,Hのいずれかを配置することとする。グループCの境界(接辺)にグループA,B,D,E,F,G,Hのいずれかを配置することとする。グループDの境界(接辺)にグループA,B,C,E,F,G,Hのいずれかを配置することとする。グループEの境界(接辺)にグループA,B,C,D,F,G,Hのいずれかを配置することとする。グループFの境界(接辺)にグループA,B,C,D,E,G,Hのいずれかを配置することとする。グループGの境界(接辺)にグループA,B,C,D,E,F,Hのいずれかを配置することとする。グループHの境界(接辺)にグループA,B,C,D,E,F,Gのいずれかを配置することとする。図10は、この条件に一致するように配置した例である。
FIG. 10 is a diagram for explaining another embodiment of the present invention.
As other embodiments, the following can be considered. That is, in order to divide the texture into a plurality of areas, 0 and 1 of the cache mapping are group A, 2, 3 are group B, 4, 5 are group C, 6, 7 are group D, 8, 9 are group E, 10 , 11 is defined as group F, 12, 13 as group G, and 14, 15 as group H. In texel cache mapping, any one of groups B, C, D, E, F, G, and H is arranged on the boundary (tangent side) of group A. One of the groups A, C, D, E, F, G, and H is arranged at the boundary (tangent side) of the group B. One of the groups A, B, D, E, F, G, and H is arranged on the boundary (side of the group C). One of the groups A, B, C, E, F, G, and H is arranged on the boundary (tangent side) of the group D. One of the groups A, B, C, D, F, G, and H is arranged on the boundary (tangent side) of the group E. Any one of the groups A, B, C, D, E, G, and H is arranged at the boundary (tangent side) of the group F. One of the groups A, B, C, D, E, F, and H is arranged at the boundary (tangent side) of the group G. One of the groups A, B, C, D, E, F, and G is arranged on the boundary (tangent side) of the group H. FIG. 10 shows an example of arrangement so as to meet this condition.

図10の場合においては、テクセルを2つずつ組にして、キャッシュに格納する。1つの組の横には、同じキャッシュマッピングアドレスを持たない組を配置するようにする。図10の取得したいテクスチャ上には、テクセル0,1、テクセル6,7、テクセル4,5、テクセル2,3が配列され、これが、横方向に繰り返すようになっている。したがって、これらのテクセルを格納するキャッシュ領域は、ワード0,1、ワード6,7、ワード4,5、ワード2,3であり、互いに重なっていないので、一度にキャッシュに読み込むことが出来ると共に、ワード0〜7をすべて使っているので、キャッシュ容量の使用率も向上する。   In the case of FIG. 10, two texels are grouped and stored in the cache. A set that does not have the same cache mapping address is arranged beside one set. On the texture to be acquired in FIG. 10, texels 0 and 1, texels 6 and 7, texels 4 and 5, and texels 2 and 3 are arranged, and this is repeated in the horizontal direction. Therefore, the cache areas for storing these texels are word 0, 1, word 6, 7, word 4, 5, and word 2, 3. Since they do not overlap each other, they can be read into the cache at one time. Since all the words 0 to 7 are used, the usage rate of the cache capacity is also improved.

図11は、図10の実施形態のキャッシュマッピングアドレス変換の回路図である。
テクセル座標uは、u[0]、u[1]、u[2]の下位3ビットを使用する。テクセル座標vは、v[0]、v[1]の下位2ビットを使用する。u[0]、u[1]は、そのままキャッシュマッピングアドレス、アドレス[0]、アドレス[1]とする。v[0]は、アドレス[3]とする。これは、v[0]が3変化する、すなわち、上方向に2個移動すると、アドレスが元に戻ることを意味する。v[1]とu[1]は、XOR回路31に入力される。XOR回路31の出力は、u[2]と共に、XOR回路32に入力される。すなわち、XOR回路31のアドレスの切り替えと、XOR回路32のアドレスの切り替えとのANDの切り替えが起きることを意味している。XOR回路31では、v[1]が変化する、すなわち、上方向に4つ進むか、u[1]が変化する、すなわち、横方向に4つ進むかすると、アドレスの切り替えが起きることを意味している。XOR回路32では、XOR回路31の切り替えのほかに、u[2]が変化する、すなわち、横方向に8つ進むと、切り替えが起きることを意味する。すなわち、XOR回路31と32の組み合わせで、上方向に4つ進むか、横方向に4つ進むか、横方向に8つ進むか、のいずれかが発生すると、アドレスの切り替えが起きるようになっている。
FIG. 11 is a circuit diagram of cache mapping address conversion in the embodiment of FIG.
The texel coordinate u uses the lower 3 bits of u [0], u [1], u [2]. The texel coordinate v uses the lower 2 bits of v [0] and v [1]. u [0] and u [1] are the cache mapping address, address [0], and address [1] as they are. v [0] is address [3]. This means that v [0] changes three, that is, if the two move upward, the address is restored. v [1] and u [1] are input to the XOR circuit 31. The output of the XOR circuit 31 is input to the XOR circuit 32 together with u [2]. That is, it means that the AND switching between the address switching of the XOR circuit 31 and the address switching of the XOR circuit 32 occurs. In the XOR circuit 31, when v [1] changes, that is, when it advances four upwards or when u [1] changes, that is, when it advances four horizontally, it means that address switching occurs. doing. In the XOR circuit 32, in addition to the switching of the XOR circuit 31, when u [2] changes, that is, when it advances eight in the horizontal direction, it means that switching occurs. In other words, in the combination of the XOR circuits 31 and 32, when one of the four progresses in the upward direction, the four proceed in the lateral direction, or the eight proceed in the lateral direction occurs, the address is switched. ing.

本発明の実施形態では、テクスチャ内の一直線上のテクセルは、キャッシュマッピングの重複が発生する前にマッピングアドレスを別のキャッシュ領域へ割り当てる。
また、テクスチャのテクセルがマッピングされたメモリからテクセルを取得し、テクスチャ内の一直線上のテクセルは重複なくキャッシュへマッピングすることができることでキャッシュ効率がよく、速度の遅いメモリ間通信が低減され高速な画像描画を可能とする。
In embodiments of the present invention, texels on a straight line in the texture assign mapping addresses to different cache areas before cache mapping overlap occurs.
In addition, texels are acquired from the memory where texture texels are mapped, and texels on a straight line in the texture can be mapped to the cache without duplication, which improves cache efficiency and reduces low-speed memory-to-memory communication. Enable image drawing.

10 画像描画装置(集積回路)
11 CPU
12 表示メモリ
13 表示装置
14 コマンド解釈部
15 頂点処理部
16 ラスタライザー
17 キャッシュ内テクセル有無判定部
18 テクセル座標−メモリアドレス変換部
19 テクセル座標−キャッシュマッピングアドレス変換部
20 アドレス出力部
21 メモリ
22 キャッシュ
23 ピクセル処理部
24 メモリアドレス変換部
30〜32 XOR回路
10 Image drawing device (integrated circuit)
11 CPU
DESCRIPTION OF SYMBOLS 12 Display memory 13 Display apparatus 14 Command interpretation part 15 Vertex process part 16 Rasterizer 17 Cache texel existence determination part 18 Texel coordinate-memory address conversion part 19 Texel coordinate-cache mapping address conversion part 20 Address output part 21 Memory 22 Cache 23 Pixel processing unit 24 Memory address conversion unit 30 to 32 XOR circuit

Claims (5)

uv座標系で位置が表される複数のテクセルを含むテクスチャを格納するメモリと、
前記メモリから前記テクスチャを取得する場合に、前記テクスチャを複数のテクスチャ領域に分割し、前記分割された複数のテクスチャ領域のうちの隣接するテクスチャ領域のそれぞれに含まれるv座標が同じ前記複数のテクセルのu座標に基づいて、前記v座標が同じ前記複数のテクセルのテクセル座標のそれぞれを互いにワードが異なるキャッシュマッピングアドレスに変換する変換回路と、
前記変換回路により変換されたキャッシュマッピングアドレスに基づいて、前記分割された複数のテクスチャ領域に含まれる前記複数のテクセルの情報を格納するキャッシュと、
前記キャッシュから前記格納された複数のテクセルの情報を取得して描画を行う描画回路と、
を備えることを特徴とする画像描画装置。
a memory for storing a texture including a plurality of texels whose positions are represented in the uv coordinate system ;
When acquiring the texture from the memory, the texture is divided into a plurality of texture areas, and the plurality of texels having the same v coordinate included in each of the adjacent texture areas among the divided texture areas. A conversion circuit for converting each of the texel coordinates of the plurality of texels having the same v coordinate to cache mapping addresses having different words based on the u coordinate of
Based on the cache mapping address converted by the conversion circuit, a cache for storing information of the plurality of texels included in the plurality of divided texture regions;
A drawing circuit that obtains and draws information on the plurality of stored texels from the cache; and
An image drawing apparatus comprising:
前記テクスチャ領域は、4×4テクセルのブロックであることを特徴とする請求項1に記載の画像描画装置。 The image drawing apparatus according to claim 1, wherein the texture region is a 4 × 4 texel block. 前記テクスチャ領域は、4×4テクセルのブロックであり
前記変換回路は、前記4×4テクセルのうちの2テクセルずつ組にしたテクセルのテクセル座標のそれぞれを互いにワードが異なるキャッシュマッピングアドレスに変換することを特徴とする請求項1に記載の画像描画装置。
The texture region is 4 × 4 texels blocks,
2. The image drawing according to claim 1, wherein the conversion circuit converts each texel coordinate of a texel that is a group of two texels of the 4 × 4 texels into cache mapping addresses having different words. apparatus.
前記変換回路は、複数ビットで表される前記テクセル座標の下位ビット信号が入力されるXOR回路を有することを特徴とする請求項1に記載の画像描画装置。 The image drawing apparatus according to claim 1, wherein the conversion circuit includes an XOR circuit to which a lower-order bit signal of the texel coordinates represented by a plurality of bits is input . uv座標系で位置が表される複数のテクセルを含むテクスチャを貼り付けることにより画像を描画する画像描画装置の画像描画方法において、
前記画像描画装置は、
メモリに前記テクスチャを格納し、
前記メモリから前記テクスチャを取得する場合に、前記テクスチャを複数のテクスチャ領域に分割し、前記分割された複数のテクスチャ領域のうちの隣接するテクスチャ領域のそれぞれに含まれるv座標が同じ前記複数のテクセルのu座標に基づいて、前記v座標が同じ前記複数のテクセルのテクセル座標のそれぞれを互いにワードが異なるキャッシュマッピングアドレスに変換し、
前記変換されたキャッシュマッピングアドレスに基づいて、前記分割された複数のテクスチャ領域に含まれる前記複数のテクセルの情報キャッシュに格納し、
前記キャッシュから前記格納された複数のテクセルの情報を取得して描画を行う、
ことを特徴とする画像描画方法。
In an image drawing method of an image drawing apparatus that draws an image by pasting a texture including a plurality of texels whose positions are represented in the uv coordinate system ,
The image drawing device includes:
Store the texture in memory ,
When acquiring the texture from the memory, the texture is divided into a plurality of texture areas, and the plurality of texels having the same v coordinate included in each of the adjacent texture areas among the divided texture areas. Based on the u coordinate of the texel coordinates of the texel of the plurality of texels having the same v coordinate is converted to a cache mapping address having a different word from each other ,
Based on the converted cache mapping address, information on the plurality of texels included in the plurality of divided texture regions is stored in a cache ,
Drawing is performed to obtain a plurality of texels of the information the storage from the cache,
An image drawing method characterized by that.
JP2009040328A 2009-02-24 2009-02-24 Image drawing device Expired - Fee Related JP5310079B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2009040328A JP5310079B2 (en) 2009-02-24 2009-02-24 Image drawing device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2009040328A JP5310079B2 (en) 2009-02-24 2009-02-24 Image drawing device

Publications (2)

Publication Number Publication Date
JP2010198156A JP2010198156A (en) 2010-09-09
JP5310079B2 true JP5310079B2 (en) 2013-10-09

Family

ID=42822846

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2009040328A Expired - Fee Related JP5310079B2 (en) 2009-02-24 2009-02-24 Image drawing device

Country Status (1)

Country Link
JP (1) JP5310079B2 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103034465B (en) * 2011-09-29 2016-04-27 腾讯科技(深圳)有限公司 Image browsing method and browing system

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH03292575A (en) * 1990-04-11 1991-12-24 Matsushita Electric Ind Co Ltd address generator
JP3770422B2 (en) * 1996-06-27 2006-04-26 ソニー株式会社 Image generating apparatus and method, and data compression method
US5945997A (en) * 1997-06-26 1999-08-31 S3 Incorporated Block- and band-oriented traversal in three-dimensional triangle rendering
US6011565A (en) * 1998-04-09 2000-01-04 S3 Incorporated Non-stalled requesting texture cache
JP3955862B2 (en) * 2004-09-27 2007-08-08 株式会社ルネサステクノロジ Data processing apparatus and system using the same

Also Published As

Publication number Publication date
JP2010198156A (en) 2010-09-09

Similar Documents

Publication Publication Date Title
US6831653B2 (en) Graphics pixel packing for improved fill rate performance
US8130234B2 (en) Computer graphics rendering apparatus and method
KR20170103667A (en) An efficient low-power texture cache architecture
JP3586991B2 (en) Texture data reading device and rendering device
JP2004078296A (en) Picture generation device
JP4795808B2 (en) Drawing apparatus, drawing method, drawing program, and drawing integrated circuit
JP2005531833A (en) Method and apparatus for encoding texture information
TWI395152B (en) A graphics processing unit and a method of processing border color information
KR980010878A (en) Image generating apparatus and method
JP2882465B2 (en) Image generation method and apparatus
JP4568950B2 (en) Graphics drawing device
KR100550240B1 (en) Tiled Graphics Architecture
JP5310079B2 (en) Image drawing device
KR20060116916A (en) Texture Caches and Three-Dimensional Graphics Systems Having the Same, and Their Control Methods
JP2003323339A (en) Memory access device, semiconductor device, memory access control method, computer program and recording medium
US6940519B2 (en) Graphics processor, graphics card and graphics processing system
US11232622B2 (en) Data flow in a distributed graphics processing unit architecture
JP2000011190A (en) Image processor
CN100595794C (en) Drawing device
JP2003132347A (en) Image processor
JP4381778B2 (en) Texture processing device
JP3971448B2 (en) Drawing apparatus and drawing method
JP4024072B2 (en) High-speed reading of mipmap data
JP4482996B2 (en) Data storage apparatus and method and image processing apparatus
US20050052459A1 (en) Method and system for rendering macropixels in a graphical image

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20111125

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130304

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130312

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130513

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20130604

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20130617

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

Ref document number: 5310079

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313111

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

LAPS Cancellation because of no payment of annual fees