2008-11-27 23:56:45 +01:00
|
|
|
/****************************************************************************
|
2010-04-17 05:08:30 +02:00
|
|
|
* graphics/nxbe/nxbe_configure.c
|
2008-11-27 23:56:45 +01:00
|
|
|
*
|
2019-03-14 21:38:56 +01:00
|
|
|
* Copyright (C) 2008-2010, 2019 Gregory Nutt. All rights reserved.
|
2011-10-14 18:58:44 +02:00
|
|
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
2008-11-27 23:56:45 +01:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
|
|
|
* used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
2009-12-17 20:24:18 +01:00
|
|
|
#include <stddef.h>
|
2008-11-27 23:56:45 +01:00
|
|
|
#include <errno.h>
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
#include "nxbe.h"
|
|
|
|
|
|
|
|
/****************************************************************************
|
2015-04-08 16:32:05 +02:00
|
|
|
* Pre-processor Definitions
|
2008-11-27 23:56:45 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2014-07-12 04:47:12 +02:00
|
|
|
#ifndef CONFIG_NX_BGCOLOR
|
|
|
|
# define CONFIG_NX_BGCOLOR 0
|
|
|
|
#endif
|
|
|
|
|
2008-11-27 23:56:45 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Private Data
|
|
|
|
****************************************************************************/
|
|
|
|
|
2014-07-12 04:47:12 +02:00
|
|
|
static const nxgl_mxpixel_t g_bgcolor[CONFIG_NX_NPLANES] =
|
|
|
|
{
|
|
|
|
CONFIG_NX_BGCOLOR
|
|
|
|
|
|
|
|
#if CONFIG_NX_NPLANES > 1
|
|
|
|
# warning Missing logic for multiple color planes
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
2008-11-27 23:56:45 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
2010-04-17 05:08:30 +02:00
|
|
|
* Name: nxbe_configure
|
2008-11-27 23:56:45 +01:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Configure the back end state structure based on information from the
|
|
|
|
* framebuffer driver
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2010-04-18 04:56:15 +02:00
|
|
|
int nxbe_configure(FAR NX_DRIVERTYPE *dev, FAR struct nxbe_state_s *be)
|
2008-11-27 23:56:45 +01:00
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
/* Get the video controller configuration */
|
|
|
|
|
2010-04-18 04:56:15 +02:00
|
|
|
ret = dev->getvideoinfo(dev, &be->vinfo);
|
2008-11-27 23:56:45 +01:00
|
|
|
if (ret < 0)
|
|
|
|
{
|
2016-06-12 19:11:57 +02:00
|
|
|
gerr("ERROR: Failed to get vinfo\n");
|
2008-11-27 23:56:45 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2014-07-12 04:47:12 +02:00
|
|
|
/* Set the initial background color */
|
|
|
|
|
|
|
|
nxgl_colorcopy(be->bgcolor, g_bgcolor);
|
|
|
|
|
2008-11-27 23:56:45 +01:00
|
|
|
/* Check the number of color planes */
|
|
|
|
|
2019-03-17 18:34:45 +01:00
|
|
|
#ifdef CONFIG_DEBUG_GRAPHICS
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->vinfo.nplanes > CONFIG_NX_NPLANES)
|
|
|
|
{
|
2016-06-12 19:11:57 +02:00
|
|
|
gerr("ERROR: NX configured for only %d planes, controller wants %d\n",
|
2008-11-27 23:56:45 +01:00
|
|
|
CONFIG_NX_NPLANES, be->vinfo.nplanes);
|
|
|
|
return -E2BIG;
|
|
|
|
}
|
|
|
|
else if (be->vinfo.nplanes < CONFIG_NX_NPLANES)
|
|
|
|
{
|
2016-06-12 19:11:57 +02:00
|
|
|
gwarn("WARNING: NX configured for %d planes, controller only needs %d\n",
|
2008-11-27 23:56:45 +01:00
|
|
|
CONFIG_NX_NPLANES, be->vinfo.nplanes);
|
|
|
|
}
|
2010-04-17 18:00:58 +02:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
|
|
|
|
/* Then get information about each color plane */
|
|
|
|
|
|
|
|
for (i = 0; i < be->vinfo.nplanes; i++)
|
|
|
|
{
|
2010-04-18 04:56:15 +02:00
|
|
|
ret = dev->getplaneinfo(dev, i, &be->plane[i].pinfo);
|
2008-11-27 23:56:45 +01:00
|
|
|
if (ret < 0)
|
|
|
|
{
|
2016-06-12 19:11:57 +02:00
|
|
|
gerr("ERROR: Failed to get pinfo[%d]\n", i);
|
2008-11-27 23:56:45 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Select rasterizers to match the BPP reported for this plane.
|
|
|
|
* NOTE that there are configuration options to eliminate support
|
|
|
|
* for unused BPP values. If the unused BPP values are not suppressed
|
|
|
|
* in this way, then ALL rasterizers will be drawn into the link and
|
|
|
|
* will signicantly increase the size
|
|
|
|
*/
|
|
|
|
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_1BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 1)
|
|
|
|
{
|
2019-03-14 21:38:56 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_1bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_1bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_1bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_1bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_1bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_1bpp;
|
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_1bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_1bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_1bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_1bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_1bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_1bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_2BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 2)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_2bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_2bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_2bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_2bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_2bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_2bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_2bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_2bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_2bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_2bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_2bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_2bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_4BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 4)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_4bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_4bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_4bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_4bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_4bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_4bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_4bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_4bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_4bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_4bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_4bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_4bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_8BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 8)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_8bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_8bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_8bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_8bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_8bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_8bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_8bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_8bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_8bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_8bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_8bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_8bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_16BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 16)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_16bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_16bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_16bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_16bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_16bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_16bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_16bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_16bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_16bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_16bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_16bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_16bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_24BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 24)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_24bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_24bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_24bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_24bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_24bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_24bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_24bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_24bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_24bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_24bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_24bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_24bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
2008-12-05 15:04:37 +01:00
|
|
|
#ifndef CONFIG_NX_DISABLE_32BPP
|
2008-11-27 23:56:45 +01:00
|
|
|
if (be->plane[i].pinfo.bpp == 32)
|
|
|
|
{
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].dev.setpixel = nxgl_setpixel_32bpp;
|
|
|
|
be->plane[i].dev.fillrectangle = nxgl_fillrectangle_32bpp;
|
|
|
|
be->plane[i].dev.getrectangle = nxgl_getrectangle_32bpp;
|
|
|
|
be->plane[i].dev.filltrapezoid = nxgl_filltrapezoid_32bpp;
|
|
|
|
be->plane[i].dev.moverectangle = nxgl_moverectangle_32bpp;
|
|
|
|
be->plane[i].dev.copyrectangle = nxgl_copyrectangle_32bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_NX_RAMBACKED
|
2019-03-15 19:15:33 +01:00
|
|
|
be->plane[i].pwfb.setpixel = pwfb_setpixel_1bpp;
|
|
|
|
be->plane[i].pwfb.fillrectangle = pwfb_fillrectangle_32bpp;
|
|
|
|
be->plane[i].pwfb.getrectangle = pwfb_getrectangle_32bpp;
|
|
|
|
be->plane[i].pwfb.filltrapezoid = pwfb_filltrapezoid_32bpp;
|
|
|
|
be->plane[i].pwfb.moverectangle = pwfb_moverectangle_32bpp;
|
|
|
|
be->plane[i].pwfb.copyrectangle = pwfb_copyrectangle_32bpp;
|
2019-03-14 21:38:56 +01:00
|
|
|
#endif
|
2008-11-27 23:56:45 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
|
|
|
{
|
2019-03-14 21:38:56 +01:00
|
|
|
gerr("ERROR: Unsupported pinfo[%d] BPP: %d\n",
|
|
|
|
i, be->plane[i].pinfo.bpp);
|
2008-11-27 23:56:45 +01:00
|
|
|
return -ENOSYS;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return OK;
|
|
|
|
}
|