| /* | |
| * FreeRTOS+FAT SL V1.0.1 (C) 2014 HCC Embedded | |
| * | |
| * The FreeRTOS+FAT SL license terms are different to the FreeRTOS license | |
| * terms. | |
| * | |
| * FreeRTOS+FAT SL uses a dual license model that allows the software to be used | |
| * under a standard GPL open source license, or a commercial license. The | |
| * standard GPL license (unlike the modified GPL license under which FreeRTOS | |
| * itself is distributed) requires that all software statically linked with | |
| * FreeRTOS+FAT SL is also distributed under the same GPL V2 license terms. | |
| * Details of both license options follow: | |
| * | |
| * - Open source licensing - | |
| * FreeRTOS+FAT SL is a free download and may be used, modified, evaluated and | |
| * distributed without charge provided the user adheres to version two of the | |
| * GNU General Public License (GPL) and does not remove the copyright notice or | |
| * this text. The GPL V2 text is available on the gnu.org web site, and on the | |
| * following URL: http://www.FreeRTOS.org/gpl-2.0.txt. | |
| * | |
| * - Commercial licensing - | |
| * Businesses and individuals who for commercial or other reasons cannot comply | |
| * with the terms of the GPL V2 license must obtain a commercial license before | |
| * incorporating FreeRTOS+FAT SL into proprietary software for distribution in | |
| * any form. Commercial licenses can be purchased from | |
| * http://shop.freertos.org/fat_sl and do not require any source files to be | |
| * changed. | |
| * | |
| * FreeRTOS+FAT SL is distributed in the hope that it will be useful. You | |
| * cannot use FreeRTOS+FAT SL unless you agree that you use the software 'as | |
| * is'. FreeRTOS+FAT SL is provided WITHOUT ANY WARRANTY; without even the | |
| * implied warranties of NON-INFRINGEMENT, MERCHANTABILITY or FITNESS FOR A | |
| * PARTICULAR PURPOSE. Real Time Engineers Ltd. and HCC Embedded disclaims all | |
| * conditions and terms, be they implied, expressed, or statutory. | |
| * | |
| * http://www.FreeRTOS.org | |
| * http://www.FreeRTOS.org/FreeRTOS-Plus | |
| * | |
| */ | |
| #include "../../api/api_mdriver_ram.h" | |
| #include "config_mdriver_ram.h" | |
| #include "../../psp/include/psp_string.h" | |
| #include "../../version/ver_mdriver_ram.h" | |
| #if VER_MDRIVER_RAM_MAJOR != 1 || VER_MDRIVER_RAM_MINOR != 2 | |
| #error Incompatible MDRIVER_RAM version number! | |
| #endif | |
| char ramdrv0[MDRIVER_RAM_VOLUME0_SIZE]; | |
| typedef struct | |
| { | |
| char * ramdrv; | |
| unsigned long maxsector; | |
| int use; | |
| F_DRIVER * driver; | |
| } t_RamDrv; | |
| static F_DRIVER t_drivers[1]; | |
| static t_RamDrv RamDrv[1] = | |
| { | |
| { ramdrv0, ( MDRIVER_RAM_VOLUME0_SIZE / MDRIVER_RAM_SECTOR_SIZE ), 0, &t_drivers[0] } | |
| }; | |
| /**************************************************************************** | |
| * Read one sector | |
| ***************************************************************************/ | |
| static int ram_readsector ( F_DRIVER * driver, void * data, unsigned long sector ) | |
| { | |
| long len; | |
| char * d = (char *)data; | |
| char * s; | |
| t_RamDrv * p = (t_RamDrv *)( driver->user_ptr ); | |
| if ( sector >= p->maxsector ) | |
| { | |
| return MDRIVER_RAM_ERR_SECTOR; | |
| } | |
| s = p->ramdrv; | |
| s += sector * MDRIVER_RAM_SECTOR_SIZE; | |
| len = MDRIVER_RAM_SECTOR_SIZE; | |
| #if MDRIVER_MEM_LONG_ACCESS | |
| if ( ( !( len & 3 ) ) && ( !( ( (long)d ) & 3 ) ) && ( !( ( (long)s ) & 3 ) ) ) | |
| { | |
| long * dd = (long *)d; | |
| long * ss = (long *)s; | |
| len >>= 2; | |
| while ( len-- ) | |
| { | |
| *dd++ = *ss++; | |
| } | |
| return MDRIVER_RAM_NO_ERROR; | |
| } | |
| #endif /* if MDRIVER_MEM_LONG_ACCESS */ | |
| while ( len-- ) | |
| { | |
| *d++ = *s++; | |
| } | |
| return MDRIVER_RAM_NO_ERROR; | |
| } | |
| /**************************************************************************** | |
| * Write one sector | |
| ***************************************************************************/ | |
| static int ram_writesector ( F_DRIVER * driver, void * data, unsigned long sector ) | |
| { | |
| long len; | |
| char * s = (char *)data; | |
| char * d; | |
| t_RamDrv * p = (t_RamDrv *)( driver->user_ptr ); | |
| if ( sector >= p->maxsector ) | |
| { | |
| return MDRIVER_RAM_ERR_SECTOR; | |
| } | |
| d = p->ramdrv; | |
| d += sector * MDRIVER_RAM_SECTOR_SIZE; | |
| len = MDRIVER_RAM_SECTOR_SIZE; | |
| #if MDRIVER_MEM_LONG_ACCESS | |
| if ( ( !( len & 3 ) ) && ( !( ( (long)d ) & 3 ) ) && ( !( ( (long)s ) & 3 ) ) ) | |
| { | |
| long * dd = (long *)d; | |
| long * ss = (long *)s; | |
| len >>= 2; | |
| while ( len-- ) | |
| { | |
| *dd++ = *ss++; | |
| } | |
| return MDRIVER_RAM_NO_ERROR; | |
| } | |
| #endif /* if MDRIVER_MEM_LONG_ACCESS */ | |
| while ( len-- ) | |
| { | |
| *d++ = *s++; | |
| } | |
| return MDRIVER_RAM_NO_ERROR; | |
| } | |
| /**************************************************************************** | |
| * | |
| * ram_getphy | |
| * | |
| * determinate ramdrive physicals | |
| * | |
| * INPUTS | |
| * | |
| * driver - driver structure | |
| * phy - this structure has to be filled with physical information | |
| * | |
| * RETURNS | |
| * | |
| * error code or zero if successful | |
| * | |
| ***************************************************************************/ | |
| static int ram_getphy ( F_DRIVER * driver, F_PHY * phy ) | |
| { | |
| t_RamDrv * p = (t_RamDrv *)( driver->user_ptr ); | |
| phy->number_of_sectors = p->maxsector; | |
| phy->bytes_per_sector = MDRIVER_RAM_SECTOR_SIZE; | |
| return MDRIVER_RAM_NO_ERROR; | |
| } | |
| /**************************************************************************** | |
| * | |
| * ram_release | |
| * | |
| * Releases a drive | |
| * | |
| * INPUTS | |
| * | |
| * driver_param - driver parameter | |
| * | |
| ***************************************************************************/ | |
| static void ram_release ( F_DRIVER * driver ) | |
| { | |
| t_RamDrv * p = (t_RamDrv *)( driver->user_ptr ); | |
| if ( p == RamDrv ) | |
| { | |
| p->use = 0; | |
| } | |
| } | |
| /**************************************************************************** | |
| * | |
| * ram_initfunc | |
| * | |
| * this init function has to be passed for highlevel to initiate the | |
| * driver functions | |
| * | |
| * INPUTS | |
| * | |
| * driver_param - driver parameter | |
| * | |
| * RETURNS | |
| * | |
| * driver structure pointer | |
| * | |
| ***************************************************************************/ | |
| F_DRIVER * ram_initfunc ( unsigned long driver_param ) | |
| { | |
| t_RamDrv * p; | |
| p = RamDrv + driver_param; | |
| if ( p != RamDrv ) | |
| { | |
| return 0; | |
| } | |
| if ( p->use ) | |
| { | |
| return 0; | |
| } | |
| (void)psp_memset( p->driver, 0, sizeof( F_DRIVER ) ); | |
| p->driver->readsector = ram_readsector; | |
| p->driver->writesector = ram_writesector; | |
| p->driver->getphy = ram_getphy; | |
| p->driver->release = ram_release; | |
| p->driver->user_ptr = p; | |
| p->use = 1; | |
| return p->driver; | |
| } /* ram_initfunc */ | |