• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

189
Vistas
Is mmap + madvise really a form of async I/O?

I'm trying to figure out if mmap'ing a file, and then using madvise() or posix_madvise() with MADV_WILLNEED/POSIX_MADV_WILLNEED actually triggers background async I/O for read-ahead. The man pages for madvise don't specify whether this is the case - the actual behavior of madvise is left mostly unclear, in order to allow for flexibility of the implementation.

But does any actual mainstream POSIX implementation (like Linux) actually perform async file I/O when madvise() with MADV_WILLNEED is called? I can't seem to get any reliable information about this. This question suggests it does, on Linux at least, even if it is not ideal since there is no callback mechanism.

This book excerpt claims that posix_fadvise with POSIX_FADV_WILLNEED will do asynchronous read ahead, but doesn't mention if madvise() does async read ahead.

Furthermore, it would seem that the whole concept of "read-ahead" I/O doesn't really make any sense unless it's asynchronous. If it was synchronous, it simply makes the user application block for the read-ahead, instead of later when actually reading the file, which doesn't seem like a particularly powerful optimization.

So, does madvise() with MADV_WILLNEED actually do async read-ahead on any mainstream platform (like Linux)?

about 3 years ago · Santiago Trujillo
2 Respuestas
Responde la pregunta

0

With Linux you can always check the source code.

See fadvise.c:

case POSIX_FADV_WILLNEED:
    ...
    force_page_cache_readahead(mapping, f.file, start_index,
                   nrpages);
    break;

So posix_fadvise calls force_page_cache_readahead to perform readahead.

Now lets look at madvise.c:

static long madvise_willneed(...)
{
    ...
    force_page_cache_readahead(file->f_mapping, file, start, end-start);
    return 0;
}

So MADV_WILLNEED and POSIX_FADV_WILLNEED are equivalent on Linux.

Can this be called asynchronous I/O? I don't think so. Async IO usually implies there is some notification that allows you to retrieve data. Advise is just an advise: not only you do not know when data is ready to be read, but if you are too late, data might be thrown away already.

about 3 years ago · Santiago Trujillo Denunciar

0

In general, you should assume that the m* functions won't perform async readahead.

about 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda