+#include "emufs.h"
+#include "did.h"
+#include "idx.h"
+#include "fsc.h"
+#include "indice_bplus.h"
+
+int emufs_tipo3_inicializar(EMUFS* efs);
+
+int emufs_tipo5_inicializar(EMUFS* efs);
+
+/** Devuelve un puntero con la memoria reservada que contiene al registro solicitado
+ * por el segundo parámetro \c ID, y almacena en \c reg_size el tamaño del
+ * registro leido, que en este caso no es necesario pues es constante y es conocicdo de antemano.
+ * Para realizar esta acción, busca en el archivo .idx el bloque al cual pertenece el registro.
+ * \param emu Esructura para manejar los archivos.
+ * \param ID Id del registro a leer.
+ * \param reg_size tamaño del registro.
+ * \param err Codigo de error devuelto en caso de falla.
+ */
+void* emufs_tipo3_leer_registro(EMUFS *emu, CLAVE clave, EMUFS_REG_SIZE* reg_size, int* err);
+
+/** Devuelve un puntero con la memoria reservada que contiene el bloque solicitado por
+ * el segundo parámetro \c num_bloque. Como la numeración de los bloques es virtual,
+ * el acceso al archivo para levantar un bloque es directo, es decir, se posiciona directamente
+ * en en número de bloque multiplicado por el tamaño del mismo, salteando antes el encabezado del archivo.
+ * \param emu Esructura para manejar los archivos.
+ * \param block_id Numero del bloque a leer.
+ * \param err Codigo de error devuelto en caso de falla.
+ */
+void* emufs_tipo3_leer_bloque(EMUFS *emu, EMUFS_BLOCK_ID block_id, int *err);