1. Field of the Invention
The present invention relates generally to graphics information processing, and in particular to methods and mechanisms for performing chroma downsampling.
2. Description of the Related Art
Computing devices and in particular mobile devices often have limited memory resources and a finite power source such as a battery. Computing devices with displays usually include different types of graphics hardware to manipulate and display video and images. Graphics hardware can perform many different types of operations to generate and process images intended for a display. One common operation performed by graphics hardware is the downsampling of chroma pixel components.
Chroma pixel components are downsampled (i.e., subsampled) to compress the amount of data used to encode an image or video stream. The terms “downsample” and “subsample” may be used interchangeably throughout this disclosure. The term ‘downsampling’ may herein be used to refer to, among other things, the change in color format of an image from a first color format to a second color format in which the number of chroma samples relative to luma samples in the first color format is higher than in the second color format. In other words, ‘downsampling’ reduces the number of chroma samples in the image, while leaving the number of luma samples unchanged.
In some widely-used formats (e.g., YCbCr), images may be transmitted with a brightness component (luminance) and two color components (chrominance). The YCbCr color space format (also referred to as YUV) utilizes a luma signal ‘Y’ to represent brightness, and color difference (or chroma) signals ‘Cb’ (representing blue) and ‘Cr’ (representing red) to represent blue and red color differences, respectively. Generally speaking, the human eye has less spatial acuity to the color information than to the luminance information, and so the amount of information devoted to the color components may be reduced without noticeably altering the image as it is perceived by the human eye.
There are several types of image and video formats that are commonly used to encode pixel information. Within the YCbCr format, several format variations may be used, such as chroma subsampling formats (i.e., ratios) 4:4:4, 4:2:2, and 4:2:0. The format 4:4:4 does not utilize subsampling, and so each of the three Y, Cb, and Cr components has the same sample rate. The term 4:2:2 refers to the ratio of the number of Y signal samples to the number of Cb and Cr signal samples in the color scheme. The format 4:2:2 indicates that for every four Y samples, the Cb and Cr signals are each sampled twice. On a pixel basis, this can be restated as for every pixel pair, there are two luma samples (Y1 and Y2) and a Cb and Cr shared among the two luma samples.
The format 4:2:0 specifies that for every four luma samples, the Cb and Cr signals are each sampled once. The first number of the 4:2:0 color format “4” represents the number of luma samples as a baseline. The second number “2” represents a defined horizontal subsampling with respect to the luma samples. The third number “0” represents a defined vertical subsampling, which in this case is a 2:1 vertical subsampling.
Typically, buffers are utilized to store pixel data in order to perform chroma downsampling on an image to generate the 4:2:2 or 4:2:0 formats. However, these buffers require large amounts of silicon area and can consume additional power, increasing the cost of the graphics hardware and reducing the battery life of mobile devices.
Various apparatuses and methods for performing inline, buffer-free downsampling of chroma pixel components of a source image are contemplated. In one embodiment, an apparatus may include a graphics processing pipeline for processing graphics data, and one of the stages of the pipeline may be a chroma downsampling unit. In one embodiment, a color space conversion (CSC) unit may precede the chroma downsampling unit in the pipeline, and the CSC unit may convey YCbCr data to the chroma downsampling unit.
In one embodiment, the YCbCr data received by the chroma downsampling unit may be in a 4:4:4 or 4:2:2 format. The output of the chroma downsampling unit may vary depending on the format of the input received and the type of downsampling being performed. The type of downsampling being performed may be programmable via a configuration register located within the chroma downsampling unit. For example, horizontal and vertical downsampling may be individually enabled via the configuration register.
In one embodiment, the chroma downsampling unit may accept four pixels per clock from the CSC unit. The four pixels may be located within a single column of the image. In a first mode, the chroma downsampling unit may perform horizontal downsampling of 4:4:4 format data to produce four pixels of 4:2:2 format data on every other clock. In a second mode, the chroma downsampling unit may perform vertical downsampling of 4:2:2 format data to produce two pixels of 4:2:0 format data on every clock. In a third mode, the chroma downsampling unit may perform horizontal and vertical downsampling of 4:4:4 format data to produce two pixels of 4:2:0 format data on every other clock. The three modes may be selected via the configuration register.
In one embodiment, the downsampling may be performed by computing the average of one or more pairs of chroma pixel components. If horizontal downsampling is enabled, then one or more averages of one or more pairs of chroma pixel components from separate columns may be computed. If vertical downsampling is enabled, then one or more averages of one or more pairs of chroma pixel components from the same column may be computed. If vertical and horizontal downsampling are both enabled, then one or more averages of one or more groups of four chroma pixel components from two separate columns may be computed. In one embodiment, a rounding component may be added to the sum of the chroma pixel components in order to implement rounding functionality during the average computation.
Vertical downsampling may be performed inline after receiving a column of even-numbered chroma pixel components in each clock cycle. The chroma pixel components may be received and stored in registers prior to the average being computed. For horizontal downsampling, each pair of pixels from the columns of chroma pixel components received on consecutive clock cycles may be added together and then divided by two to compute the average value. The first column of chroma pixel components may be written to a first set of registers in the first clock cycle and then clocked through to a second set of registers in the second clock cycle. The second clock cycle may be the clock cycle immediately after the first clock cycle. The second column of chroma pixel components received in the second clock cycle may be written to the first set of registers. The values from the first set and second set of registers may be added together in a third clock cycle and then divided by two in a fourth clock cycle to calculate the average of the pairs of chroma pixel components from both columns.
These and other features and advantages will become apparent to those of ordinary skill in the art in view of the following detailed descriptions of the approaches presented herein.
The above and further advantages of the methods and mechanisms may be better understood by referring to the following description in conjunction with the accompanying drawings, in which:
In the following description, numerous specific details are set forth to provide a thorough understanding of the methods and mechanisms presented herein. However, one having ordinary skill in the art should recognize that the various embodiments may be practiced without these specific details. In some instances, well-known structures, components, signals, computer program instructions, and techniques have not been shown in detail to avoid obscuring the approaches described herein. It will be appreciated that for simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements.
This specification includes references to “one embodiment”. The appearance of the phrase “in one embodiment” in different contexts does not necessarily refer to the same embodiment. Particular features, structures, or characteristics may be combined in any suitable manner consistent with this disclosure. Furthermore, as used throughout this application, the word “may” is used in a permissive sense (i.e., meaning having the potential to), rather than the mandatory sense (i.e., meaning must). Similarly, the words “include”, “including”, and “includes” mean including, but not limited to.
Terminology. The following paragraphs provide definitions and/or context for terms found in this disclosure (including the appended claims):
“Comprising.” This term is open-ended. As used in the appended claims, this term does not foreclose additional structure or steps. Consider a claim that recites: “An apparatus comprising a fetch unit . . . .” Such a claim does not foreclose the apparatus from including additional components (e.g., a processor, a cache, a memory controller).
“Configured To.” Various units, circuits, or other components may be described or claimed as “configured to” perform a task or tasks. In such contexts, “configured to” is used to connote structure by indicating that the units/circuits/components include structure (e.g., circuitry) that performs the task or tasks during operation. As such, the unit/circuit/component can be said to be configured to perform the task even when the specified unit/circuit/component is not currently operational (e.g., is not on). The units/circuits/components used with the “configured to” language include hardware—for example, circuits, memory storing program instructions executable to implement the operation, etc. Reciting that a unit/circuit/component is “configured to” perform one or more tasks is expressly intended not to invoke 35 U.S.C. §112, sixth paragraph, for that unit/circuit/component. Additionally, “configured to” can include generic structure (e.g., generic circuitry) that is manipulated by software and/or firmware (e.g., an FPGA or a general-purpose processor executing software) to operate in manner that is capable of performing the task(s) at issue. “Configured to” may also include adapting a manufacturing process (e.g., a semiconductor fabrication facility) to fabricate devices (e.g., integrated circuits) that are adapted to implement or perform one or more tasks.
“Based On.” As used herein, this term is used to describe one or more factors that affect a determination. This term does not foreclose additional factors that may affect a determination. That is, a determination may be solely based on those factors or based, at least in part, on those factors. Consider the phrase “determine A based on B.” While B may be a factor that affects the determination of A, such a phrase does not foreclose the determination of A from also being based on C. In other instances, A may be determined based solely on B.
Referring now to
Source image 34 may be stored in memory 12, and source image 34 may be a still image or a frame of a video stream. In other embodiments, source image 34 may be stored in other locations. Source image 34 is representative of any number of images, videos, or graphics data that may be stored in memory 12 and processed by pipeline 10. Memory 12 is representative of any number and type of memory devices (e.g., dynamic random access memory (DRAM), cache).
Source image 34 may be represented by large numbers of discrete picture elements known as pixels. In digital imaging, the smallest item of information in an image or video frame may be referred to as a “pixel”. Pixels are generally arranged in a regular two-dimensional grid. Each pixel in source image 34 may be represented by one or more pixel components. The pixel components may include color values for each color in the color space in which source image 34 is represented. For example, the color space may be a red-green-blue (RGB) color space. Each pixel may thus be represented by a red component, a green component, and a blue component. In one embodiment, the value of a color component may range from zero to 2N-1, wherein ‘N’ is the number of bits used to represent the value. The value of each color component may represent a brightness or intensity of the corresponding color in that pixel. Other color spaces may also be used, such as YCbCr. Furthermore, additional pixel components may be included. For example, an alpha value for blending may be included with the RGB components to form an ARGB color space. The number of bits used to store each pixel may depend on the particular format being utilized. For example, pixels in some systems may require 8 bits, whereas pixels in other systems may require 10 bits, and so on, with various numbers of bits per pixel being used in various systems.
Pipeline 10 may include four separate channels 14-20 to process up to four color components per pixel. Each channel may include a rotation unit, a set of tile buffers, a set of vertical scalers, and a set of horizontal scalers. In one embodiment, channel 14 may process an alpha channel. In other embodiments, channel 14 may not be utilized, and instead only three channels 16-20, corresponding to three color components, may be utilized. The read direct memory access (RDMA) unit 22 may be configured to read graphics data (e.g., source image 34) from memory 12. RDMA unit 22 may include four rotation units, four tile buffers, and a DMA buffer (not shown). The four tile buffers may be utilized for storing rotated tiles of source image 34.
There may be a plurality of vertical scalers and horizontal scalers for each color component of the source image. Each set of vertical scalers may fetch a column of pixels from the corresponding set of tile buffers. In another embodiment, pixels may be conveyed to the vertical scalers from the tile buffers. Each set of vertical scalers per channel may include any number of vertical scalers. In one embodiment, there may be four separate vertical scalers within pipeline 10 for each color component channel. In other embodiments, other numbers of vertical scalers may be utilized per color component channel.
Source image 34 may be partitioned into a plurality of tiles and may be processed by the rotation units on a tile-by-tile basis, and tiles that have been rotated may be stored in one of the tile buffers in a respective color component channel. In one embodiment, there may be four tile buffers per channel, although in other embodiments, other numbers of tile buffers may be utilized. In one embodiment, the vertical scalers may fetch a column of pixels from corresponding tile buffers. The column of pixels may extend through one or more tiles of the source image.
Source image 34 may be partitioned into tiles, and in one embodiment, the tiles may be 16 rows of pixels by 128 columns of pixels. However, the tile size (e.g., 256-by-24, 64-by-16, 512-by-32) may vary in other embodiments. The width of source image 34 may be greater than the width of the tile such that source image 34 may include multiple tiles in the horizontal direction. Also, the length of source image 34 may be greater than the length of the tile such that source image 34 may include multiple tiles in the vertical direction.
Each vertical scaler may be configured to generate a vertically scaled pixel on each clock cycle and convey the pixel to a corresponding horizontal scaler. In one embodiment, there may be four separate horizontal scalers within the pipeline for each color component channel, while in other embodiments, other numbers of horizontal scalers may be utilized per color component channel. In various embodiments, there may be a horizontal scaler corresponding to each vertical scaler within each color component channel of pipeline 10. Each horizontal scaler may generate horizontally scaled pixels from the received pixels.
In each color component channel, the horizontal scalers may output vertically and horizontally scaled pixels to normalization unit 24. In one embodiment, normalization unit 24 may be configured to convert received pixel values to the range between 0.0 and 1.0. For example, in one embodiment, the 10-bit pixel values output from a horizontal scaler may take on values from 0 to 1023. In such an embodiment, normalization unit 24 may divide the value received from the horizontal scaler by 1023 to change the range of the value. In other embodiments, normalization unit 24 may divide by other values depending on the number of bits used to represent pixel values. Also, normalization unit 24 may be configured to remove an optional offset from one or more of the pixel values. As shown in
Normalization unit 24 may convey normalized pixel values to color space conversion (CSC) unit 26. CSC unit 26 may be configured to convert between two different color spaces. In various embodiments, the CSC unit may perform a color space conversion of the graphics data it receives. For example, in one embodiment, pixel values may be represented in source image 34 by a RGB color space. In this embodiment, pipeline 10 may need to generate output images in a YCbCr color space, and so CSC unit 26 may convert pixels from the RGB color space to the YCbCr color space. Various other color spaces may be utilized in other embodiments, and CSC unit 26 may be configured to convert pixels in between these various color spaces. In some embodiments, when a color space conversion is not required, the CSC unit may be a passthrough unit.
In one embodiment, CSC unit 26 may convey pixels to chroma downsampling unit 28. Chroma downsampling unit 28 may be configured to downsample the chroma components of the pixels in an inline, buffer-free fashion. Various types of downsampling may be performed (e.g., 4:2:2, 4:2:0). For example, in one embodiment, if the source image is in a 4:4:4 format and if the destination image is specified to utilize a 4:2:0 structure, then chroma downsampling unit 28 may perform vertical and horizontal downsampling of the chroma pixel components of the source image. In some scenarios, chroma downsampling unit 28 may be a passthrough unit if downsampling of the chroma pixel components is not needed.
Although not shown in
Chroma downsampling unit 28 may be coupled to reformatting unit 30. Reformatting unit 30 may be configured to reverse the normalization that was performed by normalization unit 24. Accordingly, the pixel values may be returned to the previous range of values that were utilized prior to the pixels being normalized by normalization unit 24. Pixels may pass through dither unit 32 after being reformatted, and dither unit 32 may insert noise to randomize quantization error. The output from dither unit 32 may be the processed destination image. In various embodiments, the processed destination image may be written to a frame buffer, to memory 12, to a display controller, to a display, or to another location. In other embodiments, graphics processing pipeline 10 may include other stages or units and/or some of the units shown in
It is noted that other embodiments may include other combinations of components, including subsets or supersets of the components shown in
Turning now to
In one embodiment, tiles may be processed starting at the top left of the image, tile (0,0), and moving down the first column until reaching tile (0, N−1). After operating on the first column, tiles may be processed continuing at the top of the next column, tile (1,0). The vertical scalers may traverse through the tiles of the second column to the bottom of the column, and continue with this pattern until reaching the bottom right tile (M−1, N−1) of the image.
Each tile may be processed starting at the top left corner of the tile, and moving horizontally left to right until reaching the right edge of the tile. If a tile has 16 rows, and less than 16 pixels per column are processed in a single pass through the tile, then after reaching the right edge of the tile, processing may back to the left edge of the tile, moving down to the unprocessed rows of pixels. Each source image 34 may include up to four components per pixel, and so there may be four separate components stored for each pixel, organized and partitioned into tiles as shown in
Typically, graphics processing may be performed using “line buffers” which are configured to store pixel data corresponding to a line of an image. For example, a line buffer would generally be needed to store an even line such that when odd lines are being processed there are two vertical pixels available to combine and downsample. It is noted that line buffers are costly in terms of space and power utilization. In the embodiments described herein, the chroma downsampling units do not include such line buffers. As described in more detail below, the chroma downsampling units operate on columns of vertically contiguous pixels. Therefore, the pixels are available for downsampling without requiring the storing and reloading of pixels. In addition, individual columns of pixels may be downsampled independently of contiguous columns of pixels. Furthermore, in various embodiments, a first column of pixels received in a first clock cycle may be downsampled simultaneously while receiving a second column of pixels adjacent to the first column.
Referring now to
In block diagram 42, vertical downsampling is depicted between pixels A1 and A2. The resultant, downsampled chroma pixel value may take on the value of (A1+A2) divided by two. In other embodiments, other phases may be utilized when performing vertical downsampling. Also, other numbers of pixels besides two may be simultaneously vertically downsampled. For example, if eight pixels are received in a clock cycle, then four pairs of adjacent vertical pixels may be vertically downsampled.
In block diagram 44, an example of horizontal and vertical downsampling is depicted for pixels A1, B1, A2, and B2. The resultant, downsampled chroma pixel value may take on the value of (A1+B1+A2+B2) divided by four. In other embodiments, other phases may be utilized when performing horizontal and vertical downsampling. Also, other numbers of pixels besides four may be horizontally and vertically downsampled.
Although only three different types of downsampling are shown in
Turning now to
In clock cycle ‘N’, chroma pixel component values for a vertical column of pixels (A) may be received. The vertical column of pixels may include an even number of pixels. In one embodiment, four pixels from a vertical column of the source image may be received in clock cycle ‘N’. In other embodiments, other numbers of pixels may be received in each clock cycle. The vertical column of pixels may be received and clocked into four separate registers. The registers may also be referred to as flip-flops, or flops, for short.
In clock cycle ‘N+1’, a second vertical column of pixels (B) may be received. This second vertical column of pixels may have the same number of pixels as the first vertical column. In one embodiment, the second vertical column of pixels may be clocked into the same four registers that were utilized for the first vertical column in the previous clock cycle. The first vertical column of pixels may be clocked from the first set of four registers to a second set of four registers in the clock cycle ‘N+1’. In another embodiment, separate sets of registers may be used for storing the first and second vertical columns of pixels.
In clock cycle ‘N+2’, pairs of pixels from the first (A) and second (B) columns of pixels may be added together. Also in clock cycle ‘N+2’, a new column of pixels (C) may be received, wherein column C is the adjacent column to the right of column B. In one embodiment, a rounding component may also be added to each pair from the first and second columns of pixels. The rounding component may be the binary equivalent of value 0.5 in base-10 representation. For example, if the chroma pixel components of columns A and B are represented by a 3-bit integer field and a 14-bit fractional field, then the rounding component may have a ‘1’ in the 4th bit (i.e., LSB) of a 4-bit number, with the rest of the bits ‘0’.
If only horizontal downscaling is enabled, then the pair of pixels from the same row (with one pixel in each of columns A and B) may be added together. For example, if there are four pixels per vertical column of pixels, such that four pixels are received per clock cycle, then the top pixel of column A and the top pixel of column B may be added together in a first adder, the second from the top pixel of column A and the second from the top pixel of column B may be added together in a second adder, and so on. Four different adders may be utilized in this embodiment. In another embodiment, if eight vertical pixels are received per clock cycle, then eight different adders may be utilized for computing the sums of eight separate pairs of pixels.
If both vertical and horizontal downscaling are enabled, then pixels from adjacent rows may be added together, such that four pixels that form a 2×2 square in the received image may be added together, with two pixels from the same row and two pixels from the next lower row added together. When referring to the received image, this refers to the image received from the previous stage in the graphics processing pipeline. The actual source image, meaning the source image that was received or fetched from memory, may have been modified by one or more previous stages (e.g., rotator, scaler) of the pipeline.
In the clock cycle ‘N+3’, the one or more sums calculated during the clock cycle ‘N+2’ may be divided by the value ‘M’. Also in clock cycle ‘N+3’, a new column of pixels (D) may be received, which is the adjacent column to the right of column C. If only horizontal downsampling is being performed, then M may be two. If horizontal and vertical downsampling is being performed, then M may be four. In other embodiments, if other types of chroma downsampling are being performed, such as types that may be defined in the future for various image and video standards, then M may be other numbers (e.g., eight, sixteen). One or more dividers may be utilized to implement the division stage, depending on the number of pixels received per clock cycle and the type of downsampling being performed. In one embodiment, the dividers may perform division by dropping least significant bits (LSBs) from the calculated sums. For example, if divide-by-two is required, then the LSB from the sum may be dropped. If divide-by-four is required, then two LSBs may be dropped. The quotient(s) calculated in clock cycle ‘N+3’ may be output to the next stage of the graphics processing pipeline. The quotient(s) represent one or more downsampled chroma pixel components.
In clock cycle ‘N+4’, pixels from columns C and D may be added together. Also, although not shown, a new column of pixels may be received in clock cycle ‘N+4’. On each clock cycle, a new column of pixels may be received, and the pattern of operations shown in
In clock cycle ‘N+5’, pairs of pixels from columns C and D may be divided by ‘M’. Downsampled chroma pixel components may be generated and conveyed to the next stage of the graphics processing pipeline on every other clock cycle. In one embodiment, columns of four pixels may be received each clock cycle. In this embodiment, if only horizontal downsampling is being performed, then four horizontally downsampled chroma pixel components may be generated on every other clock cycle. If horizontal and vertical downsampling is being performed, then two horizontally and vertically downsampled chroma pixel components may be generated on every other clock cycle. In various embodiments, the chroma pixel components may be clamped if they exceed maximum or minimum values prior to being conveyed to a next stage of the graphics processing pipeline.
This timing pattern of performing horizontal chroma downsampling may continue indefinitely, such that pixels from a vertical column may be received in each clock cycle, and addition and division steps may be performed every other clock cycle. The received image may be partitioned into tiles, and tiles may be downsampled by a chroma downsampling unit beginning in the upper-left block of the image, and then downsampling may proceed down the left-most column of tiles until reaching the bottom edge of the image. Then tiles may be downsampled continuing at the top of the second left-most column and continuing in this manner throughout the rest of the image.
In other embodiments, other sequences of steps may be executed to perform chroma downsampling. In other embodiments, other variations of chroma downsampling routines may be utilized. The example illustrated in timing diagram 50 is only one possible example of a sequence of steps which may be taken to perform horizontal chroma downsampling.
Referring now to
In clock cycle ‘N+1’, pairs of chroma pixel components from adjacent rows in column A may be added together. In one embodiment, a rounding component may be added to the pixels. Any number of pairs of chroma pixel components may be added together in clock cycle ‘N+1’, depending on how many pixels are received from column A. For example, if four pixels are received from column A, then two sums may be calculated: (A1+A2) and (A3+A4). These operations may be repeated for columns B-D in clock cycles ‘N+2’ through ‘N+4’.
In clock cycle ‘N+2’, each of the sums of pairs of chroma pixel components from column A may be divided by two. In one embodiment, dividing by two may be accomplished by dropping the LSB from the sum. In some embodiments, the division stage may be performed in the same clock cycle as the addition stage. In clock cycles ‘N+3’ through ‘N+5’, the sums calculated in the prior clock cycle (for columns B-D) may be divided by two. While timing diagram 60 only shows (A1+A2)/2, (B1+B2)/2, and so on, for each of the clock cycles ‘N+2’ through ‘N+5’, it is to be understood that any number (e.g., 2, 4, 6) of sums of pairs of pixels may be divided by two in each clock cycle. The number of divide operations performed is based on the number of pixels received in each column of pixels.
In another embodiment, a horizontal row of pixels may be received in each clock cycle by the chroma downsampling unit, and contiguous rows may be received on consecutive clock cycles. In this embodiment, the chroma downsampling unit may still perform buffer-free downsampling of chroma pixel components by reversing the way it performs vertical and horizontal downsampling. In this embodiment, the unit may perform horizontal downsampling using the chroma pixel components received in a single clock cycle. For vertical downsampling, the unit may add together chroma pixel components received on consecutive clock cycles.
Referring now to
Chroma downsampling unit 70 may include two separate channels for Cb and Cr data. Chroma pixel components from a first column of the received image may be clocked into registers 72 and 86 for the Cb and Cr data, respectively, in a first clock cycle. Then, the first column may be clocked into registers 74 and 88 in a second clock cycle, while simultaneously a second column is clocked into registers 72 and 86. Adders 78 and 90 are representative of any number of adders that may be utilized as part of chroma downsampling unit 70. The number of adders being utilized may depend on the number of pixels that are received in each clock cycle. Adders 78 and 90 may perform different types of addition operations with various numbers of inputs depending on the value of configuration register 76. In one embodiment, a rounding component may be coupled to the inputs of adders 78 and 90.
Adders 78 and 90 may convey the calculated sums to dividers 80 and 92, respectively. In one embodiment, adders 78 and 90 and dividers 80 and 92 may be implemented using pipelined math. Pipelined math allows new data to be received on each clock cycle, and pipelining also allows a result to be generated on each clock cycle, after the initial lag. Dividers 80 and 92 are representative of any number of dividers that may be utilized as part of chroma downsampling unit 70. In one embodiment, dividers 80 and 92 may drop LSBs of the sums received from adders 78 and 90 to perform the actual division step. In another embodiment, dividers 80 and 92 may perform division by shifting the radix point to the left by the appropriate number of bits. The output of dividers 80 and 92 may be conveyed to clamp units 82 and 946, respectively. Clamp units 82 and 94 may clamp any values that are above a maximum or below a minimum value. In another embodiment, clamp units 82 and 94 may be omitted from chroma downsampling unit 70.
The configuration data conveyed to configuration register 76 may set the specific mode in which chroma downsampling unit 70 operates. In one embodiment, the mode may be one of horizontal, vertical, horizontal and vertical downsampling, or passthrough. The configuration data may also include other information, such as an indicator when a new tile is being processed, a new set of rows of the tile are being traversed, and/or other relevant information.
In one embodiment, chroma downsampling unit 70 may process chroma pixel components from a received image on a tile-by-tile basis. Within an individual tile, chroma downsampling unit 70 may move horizontally across columns of a tile of a received image from left to right, and responsive to reaching a right edge of the image, unit 70 may move down to a next set of rows on a left edge of the tile and continue this pattern throughout the entirety of the tile.
The block diagram shown in
Referring now to
In one embodiment, a first column of chroma pixel components may be received by a chroma downsampling unit (block 100). If horizontal downsampling is enabled for the chroma downsampling unit (conditional block 102), then a second column of chroma pixel components may be received by the chroma downsampling unit (block 104) prior to performing a downsampling operation. In one embodiment, the chroma downsampling unit may include a programmable configuration register, and the value of the configuration register may determine what type of downsampling is enabled.
If horizontal downsampling is not enabled for the chroma downsampling unit (conditional block 102), then pairs of adjacent chroma pixel components from the first column may be added together (block 114). If horizontal downsampling is not enabled for the chroma downsampling unit, then it will be assumed for the purposes of this discussion that vertical downsampling is enabled. In one embodiment, a rounding component may be added to each pair of chroma pixel components in block 114. After block 114, the sum of each pair of chroma pixel components may be divided by two (block 118), which generates a downsampled chroma pixel component value for each pair. In one embodiment, dividing each sum by two may be implemented by dropping a LSB from the sum. Then, each downsampled chroma pixel component value may be conveyed to the next stage of the graphics processing pipeline (block 112).
After block 104, if vertical downsampling is also enabled for the chroma downsampling unit (conditional block 106), then sets of four chroma pixel components including two components from each of the first and second columns may be added together (block 108). The number of sets of four chroma pixel components being added together is dependent on the number of chroma pixel components per column. For example, if the first and second columns each contain four chroma pixel components, then two sets of four chroma pixel components may be added together. Also, in one embodiment, a rounding component may be added to each set of chroma pixel components in block 108. Then, each sum generated in block 108 may be divided by four (block 110). In one embodiment, division by four may be implemented by dropping two LSBs from the sum. After block 110, each downsampled chroma pixel component value may be conveyed to the next stage of the graphics processing pipeline (block 112).
If vertical downsampling is not enabled for the chroma downsampling unit (conditional block 106), then pairs of chroma pixel components from the first and second columns may be added together (block 116). A rounding component may also be added to each pair of chroma pixel components. Next, each of the sums calculated in block 116 may be divided by two (block 118). In one embodiment, dividing each sum by two may be implemented by dropping a LSB from the sum. After block 118, each downsampled chroma pixel component value may be conveyed to the next stage of the graphics processing pipeline (block 112).
After conveying downsampled chroma pixel component values to the next stage of the graphics processing pipeline (block 112), the method may return to block 100 and another column of chroma pixel components may be received. Alternatively, downsampled chroma pixel component values may be conveyed to the next stage (block 112) while the chroma downsampling unit is simultaneously receiving the next column of chroma pixel components (block 100). This method may continue for as long as columns of chroma pixel components are received by the chroma downsampling unit.
Referring next to
IC 138 is coupled to one or more peripherals 134 and the external memory 132. A power supply 136 is also provided which supplies the supply voltages to IC 138 as well as one or more supply voltages to the memory 132 and/or the peripherals 134. In various embodiments, power supply 136 may represent a battery (e.g., a rechargeable battery in a smart phone, laptop or tablet computer). In some embodiments, more than one instance of IC 138 may be included (and more than one external memory 132 may be included as well).
The memory 132 may be any type of memory, such as dynamic random access memory (DRAM), synchronous DRAM (SDRAM), double data rate (DDR, DDR2, DDR3, etc.) SDRAM (including mobile versions of the SDRAMs such as mDDR3, etc., and/or low power versions of the SDRAMs such as LPDDR2, etc.), RAMBUS DRAM (RDRAM), static RAM (SRAM), etc. One or more memory devices may be coupled onto a circuit board to form memory modules such as single inline memory modules (SIMMs), dual inline memory modules (DIMMs), etc. Alternatively, the devices may be mounted with IC 138 in a chip-on-chip configuration, a package-on-package configuration, or a multi-chip module configuration.
The peripherals 134 may include any desired circuitry, depending on the type of system 130. For example, in one embodiment, peripherals 134 may include devices for various types of wireless communication, such as wifi, Bluetooth, cellular, global positioning system, etc. The peripherals 134 may also include additional storage, including RAM storage, solid state storage, or disk storage. The peripherals 134 may include user interface devices such as a display screen, including touch display screens or multitouch display screens, keyboard or other input devices, microphones, speakers, etc.
Turning now to
Generally, the data structure(s) of the circuitry on the computer readable medium 180 may be read by a program and used, directly or indirectly, to fabricate the hardware comprising the circuitry. For example, the data structure(s) may include one or more behavioral-level descriptions or register-transfer level (RTL) descriptions of the hardware functionality in a high level design language (HDL) such as Verilog or VHDL. The description(s) may be read by a synthesis tool which may synthesize the description to produce one or more netlists comprising lists of gates from a synthesis library. The netlist(s) comprise a set of gates which also represent the functionality of the hardware comprising the circuitry. The netlist(s) may then be placed and routed to produce one or more data sets describing geometric shapes to be applied to masks. The masks may then be used in various semiconductor fabrication steps to produce a semiconductor circuit or circuits corresponding to the circuitry. Alternatively, the data structure(s) on computer readable medium 180 may be the netlist(s) (with or without the synthesis library) or the data set(s), as desired. In yet another alternative, the data structures may comprise the output of a schematic program, or netlist(s) or data set(s) derived therefrom.
It should be emphasized that the above-described embodiments are only non-limiting examples of implementations. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications.