Programación General > C/C++

 Comprobar de forma segura el acceso a memoria

(1/2) > >>

marcialre:
Necesito comprobar si la dirección de memoria apuntada por un puntero es accesible, es decir, una lectura o escritura no generará un Segmentation Fault.

Una forma de realizarlo es leyendo o escribiendo en la dirección y tratar la señal SIGSEGV cuando se produzca. El problema es que necesito una forma más segura que no requiera generar la excepción para averiguar si la dirección es accesible.

¿Hay alguna forma de hacerlo?

SO: Linux 2.6.28, gcc.

Gracias.

Eternal Idol:
Si tenes un puntero invalido lo mas probable es que haya un problema en otra parte del programa ... ¿Para que quers hacer esto?

marcialre:
Es para aumentar la seguridad en una función de una librería. No puedo confiar en que el código del usuario sea correcto y escribir directamente en la dirección. Debo comprobar que eso es posible y comunicarlo en caso de que no lo sea.

Gracias.

Eternal Idol:
Efectivamente el problema esta en otra parte, si un programa le pasa un puntero erroneo a tu libreria no hay mucho mas que hacer ademas de capturar la excepcion pero es preferible no hacerlo y que el programa muera en lugar de enmascarar el problema real.

http://stackoverflow.com/questions/5510 ... lidity-c-c

marcialre:
Estoy de acuerdo contigo, pero me interesa conocer la forma de hacerlo. En Windows podría utilizar la función VirtualQuery para averiguar si la página a la que pertenece la dirección es accesible, pero no conozco la forma de hacerlo en Linux.

Me interesa una forma que haga uso únicamente de las llamadas al sistema y no requiera una librería externa o lenguaje específico. Debería ser implementable en C y en el caso más extremo en ensamblador.

Gracias otra vez.

Navegación

[0] Índice de Mensajes

[#] Página Siguiente

Ir a la versión completa