nuttx-update/graphics/nxbe/nxbe_colormap.c
Alin Jerpelea 0a17b87286 graphics: migrate to SPDX identifier
Most tools used for compliance and SBOM generation use SPDX identifiers
This change brings us a step closer to an easy SBOM generation.

Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>
2024-09-10 22:54:31 +08:00

127 lines
3.3 KiB
C

/****************************************************************************
* graphics/nxbe/nxbe_colormap.c
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <debug.h>
#include <nuttx/kmalloc.h>
#include "nxbe.h"
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: nxbe_colormap
*
* Description:
* Set the hardware color map to the palette expected by NX
*
****************************************************************************/
#ifdef CONFIG_FB_CMAP
int nxbe_colormap(FAR NX_DRIVERTYPE *dev)
{
struct fb_cmap_s cmap;
FAR uint8_t *alloc;
FAR uint8_t *red;
FAR uint8_t *green;
FAR uint8_t *blue;
uint8_t rval;
uint8_t gval;
int size;
int ndx;
int ret;
int i;
int j;
int k;
/* Allocate the color map tables in one allocation:
*
* size = 3 colors x CONFIG_NX_COLORS each x 8-bits per color
*/
size = 3 * CONFIG_NX_NCOLORS * sizeof(uint8_t);
alloc = kmm_malloc(size);
if (alloc == NULL)
{
return -ENOMEM;
}
memset(alloc, 0xff, size);
/* Then get pointers to each color table */
red = alloc;
green = &alloc[CONFIG_NX_NCOLORS];
blue = &alloc[2*CONFIG_NX_NCOLORS];
/* Initialize the color map tables. 6*6*6 = 216, the rest
* are (0xff, 0xfff 0xff)
*/
ndx = 0;
for (i = 0; i < 6; i++)
{
rval = (i * (CONFIG_NX_NCOLORS - 1) / 5) << 8;
for (j = 0; j < 6; j++)
{
gval = (j * (CONFIG_NX_NCOLORS - 1) / 5) << 8;
for (k = 0; k < 6; k++)
{
red[ndx] = rval;
green[ndx] = gval;
blue[ndx] = k * (CONFIG_NX_NCOLORS - 1) / 5;
ndx++;
}
}
}
/* Now configure the cmap structure */
cmap.first = 0;
cmap.len = CONFIG_NX_NCOLORS;
cmap.red = red;
cmap.green = green;
cmap.blue = blue;
#ifdef CONFIG_FB_TRANSPARENCY
cmap.transp = NULL;
#endif
/* Then set the color map */
ret = dev->putcmap(dev, &cmap);
kmm_free(alloc);
return ret;
}
#endif