| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | /* QEMU Synchronous Serial Interface support.  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* In principle SSI is a point-point interface.  As such the qemu
 | 
					
						
							|  |  |  |    implementation has a single slave device on a "bus". | 
					
						
							|  |  |  |    However it is fairly common for boards to have multiple slaves | 
					
						
							|  |  |  |    connected to a single master, and select devices with an external | 
					
						
							|  |  |  |    chip select.  This is implemented in qemu by having an explicit mux device. | 
					
						
							|  |  |  |    It is assumed that master and slave are both using the same transfer width. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef QEMU_SSI_H
 | 
					
						
							|  |  |  | #define QEMU_SSI_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "qdev.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct SSISlave SSISlave; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Slave devices.  */ | 
					
						
							|  |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2009-05-23 00:05:19 +01:00
										 |  |  |     DeviceInfo qdev; | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  |     int (*init)(SSISlave *dev); | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  |     uint32_t (*transfer)(SSISlave *dev, uint32_t val); | 
					
						
							|  |  |  | } SSISlaveInfo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct SSISlave { | 
					
						
							|  |  |  |     DeviceState qdev; | 
					
						
							|  |  |  |     SSISlaveInfo *info; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SSI_SLAVE_FROM_QDEV(dev) DO_UPCAST(SSISlave, qdev, dev)
 | 
					
						
							|  |  |  | #define FROM_SSI_SLAVE(type, dev) DO_UPCAST(type, ssidev, dev)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-10 09:41:42 +02:00
										 |  |  | void ssi_register_slave(SSISlaveInfo *info); | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | DeviceState *ssi_create_slave(SSIBus *bus, const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Master interface.  */ | 
					
						
							| 
									
										
										
										
											2009-05-23 00:05:19 +01:00
										 |  |  | SSIBus *ssi_create_bus(DeviceState *parent, const char *name); | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | uint32_t ssi_transfer(SSIBus *bus, uint32_t val); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | /* max111x.c */ | 
					
						
							|  |  |  | void max111x_set_input(DeviceState *dev, int line, uint8_t value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | #endif
 |