Switch to using read* macros instead of pointers. Change-Id: I1fe54b496a5998597b79cdd7108f3a4075744a78 Signed-off-by: Michael Niewöhner <foss@mniewoehner.de> Reviewed-on: https://review.coreboot.org/c/coreboot/+/39503 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com>
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * inteltool - dump all registers on an Intel CPU + chipset based system.
 | 
						|
 *
 | 
						|
 * Copyright (C) 2008-2010 by coresystems GmbH
 | 
						|
 * Copyright (C) 2012 Anton Kochkov
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License as published by
 | 
						|
 * the Free Software Foundation; version 2 of the License.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful,
 | 
						|
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 * GNU General Public License for more details.
 | 
						|
 */
 | 
						|
 | 
						|
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <inttypes.h>
 | 
						|
#include "inteltool.h"
 | 
						|
 | 
						|
#define MMIO_SIZE 0x100000
 | 
						|
 | 
						|
int print_gfx(struct pci_dev *gfx)
 | 
						|
{
 | 
						|
	uint64_t mmio_phys;
 | 
						|
	uint8_t *mmio;
 | 
						|
	uint32_t i;
 | 
						|
	if (!gfx) {
 | 
						|
		printf ("No IGD found\n");
 | 
						|
		return 0;
 | 
						|
	}
 | 
						|
	printf("\n============= IGD ==============\n\n");
 | 
						|
	mmio_phys = gfx->base_addr[0] & ~0x7ULL;
 | 
						|
	printf("IGD MMIO = 0x%08llx (MEM)\n\n", (unsigned long long)mmio_phys);
 | 
						|
	mmio = map_physical(mmio_phys, MMIO_SIZE);
 | 
						|
	if (mmio == NULL) {
 | 
						|
		perror("Error mapping MMIO");
 | 
						|
		exit(1);
 | 
						|
	}
 | 
						|
	for (i = 0; i < MMIO_SIZE; i += 4) {
 | 
						|
		if (read32(mmio + i))
 | 
						|
			printf("0x%06x: 0x%08x\n", i, read32(mmio + i));
 | 
						|
	}
 | 
						|
	unmap_physical((void *)mmio, MMIO_SIZE);
 | 
						|
	return 0;
 | 
						|
 | 
						|
}
 |