HWC Stres Test Enhancments
+ YV12 width/height divisable by 2 + Row width determined by getStride() + Misc comment and whitespace fixes + printf changed to testPrintI Change-Id: I27551141bafbfb258eb1b6b7f63c5295b1f9501a
This commit is contained in:
parent
1182c70f3f
commit
5d86b53dc1
@ -202,18 +202,19 @@ class YUVColor {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// File scope constants
|
// File scope constants
|
||||||
static const struct {
|
static const struct graphicFormat {
|
||||||
unsigned int format;
|
unsigned int format;
|
||||||
const char *desc;
|
const char *desc;
|
||||||
|
unsigned int wMod, hMod; // Width/height mod this value must equal zero
|
||||||
} graphicFormat[] = {
|
} graphicFormat[] = {
|
||||||
{HAL_PIXEL_FORMAT_RGBA_8888, "RGBA8888"},
|
{HAL_PIXEL_FORMAT_RGBA_8888, "RGBA8888", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_RGBX_8888, "RGBX8888"},
|
{HAL_PIXEL_FORMAT_RGBX_8888, "RGBX8888", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_RGB_888, "RGB888"},
|
{HAL_PIXEL_FORMAT_RGB_888, "RGB888", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_RGB_565, "RGB565"},
|
{HAL_PIXEL_FORMAT_RGB_565, "RGB565", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_BGRA_8888, "BGRA8888"},
|
{HAL_PIXEL_FORMAT_BGRA_8888, "BGRA8888", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_RGBA_5551, "RGBA5551"},
|
{HAL_PIXEL_FORMAT_RGBA_5551, "RGBA5551", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_RGBA_4444, "RGBA4444"},
|
{HAL_PIXEL_FORMAT_RGBA_4444, "RGBA4444", 1, 1},
|
||||||
{HAL_PIXEL_FORMAT_YV12, "YV12"},
|
{HAL_PIXEL_FORMAT_YV12, "YV12", 2, 2},
|
||||||
};
|
};
|
||||||
const unsigned int blendingOps[] = {
|
const unsigned int blendingOps[] = {
|
||||||
HWC_BLENDING_NONE,
|
HWC_BLENDING_NONE,
|
||||||
@ -478,7 +479,7 @@ main(int argc, char *argv[])
|
|||||||
exit(20);
|
exit(20);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prandomly select a subset of frames to be used by this pass.
|
// Prandomly select a subset of frames to be used by this pass.
|
||||||
vector <vector <sp<GraphicBuffer> > > selectedFrames;
|
vector <vector <sp<GraphicBuffer> > > selectedFrames;
|
||||||
selectedFrames = vectorRandSelect(frames, list->numHwLayers);
|
selectedFrames = vectorRandSelect(frames, list->numHwLayers);
|
||||||
|
|
||||||
@ -749,7 +750,6 @@ static void fillColor(GraphicBuffer *gBuf, RGBColor color, float trans)
|
|||||||
{
|
{
|
||||||
unsigned char* buf = NULL;
|
unsigned char* buf = NULL;
|
||||||
status_t err;
|
status_t err;
|
||||||
unsigned int numPixels = gBuf->getWidth() * gBuf->getHeight();
|
|
||||||
uint32_t pixel;
|
uint32_t pixel;
|
||||||
|
|
||||||
// RGB 2 YUV conversion ratios
|
// RGB 2 YUV conversion ratios
|
||||||
@ -835,9 +835,16 @@ static void fillColor(GraphicBuffer *gBuf, RGBColor color, float trans)
|
|||||||
exit(51);
|
exit(51);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (unsigned int n1 = 0; n1 < numPixels; n1++) {
|
for (unsigned int row = 0; row < gBuf->getHeight(); row++) {
|
||||||
memmove(buf, &pixel, attrib->bytes);
|
for (unsigned int col = 0; col < gBuf->getWidth(); col++) {
|
||||||
buf += attrib->bytes;
|
memmove(buf, &pixel, attrib->bytes);
|
||||||
|
buf += attrib->bytes;
|
||||||
|
}
|
||||||
|
for (unsigned int pad = 0;
|
||||||
|
pad < (gBuf->getStride() - gBuf->getWidth()) * attrib->bytes;
|
||||||
|
pad++) {
|
||||||
|
*buf++ = testRandMod(256);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = gBuf->unlock();
|
err = gBuf->unlock();
|
||||||
@ -856,14 +863,13 @@ static void fillColor(GraphicBuffer *gBuf, YUVColor color, float trans)
|
|||||||
|
|
||||||
const struct yuvAttrib {
|
const struct yuvAttrib {
|
||||||
int format;
|
int format;
|
||||||
size_t padWidth;
|
|
||||||
bool planar;
|
bool planar;
|
||||||
unsigned int uSubSampX;
|
unsigned int uSubSampX;
|
||||||
unsigned int uSubSampY;
|
unsigned int uSubSampY;
|
||||||
unsigned int vSubSampX;
|
unsigned int vSubSampX;
|
||||||
unsigned int vSubSampY;
|
unsigned int vSubSampY;
|
||||||
} yuvAttributes[] = {
|
} yuvAttributes[] = {
|
||||||
{ HAL_PIXEL_FORMAT_YV12, 16, true, 2, 2, 2, 2},
|
{ HAL_PIXEL_FORMAT_YV12, true, 2, 2, 2, 2},
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct yuvAttrib *attrib;
|
const struct yuvAttrib *attrib;
|
||||||
@ -879,12 +885,6 @@ static void fillColor(GraphicBuffer *gBuf, YUVColor color, float trans)
|
|||||||
|
|
||||||
assert(attrib->planar == true); // So far, only know how to handle planar
|
assert(attrib->planar == true); // So far, only know how to handle planar
|
||||||
|
|
||||||
// If needed round width up to pad size
|
|
||||||
if (width % attrib->padWidth) {
|
|
||||||
width += attrib->padWidth - (width % attrib->padWidth);
|
|
||||||
}
|
|
||||||
assert((width % attrib->padWidth) == 0);
|
|
||||||
|
|
||||||
err = gBuf->lock(GRALLOC_USAGE_SW_WRITE_OFTEN, (void**)(&buf));
|
err = gBuf->lock(GRALLOC_USAGE_SW_WRITE_OFTEN, (void**)(&buf));
|
||||||
if (err != 0) {
|
if (err != 0) {
|
||||||
testPrintE("fillColor lock failed: %d", err);
|
testPrintE("fillColor lock failed: %d", err);
|
||||||
@ -892,23 +892,35 @@ static void fillColor(GraphicBuffer *gBuf, YUVColor color, float trans)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Fill in Y component
|
// Fill in Y component
|
||||||
for (unsigned int x = 0; x < width; x++) {
|
for (unsigned int row = 0; row < height; row++) {
|
||||||
for (unsigned int y = 0; y < height; y++) {
|
for (unsigned int col = 0; col < width; col++) {
|
||||||
*buf++ = (x < gBuf->getWidth()) ? (255 * color.y()) : 0;
|
*buf++ = 255 * color.y();
|
||||||
|
}
|
||||||
|
for (unsigned int pad = 0; pad < gBuf->getStride() - gBuf->getWidth();
|
||||||
|
pad++) {
|
||||||
|
*buf++ = testRandMod(256);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fill in U component
|
// Fill in U component
|
||||||
for (unsigned int x = 0; x < width; x += attrib->uSubSampX) {
|
for (unsigned int row = 0; row < height; row += attrib->uSubSampY) {
|
||||||
for (unsigned int y = 0; y < height; y += attrib->uSubSampY) {
|
for (unsigned int col = 0; col < width; col += attrib->uSubSampX) {
|
||||||
*buf++ = (x < gBuf->getWidth()) ? (255 * color.u()) : 0;
|
*buf++ = 255 * color.u();
|
||||||
|
}
|
||||||
|
for (unsigned int pad = 0; pad < gBuf->getStride() - gBuf->getWidth();
|
||||||
|
pad += attrib->uSubSampX) {
|
||||||
|
*buf++ = testRandMod(256);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fill in V component
|
// Fill in V component
|
||||||
for (unsigned int x = 0; x < width; x += attrib->vSubSampX) {
|
for (unsigned int row = 0; row < height; row += attrib->vSubSampY) {
|
||||||
for (unsigned int y = 0; y < height; y += attrib->vSubSampY) {
|
for (unsigned int col = 0; col < width; col += attrib->vSubSampX) {
|
||||||
*buf++ = (x < gBuf->getWidth()) ? (255 * color.v()) : 0;
|
*buf++ = 255 * color.v();
|
||||||
|
}
|
||||||
|
for (unsigned int pad = 0; pad < gBuf->getStride() - gBuf->getWidth();
|
||||||
|
pad += attrib->vSubSampX) {
|
||||||
|
*buf++ = testRandMod(256);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -989,7 +1001,7 @@ void init(void)
|
|||||||
eglQuerySurface(dpy, surface, EGL_HEIGHT, &height);
|
eglQuerySurface(dpy, surface, EGL_HEIGHT, &height);
|
||||||
checkEglError("eglQuerySurface");
|
checkEglError("eglQuerySurface");
|
||||||
|
|
||||||
fprintf(stderr, "Window dimensions: %d x %d", width, height);
|
testPrintI("Window dimensions: %d x %d", width, height);
|
||||||
|
|
||||||
printGLString("Version", GL_VERSION);
|
printGLString("Version", GL_VERSION);
|
||||||
printGLString("Vendor", GL_VENDOR);
|
printGLString("Vendor", GL_VENDOR);
|
||||||
@ -1017,7 +1029,7 @@ void init(void)
|
|||||||
*
|
*
|
||||||
* Creates an array of graphic buffers, within the global variable
|
* Creates an array of graphic buffers, within the global variable
|
||||||
* named frames. The graphic buffers are contained within a vector of
|
* named frames. The graphic buffers are contained within a vector of
|
||||||
* verctors. All the graphic buffers in a particular row are of the same
|
* vectors. All the graphic buffers in a particular row are of the same
|
||||||
* format and dimension. Each graphic buffer is uniformly filled with a
|
* format and dimension. Each graphic buffer is uniformly filled with a
|
||||||
* prandomly selected color. It is likely that each buffer, even
|
* prandomly selected color. It is likely that each buffer, even
|
||||||
* in the same row, will be filled with a unique color.
|
* in the same row, will be filled with a unique color.
|
||||||
@ -1039,7 +1051,12 @@ void initFrames(unsigned int seed)
|
|||||||
for (unsigned int row = 0; row < rows; row++) {
|
for (unsigned int row = 0; row < rows; row++) {
|
||||||
// All frames within a row have to have the same format and
|
// All frames within a row have to have the same format and
|
||||||
// dimensions. Width and height need to be >= 1.
|
// dimensions. Width and height need to be >= 1.
|
||||||
int format = graphicFormat[testRandMod(NUMA(graphicFormat))].format;
|
unsigned int formatIdx = testRandMod(NUMA(graphicFormat));
|
||||||
|
const struct graphicFormat *formatPtr = &graphicFormat[formatIdx];
|
||||||
|
int format = formatPtr->format;
|
||||||
|
|
||||||
|
// Pick width and height, which must be >= 1 and the size
|
||||||
|
// mod the wMod/hMod value must be equal to 0.
|
||||||
size_t w = (width * maxSizeRatio) * testRandFract();
|
size_t w = (width * maxSizeRatio) * testRandFract();
|
||||||
size_t h = (height * maxSizeRatio) * testRandFract();
|
size_t h = (height * maxSizeRatio) * testRandFract();
|
||||||
w = max(1u, w);
|
w = max(1u, w);
|
||||||
@ -1048,6 +1065,12 @@ void initFrames(unsigned int seed)
|
|||||||
testPrintI(" frame %u width: %u height: %u format: %u %s",
|
testPrintI(" frame %u width: %u height: %u format: %u %s",
|
||||||
row, w, h, format, graphicFormat2str(format));
|
row, w, h, format, graphicFormat2str(format));
|
||||||
}
|
}
|
||||||
|
if ((w % formatPtr->wMod) != 0) {
|
||||||
|
w += formatPtr->wMod - (w % formatPtr->wMod);
|
||||||
|
}
|
||||||
|
if ((h % formatPtr->hMod) != 0) {
|
||||||
|
h += formatPtr->hMod - (h % formatPtr->hMod);
|
||||||
|
}
|
||||||
|
|
||||||
size_t cols = testRandMod((maxCols + 1) - minCols) + minCols;
|
size_t cols = testRandMod((maxCols + 1) - minCols) + minCols;
|
||||||
frames[row].resize(cols);
|
frames[row].resize(cols);
|
||||||
|
Loading…
Reference in New Issue
Block a user