///////////////////////////////////////////////////////////////////////////////////////////////////////// // // Name: dstat.c // Created: July 2019 // Author(s): Philip Smart // Description: Standalone App for the ZPU test application. // This program implements a loadable appliation which can be loaded from SD card by // the ZPUTA application. The idea is that commands or programs can be stored on the // SD card and executed by ZPUTA just like an OS such as Linux. The primary purpose // is to be able to minimise the size of ZPUTA for applications where minimal ram is // available. // // Credits: // Copyright: (c) 2019 Philip Smart // // History: July 2019 - Initial framework creation. // // Notes: See Makefile to enable/disable conditional components // ///////////////////////////////////////////////////////////////////////////////////////////////////////// // This source file is free software: you can redistribute it and#or modify // it under the terms of the GNU General Public License as published // by the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This source file is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . ///////////////////////////////////////////////////////////////////////////////////////////////////////// #include //#include //#include #include #include "zpu_soc.h" //#include "uart.h" #include "interrupts.h" #include "ff.h" /* Declarations of FatFs API */ #include "diskio.h" #include #include #include #include #include #include "xprintf.h" #include "utils.h" #include "zputa_app.h" #include "dstat.h" // Utility functions. #include "tools.c" // Version info. #define VERSION "v1.0" #define VERSION_DATE "18/07/2019" #define APP_NAME "DSTAT" // Main entry and start point of a ZPUTA Application. Only 2 parameters are catered for and a 32bit return code, additional parameters can be added by changing the appcrt0.s // startup code to add them to the stack prior to app() call. // // Return code is saved in _memreg by the C compiler, this is transferred to _memreg in ZPUTA in appcrt0.s prior to return. // uint32_t app(uint32_t param1, uint32_t param2) { // Initialisation. // char *ptr = (char *)param1; char line[120]; long drive; long sector; uint8_t cardType; if (xatoi(&ptr, &drive)) { if (disk_ioctl((BYTE)drive, GET_SECTOR_COUNT, §or) == RES_OK) { xprintf("Drive size: %lu sectors\n", sector); } if (disk_ioctl((BYTE)drive, GET_BLOCK_SIZE, §or) == RES_OK) { xprintf("Erase block: %lu sectors\n", sector); } if (disk_ioctl((BYTE)drive, MMC_GET_TYPE, &cardType) == RES_OK) { xprintf("Card type: %u\n", cardType); } if (disk_ioctl((BYTE)drive, MMC_GET_CSD, G->Buff) == RES_OK) { xputs("CSD:\n"); memoryDump((uint32_t)G->Buff, 16, 16, 0, 32); } if (disk_ioctl((BYTE)drive, MMC_GET_CID, G->Buff) == RES_OK) { xputs("CID:\n"); memoryDump((uint32_t)G->Buff, 16, 16, 0, 32); } if (disk_ioctl((BYTE)drive, MMC_GET_OCR, G->Buff) == RES_OK) { xputs("OCR:\n"); memoryDump((uint32_t)G->Buff, 4, 16, 0, 32); } if (disk_ioctl((BYTE)drive, MMC_GET_SDSTAT, G->Buff) == RES_OK) { xputs("SD Status:\n"); memoryDump((uint32_t)G->Buff, 64, 16, 0, 32); } if (disk_ioctl((BYTE)drive, ATA_GET_MODEL, line) == RES_OK) { line[40] = '\0'; xprintf("Model: %s\n", line); } if (disk_ioctl((BYTE)drive, ATA_GET_SN, line) == RES_OK) { line[20] = '\0'; xprintf("S/N: %s\n", line); } } else { xprintf("Illegal <#pd> value.\n"); } return(0); }