+/** 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);
+
+/** Graba un registro en un bloque donde haya espacio suficiente, y si no
+ * crea un nuevo bloque y lo agrega al final del archivo.
+ * El registro a grabar es apuntado por el segundo parámetro \param ptr
+ * y el tamaño viene indicado en \c tam.
+ * Luego de realizar la grabación, actualiza los archivos índice con los
+ * valores correspondientes.
+ * \param emu Esructura para manejar los archivos.
+ * \param ptr Cadena de datos que contiene el registro a grabar.
+ * \param err Codigo de error devuelto en caso de falla.
+ */
+EMUFS_REG_ID emufs_tipo3_grabar_registro(EMUFS *emu, void *ptr, EMUFS_REG_SIZE reg_size, int *err);
+
+/** Graba el bloque apuntado por \c ptr en el archivo
+ * \param emu Esructura para manejar los archivos.
+ * \param ptr Cadena de datos que contiene el bloque a grabar.
+ * \param block_id Numero del bloque a leer.
+ */