2 * Copyright (C) 2000 Rich Wareham <richwareham@users.sourceforge.net>
4 * This file is part of libdvdnav, a DVD navigation library.
6 * libdvdnav is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * libdvdnav is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with libdvdnav; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
21 #ifndef LIBDVDNAV_READ_CACHE_H
22 #define LIBDVDNAV_READ_CACHE_H
24 /* Opaque cache type -- defined in dvdnav_internal.h */
25 /* typedef struct read_cache_s read_cache_t; */
27 /* EXPERIMENTAL: Setting the following to 1 will use an experimental multi-threaded
30 #define _MULTITHREAD_ 0
32 /* Constructor/destructors */
33 read_cache_t
*dvdnav_read_cache_new(dvdnav_t
* dvd_self
);
34 void dvdnav_read_cache_free(read_cache_t
* self
);
36 /* This function MUST be called whenever self->file changes. */
37 void dvdnav_read_cache_clear(read_cache_t
*self
);
38 /* This function is called just after reading the NAV packet. */
39 void dvdnav_pre_cache_blocks(read_cache_t
*self
, int sector
, size_t block_count
);
40 /* This function will do the cache read.
41 * The buffer handed in must be malloced to take one dvd block.
42 * On a cache hit, a different buffer will be returned though.
43 * Those buffers must _never_ be freed. */
44 int dvdnav_read_cache_block(read_cache_t
*self
, int sector
, size_t block_count
, uint8_t **buf
);
46 #endif /* LIBDVDNAV_READ_CACHE_H */