浏览代码

move include path options to each component.

git-svn-id: https://rt-thread.googlecode.com/svn/trunk@113 bbd45198-f89e-11dd-88c7-29a3b14d5316
bernard.xiong 15 年之前
父节点
当前提交
9a7ae65085
共有 6 个文件被更改,包括 261 次插入2 次删除
  1. 76 0
      filesystem/dfs/SConscript
  2. 3 0
      finsh/SConscript
  3. 3 0
      libc/minilibc/SConscript
  4. 174 0
      libc/minilibc/time.c
  5. 3 0
      libcpu/SConscript
  6. 2 2
      net/lwip/SConscript

+ 76 - 0
filesystem/dfs/SConscript

@@ -0,0 +1,76 @@
+Import('env')
+Import('rtconfig')
+Import('RTT_ROOT')
+
+dfs = Split("""
+src/dfs_cache.c
+src/dfs_fs.c
+src/dfs_init.c
+src/dfs_posix.c
+src/dfs_raw.c
+src/dfs_util.c
+""")
+
+# DFS-FatFs options
+fatfs = Split("""
+filesystems/fatfs/fatfs_cache.c
+filesystems/fatfs/fatfs_direntry.c
+filesystems/fatfs/fatfs_fat.c
+filesystems/fatfs/fatfs_file.c
+filesystems/fatfs/fatfs_filename.c
+filesystems/fatfs/fatfs_init.c
+filesystems/fatfs_misc.c
+filesystems/fatfs/fatfs_mount.c""")
+
+# DFS-EFSL options
+efsl = Split("""
+filesystems/efsl/src/base/efs.c
+filesystems/efsl/src/base/extract.c
+filesystems/efsl/src/base/partition.c
+filesystems/efsl/src/base/plibc.c
+filesystems/efsl/src/fs/vfat/dir.c
+filesystems/efsl/src/fs/vfat/fat.c
+filesystems/efsl/src/fs/vfat/file.c
+filesystems/efsl/src/fs/vfat/fs.c
+filesystems/efsl/src/fs/vfat/ls.c
+filesystems/efsl/src/fs/vfat/time.c
+filesystems/efsl/src/fs/vfat/ui.c
+""")
+
+# DFS-YAFFS2 options
+yaffs2_main = Split("""
+filesystems/yaffs2/direct/yaffscfg.c
+filesystems/yaffs2/direct/yaffs_fileem.c
+filesystems/yaffs2/direct/yaffsfs.c
+filesystems/yaffs2/direct/dfs_yaffs2.c
+""")
+
+yaffs2_comm = Split("""
+filesystems/yaffs2/yaffs_ecc.c
+filesystems/yaffs2/yaffs_guts.c
+filesystems/yaffs2/yaffs_packedtags1.c
+filesystems/yaffs2/yaffs_tagscompat.c
+filesystems/yaffs2/yaffs_packedtags2.c
+filesystems/yaffs2/yaffs_tagsvalidity.c
+filesystems/yaffs2/yaffs_nand.c
+filesystems/yaffs2/yaffs_checkptrw.c
+filesystems/yaffs2/yaffs_qsort.c
+""")
+
+# The set of source files associated with this SConscript file.
+src_local = dfs
+path = [RTT_ROOT + '/filesystem/dfs', RTT_ROOT + '/filesystem/dfs/include']
+
+if rtconfig.RT_USING_DFS_YAFFS2:
+    src_local = src_local + yaffs2_main + yaffs2_comm
+    path = path + [RTT_ROOT + '/filesystem/dfs/filesystems/yaffs2', RTT_ROOT + '/filesystem/dfs/filesystems/yaffs2/direct']
+
+if rtconfig.RT_USING_DFS_EFSL:
+    src_local = src_local + efsl
+    path = path + [RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/include', RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/base/include', RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/fs/vfat/include']
+
+env.Append(CPPPATH = path)
+
+obj = env.Object(src_local)
+
+Return('obj')

+ 3 - 0
finsh/SConscript

@@ -1,7 +1,10 @@
 Import('env')
+Import('RTT_ROOT')
 
 # The set of source files associated with this SConscript file.
 src_local = Glob('*.c')
 
+env.Append(CPPPATH = RTT_ROOT + '/finsh')
+
 obj = env.Object(src_local)
 Return('obj')

+ 3 - 0
libc/minilibc/SConscript

@@ -1,7 +1,10 @@
 Import('env')
+Import('RTT_ROOT')
 
 # The set of source files associated with this SConscript file.
 src_local = Glob('*.c')
 
+env.Append(CPPPATH = RTT_ROOT + '/libc/minilibc')
+
 obj = env.Object(src_local)
 Return('obj')

+ 174 - 0
libc/minilibc/time.c

@@ -0,0 +1,174 @@
+#include <time.h>
+
+/* days per month -- nonleap! */
+const short __spm[13] =
+  { 0,
+    (31),
+    (31+28),
+    (31+28+31),
+    (31+28+31+30),
+    (31+28+31+30+31),
+    (31+28+31+30+31+30),
+    (31+28+31+30+31+30+31),
+    (31+28+31+30+31+30+31+31),
+    (31+28+31+30+31+30+31+31+30),
+    (31+28+31+30+31+30+31+31+30+31),
+    (31+28+31+30+31+30+31+31+30+31+30),
+    (31+28+31+30+31+30+31+31+30+31+30+31),
+  };
+static long int timezone;
+static const char days[] = "Sun Mon Tue Wed Thu Fri Sat ";
+static const char months[] = "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec ";
+
+/* seconds per day */
+#define SPD 24*60*60
+
+int __isleap(int year) {
+  /* every fourth year is a leap year except for century years that are
+   * not divisible by 400. */
+/*  return (year % 4 == 0 && (year % 100 != 0 || year % 400 == 0)); */
+  return (!(year%4) && ((year%100) || !(year%400)));
+}
+
+struct tm *gmtime_r(const time_t *timep, struct tm *r) {
+  time_t i;
+  register time_t work=*timep%(SPD);
+  r->tm_sec=work%60; work/=60;
+  r->tm_min=work%60; r->tm_hour=work/60;
+  work=*timep/(SPD);
+  r->tm_wday=(4+work)%7;
+  for (i=1970; ; ++i) {
+    register time_t k=__isleap(i)?366:365;
+    if (work>=k)
+      work-=k;
+    else
+      break;
+  }
+  r->tm_year=i-1900;
+  r->tm_yday=work;
+
+  r->tm_mday=1;
+  if (__isleap(i) && (work>58)) {
+    if (work==59) r->tm_mday=2; /* 29.2. */
+    work-=1;
+  }
+
+  for (i=11; i && (__spm[i]>work); --i) ;
+  r->tm_mon=i;
+  r->tm_mday+=work-__spm[i];
+  return r;
+}
+
+struct tm* localtime_r(const time_t* t, struct tm* r) {
+  time_t tmp;
+  struct timezone tz;
+  gettimeofday(0, &tz);
+  timezone=tz.tz_minuteswest*60L;
+  tmp=*t+timezone;
+  return gmtime_r(&tmp,r);
+}
+
+struct tm* localtime(const time_t* t) {
+  static struct tm tmp;
+  return localtime_r(t,&tmp);
+}
+
+time_t timegm(struct tm *const t) {
+  register time_t  day;
+  register time_t  i;
+  register time_t years = t->tm_year - 70;
+
+  if (t->tm_sec>60) { t->tm_min += t->tm_sec/60; t->tm_sec%=60; }
+  if (t->tm_min>60) { t->tm_hour += t->tm_min/60; t->tm_min%=60; }
+  if (t->tm_hour>60) { t->tm_mday += t->tm_hour/60; t->tm_hour%=60; }
+  if (t->tm_mon>12) { t->tm_year += t->tm_mon/12; t->tm_mon%=12; }
+  while (t->tm_mday>__spm[1+t->tm_mon]) {
+    if (t->tm_mon==1 && __isleap(t->tm_year+1900)) {
+      if (t->tm_mon==31+29) break;
+      --t->tm_mday;
+    }
+    t->tm_mday-=__spm[t->tm_mon];
+    ++t->tm_mon;
+    if (t->tm_mon>11) { t->tm_mon=0; ++t->tm_year; }
+  }
+
+  if (t->tm_year < 70)
+    return (time_t) -1;
+
+  /* Days since 1970 is 365 * number of years + number of leap years since 1970 */
+  day  = years * 365 + (years + 1) / 4;
+
+  /* After 2100 we have to substract 3 leap years for every 400 years
+     This is not intuitive. Most mktime implementations do not support
+     dates after 2059, anyway, so we might leave this out for it's
+     bloat. */
+  if ((years -= 131) >= 0) {
+    years /= 100;
+    day -= (years >> 2) * 3 + 1;
+    if ((years &= 3) == 3) years--;
+    day -= years;
+  }
+
+  day += t->tm_yday = __spm [t->tm_mon] + t->tm_mday-1 + ( __isleap (t->tm_year+1900)  &  (t->tm_mon > 1) );
+
+  /* day is now the number of days since 'Jan 1 1970' */
+  i = 7;
+  t->tm_wday = (day + 4) % i;                        /* Sunday=0, Monday=1, ..., Saturday=6 */
+
+  i = 24;
+  day *= i;
+  i = 60;
+  return ((day + t->tm_hour) * i + t->tm_min) * i + t->tm_sec;
+}
+
+time_t mktime(register struct tm* const t) {
+  time_t x=timegm(t);
+  struct timezone tz;
+  gettimeofday(0, &tz);
+  timezone=tz.tz_minuteswest*60L;
+  x+=timezone;
+  return x;
+}
+
+static void num2str(char *c,int i) {
+  c[0]=i/10+'0';
+  c[1]=i%10+'0';
+}
+
+char *asctime_r(const struct tm *t, char *buf) {
+  /* "Wed Jun 30 21:49:08 1993\n" */
+  *(int*)buf=*(int*)(days+(t->tm_wday<<2));
+  *(int*)(buf+4)=*(int*)(months+(t->tm_mon<<2));
+  num2str(buf+8,t->tm_mday);
+  if (buf[8]=='0') buf[8]=' ';
+  buf[10]=' ';
+  num2str(buf+11,t->tm_hour);
+  buf[13]=':';
+  num2str(buf+14,t->tm_min);
+  buf[16]=':';
+  num2str(buf+17,t->tm_sec);
+  buf[19]=' ';
+  num2str(buf+20,(t->tm_year+1900)/100);
+  num2str(buf+22,(t->tm_year+1900)%100);
+  buf[24]='\n';
+  return buf;
+}
+
+char *asctime(const struct tm *timeptr) {
+  static char buf[25];
+  return asctime_r(timeptr,buf);
+}
+
+char *ctime(const time_t *timep) {
+  return asctime(localtime(timep));
+}
+
+int gettimeofday (struct timeval *tp, void *ignore)
+{
+     time_t t;
+
+     t = time(NULL);
+     tp->tv_sec  = t;
+     tp->tv_usec = 0;
+     return 0;
+}

+ 3 - 0
libcpu/SConscript

@@ -11,5 +11,8 @@ if rtconfig.CC == 'armcc':
 if rtconfig.CC == 'gcc':
 	src_local = Glob(path + '/*.c') + Glob(path + '/*_gcc.s') + Glob(comm + '/*.c')
 
+if rtconfig.CC == 'iar':
+	src_local = Glob(path + '/*.c') + Glob(path + '/*_iar.s') + Glob(comm + '/*.c')
+
 obj = env.Object(src_local)
 Return('obj')

+ 2 - 2
net/lwip/SConscript

@@ -62,8 +62,8 @@ src/netif/ppp/vj.c
 # The set of source files associated with this SConscript file.
 path = [RTT_ROOT + '/net/lwip/src/include', RTT_ROOT + '/net/lwip/src/include/ipv4', RTT_ROOT + '/net/lwip/src/arch/include/arch', RTT_ROOT + '/net/lwip/src/include/netif', RTT_ROOT + '/net/lwip/src/netif/ppp']
 
-lwip_env = env.Clone()
-lwip_env.Append(CPPPATH = path)
+env.Clone()
+env.Append(CPPPATH = path)
 
 obj = lwip_env.Object(src_local)