Web server based weather station using Sparkfun Weather Meters.

Dependencies:   FatFileSystem mbed WeatherMeters SDFileSystem

Committer:
AdamGreen
Date:
Thu Feb 23 21:38:39 2012 +0000
Revision:
0:616601bde9fb

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AdamGreen 0:616601bde9fb 1 /*-----------------------------------------------------------------------*/
AdamGreen 0:616601bde9fb 2 /* Low level disk I/O module skeleton for FatFs (C)ChaN, 2007 */
AdamGreen 0:616601bde9fb 3 /*-----------------------------------------------------------------------*/
AdamGreen 0:616601bde9fb 4 /* This is a stub disk I/O module that acts as front end of the existing */
AdamGreen 0:616601bde9fb 5 /* disk I/O modules and attach it to FatFs module with common interface. */
AdamGreen 0:616601bde9fb 6 /*-----------------------------------------------------------------------*/
AdamGreen 0:616601bde9fb 7
AdamGreen 0:616601bde9fb 8 #include "diskio.h"
AdamGreen 0:616601bde9fb 9 #include <stdio.h>
AdamGreen 0:616601bde9fb 10 #include <string.h>
AdamGreen 0:616601bde9fb 11 #include "FATFileSystem.h"
AdamGreen 0:616601bde9fb 12
AdamGreen 0:616601bde9fb 13 #include "mbed.h"
AdamGreen 0:616601bde9fb 14
AdamGreen 0:616601bde9fb 15 DSTATUS disk_initialize (
AdamGreen 0:616601bde9fb 16 BYTE drv /* Physical drive nmuber (0..) */
AdamGreen 0:616601bde9fb 17 )
AdamGreen 0:616601bde9fb 18 {
AdamGreen 0:616601bde9fb 19 FFSDEBUG("disk_initialize on drv [%d]\n", drv);
AdamGreen 0:616601bde9fb 20 return (DSTATUS)FATFileSystem::_ffs[drv]->disk_initialize();
AdamGreen 0:616601bde9fb 21 }
AdamGreen 0:616601bde9fb 22
AdamGreen 0:616601bde9fb 23 DSTATUS disk_status (
AdamGreen 0:616601bde9fb 24 BYTE drv /* Physical drive nmuber (0..) */
AdamGreen 0:616601bde9fb 25 )
AdamGreen 0:616601bde9fb 26 {
AdamGreen 0:616601bde9fb 27 FFSDEBUG("disk_status on drv [%d]\n", drv);
AdamGreen 0:616601bde9fb 28 return (DSTATUS)FATFileSystem::_ffs[drv]->disk_status();
AdamGreen 0:616601bde9fb 29 }
AdamGreen 0:616601bde9fb 30
AdamGreen 0:616601bde9fb 31 DRESULT disk_read (
AdamGreen 0:616601bde9fb 32 BYTE drv, /* Physical drive nmuber (0..) */
AdamGreen 0:616601bde9fb 33 BYTE *buff, /* Data buffer to store read data */
AdamGreen 0:616601bde9fb 34 DWORD sector, /* Sector address (LBA) */
AdamGreen 0:616601bde9fb 35 BYTE count /* Number of sectors to read (1..255) */
AdamGreen 0:616601bde9fb 36 )
AdamGreen 0:616601bde9fb 37 {
AdamGreen 0:616601bde9fb 38 FFSDEBUG("disk_read(sector %d, count %d) on drv [%d]\n", sector, count, drv);
AdamGreen 0:616601bde9fb 39 for(DWORD s=sector; s<sector+count; s++) {
AdamGreen 0:616601bde9fb 40 FFSDEBUG(" disk_read(sector %d)\n", s);
AdamGreen 0:616601bde9fb 41 int res = FATFileSystem::_ffs[drv]->disk_read((char*)buff, s);
AdamGreen 0:616601bde9fb 42 if(res) {
AdamGreen 0:616601bde9fb 43 return RES_PARERR;
AdamGreen 0:616601bde9fb 44 }
AdamGreen 0:616601bde9fb 45 buff += 512;
AdamGreen 0:616601bde9fb 46 }
AdamGreen 0:616601bde9fb 47 return RES_OK;
AdamGreen 0:616601bde9fb 48 }
AdamGreen 0:616601bde9fb 49
AdamGreen 0:616601bde9fb 50 #if _READONLY == 0
AdamGreen 0:616601bde9fb 51 DRESULT disk_write (
AdamGreen 0:616601bde9fb 52 BYTE drv, /* Physical drive nmuber (0..) */
AdamGreen 0:616601bde9fb 53 const BYTE *buff, /* Data to be written */
AdamGreen 0:616601bde9fb 54 DWORD sector, /* Sector address (LBA) */
AdamGreen 0:616601bde9fb 55 BYTE count /* Number of sectors to write (1..255) */
AdamGreen 0:616601bde9fb 56 )
AdamGreen 0:616601bde9fb 57 {
AdamGreen 0:616601bde9fb 58 FFSDEBUG("disk_write(sector %d, count %d) on drv [%d]\n", sector, count, drv);
AdamGreen 0:616601bde9fb 59 for(DWORD s=sector; s<sector+count; s++) {
AdamGreen 0:616601bde9fb 60 FFSDEBUG(" disk_write(sector %d)\n", s);
AdamGreen 0:616601bde9fb 61 int res = FATFileSystem::_ffs[drv]->disk_write((char*)buff, s);
AdamGreen 0:616601bde9fb 62 if(res) {
AdamGreen 0:616601bde9fb 63 return RES_PARERR;
AdamGreen 0:616601bde9fb 64 }
AdamGreen 0:616601bde9fb 65 buff += 512;
AdamGreen 0:616601bde9fb 66 }
AdamGreen 0:616601bde9fb 67 return RES_OK;
AdamGreen 0:616601bde9fb 68 }
AdamGreen 0:616601bde9fb 69 #endif /* _READONLY */
AdamGreen 0:616601bde9fb 70
AdamGreen 0:616601bde9fb 71 DRESULT disk_ioctl (
AdamGreen 0:616601bde9fb 72 BYTE drv, /* Physical drive nmuber (0..) */
AdamGreen 0:616601bde9fb 73 BYTE ctrl, /* Control code */
AdamGreen 0:616601bde9fb 74 void *buff /* Buffer to send/receive control data */
AdamGreen 0:616601bde9fb 75 )
AdamGreen 0:616601bde9fb 76 {
AdamGreen 0:616601bde9fb 77 FFSDEBUG("disk_ioctl(%d)\n", ctrl);
AdamGreen 0:616601bde9fb 78 switch(ctrl) {
AdamGreen 0:616601bde9fb 79 case CTRL_SYNC:
AdamGreen 0:616601bde9fb 80 if(FATFileSystem::_ffs[drv] == NULL) {
AdamGreen 0:616601bde9fb 81 return RES_NOTRDY;
AdamGreen 0:616601bde9fb 82 } else if(FATFileSystem::_ffs[drv]->disk_sync()) {
AdamGreen 0:616601bde9fb 83 return RES_ERROR;
AdamGreen 0:616601bde9fb 84 }
AdamGreen 0:616601bde9fb 85 return RES_OK;
AdamGreen 0:616601bde9fb 86 case GET_SECTOR_COUNT:
AdamGreen 0:616601bde9fb 87 if(FATFileSystem::_ffs[drv] == NULL) {
AdamGreen 0:616601bde9fb 88 return RES_NOTRDY;
AdamGreen 0:616601bde9fb 89 } else {
AdamGreen 0:616601bde9fb 90 int res = FATFileSystem::_ffs[drv]->disk_sectors();
AdamGreen 0:616601bde9fb 91 if(res > 0) {
AdamGreen 0:616601bde9fb 92 *((DWORD*)buff) = res; // minimum allowed
AdamGreen 0:616601bde9fb 93 return RES_OK;
AdamGreen 0:616601bde9fb 94 } else {
AdamGreen 0:616601bde9fb 95 return RES_ERROR;
AdamGreen 0:616601bde9fb 96 }
AdamGreen 0:616601bde9fb 97 }
AdamGreen 0:616601bde9fb 98 case GET_BLOCK_SIZE:
AdamGreen 0:616601bde9fb 99 *((DWORD*)buff) = 1; // default when not known
AdamGreen 0:616601bde9fb 100 return RES_OK;
AdamGreen 0:616601bde9fb 101
AdamGreen 0:616601bde9fb 102 }
AdamGreen 0:616601bde9fb 103 return RES_PARERR;
AdamGreen 0:616601bde9fb 104 }
AdamGreen 0:616601bde9fb 105