Add missing RGB type
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@3314 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
89e4925a46
commit
6ac240a7eb
15
TODO
15
TODO
@ -11,7 +11,7 @@ NuttX TODO List (Last updated February 11, 2011)
|
|||||||
(16) Network (net/, drivers/net)
|
(16) Network (net/, drivers/net)
|
||||||
(5) Network Utilities (netutils/)
|
(5) Network Utilities (netutils/)
|
||||||
(1) USB (drivers/usbdev)
|
(1) USB (drivers/usbdev)
|
||||||
(4) Libraries (lib/)
|
(5) Libraries (lib/)
|
||||||
(12) File system/Generic drivers (fs/, drivers/)
|
(12) File system/Generic drivers (fs/, drivers/)
|
||||||
(2) Graphics subystem (graphics/)
|
(2) Graphics subystem (graphics/)
|
||||||
(1) Pascal add-on (pcode/)
|
(1) Pascal add-on (pcode/)
|
||||||
@ -355,6 +355,19 @@ o Libraries (lib/)
|
|||||||
Status: Open
|
Status: Open
|
||||||
Priority: Low
|
Priority: Low
|
||||||
|
|
||||||
|
Description: There is an issue with the way that getopt() handles errors that
|
||||||
|
return '?'.
|
||||||
|
|
||||||
|
1. Does getopt() reset its global variables after returning '?' so
|
||||||
|
that it can be re-used? That would be required to support where
|
||||||
|
the caller terminates parsing before reaching the last parameter.
|
||||||
|
2. Or is the client expected to continue parsing after getopt()
|
||||||
|
returns '?' and parse until the final parameter?
|
||||||
|
|
||||||
|
The current getopt() implementation only supports #2.
|
||||||
|
Status: Open
|
||||||
|
Priority: Low
|
||||||
|
|
||||||
o File system / Generic drivers (fs/, drivers/)
|
o File system / Generic drivers (fs/, drivers/)
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* include/nuttx/fb.h
|
* include/nuttx/fb.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2008-2010 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2008-2011 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -67,96 +67,97 @@
|
|||||||
|
|
||||||
#define FB_FMT_RGB1 3 /* BPP=1 */
|
#define FB_FMT_RGB1 3 /* BPP=1 */
|
||||||
#define FB_FMT_RGB4 4 /* BPP=4 */
|
#define FB_FMT_RGB4 4 /* BPP=4 */
|
||||||
#define FB_FMT_RGB8_332 5 /* BPP=8 */
|
#define FB_FMT_RGB8 5 /* BPP=8 RGB palette index */
|
||||||
#define FB_FMT_RGB12_444 6 /* BPP=12 */
|
#define FB_FMT_RGB8_332 6 /* BPP=8 R=3, G=3, B=2 */
|
||||||
#define FB_FMT_RGB16_555 7 /* BPP=16 R=5, G=5, B=5 (1 unused bit) */
|
#define FB_FMT_RGB12_444 7 /* BPP=12 R=4, G=4, B=4 */
|
||||||
#define FB_FMT_RGB16_565 8 /* BPP=16 R=6, G=6, B=5 */
|
#define FB_FMT_RGB16_555 8 /* BPP=16 R=5, G=5, B=5 (1 unused bit) */
|
||||||
#define FB_FMT_RGB24 9 /* BPP=24 */
|
#define FB_FMT_RGB16_565 9 /* BPP=16 R=6, G=6, B=5 */
|
||||||
#define FB_FMT_RGB32 10 /* BPP=32 */
|
#define FB_FMT_RGB24 10 /* BPP=24 */
|
||||||
|
#define FB_FMT_RGB32 11 /* BPP=32 */
|
||||||
|
|
||||||
/* Run length encoded RGB */
|
/* Run length encoded RGB */
|
||||||
|
|
||||||
#define FB_FMT_RGBRLE4 11 /* BPP=4 */
|
#define FB_FMT_RGBRLE4 12 /* BPP=4 */
|
||||||
#define FB_FMT_RGBRLE8 12 /* BPP=8 */
|
#define FB_FMT_RGBRLE8 13 /* BPP=8 */
|
||||||
|
|
||||||
/* Raw RGB */
|
/* Raw RGB */
|
||||||
|
|
||||||
#define FB_FMT_RGBRAW 13 /* BPP=? */
|
#define FB_FMT_RGBRAW 14 /* BPP=? */
|
||||||
|
|
||||||
/* Raw RGB with arbitrary sample packing within a pixel. Packing and precision
|
/* Raw RGB with arbitrary sample packing within a pixel. Packing and precision
|
||||||
* of R, G and B components is determined by bit masks for each.
|
* of R, G and B components is determined by bit masks for each.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define FB_FMT_RGBBTFLD16 14 /* BPP=16 */
|
#define FB_FMT_RGBBTFLD16 15 /* BPP=16 */
|
||||||
#define FB_FMT_RGBBTFLD24 15 /* BPP=24 */
|
#define FB_FMT_RGBBTFLD24 16 /* BPP=24 */
|
||||||
#define FB_FMT_RGBBTFLD32 16 /* BPP=32 */
|
#define FB_FMT_RGBBTFLD32 17 /* BPP=32 */
|
||||||
#define FB_FMT_RGBA16 17 /* BPP=16 Raw RGB with alpha */
|
#define FB_FMT_RGBA16 18 /* BPP=16 Raw RGB with alpha */
|
||||||
#define FB_FMT_RGBA32 18 /* BPP=32 Raw RGB with alpha */
|
#define FB_FMT_RGBA32 19 /* BPP=32 Raw RGB with alpha */
|
||||||
|
|
||||||
/* Raw RGB with a transparency field. Layout is as for stanadard RGB at 16 and
|
/* Raw RGB with a transparency field. Layout is as for stanadard RGB at 16 and
|
||||||
* 32 bits per pixel but the msb in each pixel indicates whether the pixel is
|
* 32 bits per pixel but the msb in each pixel indicates whether the pixel is
|
||||||
* transparent or not.
|
* transparent or not.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define FB_FMT_RGBT16 19 /* BPP=16 */
|
#define FB_FMT_RGBT16 20 /* BPP=16 */
|
||||||
#define FB_FMT_RGBT32 20 /* BPP=32 */
|
#define FB_FMT_RGBT32 21 /* BPP=32 */
|
||||||
|
|
||||||
#define FB_ISRGB(f) ((f) >= FB_FMT_RGB1) && (f) <= FB_FMT_RGBT32)
|
#define FB_ISRGB(f) ((f) >= FB_FMT_RGB1) && (f) <= FB_FMT_RGBT32)
|
||||||
|
|
||||||
/* Packed YUV Formats *******************************************************/
|
/* Packed YUV Formats *******************************************************/
|
||||||
|
|
||||||
#define FB_FMT_AYUV 21 /* BPP=32 Combined YUV and alpha */
|
#define FB_FMT_AYUV 22 /* BPP=32 Combined YUV and alpha */
|
||||||
#define FB_FMT_CLJR 22 /* BPP=8 4 pixels packed into a uint32_t.
|
#define FB_FMT_CLJR 23 /* BPP=8 4 pixels packed into a uint32_t.
|
||||||
* YUV 4:1:1 with l< 8 bits per YUV sample */
|
* YUV 4:1:1 with l< 8 bits per YUV sample */
|
||||||
#define FB_FMT_CYUV 23 /* BPP=16 UYVY except that height is reversed */
|
#define FB_FMT_CYUV 24 /* BPP=16 UYVY except that height is reversed */
|
||||||
#define FB_FMT_IRAW 24 /* BPP=? Intel uncompressed YUV */
|
#define FB_FMT_IRAW 25 /* BPP=? Intel uncompressed YUV */
|
||||||
#define FB_FMT_IUYV 25 /* BPP=16 Interlaced UYVY (line order
|
#define FB_FMT_IUYV 26 /* BPP=16 Interlaced UYVY (line order
|
||||||
* 0,2,4,.., 1,3,5...) */
|
* 0,2,4,.., 1,3,5...) */
|
||||||
#define FB_FMT_IY41 26 /* BPP=12 Interlaced Y41P (line order
|
#define FB_FMT_IY41 27 /* BPP=12 Interlaced Y41P (line order
|
||||||
* 0,2,4,.., 1,3,5...) */
|
* 0,2,4,.., 1,3,5...) */
|
||||||
#define FB_FMT_IYU2 27 /* BPP=24 */
|
#define FB_FMT_IYU2 28 /* BPP=24 */
|
||||||
#define FB_FMT_HDYC 28 /* BPP=16 UYVY except uses the BT709 color space */
|
#define FB_FMT_HDYC 29 /* BPP=16 UYVY except uses the BT709 color space */
|
||||||
#define FB_FMT_UYVP 29 /* BPP=24? YCbCr 4:2:2, 10-bits per component in U0Y0V0Y1 order */
|
#define FB_FMT_UYVP 30 /* BPP=24? YCbCr 4:2:2, 10-bits per component in U0Y0V0Y1 order */
|
||||||
#define FB_FMT_UYVY 30 /* BPP=16 YUV 4:2:2 */
|
#define FB_FMT_UYVY 31 /* BPP=16 YUV 4:2:2 */
|
||||||
#define FB_FMT_UYNV FB_FMT_UYVY /* BPP=16 */
|
#define FB_FMT_UYNV FB_FMT_UYVY /* BPP=16 */
|
||||||
#define FB_FMT_Y422 FB_FMT_UYVY /* BPP=16 */
|
#define FB_FMT_Y422 FB_FMT_UYVY /* BPP=16 */
|
||||||
#define FB_FMT_V210 31 /* BPP=32 10-bit 4:2:2 YCrCb */
|
#define FB_FMT_V210 32 /* BPP=32 10-bit 4:2:2 YCrCb */
|
||||||
#define FB_FMT_V422 32 /* BPP=16 Upside down version of UYVY */
|
#define FB_FMT_V422 33 /* BPP=16 Upside down version of UYVY */
|
||||||
#define FB_FMT_V655 33 /* BPP=16? 16-bit YUV 4:2:2 */
|
#define FB_FMT_V655 34 /* BPP=16? 16-bit YUV 4:2:2 */
|
||||||
#define FB_FMT_VYUY 34 /* BPP=? ATI Packed YUV Data */
|
#define FB_FMT_VYUY 35 /* BPP=? ATI Packed YUV Data */
|
||||||
#define FB_FMT_YUYV 35 /* BPP=16 YUV 4:2:2 */
|
#define FB_FMT_YUYV 36 /* BPP=16 YUV 4:2:2 */
|
||||||
#define FB_FMT_YUY2 FB_FMT_YUYV /* BPP=16 YUV 4:2:2 */
|
#define FB_FMT_YUY2 FB_FMT_YUYV /* BPP=16 YUV 4:2:2 */
|
||||||
#define FB_FMT_YUNV FB_FMT_YUYV /* BPP=16 YUV 4:2:2 */
|
#define FB_FMT_YUNV FB_FMT_YUYV /* BPP=16 YUV 4:2:2 */
|
||||||
#define FB_FMT_YVYU 36 /* BPP=16 YUV 4:2:2 */
|
#define FB_FMT_YVYU 37 /* BPP=16 YUV 4:2:2 */
|
||||||
#define FB_FMT_Y41P 37 /* BPP=12 YUV 4:1:1 */
|
#define FB_FMT_Y41P 38 /* BPP=12 YUV 4:1:1 */
|
||||||
#define FB_FMT_Y411 38 /* BPP=12 YUV 4:1:1 */
|
#define FB_FMT_Y411 39 /* BPP=12 YUV 4:1:1 */
|
||||||
#define FB_FMT_Y211 39 /* BPP=8 */
|
#define FB_FMT_Y211 40 /* BPP=8 */
|
||||||
#define FB_FMT_Y41T 40 /* BPP=12 Y41P LSB for transparency */
|
#define FB_FMT_Y41T 41 /* BPP=12 Y41P LSB for transparency */
|
||||||
#define FB_FMT_Y42T 41 /* BPP=16 UYVY LSB for transparency */
|
#define FB_FMT_Y42T 42 /* BPP=16 UYVY LSB for transparency */
|
||||||
#define FB_FMT_YUVP 42 /* BPP=24? YCbCr 4:2:2 Y0U0Y1V0 order */
|
#define FB_FMT_YUVP 43 /* BPP=24? YCbCr 4:2:2 Y0U0Y1V0 order */
|
||||||
|
|
||||||
#define FB_ISYUVPACKED(f) ((f) >= FB_FMT_AYUV) && (f) <= FB_FMT_YUVP)
|
#define FB_ISYUVPACKED(f) ((f) >= FB_FMT_AYUV) && (f) <= FB_FMT_YUVP)
|
||||||
|
|
||||||
/* Packed Planar YUV Formats ************************************************/
|
/* Packed Planar YUV Formats ************************************************/
|
||||||
|
|
||||||
#define FB_FMT_YVU9 43 /* BPP=9 8-bit Y followed by 8-bit 4x4 VU */
|
#define FB_FMT_YVU9 44 /* BPP=9 8-bit Y followed by 8-bit 4x4 VU */
|
||||||
#define FB_FMT_YUV9 44 /* BPP=9? */
|
#define FB_FMT_YUV9 45 /* BPP=9? */
|
||||||
#define FB_FMT_IF09 45 /* BPP=9.5 YVU9 + 4x4 plane of delta relative to tframe. */
|
#define FB_FMT_IF09 46 /* BPP=9.5 YVU9 + 4x4 plane of delta relative to tframe. */
|
||||||
#define FB_FMT_YV16 46 /* BPP=16 8-bit Y followed by 8-bit 2x1 VU */
|
#define FB_FMT_YV16 47 /* BPP=16 8-bit Y followed by 8-bit 2x1 VU */
|
||||||
#define FB_FMT_YV12 47 /* BPP=12 8-bit Y followed by 8-bit 2x2 VU */
|
#define FB_FMT_YV12 48 /* BPP=12 8-bit Y followed by 8-bit 2x2 VU */
|
||||||
#define FB_FMT_I420 48 /* BPP=12 8-bit Y followed by 8-bit 2x2 UV */
|
#define FB_FMT_I420 49 /* BPP=12 8-bit Y followed by 8-bit 2x2 UV */
|
||||||
#define FB_FMT_IYUV FB_FMT_I420 /* BPP=12 */
|
#define FB_FMT_IYUV FB_FMT_I420 /* BPP=12 */
|
||||||
#define FB_FMT_NV12 49 /* BPP=12 8-bit Y followed by an interleaved 2x2 UV */
|
#define FB_FMT_NV12 50 /* BPP=12 8-bit Y followed by an interleaved 2x2 UV */
|
||||||
#define FB_FMT_NV21 50 /* BPP=12 NV12 with UV reversed */
|
#define FB_FMT_NV21 51 /* BPP=12 NV12 with UV reversed */
|
||||||
#define FB_FMT_IMC1 51 /* BPP=12 YV12 except UV planes ame stride as Y */
|
#define FB_FMT_IMC1 52 /* BPP=12 YV12 except UV planes ame stride as Y */
|
||||||
#define FB_FMT_IMC2 52 /* BPP=12 IMC1 except UV lines interleaved at half stride boundaries */
|
#define FB_FMT_IMC2 53 /* BPP=12 IMC1 except UV lines interleaved at half stride boundaries */
|
||||||
#define FB_FMT_IMC3 53 /* BPP=12 As IMC1 except that UV swapped */
|
#define FB_FMT_IMC3 54 /* BPP=12 As IMC1 except that UV swapped */
|
||||||
#define FB_FMT_IMC4 54 /* BPP=12 As IMC2 except that UV swapped */
|
#define FB_FMT_IMC4 55 /* BPP=12 As IMC2 except that UV swapped */
|
||||||
#define FB_FMT_CLPL 55 /* BPP=12 YV12 but including a level of indirection. */
|
#define FB_FMT_CLPL 56 /* BPP=12 YV12 but including a level of indirection. */
|
||||||
#define FB_FMT_Y41B 56 /* BPP=12? 4:1:1 planar. */
|
#define FB_FMT_Y41B 57 /* BPP=12? 4:1:1 planar. */
|
||||||
#define FB_FMT_Y42B 57 /* BPP=16? YUV 4:2:2 planar. */
|
#define FB_FMT_Y42B 58 /* BPP=16? YUV 4:2:2 planar. */
|
||||||
#define FB_FMT_CXY1 58 /* BPP=12 */
|
#define FB_FMT_CXY1 59 /* BPP=12 */
|
||||||
#define FB_FMT_CXY2 59 /* BPP=16 */
|
#define FB_FMT_CXY2 60 /* BPP=16 */
|
||||||
|
|
||||||
#define FB_ISYUVPLANAR(f) ((f) >= FB_FMT_AYUV) && (f) <= FB_FMT_YUVP)
|
#define FB_ISYUVPLANAR(f) ((f) >= FB_FMT_AYUV) && (f) <= FB_FMT_YUVP)
|
||||||
#define FB_ISYUV(f) (FB_ISYUVPACKED(f) || FB_ISYUVPLANAR(f))
|
#define FB_ISYUV(f) (FB_ISYUVPACKED(f) || FB_ISYUVPLANAR(f))
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* lib/lib_getopt.c
|
* lib/lib_getopt.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007-2009 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2007-2009, 2011 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -85,7 +85,7 @@ static bool g_binitialized = false;
|
|||||||
* If there are no more option characters, getopt() returns -1. Then optind
|
* If there are no more option characters, getopt() returns -1. Then optind
|
||||||
* is the index in argv of the first argv-element that is not an option.
|
* is the index in argv of the first argv-element that is not an option.
|
||||||
*
|
*
|
||||||
* The 'optstring argument is a string containing the legitimate option
|
* The 'optstring' argument is a string containing the legitimate option
|
||||||
* characters. If such a character is followed by a colon, this indicates
|
* characters. If such a character is followed by a colon, this indicates
|
||||||
* that the option requires an argument. If an argument is required for an
|
* that the option requires an argument. If an argument is required for an
|
||||||
* option so getopt() places a pointer to the following text in the same
|
* option so getopt() places a pointer to the following text in the same
|
||||||
@ -95,6 +95,11 @@ static bool g_binitialized = false;
|
|||||||
* 1. opterr is not supported and this implementation of getopt() never
|
* 1. opterr is not supported and this implementation of getopt() never
|
||||||
* printfs error messages.
|
* printfs error messages.
|
||||||
* 2. getopt is NOT threadsafe!
|
* 2. getopt is NOT threadsafe!
|
||||||
|
* 3. This version of getopt() does not reset global variables until
|
||||||
|
* -1 is returned. As a result, your command line parsing loops
|
||||||
|
* must call getopt() repeatedly and continue to parse if other
|
||||||
|
* errors are returned ('?' or ':') until getopt() finally returns -1.
|
||||||
|
* (You can also set optind to -1 to force a reset).
|
||||||
*
|
*
|
||||||
* Return: If an option was successfully found, then getopt() returns the
|
* Return: If an option was successfully found, then getopt() returns the
|
||||||
* option character. If all command-line options have been parsed, then
|
* option character. If all command-line options have been parsed, then
|
||||||
@ -162,9 +167,6 @@ int getopt(int argc, FAR char *const argv[], FAR const char *optstring)
|
|||||||
/* There are no more arguments, we are finished */
|
/* There are no more arguments, we are finished */
|
||||||
|
|
||||||
g_binitialized = false;
|
g_binitialized = false;
|
||||||
|
|
||||||
/* Return -1 with optind == all of the arguments */
|
|
||||||
|
|
||||||
return ERROR;
|
return ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -176,11 +178,7 @@ int getopt(int argc, FAR char *const argv[], FAR const char *optstring)
|
|||||||
{
|
{
|
||||||
/* The argument does not start with '-', we are finished */
|
/* The argument does not start with '-', we are finished */
|
||||||
|
|
||||||
g_optptr = NULL;
|
|
||||||
g_binitialized = false;
|
g_binitialized = false;
|
||||||
|
|
||||||
/* Return the -1 with optind set to the non-option argument */
|
|
||||||
|
|
||||||
return ERROR;
|
return ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -226,13 +224,15 @@ int getopt(int argc, FAR char *const argv[], FAR const char *optstring)
|
|||||||
|
|
||||||
if (optchar[1] != ':')
|
if (optchar[1] != ':')
|
||||||
{
|
{
|
||||||
/* No, just return the character that we found */
|
/* No, no arguments. Just return the character that we found */
|
||||||
|
|
||||||
g_optptr++;
|
g_optptr++;
|
||||||
return *optchar;
|
return *optchar;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Yes. Is the required argument after the command in this same argument? */
|
/* Yes, it has a required argument. Is the required argument
|
||||||
|
* immediately after the command in this same argument?
|
||||||
|
*/
|
||||||
|
|
||||||
if (g_optptr[1] != '\0')
|
if (g_optptr[1] != '\0')
|
||||||
{
|
{
|
||||||
@ -264,6 +264,6 @@ int getopt(int argc, FAR char *const argv[], FAR const char *optstring)
|
|||||||
return noarg_ret;
|
return noarg_ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
optind = 1;
|
g_binitialized = false;
|
||||||
return ERROR;
|
return ERROR;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user