Sauvegarde sur carte microSD

Dependents:   microSD_Card

Committer:
adrevong
Date:
Tue Jan 28 11:11:57 2020 +0000
Revision:
0:c9f6f3f0cd78

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
adrevong 0:c9f6f3f0cd78 1 /* mbed Microcontroller Library - MemFileSystem
adrevong 0:c9f6f3f0cd78 2 * Copyright (c) 2008, sford
adrevong 0:c9f6f3f0cd78 3 */
adrevong 0:c9f6f3f0cd78 4
adrevong 0:c9f6f3f0cd78 5
adrevong 0:c9f6f3f0cd78 6 #ifndef MBED_MEMFILESYSTEM_H
adrevong 0:c9f6f3f0cd78 7 #define MBED_MEMFILESYSTEM_H
adrevong 0:c9f6f3f0cd78 8
adrevong 0:c9f6f3f0cd78 9 #include "FATFileSystem.h"
adrevong 0:c9f6f3f0cd78 10
adrevong 0:c9f6f3f0cd78 11 namespace mbed
adrevong 0:c9f6f3f0cd78 12 {
adrevong 0:c9f6f3f0cd78 13
adrevong 0:c9f6f3f0cd78 14 class MemFileSystem : public FATFileSystem
adrevong 0:c9f6f3f0cd78 15 {
adrevong 0:c9f6f3f0cd78 16 public:
adrevong 0:c9f6f3f0cd78 17
adrevong 0:c9f6f3f0cd78 18 // 2000 sectors, each 512 bytes (malloced as required)
adrevong 0:c9f6f3f0cd78 19 char *sectors[2000];
adrevong 0:c9f6f3f0cd78 20
adrevong 0:c9f6f3f0cd78 21 MemFileSystem(const char* name) : FATFileSystem(name) {
adrevong 0:c9f6f3f0cd78 22 memset(sectors, 0, sizeof(sectors));
adrevong 0:c9f6f3f0cd78 23 }
adrevong 0:c9f6f3f0cd78 24
adrevong 0:c9f6f3f0cd78 25 virtual ~MemFileSystem() {
adrevong 0:c9f6f3f0cd78 26 for(int i = 0; i < 2000; i++) {
adrevong 0:c9f6f3f0cd78 27 if(sectors[i]) {
adrevong 0:c9f6f3f0cd78 28 free(sectors[i]);
adrevong 0:c9f6f3f0cd78 29 }
adrevong 0:c9f6f3f0cd78 30 }
adrevong 0:c9f6f3f0cd78 31 }
adrevong 0:c9f6f3f0cd78 32
adrevong 0:c9f6f3f0cd78 33 // read a sector in to the buffer, return 0 if ok
adrevong 0:c9f6f3f0cd78 34 virtual int disk_read(char *buffer, int sector) {
adrevong 0:c9f6f3f0cd78 35 if(sectors[sector] == 0) {
adrevong 0:c9f6f3f0cd78 36 // nothing allocated means sector is empty
adrevong 0:c9f6f3f0cd78 37 memset(buffer, 0, 512);
adrevong 0:c9f6f3f0cd78 38 } else {
adrevong 0:c9f6f3f0cd78 39 memcpy(buffer, sectors[sector], 512);
adrevong 0:c9f6f3f0cd78 40 }
adrevong 0:c9f6f3f0cd78 41 return 0;
adrevong 0:c9f6f3f0cd78 42 }
adrevong 0:c9f6f3f0cd78 43
adrevong 0:c9f6f3f0cd78 44 // write a sector from the buffer, return 0 if ok
adrevong 0:c9f6f3f0cd78 45 virtual int disk_write(const char *buffer, int sector) {
adrevong 0:c9f6f3f0cd78 46 // if buffer is zero deallocate sector
adrevong 0:c9f6f3f0cd78 47 char zero[512];
adrevong 0:c9f6f3f0cd78 48 memset(zero, 0, 512);
adrevong 0:c9f6f3f0cd78 49 if(memcmp(zero, buffer, 512)==0) {
adrevong 0:c9f6f3f0cd78 50 if(sectors[sector] != 0) {
adrevong 0:c9f6f3f0cd78 51 free(sectors[sector]);
adrevong 0:c9f6f3f0cd78 52 sectors[sector] = 0;
adrevong 0:c9f6f3f0cd78 53 }
adrevong 0:c9f6f3f0cd78 54 return 0;
adrevong 0:c9f6f3f0cd78 55 }
adrevong 0:c9f6f3f0cd78 56 // else allocate a sector if needed, and write
adrevong 0:c9f6f3f0cd78 57 if(sectors[sector] == 0) {
adrevong 0:c9f6f3f0cd78 58 char *sec = (char*)malloc(512);
adrevong 0:c9f6f3f0cd78 59 if(sec==0) {
adrevong 0:c9f6f3f0cd78 60 return 1; // out of memory
adrevong 0:c9f6f3f0cd78 61 }
adrevong 0:c9f6f3f0cd78 62 sectors[sector] = sec;
adrevong 0:c9f6f3f0cd78 63 }
adrevong 0:c9f6f3f0cd78 64 memcpy(sectors[sector], buffer, 512);
adrevong 0:c9f6f3f0cd78 65 return 0;
adrevong 0:c9f6f3f0cd78 66 }
adrevong 0:c9f6f3f0cd78 67
adrevong 0:c9f6f3f0cd78 68 // return the number of sectors
adrevong 0:c9f6f3f0cd78 69 virtual int disk_sectors() {
adrevong 0:c9f6f3f0cd78 70 return sizeof(sectors)/sizeof(sectors[0]);
adrevong 0:c9f6f3f0cd78 71 }
adrevong 0:c9f6f3f0cd78 72
adrevong 0:c9f6f3f0cd78 73 };
adrevong 0:c9f6f3f0cd78 74
adrevong 0:c9f6f3f0cd78 75 }
adrevong 0:c9f6f3f0cd78 76
adrevong 0:c9f6f3f0cd78 77 #endif