00001 
00002 #include "routix/system.h"
00003 #include "string.h"
00004 #include "drivers/fat.h"
00005 #include "routix/paging.h"
00006 #include "routix/kalloc.h"
00007 #include <routix/kstdio.h>
00008 #include "routix/file.h"
00009 #include "routix/task.h"
00010 #include <drivers/floppy.h>
00011 #include <fs/blockcache.h>
00012 #include <error.h>
00013 
00014 #define RUNSTATS 1
00015 
00016 file_opened_t *header_archivos_abiertos;
00017 
00018 extern dev_fat_t dev_fat[0];
00019 
00021 
00022 
00024 
00025 
00026 
00027 file_opened_t *header_archivos_abiertos=NULL;
00028 
00029 
00030 
00031 
00032 dword file_descriptor_actual=1; 
00033 
00034 
00035 
00036 
00037 
00038 
00039 
00040 
00041 
00042 extern task_struct_t *actual;
00043 
00044 int open (char *nombre)
00045 {
00046     word i;
00047     int fd = -1;
00048 
00049 
00050     
00051     for (i=0 ; i < MAX_FILES_POR_TAREA ; i++)
00052                 if ( actual->open_files[i] == NULL ) {
00053                 fd = i;
00054                 break;
00055                 }
00056         
00057     if ( fd < 0 ) {
00058         actual->err_no = EMFILE;
00059                 return -1;      
00060     }
00061     struct file aux;
00062 
00063 
00064 
00065 
00066                       
00067     aux.device = DRIVE_0 ;
00068     aux.fs = FAT12;
00069 
00070     actual->open_files[fd] = (struct file *) malloc (sizeof(struct file));
00071     if ( ! actual->open_files[fd] )
00072                 return -1;
00073 
00074         file_alloc++;
00075     
00076     if ( aux.fs == FAT12 ) 
00077                 if ( open_FAT12(nombre, fd)!=OK ) {
00078                         kprintf("POR ACA....\n");
00079                 free(actual->open_files[fd]);
00080                 actual->open_files[fd] = NULL;
00081                 return -1;
00082         }
00083             
00084     return fd;
00085 }       
00086 
00087 
00088 int open_FAT12 (char *nombre, int fd)
00089 {
00090     if ((dev_fat[0].boot_leido==FALSE) || (dev_fat[0].fat_levantada==FALSE) ) 
00091         if ( init_floppy_fs() != OK ) {
00092             kprintf("No se puede leer disco\n");
00093             return -1;
00094         }
00095     
00096     fat12_entry_ext_t archivo;
00097 
00098     
00099     if ( fat_file_find(nombre , &archivo.fat12_data) == NULL )  {
00100 kprintf("Cantidad de Mallocs: %d\tFrees: %d\n", num_mallocs, num_frees);
00101                 kprintf("No se encuentra el archivete\n");
00102                 return -1;
00103     }
00104     
00105     actual->open_files[fd]->sectores = archivo.fat12_data.size / SECTOR_SIZE;
00106 
00107     if ( archivo.fat12_data.size % SECTOR_SIZE )            
00108         actual->open_files[fd]->sectores++;
00109 
00110     actual->open_files[fd]->offset = 0;
00111     actual->open_files[fd]->offset_rel = 0;
00112     actual->open_files[fd]->sector_origen = archivo.fat12_data.sector + dev_fat[0].root_dir_start + \
00113                 dev_fat[0].root_dir_size - 2;
00114     actual->open_files[fd]->sector_actual = actual->open_files[fd]->sector_origen;
00115 
00116     actual->open_files[fd]->size = archivo.fat12_data.size;
00117     
00118     return OK;
00119 }       
00120 
00121 
00122 
00123 int lseek (int fd, int offset, int donde)
00124 {
00125     
00126     struct file *aux = actual->open_files[fd];
00127 
00128     dword sector_aux;   
00129                         
00130     if (aux == NULL)
00131                 return -1;
00132 
00133 
00134     if (donde == SEEK_SET) {            
00135       
00136                 aux->sector_actual = aux->sector_origen;    
00137                 if (offset < 0) {
00138                     aux->offset = 0;
00139                     return 0;               
00140                 }
00141 
00142                 sector_aux = offset / SECTOR_SIZE;
00143 
00144                 
00145                 while ( sector_aux--  ) {
00146                     aux->sector_actual = fat_next_sector(aux->sector_actual);
00147                     if (aux->sector_actual <= 31)       
00148                                 return 0;       
00149                 }
00150 
00151                 aux->offset = offset;
00152                 aux->offset_rel = offset % SECTOR_SIZE;     
00153                 return offset;
00154     }
00155         
00156     else if (donde == SEEK_CUR) {
00157 
00158                 offset = aux->offset + offset;  
00159                 return lseek(fd, offset , SEEK_SET);        
00160     }                                               
00161 
00162         else if (donde == SEEK_END) {
00163                 if (offset > 0) 
00164                     return 0;
00165         
00166                 offset = aux->size + offset;    
00167                 return lseek(fd, offset , SEEK_SET);
00168     }
00169 
00170     else return aux->offset;
00171     
00172 }       
00173 
00174 
00175 
00176 
00177 int close (int fd)
00178 {
00179     struct file *aux;
00180     if ( (aux = actual->open_files[fd])==NULL )
00181                 return -1;
00182     
00183     free(actual->open_files[fd]);
00184     actual->open_files[fd] = NULL;
00185 file_free++;
00186     return fd;
00187 }
00188 
00189 
00190 
00191 
00192 
00193 
00194 
00195 
00196 
00197 
00198 
00199 
00200 
00201 
00202 
00203 
00204 
00205 
00206 
00207 
00208 
00209 
00210 
00211 
00212 
00213 
00214 
00215 
00216 
00217 
00218 
00219 
00220 
00221 
00222 
00223 
00224 
00225 
00226 
00227 
00228 
00229 
00230 
00231 
00232 
00233 
00234 
00235 
00236 
00237 
00238 
00239 ssize_t read (int fd, void *buf, size_t nbytes)
00240 {
00241     size_t len=nbytes;
00242     ssize_t aux_len;
00243     
00244     struct file *aux;       
00245 
00246 #ifdef RUNSTATS
00247                 long long counter;
00248 
00249                 if ( getvar("debugread") == 2 ) {
00250                         rdtscl(counter);
00251                 }
00252 #endif
00253         
00254     
00255     if ( (aux=actual->open_files[fd] )==NULL)       
00256                         return -1;
00257 
00258     
00259     if ( (aux->size) < (len + aux->offset) )
00260                         len = (aux->size) - aux->offset;
00261 
00262     aux_len = len;
00263     
00264     
00265     word remanente = SECTOR_SIZE - aux->offset_rel;
00266     word desplaz=0;
00267     
00268 
00269     
00270     while (len > 0) {
00271                         
00272                                 
00273 
00274 
00275 
00276 
00277                         
00278                                 
00279                                 
00280                                 if ( cache_read(fd0,aux->sector_actual,aux->offset_rel,buf+desplaz,aux_len) == -1 )
00281                                         return -1;
00282                                                 
00283 
00284                 if (len <= remanente)   
00285                     aux_len = len;      
00286 
00287                 else aux_len = remanente;   
00288                                     
00289                                     
00290 
00291                 
00292                 
00293         
00294                 
00295                 lseek(fd, aux_len, SEEK_CUR );
00296                 desplaz = desplaz + aux_len;
00297                 len = len - aux_len;
00298         remanente = SECTOR_SIZE - aux->offset_rel;
00299     }
00300 
00301 #ifdef RUNSTATS
00302   if ( getvar("debugread") == 2 ) {
00303                 long long int counterfinal;
00304                 rdtscl(counterfinal);
00305                 kprintf("R0x%llx ",counterfinal-counter);
00306         }       
00307 #endif
00308                 
00309 
00310         return desplaz;
00311 }
00312