diff --git a/ChangeLog b/ChangeLog index fad579bf56..efa9d15d73 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2172,3 +2172,9 @@ interfaces to read from graphics memory * graphics/nxbe/nxbe_bitmap.c: Fix an error in the error handling that can cause valid bitmaps to fail to render. + * include/nuttx/rgbcolors.h: Fix errors in some 16- and 8-bit color + conversion macros. + * tools/incdir.sh: Fix issues when g++ is used as the compiler. It was + not being recognized and handled properly. + * graphics/nxsu/nx_releasebkgdg.c: Fix a bad cast that was causing + problems with the backgournd window was released. diff --git a/configs/sim/nsh/defconfig b/configs/sim/nsh/defconfig index a64830e7e7..010e08c26f 100644 --- a/configs/sim/nsh/defconfig +++ b/configs/sim/nsh/defconfig @@ -58,6 +58,7 @@ CONFIG_ARCH_BOARD_SIM=y # CONFIG_DEBUG_VERBOSE - enables verbose debug output # CONFIG_DEBUG_SYMBOLS - build without optimization and with # debug symbols (needed for use with a debugger). +# CONFIG_HAVE_CXX - Enable support for C++ # CONFIG_MM_REGIONS - If the architecture includes multiple # regions of memory to allocate from, this specifies the # number of memory regions that the memory manager must @@ -118,6 +119,7 @@ CONFIG_ARCH_BOARD_SIM=y CONFIG_DEBUG=y CONFIG_DEBUG_VERBOSE=y CONFIG_DEBUG_SYMBOLS=n +CONFIG_HAVE_CXX=n CONFIG_MM_REGIONS=1 CONFIG_ARCH_LOWPUTC=y CONFIG_RR_INTERVAL=0 diff --git a/configs/sim/nx/defconfig b/configs/sim/nx/defconfig index 3dfd3e820f..e70163be70 100644 --- a/configs/sim/nx/defconfig +++ b/configs/sim/nx/defconfig @@ -65,6 +65,7 @@ CONFIG_SIM_FBBPP=8 # CONFIG_DEBUG_VERBOSE - enables verbose debug output # CONFIG_DEBUG_SYMBOLS - build without optimization and with # debug symbols (needed for use with a debugger). +# CONFIG_HAVE_CXX - Enable support for C++ # CONFIG_MM_REGIONS - If the architecture includes multiple # regions of memory to allocate from, this specifies the # number of memory regions that the memory manager must @@ -126,6 +127,7 @@ CONFIG_DEBUG=y CONFIG_DEBUG_VERBOSE=y CONFIG_DEBUG_SYMBOLS=n CONFIG_DEBUG_GRAPHICS=y +CONFIG_HAVE_CXX=n CONFIG_MM_REGIONS=1 CONFIG_ARCH_LOWPUTC=y CONFIG_RR_INTERVAL=0 diff --git a/graphics/nxmu/nx_releasebkgd.c b/graphics/nxmu/nx_releasebkgd.c index 1326e951ed..4e8a756790 100644 --- a/graphics/nxmu/nx_releasebkgd.c +++ b/graphics/nxmu/nx_releasebkgd.c @@ -2,7 +2,7 @@ * graphics/nxmu/nx_releasebkgd.c * * Copyright (C) 2008-2009, 2011 Gregory Nutt. All rights reserved. - * Author: Gregory Nutt + * Author: Gregory Nutt * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions diff --git a/graphics/nxsu/nx_releasebkgd.c b/graphics/nxsu/nx_releasebkgd.c index a19b85ac42..b0cbbf5c16 100644 --- a/graphics/nxsu/nx_releasebkgd.c +++ b/graphics/nxsu/nx_releasebkgd.c @@ -2,7 +2,7 @@ * graphics/nxsu/nx_releasebkgd.c * * Copyright (C) 2008-2009 Gregory Nutt. All rights reserved. - * Author: Gregory Nutt + * Author: Gregory Nutt * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -86,11 +86,10 @@ int nx_releasebkgd(NXWINDOW hwnd) { - FAR struct nxfe_state_s *fe = (FAR struct nxfe_state_s *)hwnd; - FAR struct nxbe_state_s *be = &fe->be; + FAR struct nxbe_window_s *bkgd = (FAR struct nxbe_window_s *)hwnd; #ifdef CONFIG_DEBUG - if (!fe) + if (!bkgd) { errno = EINVAL; return ERROR; @@ -99,12 +98,12 @@ int nx_releasebkgd(NXWINDOW hwnd) /* Restore the NX background window callbacks */ - be->bkgd.cb = &g_bkgdcb; - be->bkgd.arg = NULL; + bkgd->cb = &g_bkgdcb; + bkgd->arg = NULL; /* Redraw the background window */ - nxfe_redrawreq(&be->bkgd, &be->bkgd.bounds); + nxfe_redrawreq(bkgd, &bkgd->bounds); return OK; } diff --git a/include/nuttx/rgbcolors.h b/include/nuttx/rgbcolors.h index d2fcba8f13..93212f6e17 100644 --- a/include/nuttx/rgbcolors.h +++ b/include/nuttx/rgbcolors.h @@ -70,7 +70,7 @@ /* This macro creates RGB8 (3:3:2) from 8:8:8 RGB */ #define RGBTO8(r,g,b) \ - ((((uint8_t)(r) << 5) & 0xe0) | (((uint8_t)(r) << 2) & 0x1c) | ((uint8_t)(r) & 0x03)) + ((((uint8_t)(r) << 5) & 0xe0) | (((uint8_t)(g) << 2) & 0x1c) | ((uint8_t)(b) & 0x03)) /* And these macros perform the inverse transformation */ diff --git a/tools/incdir.sh b/tools/incdir.sh index 76f767e839..be6a1d07a7 100755 --- a/tools/incdir.sh +++ b/tools/incdir.sh @@ -2,7 +2,7 @@ # tools/incdir.sh # # Copyright (C) 2008-2009, 2011 Gregory Nutt. All rights reserved. -# Author: Gregory Nutt +# Author: Gregory Nutt # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions @@ -111,27 +111,29 @@ fi os=`uname -o 2>/dev/null || echo "Other"` -# Let's assume that all GCC compiler paths contain the string gcc and -# no non-GCC compiler pathes include this substring +# Let's assume that all GCC compiler paths contain the string gcc or +# g++ and no non-GCC compiler pathes include these substrings gcc=`echo $ccpath | grep gcc` +if [ -z "${gcc}" ]; then + gcc=`echo $ccpath | grep g++` +fi + sdcc=`echo $ccpath | grep sdcc` if [ "X$os" = "XCygwin" ]; then # We can treat Cygwin native toolchains just like Linux native # toolchains in the Linux. Let's assume: # 1. GCC or SDCC are the only possible Cygwin native compilers - # 2. If this is a Window native GCC version, then -w provided - # on the command line (wintool=y) + # 2. If this is a Window native GCC version, then -w must be + # provided on the command line (wintool=y) if [ -z "$gcc" -a -z "$sdcc" ]; then - # Not GCC or SDCC, must be Windows native windows=yes compiler=`cygpath -u "$ccpath"` else if [ "X$wintool" == "Xy" ]; then - # It is a native GCC or SDCC compiler windows=yes compiler=`cygpath -u "$ccpath"`