blob: e9a2ea03f1205b588f3f43ef01024bd05e0055dc [file] [log] [blame]
/**
* Functions for generating pseudo-random CPER generic processor sections.
*
* Author: Lawrence.Tang@arm.com
**/
#include <stdlib.h>
#include "../../edk/BaseTypes.h"
#include "../gen-utils.h"
#include "gen-section.h"
//Generates a single pseudo-random generic processor section, saving the resulting address to the given
//location. Returns the size of the newly created section.
size_t generate_section_generic(void** location)
{
//Create random bytes.
size_t size = generate_random_section(location, 192);
//Set reserved locations to zero.
UINT8* start_byte = (UINT8*)*location;
*((UINT64*)start_byte) &= 0xFFF;
*(start_byte + 12) &= 0b111;
*((UINT16*)(start_byte + 14)) = 0x0;
//Ensure CPU brand string does not terminate early.
for (int i=0; i<128; i++)
{
UINT8* byte = start_byte + 24 + i;
if (*byte == 0x0)
*byte = rand() % 127 + 1;
//Null terminate last byte.
if (i == 127)
*byte = 0x0;
}
return size;
}