mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 12:03:40 +00:00 
			
		
		
		
	 0e2c24c626
			
		
	
	
		0e2c24c626
		
	
	
	
	
		
			
			The AST2600 includes a second cut-down version of the SD/MMC controller found in the AST2500, named the eMMC controller. It's cut down in the sense that it only supports one slot rather than two, but it brings the total number of slots supported by the AST2600 to three. The existing code assumed that the SD controller always provided two slots. Rework the SDHCI object to expose the number of slots as a property to be set by the SoC configuration. Signed-off-by: Andrew Jeffery <andrew@aj.id.au> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Cédric Le Goater <clg@kaod.org> Signed-off-by: Cédric Le Goater <clg@kaod.org> Message-id: 20200114103433.30534-2-clg@kaod.org [PMM: fixed up to use device_class_set_props()] Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
		
			
				
	
	
		
			36 lines
		
	
	
		
			856 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			856 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Aspeed SD Host Controller
 | |
|  * Eddie James <eajames@linux.ibm.com>
 | |
|  *
 | |
|  * Copyright (C) 2019 IBM Corp
 | |
|  * SPDX-License-Identifer: GPL-2.0-or-later
 | |
|  */
 | |
| 
 | |
| #ifndef ASPEED_SDHCI_H
 | |
| #define ASPEED_SDHCI_H
 | |
| 
 | |
| #include "hw/sd/sdhci.h"
 | |
| 
 | |
| #define TYPE_ASPEED_SDHCI "aspeed.sdhci"
 | |
| #define ASPEED_SDHCI(obj) OBJECT_CHECK(AspeedSDHCIState, (obj), \
 | |
|                                        TYPE_ASPEED_SDHCI)
 | |
| 
 | |
| #define ASPEED_SDHCI_CAPABILITIES 0x01E80080
 | |
| #define ASPEED_SDHCI_NUM_SLOTS    2
 | |
| #define ASPEED_SDHCI_NUM_REGS     (ASPEED_SDHCI_REG_SIZE / sizeof(uint32_t))
 | |
| #define ASPEED_SDHCI_REG_SIZE     0x100
 | |
| 
 | |
| typedef struct AspeedSDHCIState {
 | |
|     SysBusDevice parent;
 | |
| 
 | |
|     SDHCIState slots[ASPEED_SDHCI_NUM_SLOTS];
 | |
|     uint8_t num_slots;
 | |
| 
 | |
|     MemoryRegion iomem;
 | |
|     qemu_irq irq;
 | |
| 
 | |
|     uint32_t regs[ASPEED_SDHCI_NUM_REGS];
 | |
| } AspeedSDHCIState;
 | |
| 
 | |
| #endif /* ASPEED_SDHCI_H */
 |