blob: 48e8fd1a9474e79a4401129ac26bc34a46fe9165 (
plain) (
tree)
|
|
/*! @file CoverageWriterRTEMS.cc
* @brief CoverageWriterRTEMS Implementation
*
* This file contains the implementation of the functions supporting
* the unified overage file format.
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include <iomanip>
#include <rld.h>
#include "CoverageWriterRTEMS.h"
#include "rtemscov_header.h"
namespace Coverage {
CoverageWriterRTEMS::CoverageWriterRTEMS()
{
}
CoverageWriterRTEMS::~CoverageWriterRTEMS()
{
}
void CoverageWriterRTEMS::writeFile(
const char* const file,
CoverageMapBase* coverage,
uint32_t lowAddress,
uint32_t highAddress
)
{
FILE* coverageFile;
uint32_t a;
int status;
uint8_t cover;
rtems_coverage_map_header_t header;
/*
* read the file and update the coverage map passed in
*/
coverageFile = ::fopen( file, "w" );
if ( !coverageFile ) {
std::ostringstream what;
what << "Unable to open " << file;
throw rld::error( what, "CoverageWriterRTEMS::writeFile" );
}
/* clear out the header and fill it in */
memset( &header, 0, sizeof(header) );
header.ver = 0x1;
header.header_length = sizeof(header);
header.start = lowAddress;
header.end = highAddress;
strcpy( header.desc, "RTEMS Coverage Data" );
status = ::fwrite(&header, 1, sizeof(header), coverageFile);
if (status != sizeof(header)) {
::fclose( coverageFile );
std::ostringstream what;
what << "Unable to write header to " << file;
throw rld::error( what, "CoverageWriterRTEMS::writeFile" );
}
for ( a=lowAddress ; a < highAddress ; a++ ) {
cover = ((coverage->wasExecuted( a )) ? 0x01 : 0);
status = fwrite(&cover, 1, sizeof(cover), coverageFile);
if (status != sizeof(cover)) {
std::cerr << "CoverageWriterRTEMS::writeFile - write to "
<< file
<< " at address 0x%"
<< std::hex << std::setfill('0')
<< std::setw(8) << a
<< std::setfill(' ') << std::dec
<< " failed"
<< std::endl;
}
}
::fclose( coverageFile );
}
}
|