diff options
author | germeier <germeier> | 2002-09-15 12:03:22 +0000 |
---|---|---|
committer | germeier <germeier> | 2002-09-15 12:03:22 +0000 |
commit | a9c7d297c5244f6ffc5ac0f977b56f7e19d14cd1 (patch) | |
tree | 9fcfa9442c1574c9c7dee5b8ff4dd0560888e881 /libmpio | |
parent | f8ffc3a54f0f6dce3929b32fb582a77d871e87a3 (diff) | |
download | mpiosh-a9c7d297c5244f6ffc5ac0f977b56f7e19d14cd1.tar.gz mpiosh-a9c7d297c5244f6ffc5ac0f977b56f7e19d14cd1.tar.bz2 mpiosh-a9c7d297c5244f6ffc5ac0f977b56f7e19d14cd1.zip |
added model identification
use 0x80 for external memory on the DMG line
added code to dump first 0x100 sectors of memory
Diffstat (limited to 'libmpio')
-rw-r--r-- | libmpio/defs.h | 28 | ||||
-rw-r--r-- | libmpio/io.c | 42 | ||||
-rw-r--r-- | libmpio/io.h | 4 | ||||
-rw-r--r-- | libmpio/mpio.c | 48 | ||||
-rw-r--r-- | libmpio/mpio.h | 5 |
5 files changed, 104 insertions, 23 deletions
diff --git a/libmpio/defs.h b/libmpio/defs.h index ad4177c..0032893 100644 --- a/libmpio/defs.h +++ b/libmpio/defs.h @@ -1,7 +1,7 @@ /* -*- linux-c -*- */ /* - * $Id: defs.h,v 1.3 2002/09/11 00:18:34 germeier Exp $ + * $Id: defs.h,v 1.4 2002/09/15 12:03:23 germeier Exp $ * * Library for USB MPIO-* * @@ -38,6 +38,22 @@ typedef unsigned int DWORD; typedef enum { MPIO_INTERNAL_MEM = 0x01, MPIO_EXTERNAL_MEM = 0x10 } mpio_mem_t; +/* model type */ +typedef enum { MPIO_MODEL_DME = 0x00, + MPIO_MODEL_DMG = 0x01, + MPIO_MODEL_DMB = 0x02, + MPIO_MODEL_DMB_PLUS = 0x03, + MPIO_MODEL_DMK = 0x04, + MPIO_MODEL_UNKNOWN = 0x05 } mpio_model_t; + +static BYTE *mpio_model_name[] = { + "MPIO-DME", + "MPIO-DMG", + "MPIO-DMB", + "MPIO-DMB+", + "MPIO-DMK", + "unknown" }; + /* USB commands */ typedef enum { GET_VERSION = 0x01, GET_BLOCK = 0x02, @@ -84,12 +100,14 @@ typedef enum { FTYPE_CONF = 'C', /* get formatted information, about the MPIO player */ typedef struct { - BYTE firmware_id[INFO_LINE]; + BYTE firmware_id[INFO_LINE]; BYTE firmware_version[INFO_LINE]; BYTE firmware_date[INFO_LINE]; - BYTE firmware_mem_internal[INFO_LINE]; - BYTE firmware_mem_external[INFO_LINE]; + BYTE model[INFO_LINE]; + + BYTE mem_internal[INFO_LINE]; + BYTE mem_external[INFO_LINE]; } mpio_info_t; @@ -152,6 +170,8 @@ typedef struct { mpio_firmware_t firmware; + mpio_model_t model; + mpio_smartmedia_t internal; mpio_smartmedia_t external; } mpio_t; diff --git a/libmpio/io.c b/libmpio/io.c index f4a5daf..ebce296 100644 --- a/libmpio/io.c +++ b/libmpio/io.c @@ -2,7 +2,7 @@ /* * - * $Id: io.c,v 1.11 2002/09/11 13:44:30 germeier Exp $ + * $Id: io.c,v 1.12 2002/09/15 12:03:23 germeier Exp $ * * Library for USB MPIO-* * @@ -44,11 +44,28 @@ #include "debug.h" #include "ecc.h" +BYTE model2externalmem(mpio_model_t); WORD index2blockaddress(WORD); WORD cluster2blockaddress(DWORD, BYTE); int cluster2block(int mem, int sector); void fatentry2hw(mpio_fatentry_t *, BYTE *, DWORD *); +BYTE +model2externalmem(mpio_model_t model) +{ + BYTE m; + + switch(model) + { + case MPIO_MODEL_DMG: + m = 0x80; + default: + m = 0x10; + } + + return m; +} + void fatentry2hw(mpio_fatentry_t *f, BYTE *chip, DWORD *address) { @@ -222,15 +239,20 @@ cluster2blockaddress(DWORD index, BYTE size) */ int -mpio_io_set_cmdpacket(mpio_cmd_t cmd, mpio_mem_t mem, DWORD index, +mpio_io_set_cmdpacket(mpio_t *m, mpio_cmd_t cmd, mpio_mem_t mem, DWORD index, BYTE size, BYTE wsize, BYTE *buffer) { + BYTE memory; /* clear cmdpacket*/ memset(buffer, 0, 0x40); *buffer = cmd; - *(buffer + 0x01) = mem; + memory = mem; + if (mem == MPIO_EXTERNAL_MEM) + memory = model2externalmem(m->model); + + *(buffer + 0x01) = memory; *(buffer + 0x03) = (BYTE) (index & 0x00ff); *(buffer + 0x04) = (BYTE)((index & 0xff00) >> 8); /* SM cards with less or equal 32 MB only need 2 Bytes @@ -340,7 +362,7 @@ mpio_io_version_read(mpio_t *m, BYTE *buffer) BYTE cmdpacket[CMD_SIZE], status[CMD_SIZE]; /* Send command packet to MPIO */ - mpio_io_set_cmdpacket (GET_VERSION, 0, 0, 0xff, 0, cmdpacket); + mpio_io_set_cmdpacket (m, GET_VERSION, 0, 0, 0xff, 0, cmdpacket); debugn (5, ">>> MPIO\n"); hexdump (cmdpacket, sizeof(cmdpacket)); @@ -404,7 +426,7 @@ mpio_io_sector_read(mpio_t *m, BYTE mem, DWORD index, BYTE *output) exit (-1); } - mpio_io_set_cmdpacket (GET_SECTOR, mem, index, sm->size, 0, cmdpacket); + mpio_io_set_cmdpacket (m, GET_SECTOR, mem, index, sm->size, 0, cmdpacket); debugn (5, "\n>>> MPIO\n"); hexdump (cmdpacket, sizeof(cmdpacket)); @@ -488,7 +510,7 @@ mpio_io_sector_write(mpio_t *m, BYTE mem, DWORD index, BYTE *input) exit (-1); } - mpio_io_set_cmdpacket(PUT_SECTOR, mem, index, sm->size, 0, cmdpacket); + mpio_io_set_cmdpacket(m, PUT_SECTOR, mem, index, sm->size, 0, cmdpacket); debugn (5, "\n>>> MPIO\n"); hexdump (cmdpacket, sizeof(cmdpacket)); @@ -564,7 +586,7 @@ mpio_io_block_read(mpio_t *m, BYTE mem, mpio_fatentry_t *f, BYTE *output) fatentry2hw(f, &chip, &address); - mpio_io_set_cmdpacket(GET_BLOCK, chip, address, sm->size, 0, cmdpacket); + mpio_io_set_cmdpacket(m, GET_BLOCK, chip, address, sm->size, 0, cmdpacket); debugn(5, "\n>>> MPIO\n"); hexdump(cmdpacket, sizeof(cmdpacket)); @@ -654,7 +676,7 @@ mpio_io_spare_read(mpio_t *m, BYTE area, DWORD index, BYTE size, for (chip = 1; chip <= chips; chip++) { - mpio_io_set_cmdpacket(GET_SPARE_AREA, chip, index, size, + mpio_io_set_cmdpacket(m, GET_SPARE_AREA, chip, index, size, wsize, cmdpacket); debugn(5, "\n>>> MPIO\n"); hexdump(cmdpacket, sizeof(cmdpacket)); @@ -706,7 +728,7 @@ mpio_io_block_delete(mpio_t *m, BYTE mem, mpio_fatentry_t *f) /* Send command packet to MPIO */ - mpio_io_set_cmdpacket(DEL_BLOCK, chip, address, sm->size, 0, cmdpacket); + mpio_io_set_cmdpacket(m, DEL_BLOCK, chip, address, sm->size, 0, cmdpacket); debugn (5, ">>> MPIO\n"); hexdump (cmdpacket, sizeof(cmdpacket)); @@ -803,7 +825,7 @@ mpio_io_block_write(mpio_t *m, BYTE mem, mpio_fatentry_t *f, BYTE *data) } } - mpio_io_set_cmdpacket(PUT_BLOCK, chip, address, sm->size, 0x48 , cmdpacket); + mpio_io_set_cmdpacket(m, PUT_BLOCK, chip, address, sm->size, 0x48 , cmdpacket); debugn(5, "\n>>> MPIO\n"); hexdump(cmdpacket, sizeof(cmdpacket)); diff --git a/libmpio/io.h b/libmpio/io.h index 0f97eed..330a494 100644 --- a/libmpio/io.h +++ b/libmpio/io.h @@ -2,7 +2,7 @@ /* * - * $Id: io.h,v 1.5 2002/09/10 12:31:09 germeier Exp $ + * $Id: io.h,v 1.6 2002/09/15 12:03:23 germeier Exp $ * * Library for USB MPIO-* * @@ -34,7 +34,7 @@ #include "defs.h" /* real I/O */ -int mpio_io_set_cmdpacket(mpio_cmd_t, mpio_mem_t, +int mpio_io_set_cmdpacket(mpio_t *, mpio_cmd_t, mpio_mem_t, DWORD, BYTE, BYTE, BYTE *); int mpio_io_bulk_read (int, BYTE *, int); diff --git a/libmpio/mpio.c b/libmpio/mpio.c index f65b47e..51a2894 100644 --- a/libmpio/mpio.c +++ b/libmpio/mpio.c @@ -1,6 +1,6 @@ /* * - * $Id: mpio.c,v 1.16 2002/09/14 22:54:41 germeier Exp $ + * $Id: mpio.c,v 1.17 2002/09/15 12:03:23 germeier Exp $ * * Library for USB MPIO-* * @@ -158,7 +158,6 @@ mpio_init(void) mpio_io_version_read(new_mpio, new_mpio->version); /* fill in values */ - /* TODO: check for different versions !! */ snprintf(new_mpio->firmware.id, 12, "%s", new_mpio->version); snprintf(new_mpio->firmware.major, 3, "%s", new_mpio->version + 0x0c); snprintf(new_mpio->firmware.minor, 3, "%s", new_mpio->version + 0x0e); @@ -166,6 +165,27 @@ mpio_init(void) snprintf(new_mpio->firmware.month, 3, "%s", new_mpio->version + 0x14); snprintf(new_mpio->firmware.day, 3, "%s", new_mpio->version + 0x16); + /* identify different versions */ + switch (new_mpio->version[5]) + { + case 'E': + new_mpio->model = MPIO_MODEL_DME; + break ; + case 'K': + new_mpio->model = MPIO_MODEL_DMK; + break ; + case 'G': + new_mpio->model = MPIO_MODEL_DMG; + break ; + case 'B': + new_mpio->model = MPIO_MODEL_DMB; + if (new_mpio->version[6] == 'P') + new_mpio->model = MPIO_MODEL_DMB_PLUS; + break; + default: + new_mpio->model = MPIO_MODEL_UNKNOWN; + } + /* internal init */ mpio_init_internal(new_mpio); @@ -225,14 +245,15 @@ mpio_get_info(mpio_t *m, mpio_info_t *info) m->firmware.major, m->firmware.minor); snprintf(info->firmware_date, max, "%s.%s.%s", m->firmware.day, m->firmware.month, m->firmware.year); + snprintf(info->model, max, "%s", mpio_model_name[m->model]); if (m->internal.chips == 1) { - snprintf(info->firmware_mem_internal, max, "%3dMB (%s)", + snprintf(info->mem_internal, max, "%3dMB (%s)", mpio_id2mem(m->internal.id), mpio_id2manufacturer(m->internal.manufacturer)); } else { - snprintf(info->firmware_mem_internal, max, "%3dMB (%s) - %d chips", + snprintf(info->mem_internal, max, "%3dMB (%s) - %d chips", mpio_id2mem(m->internal.id)*m->internal.chips, mpio_id2manufacturer(m->internal.manufacturer), m->internal.chips); @@ -240,11 +261,11 @@ mpio_get_info(mpio_t *m, mpio_info_t *info) if (m->external.id) { - snprintf(info->firmware_mem_external, max, "%3dMB (%s)", + snprintf(info->mem_external, max, "%3dMB (%s)", mpio_id2mem(m->external.id), mpio_id2manufacturer(m->external.manufacturer)); } else { - snprintf(info->firmware_mem_external, max, "not available"); + snprintf(info->mem_external, max, "not available"); } } @@ -666,5 +687,20 @@ mpio_sync(mpio_t *m, mpio_mem_t mem) mpio_fat_write(m, mem); } +int +mpio_memory_debug(mpio_t *m, mpio_mem_t mem) +{ + BYTE block[BLOCK_SIZE]; + int i; + + for (i = 0 ; i<=0x100 ; i++) + mpio_io_sector_read(m, mem, i, block); + + return 0; +} + + + + diff --git a/libmpio/mpio.h b/libmpio/mpio.h index 0acf8c9..6ace073 100644 --- a/libmpio/mpio.h +++ b/libmpio/mpio.h @@ -1,7 +1,7 @@ /* -*- linux-c -*- */ /* - * $Id: mpio.h,v 1.3 2002/09/14 22:54:41 germeier Exp $ + * $Id: mpio.h,v 1.4 2002/09/15 12:03:23 germeier Exp $ * * Library for USB MPIO-* * @@ -91,6 +91,9 @@ int mpio_memory_format(mpio_t *, mpio_mem_t, BYTE (*)(int, int)); /* context, memory bank */ int mpio_sync(mpio_t *, mpio_mem_t); +/* context, memory bank */ +int mpio_memory_debug(mpio_t *, mpio_mem_t); + /* * timeline: * --------- |