diff --git a/ChangeLog b/ChangeLog index a1f19142b7..b757197851 100644 --- a/ChangeLog +++ b/ChangeLog @@ -585,3 +585,5 @@ * Added fixed precision math support * Added some color converson routines into what may become a real graphics library someday. * Added a framebuffer driver for the DM320 (untested on initial check-in) + * Network: add support for outgoing multicast addresses + * Added some rasterizers to the graphics library diff --git a/Documentation/NuttX.html b/Documentation/NuttX.html index f24304ccca..b752096b60 100644 --- a/Documentation/NuttX.html +++ b/Documentation/NuttX.html @@ -8,7 +8,7 @@

NuttX RTOS

-

Last Updated: November 25, 2008

+

Last Updated: November 26, 2008

@@ -1221,6 +1221,8 @@ nuttx-0.3.19 2008-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr> * Added fixed precision math support * Added some color converson routines into what may become a real graphics library someday. * Added a framebuffer driver for the DM320 (untested on initial check-in) + * Network: add support for outgoing multicast addresses + * Added some rasterizers to the graphics library pascal-0.1.3 2008-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr> diff --git a/graphics/Makefile b/graphics/Makefile index fc258d997c..63f1b82de9 100644 --- a/graphics/Makefile +++ b/graphics/Makefile @@ -62,9 +62,10 @@ BIN = libgraphics$(LIBEXT) VPATH = nxglib:nx -all: $(BIN) -.PHONY : depend clean distclean gensources gen1bppsources gen2bppsource gen4bppsource \ - gen8bppsource gen16bppsource gen24bppsource gen32bppsources +all: mklibgraphics +.PHONY : depend clean distclean mklibgraphics gensources gen1bppsources \ + gen2bppsource gen4bppsource gen8bppsource gen16bppsource gen24bppsource \ + gen32bppsources gen1bppsources: @make -C nxglib -f Makefile.sources TOPDIR=$(TOPDIR) NXGLIB_BITSPERPIXEL=1 @@ -95,11 +96,13 @@ $(AOBJS): %$(OBJEXT): %.S $(COBJS): %$(OBJEXT): %.c $(call COMPILE, $<, $@) -$(BIN): gensources $(OBJS) +$(BIN): $(OBJS) @( for obj in $(OBJS) ; do \ $(call ARCHIVE, $@, $${obj}); \ done ; ) +mklibgraphics: gensources $(BIN) + .depend: gensources Makefile $(SRCS) @$(MKDEP) $(DEPPATH) $(CC) -- $(CFLAGS) -- $(SRCS) >Make.dep @touch $@ diff --git a/graphics/nxglib/Make.defs b/graphics/nxglib/Make.defs index bf7c2bef86..9d7a16d8ef 100644 --- a/graphics/nxglib/Make.defs +++ b/graphics/nxglib/Make.defs @@ -35,9 +35,14 @@ NXGLIB_ASRCS = -#FILL_CSRCS1 = nxglib_fillrectangle_1bpp.c nxglib_fillrectangle_2bpp.c \ +#FILL1_CSRCS = nxglib_fillrectangle_1bpp.c nxglib_fillrectangle_2bpp.c \ # nxglib_fillrectangle_4bpp.c -FILL_CSRCS2 = nxglib_fillrectangle_8bpp.c nxglib_fillrectangle_16bpp.c \ +FILL2_CSRCS = nxglib_fillrectangle_8bpp.c nxglib_fillrectangle_16bpp.c \ nxglib_fillrectangle_24bpp.c nxglib_fillrectangle_32bpp.c -NXGLIB_CSRCS = nxglib_rgb2yuv.c nxglib_yuv2rgb.c $(FILL_CSRCS1) $(FILL_CSRCS2) +#MOVE1_CSRCS = nxglib_moverectangle_1bpp.c nxglib_moverectangle_2bpp.c \ +# nxglib_moverectangle_4bpp.c +MOVE2_CSRCS = nxglib_moverectangle_8bpp.c nxglib_moverectangle_16bpp.c \ + nxglib_moverectangle_24bpp.c nxglib_moverectangle_32bpp.c +NXGLIB_CSRCS = nxglib_rgb2yuv.c nxglib_yuv2rgb.c \ + $(FILL1_CSRCS) $(FILL2_CSRCS) $(MOVE1_CSRCS) $(MOVE2_CSRCS) diff --git a/graphics/nxglib/Makefile.sources b/graphics/nxglib/Makefile.sources index 2d38547a29..a282867a18 100644 --- a/graphics/nxglib/Makefile.sources +++ b/graphics/nxglib/Makefile.sources @@ -65,8 +65,12 @@ FILL1_CSRCS = nxglib_fillrectangle_1bpp.c nxglib_fillrectangle_2bpp.c \ nxglib_fillrectangle_4bpp.c FILL2_CSRCS = nxglib_fillrectangle_8bpp.c nxglib_fillrectangle_16bpp.c \ nxglib_fillrectangle_24bpp.c nxglib_fillrectangle_32bpp.c +MOVE1_CSRCS = nxglib_moverectangle_1bpp.c nxglib_moverectangle_2bpp.c \ + nxglib_moverectangle_4bpp.c +MOVE2_CSRCS = nxglib_moverectangle_8bpp.c nxglib_moverectangle_16bpp.c \ + nxglib_moverectangle_24bpp.c nxglib_moverectangle_32bpp.c -GEN_CSRCS = $(FILL1_CSRCS) $(FILL2_CSRCS) +GEN_CSRCS = $(FILL1_CSRCS) $(FILL2_CSRCS) $(MOVE1_CSRCS) $(MOVE2_CSRCS) all: $(GEN_CSRCS) .PHONY : clean distclean @@ -81,9 +85,18 @@ ifneq ($(NXGLIB_BITSPERPIXEL),) $(call PREPROCESS, nxglib_fillrectangle.c, $@) endif +$(MOVE1_CSRCS) : nxglib_moverectangle.c nxglib_bitblit.h +ifneq ($(NXGLIB_BITSPERPIXEL),) + $(call PREPROCESS, nxglib_moverectangle.c, $@) +endif + +$(MOVE2_CSRCS) : nxglib_moverectangle.c nxglib_bitblit.h +ifneq ($(NXGLIB_BITSPERPIXEL),) + $(call PREPROCESS, nxglib_moverectangle.c, $@) +endif clean: @rm -f *~ .*.swp distclean: clean - @rm -f nxglib_fillrectangle_*bpp.c + @rm -f nxglib_fillrectangle_*bpp.c nxglib_moverectangle_*bpp.c diff --git a/graphics/nxglib/nxglib_bitblit.h b/graphics/nxglib/nxglib_bitblit.h index b327204bdc..c53e369cf5 100644 --- a/graphics/nxglib/nxglib_bitblit.h +++ b/graphics/nxglib/nxglib_bitblit.h @@ -61,69 +61,69 @@ #if NXGLIB_BITSPERPIXEL == 1 -# define NX_PIXELSHIFT 3 -# define NX_PIXELMASK 7 -# define NX_MULTIPIXEL(p) ((p) ? 0xff | 0x00) -# define NX_PIXEL_T ubyte +# define NXGL_PIXELSHIFT 3 +# define NXGL_PIXELMASK 7 +# define NXGL_MULTIPIXEL(p) ((p) ? 0xff | 0x00) +# define NXGL_PIXEL_T ubyte #elif NXGLIB_BITSPERPIXEL == 2 -# define NX_PIXELSHIFT 2 -# define NX_PIXELMASK 3 -# define NX_MULTIPIXEL(p) ((ubyte)(p) << 6 | (ubyte)(p) << 4 | (ubyte)(p) << 2 | (p)) -# define NX_PIXEL_T ubyte +# define NXGL_PIXELSHIFT 2 +# define NXGL_PIXELMASK 3 +# define NXGL_MULTIPIXEL(p) ((ubyte)(p) << 6 | (ubyte)(p) << 4 | (ubyte)(p) << 2 | (p)) +# define NXGL_PIXEL_T ubyte #elif NXGLIB_BITSPERPIXEL == 4 -# define NX_PIXELSHIFT 1 -# define NX_PIXELMASK 1 -# define NX_MULTIPIXEL(p) ((ubyte)(p) << 4 | (p)) -# define NX_PIXEL_T ubyte +# define NXGL_PIXELSHIFT 1 +# define NXGL_PIXELMASK 1 +# define NXGL_MULTIPIXEL(p) ((ubyte)(p) << 4 | (p)) +# define NXGL_PIXEL_T ubyte #elif NXGLIB_BITSPERPIXEL == 8 -# define NX_SCALEX(x) (x) -# define NX_PIXEL_T ubyte +# define NXGL_SCALEX(x) (x) +# define NXGL_PIXEL_T ubyte #elif NXGLIB_BITSPERPIXEL == 16 -# define NX_SCALEX(x) ((x) << 1) -# define NX_PIXEL_T uint16 +# define NXGL_SCALEX(x) ((x) << 1) +# define NXGL_PIXEL_T uint16 #elif NXGLIB_BITSPERPIXEL == 24 -# define NX_SCALEX(x) (((x) << 1) + (x)) -# define NX_PIXEL_T uint32 +# define NXGL_SCALEX(x) (((x) << 1) + (x)) +# define NXGL_PIXEL_T uint32 #elif NXGLIB_BITSPERPIXEL == 32 -# define NX_SCALEX(x) ((x) << 2) -# define NX_PIXEL_T uint32 +# define NXGL_SCALEX(x) ((x) << 2) +# define NXGL_PIXEL_T uint32 #endif #if NXGLIB_BITSPERPIXEL < 8 -# define NX_SCALEX(x) ((x) >> NX_PIXELSHIFT) -# define NX_REMAINDERX(x) ((x) & NX_PIXELMASK) -# define NX_ALIGNDOWN(x) ((x) & ~NX_PIXELMASK) -# define NX_ALIGNUP(x) (((x) + NX_PIXELMASK) & ~NX_PIXELMASK) +# define NXGL_SCALEX(x) ((x) >> NXGL_PIXELSHIFT) +# define NXGL_REMAINDERX(x) ((x) & NXGL_PIXELMASK) +# define NXGL_ALIGNDOWN(x) ((x) & ~NXGL_PIXELMASK) +# define NXGL_ALIGNUP(x) (((x) + NXGL_PIXELMASK) & ~NXGL_PIXELMASK) -# ifdef CONFIG_NX_PACKEDMSFIRST -# define NX_MASKEDSRC1(s,r) ((s) & (((ubyte)0xff) >> (8 - ((r) << pixelshift)))) -# define NX_MASKEDVALUE1(s,r) ((s) & (((ubyte)0xff) << ((r) << NX_PIXELSHFIT))) -# define NX_MASKEDSRC2(s,r) ((s) & (((ubyte)0xff) >> ((r) << pixelshift))) -# define NX_MASKEDVALUE2(s,r) ((s) & (((ubyte)0xff) << (8 - ((r) << NX_PIXELSHFIT)))) +# ifdef CONFIG_NXGL_PACKEDMSFIRST +# define NXGL_MASKEDSRC1(s,r) ((s) & (((ubyte)0xff) >> (8 - ((r) << pixelshift)))) +# define NXGL_MASKEDVALUE1(s,r) ((s) & (((ubyte)0xff) << ((r) << NXGL_PIXELSHFIT))) +# define NXGL_MASKEDSRC2(s,r) ((s) & (((ubyte)0xff) >> ((r) << pixelshift))) +# define NXGL_MASKEDVALUE2(s,r) ((s) & (((ubyte)0xff) << (8 - ((r) << NXGL_PIXELSHFIT)))) # else -# define NX_MASKEDSRC1(s,r) ((s) & (((ubyte)0xff) >> ((r) << pixelshift))) -# define NX_MASKEDVALUE1(s,r) ((s) & (((ubyte)0xff) << (8 - ((r) << NX_PIXELSHFIT)))) -# define NX_MASKEDSRC2(s,r) ((s) & (((ubyte)0xff) >> (8 - ((r) << pixelshift)))) -# define NX_MASKEDVALUE2(s,r) ((s) & (((ubyte)0xff) << ((r) << NX_PIXELSHFIT))) +# define NXGL_MASKEDSRC1(s,r) ((s) & (((ubyte)0xff) >> ((r) << pixelshift))) +# define NXGL_MASKEDVALUE1(s,r) ((s) & (((ubyte)0xff) << (8 - ((r) << NXGL_PIXELSHFIT)))) +# define NXGL_MASKEDSRC2(s,r) ((s) & (((ubyte)0xff) >> (8 - ((r) << pixelshift)))) +# define NXGL_MASKEDVALUE2(s,r) ((s) & (((ubyte)0xff) << ((r) << NXGL_PIXELSHFIT))) # endif # define NXGL_MEMSET(dest,value,width) \ { \ FAR ubyte *_ptr = (FAR ubyte*)dest; \ - int nbytes = NX_SCALEX(width); \ + int nbytes = NXGL_SCALEX(width); \ while (nbytes--) \ { \ *_ptr++ = value; \ @@ -133,8 +133,8 @@ { \ FAR ubyte *_dptr = (FAR ubyte*)dest; \ FAR ubyte *_sptr = (FAR ubyte*)src; \ - int nbytes = NX_SCALEX(width); \ - while (npixels--) \ + int nbytes = NXGL_SCALEX(width); \ + while (nbytes--) \ { \ *_dptr++ = *_sptr++; \ } \ diff --git a/graphics/nxglib/nxglib_fillrectangle.c b/graphics/nxglib/nxglib_fillrectangle.c index 3da969c4aa..727c575804 100644 --- a/graphics/nxglib/nxglib_fillrectangle.c +++ b/graphics/nxglib/nxglib_fillrectangle.c @@ -74,7 +74,7 @@ ****************************************************************************/ /**************************************************************************** - * Name: nxgl_fillrectangle* + * Name: nxgl_fillrectangle_*bpp * * Descripton: * Fill a rectangle region in the framebuffer memory with a fixed color @@ -82,7 +82,7 @@ ****************************************************************************/ void NXGL_FUNCNAME(nxgl_fillrectangle,NXGLIB_SUFFIX) -(FAR struct fb_planeinfo_s *pinfo, FAR const struct nxgl_rect_s *rect, NX_PIXEL_T color) +(FAR struct fb_planeinfo_s *pinfo, FAR const struct nxgl_rect_s *rect, NXGL_PIXEL_T color) { ubyte *line; unsigned int width; @@ -100,7 +100,7 @@ void NXGL_FUNCNAME(nxgl_fillrectangle,NXGLIB_SUFFIX) /* Get the address of the first byte in the first line to write */ - line = pinfo->fbmem + rect->pt1.y * stride + NX_SCALEX(rect->pt1.x); + line = pinfo->fbmem + rect->pt1.y * stride + NXGL_SCALEX(rect->pt1.x); /* Then fill the rectangle line-by-line */ diff --git a/graphics/nxglib/nxglib_moverectangle.c b/graphics/nxglib/nxglib_moverectangle.c new file mode 100644 index 0000000000..154cf39b14 --- /dev/null +++ b/graphics/nxglib/nxglib_moverectangle.c @@ -0,0 +1,126 @@ +/**************************************************************************** + * graphics/nxglib/nxglib_moverectangle.c + * + * Copyright (C) 2008 Gregory Nutt. All rights reserved. + * Author: Gregory Nutt + * + * 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 + +#include +#include +#include + +#include "nxglib_bitblit.h" + +/**************************************************************************** + * Pre-Processor Definitions + ****************************************************************************/ + +/**************************************************************************** + * Private Types + ****************************************************************************/ + +/**************************************************************************** + * Private Data + ****************************************************************************/ + +/**************************************************************************** + * Public Data + ****************************************************************************/ + +/**************************************************************************** + * Private Functions + ****************************************************************************/ + +/**************************************************************************** + * Public Functions + ****************************************************************************/ + +/**************************************************************************** + * Name: nxgl_moverectangle_*bpp + * + * Descripton: + * Move a rectangular region from location to another in the + * framebuffer memory. + * + ****************************************************************************/ + +void NXGL_FUNCNAME(nxgl_moverectangle,NXGLIB_SUFFIX) +(FAR struct fb_planeinfo_s *pinfo, FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset) +{ + const ubyte *sptr; + ubyte *dptr; + unsigned int width; + unsigned int stride; + unsigned int rows; + + /* Get the width of the framebuffer in bytes */ + + stride = pinfo->stride; + + /* Get the dimensions of the rectange to fill: height in rows and width in bytes */ + + width = NXGL_SCALEX(rect->pt2.x - rect->pt1.x); + rows = rect->pt2.y - rect->pt1.y; + + /* Case 1: The starting position is above the display */ + + if (offset->y < 0) + { + dptr = pinfo->fbmem + rect->pt1.y * stride + NXGL_SCALEX(rect->pt1.x); + sptr = dptr - offset->y * stride - NXGL_SCALEX(offset->x); + + while (rows--) + { + NXGL_MEMCPY(dptr, sptr, width); + dptr += stride; + sptr += stride; + } + } + else + { + dptr = pinfo->fbmem + rect->pt2.y * stride + NXGL_SCALEX(rect->pt1.x); + sptr = dptr - offset->y * stride - NXGL_SCALEX(offset->x); + + while (rows--) + { + dptr -= stride; + sptr -= stride; + NXGL_MEMCPY(dptr, sptr, width); + } + } +} diff --git a/graphics/nxglib/nxglib_rgb2yuv.c b/graphics/nxglib/nxglib_rgb2yuv.c index fca2082e27..49a29ca671 100644 --- a/graphics/nxglib/nxglib_rgb2yuv.c +++ b/graphics/nxglib/nxglib_rgb2yuv.c @@ -85,7 +85,6 @@ * Description: * Convert 8-bit RGB triplet to 8-bit YUV triplet * - * ****************************************************************************/ void nxgl_rgb2yuv(ubyte r, ubyte g, ubyte b, ubyte *y, ubyte *u, ubyte *v) diff --git a/graphics/nxglib/nxglib_yuv2rgb.c b/graphics/nxglib/nxglib_yuv2rgb.c index 18c16dd91e..72002d8af4 100644 --- a/graphics/nxglib/nxglib_yuv2rgb.c +++ b/graphics/nxglib/nxglib_yuv2rgb.c @@ -81,7 +81,6 @@ * Description: * Convert 8-bit RGB triplet to 8-bit YUV triplet * - * ****************************************************************************/ void nxgl_yuv2rgb(ubyte y, ubyte u, ubyte v, ubyte *r, ubyte *g, ubyte *b) diff --git a/include/nuttx/nxglib.h b/include/nuttx/nxglib.h index b9269ed526..a7abe89df7 100644 --- a/include/nuttx/nxglib.h +++ b/include/nuttx/nxglib.h @@ -68,8 +68,8 @@ struct nxgl_point_s struct nxgl_rect_s { - struct nxgl_point_t pt1; /* Upper, left-hand corner */ - struct nxgl_point_t pt2; /* Lower, right-hand corner */ + struct nxgl_point_s pt1; /* Upper, left-hand corner */ + struct nxgl_point_s pt2; /* Lower, right-hand corner */ }; /**************************************************************************** @@ -88,11 +88,91 @@ extern "C" { * Public Function Prototypes ****************************************************************************/ -/* Color conversons */ +/* Color conversons *********************************************************/ + +/**************************************************************************** + * Name: nxgl_rgb2yuv + * + * Description: + * Convert 8-bit RGB triplet to 8-bit YUV triplet + * + ****************************************************************************/ EXTERN void nxgl_rgb2yuv(ubyte r, ubyte g, ubyte b, ubyte *y, ubyte *u, ubyte *v); + +/**************************************************************************** + * Name: nxgl_yuv2rgb + * + * Description: + * Convert 8-bit RGB triplet to 8-bit YUV triplet + * + ****************************************************************************/ + EXTERN void nxgl_yuv2rgb(ubyte y, ubyte u, ubyte v, ubyte *r, ubyte *g, ubyte *b); +/* Rasterizers **************************************************************/ + +/**************************************************************************** + * Name: nxgl_fillrectangle_*bpp + * + * Descripton: + * Fill a rectangle region in the framebuffer memory with a fixed color + * + ****************************************************************************/ + +EXTERN void nxgl_fillrectangle_1bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + ubyte color); +EXTERN void nxgl_fillrectangle_2bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + ubyte color); +EXTERN void nxgl_fillrectangle_4bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + ubyte color); +EXTERN void nxgl_fillrectangle_8bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + ubyte color); +EXTERN void nxgl_fillrectangle_16bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + uint16 color); +EXTERN void nxgl_fillrectangle_24bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + uint32 color); +EXTERN void nxgl_fillrectangle_32bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + uint32 color); + +/**************************************************************************** + * Name: nxgl_moverectangle_*bpp + * + * Descripton: + * Move a rectangular region from location to another in the + * framebuffer memory. + * + ****************************************************************************/ + +EXTERN void nxgl_moverectangle_1bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_2bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_4bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_8bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_16bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_24bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); +EXTERN void nxgl_moverectangle_32bpp(FAR struct fb_planeinfo_s *pinfo, + FAR const struct nxgl_rect_s *rect, + FAR struct nxgl_point_s *offset); + #undef EXTERN #if defined(__cplusplus) }