tail head cat sleep
QR code linking to this page

manページ  — MPOOL

名称

mpool – 共有メモリバッファプール

内容

書式

#include <db.h>
#include <mpool.h>

MPOOL *
mpool_open(void *key, int fd, pgno_t pagesize, pgno_t maxcache);

void
mpool_filter(MPOOL *mp, void (*pgin)(void *, pgno_t, void *), void (*pgout)(void *, pgno_t, void *), void *pgcookie);

void *
mpool_new(MPOOL *mp, pgno_t *pgnoaddr);

void *
mpool_get(MPOOL *mp, pgno_t pgno, u_int flags);

int
mpool_put(MPOOL *mp, void *pgaddr, u_int flags);

int
mpool_sync(MPOOL *mp);

int
mpool_close(MPOOL *mp);

解説

mpool は、ページを基準にした、ファイルのバッファ管理を行なう ライブラリインタフェースです。バッファはプロセス間で共有できます。

関数 mpool_open() はメモリプールを初期化します。引数 key は、バッファ を共有する複数のプロセス間でネゴシエートするために使われる バイトストリングです。 ファイルバッファが共有メモリにマップされた場合は、同じキーを 使用しているすべてのプロセスがバッファを共有します。 key NULL である場合、バッファはプライベートメモリにマップされます。 引数 fd は、基礎となる ファイルのファイル記述子で、検索可能になっている必要があります。 key NULL ではなく、すでにマップされているファイルと一致する場合、引数 fd は無視されます。

引数 pagesize は、ファイルを分割するページのサイズ (バイト単位) です。引数 maxcache は、一度にキャッシュする、基礎となるファイルの最大ページ数です。 この値は、ファイルのバッファを共有するプロセス数とは 関係ありませんが、ファイルを共有するプロセスが指定した最大値になります。

関数 mpool_filter() は、ページの透過的入出力処理を行ないます。 pgin 関数が指定されると、保存ファイルからメモリプールにバッファを 読み込むたびに呼び出されます。 pgout 関数が指定されると、保存ファイルにバッファが書き込まれるたびに 呼び出されます。どちらの関数も、 pgcookie ポインタ、ページ番号、読み書きを行なうページのポインタで呼び出されます。

関数 mpool_new() は、 MPOOL ポインタとアドレスを引数として取ります。 新しいページを割り振ることができる場合は、ページのポインタが返され、 ページ番号が pgnoaddr アドレスに保存されます。割り振ることができない場合は NULL が返され、 errno が設定されます。

関数 mpool_get() は、 MPOOL ポインタとページ番号を引数として取ります。 ページが存在する場合は、ページのポインタが返されます。 ページが存在しない場合は NULL が返され、 errno がセットされます。 flags パラメータは、今のところ使用されていません。

関数 mpool_put() は、 pgaddr が参照するページを解放します。 pgaddr は、あらかじめ mpool_get() または mpool_new() が返したアドレスでなければなりません。 flags パラメータは以下の値の論理和 ( or ) によって指定されます。
MPOOL_DIRTY
  ページが修正されており、保存ファイルに書き込む必要があります。

関数 mpool_put() は、正常終了時には 0 を返し、エラーのときは -1 を返します。

関数 mpool_sync() は、 MPOOL ポインタに対して、変更されたすべてのページを 保存ファイルに書き込みます。 mpool_sync() は、正常終了時には 0 を返し、エラーのときは -1 を返します。

関数 mpool_close() は、メモリプールクッキーに対して割り振られたメモリを解放します。 修正されたページは、保存ファイルに書き込まれ ませんmpool_close() は、正常終了時には 0 を返し、エラーのときは -1 を返します。

エラー

関数 mpool_open() でエラーが発生すると、ライブラリルーチン malloc(3) で指定されたエラーの errno がセットされます。

関数 mpool_get() でエラーが発生すると、以下の errno がセットされます。
[EINVAL]
  要求されたレコードが存在しない。

関数 mpool_new()mpool_get() でエラーが発生すると、ライブラリルーチン read(2), write(2), malloc(3) で指定されたエラーの errno がセットされます。

関数 mpool_sync() でエラーが発生すると、ライブラリルーチン write(2) で指定されたエラーの errno がセットされます。

関数 mpool_close() でエラーが発生すると、ライブラリルーチン free(3) で 指定したエラーの errno がセットされます。

関連項目

btree(3), dbopen(3), hash(3), recno(3)

MPOOL (3) June 4, 1993

tail head cat sleep
QR code linking to this page


このマニュアルページサービスについてのご意見は Ben Bullock にお知らせください。 Privacy policy.

The number of UNIX installations has grown to 10, with more expected.
— UNIX Programming Manual, 1972