Annotation of embedaddon/php/Zend/zend_canary.c, revision 1.1

1.1     ! misho       1: /*
        !             2:    +----------------------------------------------------------------------+
        !             3:    | Suhosin-Patch for PHP                                                |
        !             4:    +----------------------------------------------------------------------+
        !             5:    | Copyright (c) 2004-2009 Stefan Esser                                 |
        !             6:    +----------------------------------------------------------------------+
        !             7:    | This source file is subject to version 2.02 of the PHP license,      |
        !             8:    | that is bundled with this package in the file LICENSE, and is        |
        !             9:    | available at through the world-wide-web at                           |
        !            10:    | http://www.php.net/license/2_02.txt.                                 |
        !            11:    | If you did not receive a copy of the PHP license and are unable to   |
        !            12:    | obtain it through the world-wide-web, please send a note to          |
        !            13:    | license@php.net so we can mail you a copy immediately.               |
        !            14:    +----------------------------------------------------------------------+
        !            15:    | Author: Stefan Esser <stefan.esser@sektioneins.de>                   |
        !            16:    +----------------------------------------------------------------------+
        !            17:  */
        !            18: /* $Id: zend_canary.c,v 1.1 2004/11/26 12:45:41 ionic Exp $ */
        !            19: 
        !            20: #include "zend.h"
        !            21: 
        !            22: #include <stdio.h>
        !            23: #include <stdlib.h>
        !            24: 
        !            25: 
        !            26: #if SUHOSIN_PATCH
        !            27: 
        !            28: static size_t last_canary = 0x73625123;
        !            29: 
        !            30: /* will be replaced later with more compatible method */
        !            31: ZEND_API void zend_canary(void *buf, int len)
        !            32: {
        !            33:        time_t t;
        !            34:        size_t canary;
        !            35:        int fd;
        !            36:        
        !            37: #ifndef PHP_WIN32
        !            38:        fd = open("/dev/urandom", 0);
        !            39:        if (fd != -1) {
        !            40:                int r = read(fd, buf, len);
        !            41:                close(fd);
        !            42:                if (r == len) {
        !            43:                        return;
        !            44:                }
        !            45:        }
        !            46: #endif 
        !            47:        /* not good but we never want to do this */
        !            48:        time(&t);
        !            49:        canary = *(unsigned int *)&t + getpid() << 16 + last_canary;
        !            50:        last_canary ^= (canary << 5) | (canary >> (32-5));
        !            51:        /* When we ensure full win32 compatibility in next version
        !            52:           we will replace this with the random number code from zend_alloc.c */
        !            53:         memcpy(buf, &canary, len);
        !            54: }
        !            55: 
        !            56: #endif
        !            57: 
        !            58: 
        !            59: /*
        !            60:  * Local variables:
        !            61:  * tab-width: 4
        !            62:  * c-basic-offset: 4
        !            63:  * End:
        !            64:  * vim600: sw=4 ts=4 fdm=marker
        !            65:  * vim<600: sw=4 ts=4
        !            66:  */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>