Changeset 286 for trunk/src


Ignore:
Timestamp:
Jun 6, 2010, 7:20:55 PM (15 years ago)
Author:
katerina
Message:

Fix for ticket #211 (samhain_kmem compile problems) and ticket #210 (line length, filename quoting in config file).

Location:
trunk/src
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/kern_head.c

    r279 r286  
    9898  char    * kmap;
    9999
    100 
    101   /* first, try read()
    102    */
    103   int  ret_old = kmem_read (fd, addr, buf, len);
    104 
    105   if (ret_old == 0)
    106     return ret_old;
    107 
    108   if (verbose)
    109     fprintf(stderr, "kmem_mmap: read() failed, now trying mmap()\n");
    110 
    111100  sz = getpagesize(); /* unistd.h */
    112101
     
    117106  if (kmap == MAP_FAILED)
    118107    {
     108      /* then, try read()
     109       */
     110      if (verbose)
     111        fprintf(stderr, "kmem_mmap: mmap() failed, now trying read()\n");
     112
     113      if (0 == sh_kern_kmem_read (fd, addr, buf, len))
     114        return 0;
     115
    119116      perror("kmem_mmap: mmap");
    120117      return -1;
    121118    }
     119
    122120  memcpy (buf, &kmap[roff], len);
    123121     
  • trunk/src/samhain_kmem.c

    r279 r286  
    1515#define _(string) string
    1616
     17#include <linux/version.h>
    1718#include <linux/module.h>
    1819#include <linux/kernel.h>
     
    3637#include <linux/backing-dev.h>
    3738#include <linux/bootmem.h>
     39#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,22)
    3840#include <linux/splice.h>
     41#endif
    3942#include <linux/pfn.h>
    40 #include <linux/version.h>
    4143
    4244#include <asm/uaccess.h>
     
    514516{
    515517  loff_t ret;
    516  
     518 
     519#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,35)
     520  mutex_lock(&file->f_dentry->d_inode->i_mutex);
     521#else
    517522  mutex_lock(&file->f_path.dentry->d_inode->i_mutex);
     523#endif
     524
    518525  switch (orig) {
    519526  case 0:
     
    533540    ret = -EINVAL;
    534541  }
     542#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,35)
     543  mutex_unlock(&file->f_dentry->d_inode->i_mutex);
     544#else
    535545  mutex_unlock(&file->f_path.dentry->d_inode->i_mutex);
     546#endif
    536547  return ret;
    537548}
  • trunk/src/sh_files.c

    r256 r286  
    2323#include <stdlib.h>
    2424#include <string.h>
     25#include <ctype.h>
    2526#include <limits.h>
    2627
     
    7273#undef  FIL__
    7374#define FIL__  _("sh_files.c")
     75
     76static char * sh_files_C_dequote (char * s, size_t * length)
     77{
     78  size_t i, j, len = *length;
     79  int    flag = 0;
     80  char  *p, *q, *po, *pend;
     81 
     82  /* search for backslash
     83   */
     84  for (i = 0; i < len; ++i)
     85    {
     86      if (s[i] == '\\')
     87        {
     88          flag = 1;
     89          break;
     90        }
     91    }
     92
     93  if (flag == 0 || *s == '\0')
     94    return s;
     95
     96  po = SH_ALLOC(len+1); *po = '\0'; p = po; pend = &po[len];
     97
     98  i = 0; j = 0; q = s;
     99
     100  do
     101    {
     102      if (*q == '\\')
     103        {
     104          ++q;
     105
     106          if (*q == '\0')
     107            { *p = *q; flag = 0; break; }
     108          else if (*q == 'a')
     109            { *p = '\a'; ++p; ++q; }
     110          else if (*q == 'b')
     111            { *p = '\b'; ++p; ++q; }
     112          else if (*q == 'f')
     113            { *p = '\f'; ++p; ++q; }
     114          else if (*q == 'n')
     115            { *p = '\n'; ++p; ++q; }
     116          else if (*q == 'r')
     117            { *p = '\r'; ++p; ++q; }
     118          else if (*q == 't')
     119            { *p = '\t'; ++p; ++q; }
     120          else if (*q == 'v')
     121            { *p = '\v'; ++p; ++q; }
     122          else if (*q == '\\')
     123            { *p = '\\'; ++p; ++q; }
     124          else if (*q == '\'')
     125            { *p = '\''; ++p; ++q; }
     126          else if (*q == '"')
     127            { *p = '"';  ++p; ++q; }
     128          else if (*q == 'x')
     129            {
     130              if (isxdigit((int) q[1]) && isxdigit((int) q[2]))
     131                {
     132                  /* hexadecimal value following */
     133                  unsigned char cc = (16 * sh_util_hexchar(q[1]))
     134                    + sh_util_hexchar(q[2]);
     135                  *p = (char) cc;
     136                  ++p; q += 3;
     137                }
     138              else
     139                {
     140                  *p = '\0'; flag = 0; break;
     141                }
     142            }
     143          else if (isdigit((int)*q))
     144            {
     145              if (isdigit((int) q[1]) && q[1] < '8' &&
     146                  isdigit((int) q[2]) && q[2] < '8')
     147                {
     148                  /* octal value following */
     149                  char tmp[4];  unsigned char cc;
     150                  tmp[0] = *q; ++q; tmp[1] = *q; ++q; tmp[2] = *q; ++q;
     151                  tmp[3] = '\0';
     152                  cc = strtol(tmp, NULL, 8);
     153                  *p = (char) cc; ++p;
     154                }
     155              else
     156                {
     157                  *p = '\0'; flag = 0; break;
     158                }
     159            }
     160          else
     161            {
     162              /* invalid escape sequence */
     163              *p = '\0'; flag = 0; break;
     164            }
     165        }
     166      else
     167        {
     168          *p = *q;
     169          ++p; ++q;
     170        }
     171    } while (*q && p <= pend);
     172
     173  SL_REQUIRE (p <= pend, _("p <= pend"));
     174
     175  if (flag)
     176    {
     177      *p = '\0';
     178      *length = strlen(po);
     179    }
     180  else
     181    {
     182      SH_FREE(po);
     183      po = NULL;
     184      *length = 0;
     185    }
     186
     187  SL_REQUIRE (*length <= len, _("*length <= len"));
     188
     189  SH_FREE(s);
     190  return po;
     191}
    74192
    75193extern int flag_err_debug;
     
    9991117    }
    10001118
    1001   if (str_s == NULL)
     1119  if (str_s == NULL || str_s[0] == '\0')
    10021120    SL_RETURN((-1),_("sh_files_pushfile"));
    10031121
    10041122  len = sl_strlen(str_s);
     1123
     1124  if ( (str_s[0] == '"'  && str_s[len-1] == '"' ) ||
     1125       (str_s[0] == '\'' && str_s[len-1] == '\'') )
     1126    {
     1127      if (len < 3)
     1128        SL_RETURN((-1),_("sh_files_pushfile"));
     1129      --len;
     1130      p = sh_util_strdup_l(&str_s[1], len);
     1131      p[len-1] = '\0';
     1132      --len;
     1133    }
     1134  else
     1135    {
     1136      p = sh_util_strdup_l(str_s, len);
     1137    }
     1138
     1139  p = sh_files_C_dequote(p, &len);
     1140  if (!p || len == 0)
     1141    SL_RETURN((-1), _("sh_files_pushdir"));
    10051142
    10061143  if (len >= PATH_MAX)
     
    10081145      /* Name too long
    10091146       */
    1010       tmp = sh_util_safe_name (str_s);
     1147      tmp = sh_util_safe_name (p);
    10111148      sh_error_handle ((-1), FIL__, __LINE__, 0, MSG_FI_2LONG,
    10121149                       tmp);
     
    10141151      SL_RETURN((-1),_("sh_files_pushfile"));
    10151152    }
    1016   else if (len < 1)
    1017     {
    1018       /* Should not happen (str_s == NULL caught further above)
    1019        */
    1020       SL_RETURN((-1),_("sh_files_pushfile"));
    1021     }
    1022   else if (str_s[0] != '/')
     1153  else if (p[0] != '/')
    10231154    {
    10241155      /* Not an absolute path
    10251156       */
    1026       tmp = sh_util_safe_name (str_s);
     1157      tmp = sh_util_safe_name (p);
    10271158      sh_error_handle ((-1), FIL__, __LINE__, 0, MSG_FI_NOPATH,
    10281159                       tmp);
     
    10351166       * special case of the root directory.
    10361167       */
    1037       p = sh_util_strdup (str_s);
    10381168      if (p[len-1] == '/' && len > 1)
    10391169        {
     
    10411171          --len;
    10421172        }
    1043      
    10441173    }
    10451174
     
    13641493  }
    13651494
    1366   if (str_s == NULL)
     1495  if (str_s == NULL || str_s[0] == '\0')
     1496    SL_RETURN((-1),_("sh_files_pushdir"));
     1497
     1498  len = sl_strlen(str_s);
     1499
     1500  if ( (str_s[0] == '"'  && str_s[len-1] == '"' ) ||
     1501       (str_s[0] == '\'' && str_s[len-1] == '\'') )
     1502    {
     1503      if (len < 3)
     1504        SL_RETURN((-1),_("sh_files_pushdir"));
     1505      --len;
     1506      p = sh_util_strdup_l(&str_s[1], len);
     1507      p[len-1] = '\0';
     1508      --len;
     1509    }
     1510  else
     1511    {
     1512      p = sh_util_strdup_l(str_s, len);
     1513    }
     1514
     1515  p = sh_files_C_dequote(p, &len);
     1516  if (!p || len == 0)
    13671517    SL_RETURN((-1), _("sh_files_pushdir"));
    1368  
    1369   p = sh_util_strdup (str_s);
    13701518
    13711519  if (p[0] != '/')
     
    14121560  else
    14131561    {
    1414      
    14151562      if (tail[len-1] == '/' && len > 1)
    14161563        {
     
    14181565          --len;
    14191566        }
    1420      
    14211567    }
    14221568
     
    24202566
    24212567#endif
     2568
     2569#ifdef SH_CUTEST
     2570#include "CuTest.h"
     2571
     2572void Test_file_dequote (CuTest *tc)
     2573{
     2574#if (defined (SH_WITH_CLIENT) || defined (SH_STANDALONE))
     2575
     2576  char str1[]  = "1234567890";
     2577  char str1a[] = "123456\\\"789\\r";
     2578  char str1b[] = "12345678\\r9";
     2579  char str1c[] = "12345678\\x0a_9";
     2580  char str1d[] = "12345678\\007_9";
     2581  char str1e[] = "123456789\\\\";
     2582
     2583  char str2[] = "1234567890\\xw";
     2584  char str3[] = "1234567890\\xw99";
     2585  char str4[] = "1234567890\\0ww";
     2586  char str5[] = "12345\\g67890";
     2587  char str6[] = "1234567890\\009a";
     2588
     2589  char *s, *p, *q;
     2590  size_t lo, lr;
     2591
     2592  s = SH_ALLOC(64); sl_strlcpy(s, str1, 64); p = s; lo = strlen(s); lr = lo;
     2593  q = sh_files_C_dequote(s, &lr);
     2594  CuAssertPtrNotNull(tc, q);
     2595  CuAssertTrue(tc, p  == q);
     2596  CuAssertTrue(tc, lr == lo);
     2597
     2598  s = SH_ALLOC(64); sl_strlcpy(s, str1a, 64); p = s; lo = strlen(s); lr = lo;
     2599  q = sh_files_C_dequote(s, &lr);
     2600  CuAssertPtrNotNull(tc, q);
     2601  CuAssertTrue(tc, p  != q);
     2602  CuAssertTrue(tc, 0 == strcmp(q, "123456\"789\r"));
     2603  CuAssertTrue(tc, lr == (lo-2));
     2604
     2605  s = SH_ALLOC(64); sl_strlcpy(s, str1b, 64); p = s; lo = strlen(s); lr = lo;
     2606  q = sh_files_C_dequote(s, &lr);
     2607  CuAssertPtrNotNull(tc, q);
     2608  CuAssertTrue(tc, p  != q);
     2609  CuAssertTrue(tc, 0 == strcmp(q, "12345678\r9"));
     2610  CuAssertTrue(tc, lr == (lo-1));
     2611
     2612  s = SH_ALLOC(64); sl_strlcpy(s, str1c, 64); p = s; lo = strlen(s); lr = lo;
     2613  q = sh_files_C_dequote(s, &lr);
     2614  CuAssertPtrNotNull(tc, q);
     2615  CuAssertTrue(tc, p  != q);
     2616  CuAssertTrue(tc, 0 == strcmp(q, "12345678\x0a_9"));
     2617  CuAssertTrue(tc, lr == (lo-3));
     2618
     2619  s = SH_ALLOC(64); sl_strlcpy(s, str1d, 64); p = s; lo = strlen(s); lr = lo;
     2620  q = sh_files_C_dequote(s, &lr);
     2621  CuAssertPtrNotNull(tc, q);
     2622  CuAssertTrue(tc, p  != q);
     2623  CuAssertTrue(tc, 0 == strcmp(q, "12345678\007_9"));
     2624  CuAssertTrue(tc, lr == (lo-3));
     2625
     2626  s = SH_ALLOC(64); sl_strlcpy(s, str1e, 64); p = s; lo = strlen(s); lr = lo;
     2627  q = sh_files_C_dequote(s, &lr);
     2628  CuAssertPtrNotNull(tc, q);
     2629  CuAssertTrue(tc, p  != q);
     2630  CuAssertTrue(tc, 0 == strcmp(q, "123456789\\"));
     2631  CuAssertTrue(tc, lr == (lo-1));
     2632
     2633  s = SH_ALLOC(64); sl_strlcpy(s, str2, 64); p = s; lo = strlen(s); lr = lo;
     2634  q = sh_files_C_dequote(s, &lr);
     2635  CuAssertTrue(tc, q == NULL);
     2636  CuAssertTrue(tc, lr == 0);
     2637
     2638  s = SH_ALLOC(64); sl_strlcpy(s, str3, 64); p = s; lo = strlen(s); lr = lo;
     2639  q = sh_files_C_dequote(s, &lr);
     2640  CuAssertTrue(tc, q == NULL);
     2641  CuAssertTrue(tc, lr == 0);
     2642
     2643  s = SH_ALLOC(64); sl_strlcpy(s, str4, 64); p = s; lo = strlen(s); lr = lo;
     2644  q = sh_files_C_dequote(s, &lr);
     2645  CuAssertTrue(tc, q == NULL);
     2646  CuAssertTrue(tc, lr == 0);
     2647
     2648  s = SH_ALLOC(64); sl_strlcpy(s, str5, 64); p = s; lo = strlen(s); lr = lo;
     2649  q = sh_files_C_dequote(s, &lr);
     2650  CuAssertTrue(tc, q == NULL);
     2651  CuAssertTrue(tc, lr == 0);
     2652
     2653  s = SH_ALLOC(64); sl_strlcpy(s, str6, 64); p = s; lo = strlen(s); lr = lo;
     2654  q = sh_files_C_dequote(s, &lr);
     2655  CuAssertTrue(tc, q == NULL);
     2656  CuAssertTrue(tc, lr == 0);
     2657
     2658  return;
     2659#else
     2660  (void) tc; /* fix compiler warning */
     2661  return;
     2662#endif
     2663}
     2664#endif
     2665
  • trunk/src/sh_kern.c

    r279 r286  
    495495  char    * kmap;
    496496
    497   /* first, try read()
    498    */
    499   if (0 == sh_kern_kmem_read (fd, addr, buf, len))
    500     return 0;
    501 
    502497  /* next, try mmap()
    503498   */
     
    511506  if (kmap == MAP_FAILED)
    512507    {
     508      /* then, try read()
     509       */
     510      if (0 == sh_kern_kmem_read (fd, addr, buf, len))
     511        return 0;
     512
    513513      memset(buf, '\0', len);
    514514      return -1;
    515515    }
     516
    516517  memcpy (buf, &kmap[roff], len);
    517518  return munmap(kmap, len+sz);
  • trunk/src/sh_readconf.c

    r279 r286  
    340340  char * tmp;
    341341
    342   char   line_in[512+2];
     342#define SH_LINE_IN 16384
     343  char * line_in;
    343344  char * line;
    344345
     
    373374
    374375      if (!SL_ISERROR(fd))
    375         local_file = 0;
     376        {
     377          local_file = 0;
     378        }
    376379      else if (sh.flag.checkSum != SH_CHECK_INIT)
    377         aud_exit (FIL__, __LINE__, EXIT_FAILURE);
     380        {
     381          aud_exit (FIL__, __LINE__, EXIT_FAILURE);
     382        }
    378383      else
    379384        {
     
    427432  sl_rewind (fd);
    428433
     434  line_in = SH_ALLOC(SH_LINE_IN);
     435
    429436#if defined(SH_STEALTH) && !defined(SH_STEALTH_MICRO)
    430437    /* extract the data and copy to temporary file
     
    434441  sh_unix_getline_stealth (0, NULL, 0); /* initialize */
    435442
    436   while ( sh_unix_getline_stealth (fd, line_in, 512) > 0) {
     443  while ( sh_unix_getline_stealth (fd, line_in, SH_LINE_IN-2) > 0) {
    437444    hidden_count++;
    438445    if (line_in[0] == '\n')
     
    451458      break;
    452459#endif
    453     if (hidden_count > 4096)  /* arbitrary safeguard */
     460    if (hidden_count > 1048576)  /* arbitrary safeguard, 1024*1024 */
    454461      break;
    455462  }
     
    464471  conf_line = 0;
    465472
    466   while ( sh_unix_getline (fd, line_in, 512) > 0) {
     473  while ( sh_unix_getline (fd, line_in, SH_LINE_IN-2) > 0) {
    467474
    468475    ++conf_line;
     
    502509            sh_error_handle ((-1), FIL__, __LINE__, 0, MSG_EXIT_ABORT1,
    503510                             sh.prg_name);
     511            SH_FREE(line_in);
    504512            aud_exit (FIL__, __LINE__,EXIT_FAILURE);
    505513          }
     
    660668  sl_rewind (fd);
    661669  if (0 != sh_gpg_check_sign (fd, 0, 1))
    662     aud_exit (FIL__, __LINE__, EXIT_FAILURE);
     670    {
     671      SH_FREE(line_in);
     672      aud_exit (FIL__, __LINE__, EXIT_FAILURE);
     673    }
    663674#endif
    664675
     
    669680  read_mode = SH_SECTION_NONE; /* reset b/o sighup reload */
    670681
     682  SH_FREE(line_in);
    671683  SL_RETURN( 0, _("sh_readconf_read"));
    672684}
  • trunk/src/sstrip.c

    r48 r286  
    216216    Elf32_Phdr   const   *phdr;
    217217    unsigned long       size, n;
    218     int                 i;
     218    unsigned int        i;
    219219
    220220    /* Start by setting the size to include the ELF header and the
     
    245245    Elf64_Phdr   const   *phdr;
    246246    unsigned long         size, n;
    247     int                   i;
     247    unsigned int          i;
    248248
    249249    /* Start by setting the size to include the ELF header and the
     
    308308{
    309309    Elf32_Phdr   *phdr;
    310     int           i;
     310    unsigned int  i;
    311311
    312312    /* If the section header table is gone, then remove all references
     
    340340{
    341341    Elf64_Phdr   *phdr;
    342     int           i;
     342    unsigned int  i;
    343343
    344344    /* If the section header table is gone, then remove all references
Note: See TracChangeset for help on using the changeset viewer.