From 33fc8a1cc2854a225d5da0174efc8eb6325c2f3a Mon Sep 17 00:00:00 2001 From: woglinde Date: Tue, 3 Feb 2009 13:50:02 +0100 Subject: dietlibc: introduce dietlibc to openembedded --- packages/dietlibc/files/ai_addrconfig.patch | 13 ++++ packages/dietlibc/files/ccache.patch | 74 ++++++++++++++++++++++ packages/dietlibc/files/ceil.patch | 97 +++++++++++++++++++++++++++++ 3 files changed, 184 insertions(+) create mode 100644 packages/dietlibc/files/ai_addrconfig.patch create mode 100644 packages/dietlibc/files/ccache.patch create mode 100644 packages/dietlibc/files/ceil.patch (limited to 'packages/dietlibc/files') diff --git a/packages/dietlibc/files/ai_addrconfig.patch b/packages/dietlibc/files/ai_addrconfig.patch new file mode 100644 index 0000000000..5687e9f0f4 --- /dev/null +++ b/packages/dietlibc/files/ai_addrconfig.patch @@ -0,0 +1,13 @@ +Index: dietlibc-0.31/include/sys/socket.h +=================================================================== +--- dietlibc-0.31.orig/include/sys/socket.h 2009-02-03 13:39:38.475445568 +0100 ++++ dietlibc-0.31/include/sys/socket.h 2009-02-03 13:39:55.742105983 +0100 +@@ -439,6 +439,8 @@ + #define EAI_AGAIN -10 + #define EAI_SYSTEM -11 + ++#define AI_ADDRCONFIG 0 ++ + #define AI_NUMERICHOST 1 + #define AI_CANONNAME 2 + #define AI_PASSIVE 4 diff --git a/packages/dietlibc/files/ccache.patch b/packages/dietlibc/files/ccache.patch new file mode 100644 index 0000000000..f6d72f5370 --- /dev/null +++ b/packages/dietlibc/files/ccache.patch @@ -0,0 +1,74 @@ +Index: dietlibc-0.31/diet.c +=================================================================== +--- dietlibc-0.31.orig/diet.c 2006-08-27 15:49:00.000000000 +0200 ++++ dietlibc-0.31/diet.c 2009-01-31 22:56:06.828080683 +0100 +@@ -127,7 +127,12 @@ + } + } + { +- char *cc=argv[1]; ++ char *cc; ++ if (!strcmp(argv[1],"ccache")) { ++ cc=argv[2]; ++ } else { ++ cc=argv[1]; ++ } + char *tmp=strchr(cc,0)-2; + char *tmp2,*tmp3; + if (tmp90) error("platform name too long!\n"); + shortplatform=platform+len; +- memmove(shortplatform,argv[1],(size_t)(tmp2-cc)); ++ memmove(shortplatform,cc,(size_t)(tmp2-cc)); + platform[tmp2-cc+len]=0; + if (shortplatform[0]=='i' && shortplatform[2]=='8' && shortplatform[3]=='6') shortplatform[1]='3'; + } else { +@@ -285,6 +290,9 @@ + + dest=newargv; + *dest++=argv[1]; ++ if (strcmp(argv[1],"ccache") == 0) { ++ *dest++=argv[2]; ++ } + if (argv[2]) { + if (!strcmp(argv[2],"-V")) { + *dest++=argv[2]; +@@ -294,9 +302,9 @@ + } else if (!memcmp(argv[2],"-V",2)) { + *dest++=argv[2]; + ++argv; +- --argc; + } + } ++ + #ifndef __DYN_LIB + if (_link) { *dest++=(char*)nostdlib; *dest++=dashstatic; *dest++=dashL; } + #else +@@ -314,7 +322,15 @@ + #ifdef WANT_DYNAMIC + if (_link) { *dest++=d; } + #endif +- for (i=2; i ++ ++typedef union { ++ double value; ++ struct { ++ unsigned int lsw; ++ unsigned int msw; ++ } parts; ++} ieee_double_shape_type; ++ ++/* Get two 32 bit ints from a double. */ ++ ++#define EXTRACT_WORDS(ix0,ix1,d) \ ++do { \ ++ ieee_double_shape_type ew_u; \ ++ ew_u.value = (d); \ ++ (ix0) = ew_u.parts.msw; \ ++ (ix1) = ew_u.parts.lsw; \ ++} while (0) ++ ++#define INSERT_WORDS(d,ix0,ix1) \ ++do { \ ++ ieee_double_shape_type iw_u; \ ++ iw_u.parts.msw = (ix0); \ ++ iw_u.parts.lsw = (ix1); \ ++ (d) = iw_u.value; \ ++} while (0) ++ ++static const double huge = 1.0e300; ++ ++double ceil(double x) ++{ ++ int i0,i1,j0; ++ unsigned int i,j; ++ EXTRACT_WORDS(i0,i1,x); ++ j0 = ((i0>>20)&0x7ff)-0x3ff; ++ if(j0<20) { ++ if(j0<0) { /* raise inexact if x != 0 */ ++ if(huge+x>0.0) {/* return 0*sign(x) if |x|<1 */ ++ if(i0<0) {i0=0x80000000;i1=0;} ++ else if((i0|i1)!=0) { i0=0x3ff00000;i1=0;} ++ } ++ } else { ++ i = (0x000fffff)>>j0; ++ if(((i0&i)|i1)==0) return x; /* x is integral */ ++ if(huge+x>0.0) { /* raise inexact flag */ ++ if(i0>0) i0 += (0x00100000)>>j0; ++ i0 &= (~i); i1=0; ++ } ++ } ++ } else if (j0>51) { ++ if(j0==0x400) return x+x; /* inf or NaN */ ++ else return x; /* x is integral */ ++ } else { ++ i = ((unsigned int)(0xffffffff))>>(j0-20); ++ if((i1&i)==0) return x; /* x is integral */ ++ if(huge+x>0.0) { /* raise inexact flag */ ++ if(i0>0) { ++ if(j0==20) i0+=1; ++ else { ++ j = i1 + (1<<(52-j0)); ++ if(j