On 10/11/2016 10:19 AM, Thomas Huth wrote:
> The pxe-test is quite slow on ppc64 with tcg. We can speed it up
> a little bit by decreasing the size of the file that has to be
> loaded via TFTP.
> 
> Signed-off-by: Thomas Huth <th...@redhat.com>
> ---
>  tests/boot-sector.c | 6 +++---
>  1 file changed, 3 insertions(+), 3 deletions(-)
> 
> diff --git a/tests/boot-sector.c b/tests/boot-sector.c
> index e3193c0..0168fd0 100644
> --- a/tests/boot-sector.c
> +++ b/tests/boot-sector.c
> @@ -72,6 +72,7 @@ static uint8_t boot_sector[0x7e000] = {

The size of 0x7e000...

>  int boot_sector_init(const char *fname)
>  {
>      FILE *f = fopen(fname, "w");
> +    size_t len = sizeof boot_sector;
>  
>      if (!f) {
>          fprintf(stderr, "Couldn't open \"%s\": %s", fname, strerror(errno));
> @@ -80,13 +81,12 @@ int boot_sector_init(const char *fname)
>  
>      /* For Open Firmware based system, we can use a Forth script instead */
>      if (strcmp(qtest_get_arch(), "ppc64") == 0) {
> -        memset(boot_sector, ' ', sizeof boot_sector);
> -        sprintf((char *)boot_sector, "\\ Bootscript\n%x %x c! %x %x c!\n",
> +        len = sprintf((char *)boot_sector, "\\ Bootscript\n%x %x c! %x %x 
> c!\n",

...is enough to ensure the sprintf() doesn't overflow.  Still, I think
an snprintf() would be a bit nicer on maintainers to not have to worry
about whether overflow is even possible.

>                  LOW(SIGNATURE), BOOT_SECTOR_ADDRESS + SIGNATURE_OFFSET,
>                  HIGH(SIGNATURE), BOOT_SECTOR_ADDRESS + SIGNATURE_OFFSET + 1);

Worth reindenting this to match the line above?

>      }
>  
> -    fwrite(boot_sector, 1, sizeof boot_sector, f);
> +    fwrite(boot_sector, 1, len, f);

At any rate, the change makes sense, and I can't find anything
technically wrong with it, so feel free to add:
Reviewed-by: Eric Blake <ebl...@redhat.com>

-- 
Eric Blake   eblake redhat com    +1-919-301-3266
Libvirt virtualization library http://libvirt.org

Attachment: signature.asc
Description: OpenPGP digital signature

Reply via email to