Я признаю: мой проект Ethernet Shield застрял из-за слишком большого количества других неотложных приоритетов. Я не был доволен тем, как в проекте использовались данные конфигурации из флэш-памяти: у меня сейчас используется несколько сетевых экранов Ethernet, и настройка IP-адреса для каждого экрана является трудной задачей. У меня не работает DHCP (пока), так почему бы не использовать SD-карту на экране для данных конфигурации? И как раз вовремя я получил совет от Марка о MinIni : идеально, именно то, что мне нужно!
MININI
MinIni (см. Http://www.compuphase.com/minini.htm ) — это библиотека программистов для чтения и записи файлов INI для встроенных систем. INI-файлы — это текстовые файлы с «разделами» и «ключами», например:
[W5100] Gateway = 192.168.1.1 NetMask = 255.255.255.0 MAC = 90-A2-DA-0D-42-DD IP = 192.168.0.90
Библиотека MinIni небольшая и эффективная, в основном это только один исходный файл и один заголовочный файл, и она используется с «склеивающими» файлами для разных систем памяти. Одним из них является FatFS, который я уже много использую. Так что MinIni просто идеально подходит для того, что мне нужно.
MinIni Компонент
Хотя источники MinIni можно использовать «как есть», я хотел перенести их на следующий уровень, поэтому я создал для них компонент MinIni Processor Expert:
Таким образом, у меня есть подсказки для каждого из методов:
Здесь это не останавливается: щелкните правой кнопкой мыши по компоненту и используйте « Справку по компоненту », и у вас также есть доступ к руководству пользователя (PDF):
Ниже приведен скриншот свойств компонента:
- Portable strnicmp(): if enabled, the library has a library for strnicmp().
- Use Real: if enabled, the library enables reading and writing floating point values.
- Read Only: if enabled, it only reads from the configuration file, and all write methods are disabled.
- No Debug: if enabled, assert() in the library is not used. If you disable it, make sure assert() is provided either in your application code or in the standard library.
- FatFS Buffer Size: this size (in bytes) defines the maximum file name size and the size of a configuration line item. The library does not use any global variables, so make sure that your stack has enough space available.
FatFS String Functions
Because MinIni uses the FatFS string functions f_gets() and f_puts(), make sure you have them enabled:
Usage
The following code shows how I read configuration data from the SD card to configure the WizNet 5100 chip:
#if PL_USE_INI { uint8_t buf[32]; int val; const unsigned char *p; uint8_t res; CLS1_SendStr((unsigned char*)"Loading values from " INI_FILE_NAME "\r\n", CLS1_GetStdio()->stdOut); /* Gateway */ val = MINI1_ini_gets(INI_SECTION_NAME, "Gateway", "192.168.1.1", (char*)buf, sizeof(buf), INI_FILE_NAME); CLS1_SendStr((unsigned char*)"Gateway: ", CLS1_GetStdio()->stdOut); CLS1_SendStr(buf, CLS1_GetStdio()->stdOut); CLS1_SendStr((unsigned char*)"\r\n", CLS1_GetStdio()->stdOut); if (val!=0) { p = &buf[0]; res = UTIL1_ScanSeparatedNumbers(&p, &W5100_config.gateway[0], sizeof(W5100_config.gateway), '.', UTIL1_SEP_NUM_TYPE_UINT8); if (res!=ERR_OK) { CLS1_SendStr((unsigned char*)"Gateway FAILED!\r\n", CLS1_GetStdio()->stdOut); } } /* NetMask */ val = MINI1_ini_gets(INI_SECTION_NAME, "NetMask", "255.255.255.0", (char*)buf, sizeof(buf), INI_FILE_NAME); CLS1_SendStr((unsigned char*)"NetMask: ", CLS1_GetStdio()->stdOut); CLS1_SendStr(buf, CLS1_GetStdio()->stdOut); CLS1_SendStr((unsigned char*)"\r\n", CLS1_GetStdio()->stdOut); if (val!=0) { p = &buf[0]; res = UTIL1_ScanSeparatedNumbers(&p, &W5100_config.netmask[0], sizeof(W5100_config.netmask), '.', UTIL1_SEP_NUM_TYPE_UINT8); if (res!=ERR_OK) { CLS1_SendStr((unsigned char*)"Netmask FAILED!\r\n", CLS1_GetStdio()->stdOut); } } /* IP */ val = MINI1_ini_gets(INI_SECTION_NAME, "IP", "192.168.0.1", (char*)buf, sizeof(buf), INI_FILE_NAME); CLS1_SendStr((unsigned char*)"IP: ", CLS1_GetStdio()->stdOut); CLS1_SendStr(buf, CLS1_GetStdio()->stdOut); CLS1_SendStr((unsigned char*)"\r\n", CLS1_GetStdio()->stdOut); if (val!=0) { p = &buf[0]; res = UTIL1_ScanSeparatedNumbers(&p, &W5100_config.ipaddr[0], sizeof(W5100_config.ipaddr), '.', UTIL1_SEP_NUM_TYPE_UINT8); if (res!=ERR_OK) { CLS1_SendStr((unsigned char*)"IP FAILED!\r\n", CLS1_GetStdio()->stdOut); } } /* IP */ val = MINI1_ini_gets(INI_SECTION_NAME, "MAC", "FF-FF-FF-FF-FF-FF", (char*)buf, sizeof(buf), INI_FILE_NAME); CLS1_SendStr((unsigned char*)"MAC: ", CLS1_GetStdio()->stdOut); CLS1_SendStr(buf, CLS1_GetStdio()->stdOut); CLS1_SendStr((unsigned char*)"\r\n", CLS1_GetStdio()->stdOut); if (val!=0) { p = &buf[0]; res = UTIL1_ScanSeparatedNumbers(&p, &W5100_config.hwaddr[0], sizeof(W5100_config.hwaddr), '-', UTIL1_SEP_NUM_TYPE_UINT8_HEX_NO_PREFIX); if (res!=ERR_OK) { CLS1_SendStr((unsigned char*)"MAC FAILED!\r\n", CLS1_GetStdio()->stdOut); } } } #endif
With this, the output to the shell in my application is as below:
Reset W5100. Configure network. Loading values from config.ini Gateway: 192.168.1.1 NetMask: 255.255.255.0 IP: 192.168.0.90 MAC: 90-A2-DA-0D-42-DD Configure RX/TX memory. done! Running web server...
The full source code can be found in the GitHub project link at the end of this article.
Summary
With MinIni I have a convenient way to configure my projects based on FatFS and MinIni. Having both parts as Processor Expert components makes things even simpler and faster to use. My Ethernet project for the FRDM-KL25Z has been updated on GitHub to use MinIni. The component sources are on GitHub too and will be released with the next *.PEupd update.
And of course I have some more ideas:
- Adding command line interface to the component
- Offer other storage than FatFS: microcontroller Flash memory, external EEPROM would be great!
PS: Thanks again to Marc!