mirror of https://github.com/FOME-Tech/openblt.git
Refs #371. Added silent mode (-sm) command line option to BootCommander.
git-svn-id: https://svn.code.sf.net/p/openblt/code/trunk@355 5dc33758-31d5-4daf-9ae8-b24bf3d40d73
This commit is contained in:
parent
1c9770dd64
commit
55d38167ee
|
@ -73,6 +73,20 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************************
|
||||||
|
* Type definitions
|
||||||
|
****************************************************************************************/
|
||||||
|
/** \brief Type for program settings. */
|
||||||
|
typedef struct t_program_settings
|
||||||
|
{
|
||||||
|
/* \brief Controls what gets written to the standard output. If set to false then all
|
||||||
|
* information is written. If set to true then only the most basic progress
|
||||||
|
* information is shows.
|
||||||
|
*/
|
||||||
|
bool silentMode;
|
||||||
|
} tProgramSettings;
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************************
|
/****************************************************************************************
|
||||||
* Function prototypes
|
* Function prototypes
|
||||||
****************************************************************************************/
|
****************************************************************************************/
|
||||||
|
@ -80,6 +94,9 @@ static void DisplayProgramInfo(void);
|
||||||
static void DisplayProgramUsage(void);
|
static void DisplayProgramUsage(void);
|
||||||
static void DisplaySessionInfo(uint32_t sessionType, void const * sessionSettings);
|
static void DisplaySessionInfo(uint32_t sessionType, void const * sessionSettings);
|
||||||
static void DisplayTransportInfo(uint32_t transportType, void const * transportSettings);
|
static void DisplayTransportInfo(uint32_t transportType, void const * transportSettings);
|
||||||
|
static void DisplayFirmwareDataInfo(uint32_t segments, uint32_t base, uint32_t size);
|
||||||
|
static void ExtractProgramSettingsFromCommandLine(int argc, char const * const argv[],
|
||||||
|
tProgramSettings * programSettings);
|
||||||
static uint32_t ExtractSessionTypeFromCommandLine(int argc, char const * const argv[]);
|
static uint32_t ExtractSessionTypeFromCommandLine(int argc, char const * const argv[]);
|
||||||
static void * ExtractSessionSettingsFromCommandLine(int argc, char const * const argv[],
|
static void * ExtractSessionSettingsFromCommandLine(int argc, char const * const argv[],
|
||||||
uint32_t sessionType);
|
uint32_t sessionType);
|
||||||
|
@ -104,22 +121,22 @@ static void ErasePercentageTrailer(void);
|
||||||
int main(int argc, char const * const argv[])
|
int main(int argc, char const * const argv[])
|
||||||
{
|
{
|
||||||
int result = RESULT_OK;
|
int result = RESULT_OK;
|
||||||
|
tProgramSettings appProgramSettings = { 0 };
|
||||||
uint32_t appSessionType = 0;
|
uint32_t appSessionType = 0;
|
||||||
void * appSessionSettings = NULL;
|
void * appSessionSettings = NULL;
|
||||||
uint32_t appTransportType = 0;;
|
uint32_t appTransportType = 0;;
|
||||||
void * appTransportSettings = NULL;
|
void * appTransportSettings = NULL;
|
||||||
char const * appFirmwareFile = NULL;
|
char const * appFirmwareFile = NULL;
|
||||||
uint32_t firmwareDataTotalSize;
|
|
||||||
|
|
||||||
/* -------------------- Display info ----------------------------------------------- */
|
/* -------------------- Display info ----------------------------------------------- */
|
||||||
/* Display program info */
|
|
||||||
DisplayProgramInfo();
|
|
||||||
/* Check that at least enough command line arguments were specified. The first one is
|
/* Check that at least enough command line arguments were specified. The first one is
|
||||||
* always the name of the executable. Additionally, the firmware file must at least
|
* always the name of the executable. Additionally, the firmware file must at least
|
||||||
* be specified.
|
* be specified.
|
||||||
*/
|
*/
|
||||||
if (argc < 2)
|
if (argc < 2)
|
||||||
{
|
{
|
||||||
|
/* Display program info */
|
||||||
|
DisplayProgramInfo();
|
||||||
/* Display program usage. */
|
/* Display program usage. */
|
||||||
DisplayProgramUsage();
|
DisplayProgramUsage();
|
||||||
/* Set error code. */
|
/* Set error code. */
|
||||||
|
@ -129,10 +146,13 @@ int main(int argc, char const * const argv[])
|
||||||
/* -------------------- Process command line --------------------------------------- */
|
/* -------------------- Process command line --------------------------------------- */
|
||||||
if (result == RESULT_OK)
|
if (result == RESULT_OK)
|
||||||
{
|
{
|
||||||
|
/* Extract program specific settings from the command line. */
|
||||||
|
ExtractProgramSettingsFromCommandLine(argc, argv, &appProgramSettings);
|
||||||
/* Extract the session type from the command line. */
|
/* Extract the session type from the command line. */
|
||||||
appSessionType = ExtractSessionTypeFromCommandLine(argc, argv);
|
appSessionType = ExtractSessionTypeFromCommandLine(argc, argv);
|
||||||
/* Extract the session type specific settings from the command line. */
|
/* Extract the session type specific settings from the command line. */
|
||||||
appSessionSettings = ExtractSessionSettingsFromCommandLine(argc, argv, appSessionType);
|
appSessionSettings = ExtractSessionSettingsFromCommandLine(argc, argv,
|
||||||
|
appSessionType);
|
||||||
/* Extract the transport type from the command line. */
|
/* Extract the transport type from the command line. */
|
||||||
appTransportType = ExtractTransportTypeFromCommandLine(argc, argv);
|
appTransportType = ExtractTransportTypeFromCommandLine(argc, argv);
|
||||||
/* Extract the transport type specific settings from the command line. */
|
/* Extract the transport type specific settings from the command line. */
|
||||||
|
@ -144,17 +164,24 @@ int main(int argc, char const * const argv[])
|
||||||
if ( (appSessionSettings == NULL) || (appTransportSettings == NULL) ||
|
if ( (appSessionSettings == NULL) || (appTransportSettings == NULL) ||
|
||||||
(appFirmwareFile == NULL) )
|
(appFirmwareFile == NULL) )
|
||||||
{
|
{
|
||||||
|
/* Display program info */
|
||||||
|
DisplayProgramInfo();
|
||||||
/* Display program usage. */
|
/* Display program usage. */
|
||||||
DisplayProgramUsage();
|
DisplayProgramUsage();
|
||||||
/* Set error code. */
|
/* Set error code. */
|
||||||
result = RESULT_ERROR_COMMANDLINE;
|
result = RESULT_ERROR_COMMANDLINE;
|
||||||
}
|
}
|
||||||
|
if ((!appProgramSettings.silentMode))
|
||||||
|
{
|
||||||
|
/* Display program info */
|
||||||
|
DisplayProgramInfo();
|
||||||
|
}
|
||||||
printf("Processing command line parameters...");
|
printf("Processing command line parameters...");
|
||||||
printf("%s\n", GetLineTrailerByResult((bool)(result != RESULT_OK)));
|
printf("%s\n", GetLineTrailerByResult((bool)(result != RESULT_OK)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------- Display detected parameters -------------------------------- */
|
/* -------------------- Display detected parameters -------------------------------- */
|
||||||
if (result == RESULT_OK)
|
if ( (result == RESULT_OK) && (!appProgramSettings.silentMode) )
|
||||||
{
|
{
|
||||||
/* Display firmware file. */
|
/* Display firmware file. */
|
||||||
printf("Detected firmware file: %s\n", appFirmwareFile);
|
printf("Detected firmware file: %s\n", appFirmwareFile);
|
||||||
|
@ -162,7 +189,6 @@ int main(int argc, char const * const argv[])
|
||||||
DisplaySessionInfo(appSessionType, appSessionSettings);
|
DisplaySessionInfo(appSessionType, appSessionSettings);
|
||||||
/* Display transport info. */
|
/* Display transport info. */
|
||||||
DisplayTransportInfo(appTransportType, appTransportSettings);
|
DisplayTransportInfo(appTransportType, appTransportSettings);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------- Firmware loading ------------------------------------------- */
|
/* -------------------- Firmware loading ------------------------------------------- */
|
||||||
|
@ -192,16 +218,19 @@ int main(int argc, char const * const argv[])
|
||||||
/* Determine and output firmware data statistics. */
|
/* Determine and output firmware data statistics. */
|
||||||
if (result == RESULT_OK)
|
if (result == RESULT_OK)
|
||||||
{
|
{
|
||||||
|
uint32_t firmwareDataTotalSize;
|
||||||
|
uint32_t firmwareDataTotalSegments;
|
||||||
|
uint32_t firmwareDataBaseAddress = 0;
|
||||||
uint32_t segmentIdx;
|
uint32_t segmentIdx;
|
||||||
uint32_t segmentLen;
|
uint32_t segmentLen;
|
||||||
uint32_t segmentBase;
|
uint32_t segmentBase;
|
||||||
uint8_t const * segmentData;
|
uint8_t const * segmentData;
|
||||||
|
|
||||||
/* Output number of segments. */
|
/* Store the number of segments. */
|
||||||
printf(" -> Number of segments: %u\n", BltFirmwareGetSegmentCount());
|
firmwareDataTotalSegments = BltFirmwareGetSegmentCount();
|
||||||
/* Loop through all segments. */
|
/* Loop through all segments. */
|
||||||
firmwareDataTotalSize = 0;
|
firmwareDataTotalSize = 0;
|
||||||
for (segmentIdx = 0; segmentIdx < BltFirmwareGetSegmentCount(); segmentIdx++)
|
for (segmentIdx = 0; segmentIdx < firmwareDataTotalSegments; segmentIdx++)
|
||||||
{
|
{
|
||||||
/* Extract segment info. */
|
/* Extract segment info. */
|
||||||
segmentData = BltFirmwareGetSegment(segmentIdx, &segmentBase, &segmentLen);
|
segmentData = BltFirmwareGetSegment(segmentIdx, &segmentBase, &segmentLen);
|
||||||
|
@ -209,16 +238,20 @@ int main(int argc, char const * const argv[])
|
||||||
assert( (segmentData != NULL) && (segmentLen > 0) );
|
assert( (segmentData != NULL) && (segmentLen > 0) );
|
||||||
/* Update total size. */
|
/* Update total size. */
|
||||||
firmwareDataTotalSize += segmentLen;
|
firmwareDataTotalSize += segmentLen;
|
||||||
/* If it is the first segment, then output the base address. */
|
/* If it is the first segment, then store the base address. */
|
||||||
if (segmentIdx == 0)
|
if (segmentIdx == 0)
|
||||||
{
|
{
|
||||||
printf(" -> Base memory address: 0x%08x\n", segmentBase);
|
firmwareDataBaseAddress = segmentBase;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Sanity check. */
|
/* Sanity check. */
|
||||||
assert(firmwareDataTotalSize > 0);
|
assert(firmwareDataTotalSize > 0);
|
||||||
/* Ouput total firmware data size. */
|
/* Output firmware data information. */
|
||||||
printf(" -> Total data size: %u bytes\n", firmwareDataTotalSize);
|
if (!appProgramSettings.silentMode)
|
||||||
|
{
|
||||||
|
DisplayFirmwareDataInfo(firmwareDataTotalSegments, firmwareDataBaseAddress,
|
||||||
|
firmwareDataTotalSize);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,7 +327,7 @@ int main(int argc, char const * const argv[])
|
||||||
uint32_t segmentBase;
|
uint32_t segmentBase;
|
||||||
uint8_t const * segmentData;
|
uint8_t const * segmentData;
|
||||||
|
|
||||||
/* Program the memory segments on the target with the firmwware data. */
|
/* Program the memory segments on the target with the firmware data. */
|
||||||
for (segmentIdx = 0; segmentIdx < BltFirmwareGetSegmentCount(); segmentIdx++)
|
for (segmentIdx = 0; segmentIdx < BltFirmwareGetSegmentCount(); segmentIdx++)
|
||||||
{
|
{
|
||||||
/* Extract segment info. */
|
/* Extract segment info. */
|
||||||
|
@ -467,6 +500,10 @@ static void DisplayProgramUsage(void)
|
||||||
printf(" as 29-bit CAN identifiers, if this 8-bit value is > 0\n");
|
printf(" as 29-bit CAN identifiers, if this 8-bit value is > 0\n");
|
||||||
printf(" (Default = 0).\n");
|
printf(" (Default = 0).\n");
|
||||||
printf("\n");
|
printf("\n");
|
||||||
|
printf("Program settings:\n");
|
||||||
|
printf(" -sm Silent mode switch. When specified, only minimal\n");
|
||||||
|
printf(" information is written to the output (Optional).\n");
|
||||||
|
printf("\n");
|
||||||
printf("Note that it is not necessary to specify an option if its default value\n");
|
printf("Note that it is not necessary to specify an option if its default value\n");
|
||||||
printf("is already the desired value.\n");
|
printf("is already the desired value.\n");
|
||||||
printf("-------------------------------------------------------------------------\n");
|
printf("-------------------------------------------------------------------------\n");
|
||||||
|
@ -638,6 +675,68 @@ static void DisplayTransportInfo(uint32_t transportType, void const * transportS
|
||||||
} /*** end of DisplayTransportInfo ***/
|
} /*** end of DisplayTransportInfo ***/
|
||||||
|
|
||||||
|
|
||||||
|
/************************************************************************************//**
|
||||||
|
** \brief Displays firmware data information on the standard output.
|
||||||
|
** \param segments Total number of firmware data segments
|
||||||
|
** \param base The base memory address of the firmware data.
|
||||||
|
** \param size Total number of firmware data bytes.
|
||||||
|
**
|
||||||
|
****************************************************************************************/
|
||||||
|
static void DisplayFirmwareDataInfo(uint32_t segments, uint32_t base, uint32_t size)
|
||||||
|
{
|
||||||
|
/* Output number of segments. */
|
||||||
|
printf(" -> Number of segments: %u\n", segments);
|
||||||
|
/* Output the base address. */
|
||||||
|
printf(" -> Base memory address: 0x%08x\n", base);
|
||||||
|
/* Ouput total firmware data size. */
|
||||||
|
printf(" -> Total data size: %u bytes\n", size);
|
||||||
|
} /*** end of DisplayFirmwareDataInfo ***/
|
||||||
|
|
||||||
|
|
||||||
|
/************************************************************************************//**
|
||||||
|
** \brief Parses the command line to extract the program settings. Note that this
|
||||||
|
** function allocates the memory necessary to store the settings. It is the
|
||||||
|
** caller's responsibility to free this memory after it is done with it.
|
||||||
|
** \param argc Number of program arguments.
|
||||||
|
** \param argv Array with program parameter strings.
|
||||||
|
** \param programSettings Pointer to the setting structure where the program settings
|
||||||
|
** should be written to.
|
||||||
|
**
|
||||||
|
****************************************************************************************/
|
||||||
|
static void ExtractProgramSettingsFromCommandLine(int argc, char const * const argv[],
|
||||||
|
tProgramSettings * programSettings)
|
||||||
|
{
|
||||||
|
uint8_t paramIdx;
|
||||||
|
|
||||||
|
/* Check parameters. */
|
||||||
|
assert(argv != NULL);
|
||||||
|
assert(programSettings != NULL);
|
||||||
|
|
||||||
|
/* Set default program settings. */
|
||||||
|
programSettings->silentMode = false;
|
||||||
|
|
||||||
|
/* Only continue if parameters are valid. */
|
||||||
|
if ( (argv != NULL) && (programSettings != NULL) ) /*lint !e774 */
|
||||||
|
{
|
||||||
|
/* Loop through all the command line parameters, just skip the 1st one because
|
||||||
|
* this is the name of the program, which we are not interested in.
|
||||||
|
*/
|
||||||
|
for (paramIdx = 1; paramIdx < argc; paramIdx++)
|
||||||
|
{
|
||||||
|
/* Is this the -sm parameter? */
|
||||||
|
if ( (strstr(argv[paramIdx], "-sm") != NULL) &&
|
||||||
|
(strlen(argv[paramIdx]) == 3) )
|
||||||
|
{
|
||||||
|
/* Activate silent mode. */
|
||||||
|
programSettings->silentMode = true;
|
||||||
|
/* Continue with next loop iteration. */
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} /*** end of ExtractProgramSettingsFromCommandLine ***/
|
||||||
|
|
||||||
|
|
||||||
/************************************************************************************//**
|
/************************************************************************************//**
|
||||||
** \brief Parses the command line to extract the session type. This is the one
|
** \brief Parses the command line to extract the session type. This is the one
|
||||||
** specified via the -s=[name] parameter.
|
** specified via the -s=[name] parameter.
|
||||||
|
|
Loading…
Reference in New Issue