2003-02-28 01:43:38 +08:00
|
|
|
/*
|
|
|
|
+----------------------------------------------------------------------+
|
2004-01-09 01:33:29 +08:00
|
|
|
| PHP Version 5 |
|
2003-02-28 01:43:38 +08:00
|
|
|
+----------------------------------------------------------------------+
|
2007-12-31 15:17:19 +08:00
|
|
|
| Copyright (c) 1997-2008 The PHP Group |
|
2003-02-28 01:43:38 +08:00
|
|
|
+----------------------------------------------------------------------+
|
2006-01-01 20:51:34 +08:00
|
|
|
| This source file is subject to version 3.01 of the PHP license, |
|
2003-02-28 01:43:38 +08:00
|
|
|
| that is bundled with this package in the file LICENSE, and is |
|
2003-06-11 04:04:29 +08:00
|
|
|
| available through the world-wide-web at the following url: |
|
2006-01-01 20:51:34 +08:00
|
|
|
| http://www.php.net/license/3_01.txt |
|
2003-02-28 01:43:38 +08:00
|
|
|
| If you did not receive a copy of the PHP license and are unable to |
|
|
|
|
| obtain it through the world-wide-web, please send a note to |
|
|
|
|
| license@php.net so we can mail you a copy immediately. |
|
|
|
|
+----------------------------------------------------------------------+
|
|
|
|
| Author: Wez Furlong <wez@thebrainroom.com> |
|
|
|
|
+----------------------------------------------------------------------+
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* $Id$ */
|
|
|
|
|
|
|
|
/* Memory Mapping interface for streams.
|
|
|
|
* The intention is to provide a uniform interface over the most common
|
|
|
|
* operations that are used within PHP itself, rather than a complete
|
|
|
|
* API for all memory mapping needs.
|
|
|
|
*
|
|
|
|
* ATM, we support only mmap(), but win32 memory mapping support will
|
|
|
|
* follow soon.
|
|
|
|
* */
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
/* Does the stream support mmap ? */
|
|
|
|
PHP_STREAM_MMAP_SUPPORTED,
|
|
|
|
/* Request a range and offset to be mapped;
|
|
|
|
* while mapped, you MUST NOT use any read/write functions
|
|
|
|
* on the stream (win9x compatibility) */
|
|
|
|
PHP_STREAM_MMAP_MAP_RANGE,
|
|
|
|
/* Unmap the last range that was mapped for the stream */
|
|
|
|
PHP_STREAM_MMAP_UNMAP
|
|
|
|
} php_stream_mmap_operation_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
PHP_STREAM_MAP_MODE_READONLY,
|
|
|
|
PHP_STREAM_MAP_MODE_READWRITE,
|
|
|
|
PHP_STREAM_MAP_MODE_SHARED_READONLY,
|
|
|
|
PHP_STREAM_MAP_MODE_SHARED_READWRITE
|
|
|
|
} php_stream_mmap_access_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/* requested offset and length.
|
|
|
|
* If length is 0, the whole file is mapped */
|
|
|
|
size_t offset;
|
|
|
|
size_t length;
|
|
|
|
|
|
|
|
php_stream_mmap_access_t mode;
|
|
|
|
|
|
|
|
/* returned mapped address */
|
|
|
|
char *mapped;
|
|
|
|
|
|
|
|
} php_stream_mmap_range;
|
|
|
|
|
|
|
|
#define php_stream_mmap_supported(stream) (_php_stream_set_option((stream), PHP_STREAM_OPTION_MMAP_API, PHP_STREAM_MMAP_SUPPORTED, NULL TSRMLS_CC) == 0 ? 1 : 0)
|
|
|
|
|
|
|
|
/* Returns 1 if the stream in its current state can be memory mapped,
|
|
|
|
* 0 otherwise */
|
|
|
|
#define php_stream_mmap_possible(stream) (!php_stream_is_filtered((stream)) && php_stream_mmap_supported((stream)))
|
|
|
|
|
2004-02-20 16:22:12 +08:00
|
|
|
BEGIN_EXTERN_C()
|
2003-02-28 01:43:38 +08:00
|
|
|
PHPAPI char *_php_stream_mmap_range(php_stream *stream, size_t offset, size_t length, php_stream_mmap_operation_t mode, size_t *mapped_len TSRMLS_DC);
|
|
|
|
#define php_stream_mmap_range(stream, offset, length, mode, mapped_len) _php_stream_mmap_range((stream), (offset), (length), (mode), (mapped_len) TSRMLS_CC)
|
|
|
|
|
|
|
|
/* un-maps the last mapped range */
|
|
|
|
PHPAPI int _php_stream_mmap_unmap(php_stream *stream TSRMLS_DC);
|
|
|
|
#define php_stream_mmap_unmap(stream) _php_stream_mmap_unmap((stream) TSRMLS_CC)
|
2004-02-20 16:22:12 +08:00
|
|
|
END_EXTERN_C()
|
2003-02-28 01:43:38 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Local variables:
|
|
|
|
* tab-width: 4
|
|
|
|
* c-basic-offset: 4
|
|
|
|
* End:
|
|
|
|
* vim600: noet sw=4 ts=4 fdm=marker
|
|
|
|
* vim<600: noet sw=4 ts=4
|
|
|
|
*/
|