| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | /* vim:set shiftwidth=4 ts=4 et: */ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * PXA255 Sharp Zaurus SL-6000 PDA platform | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2008 Dmitry Baryshkov | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Code based on spitz platform by Andrzej Zaborowski <balrog@zabor.org> | 
					
						
							|  |  |  |  * This code is licensed under the GNU GPL v2. | 
					
						
							| 
									
										
										
										
											2012-01-13 17:44:23 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Contributions after 2012-01-13 are licensed under the terms of the | 
					
						
							|  |  |  |  * GNU GPL, version 2 or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-07 16:23:45 +00:00
										 |  |  | #include "qemu/osdep.h"
 | 
					
						
							| 
									
										
											  
											
												include/qemu/osdep.h: Don't include qapi/error.h
Commit 57cb38b included qapi/error.h into qemu/osdep.h to get the
Error typedef.  Since then, we've moved to include qemu/osdep.h
everywhere.  Its file comment explains: "To avoid getting into
possible circular include dependencies, this file should not include
any other QEMU headers, with the exceptions of config-host.h,
compiler.h, os-posix.h and os-win32.h, all of which are doing a
similar job to this file and are under similar constraints."
qapi/error.h doesn't do a similar job, and it doesn't adhere to
similar constraints: it includes qapi-types.h.  That's in excess of
100KiB of crap most .c files don't actually need.
Add the typedef to qemu/typedefs.h, and include that instead of
qapi/error.h.  Include qapi/error.h in .c files that need it and don't
get it now.  Include qapi-types.h in qom/object.h for uint16List.
Update scripts/clean-includes accordingly.  Update it further to match
reality: replace config.h by config-target.h, add sysemu/os-posix.h,
sysemu/os-win32.h.  Update the list of includes in the qemu/osdep.h
comment quoted above similarly.
This reduces the number of objects depending on qapi/error.h from "all
of them" to less than a third.  Unfortunately, the number depending on
qapi-types.h shrinks only a little.  More work is needed for that one.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
[Fix compilation without the spice devel packages. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
											
										 
											2016-03-14 09:01:28 +01:00
										 |  |  | #include "qapi/error.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-04 15:40:22 +01:00
										 |  |  | #include "hw/hw.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-05 17:06:20 +01:00
										 |  |  | #include "hw/arm/pxa.h"
 | 
					
						
							| 
									
										
										
										
											2013-04-09 15:26:55 +01:00
										 |  |  | #include "hw/arm/arm.h"
 | 
					
						
							|  |  |  | #include "hw/devices.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-05 17:06:20 +01:00
										 |  |  | #include "hw/arm/sharpsl.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-04 15:40:22 +01:00
										 |  |  | #include "hw/pcmcia.h"
 | 
					
						
							|  |  |  | #include "hw/boards.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-05 17:06:20 +01:00
										 |  |  | #include "hw/i2c/i2c.h"
 | 
					
						
							| 
									
										
										
										
											2016-01-21 14:15:03 +00:00
										 |  |  | #include "hw/ssi/ssi.h"
 | 
					
						
							| 
									
										
										
										
											2014-10-07 13:59:18 +02:00
										 |  |  | #include "sysemu/block-backend.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-04 15:40:22 +01:00
										 |  |  | #include "hw/sysbus.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-17 18:19:49 +01:00
										 |  |  | #include "exec/address-spaces.h"
 | 
					
						
							| 
									
										
										
										
											2016-10-28 14:12:31 +01:00
										 |  |  | #include "sysemu/sysemu.h"
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TOSA_RAM    0x04000000
 | 
					
						
							|  |  |  | #define TOSA_ROM	0x00800000
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-11 23:57:37 +03:00
										 |  |  | #define TOSA_GPIO_USB_IN		(5)
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | #define TOSA_GPIO_nSD_DETECT	(9)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_ON_RESET		(19)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_CF_IRQ		(21)	/* CF slot0 Ready */
 | 
					
						
							|  |  |  | #define TOSA_GPIO_CF_CD			(13)
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:45:49 +00:00
										 |  |  | #define TOSA_GPIO_TC6393XB_INT  (15)
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | #define TOSA_GPIO_JC_CF_IRQ		(36)	/* CF slot1 Ready */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  | #define TOSA_SCOOP_GPIO_BASE	1
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | #define TOSA_GPIO_IR_POWERDWN	(TOSA_SCOOP_GPIO_BASE + 2)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_SD_WP			(TOSA_SCOOP_GPIO_BASE + 3)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_PWR_ON		(TOSA_SCOOP_GPIO_BASE + 4)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  | #define TOSA_SCOOP_JC_GPIO_BASE		1
 | 
					
						
							|  |  |  | #define TOSA_GPIO_BT_LED		(TOSA_SCOOP_JC_GPIO_BASE + 0)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_NOTE_LED		(TOSA_SCOOP_JC_GPIO_BASE + 1)
 | 
					
						
							|  |  |  | #define TOSA_GPIO_CHRG_ERR_LED		(TOSA_SCOOP_JC_GPIO_BASE + 2)
 | 
					
						
							| 
									
										
										
										
											2008-11-04 09:04:41 +00:00
										 |  |  | #define TOSA_GPIO_TC6393XB_L3V_ON	(TOSA_SCOOP_JC_GPIO_BASE + 5)
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  | #define TOSA_GPIO_WLAN_LED		(TOSA_SCOOP_JC_GPIO_BASE + 7)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | #define	DAC_BASE	0x4e
 | 
					
						
							|  |  |  | #define DAC_CH1		0
 | 
					
						
							|  |  |  | #define DAC_CH2		1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  | static void tosa_microdrive_attach(PXA2xxState *cpu) | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  |     PCMCIACardState *md; | 
					
						
							| 
									
										
										
										
											2009-07-22 16:42:57 +02:00
										 |  |  |     DriveInfo *dinfo; | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-22 16:42:57 +02:00
										 |  |  |     dinfo = drive_get(IF_IDE, 0, 0); | 
					
						
							| 
									
										
										
										
											2011-08-03 15:08:13 +02:00
										 |  |  |     if (!dinfo || dinfo->media_cd) | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  |         return; | 
					
						
							| 
									
										
										
										
											2011-08-03 15:08:13 +02:00
										 |  |  |     md = dscm1xxxx_init(dinfo); | 
					
						
							|  |  |  |     pxa2xx_pcmcia_attach(cpu->pcmcia[0], md); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  | static void tosa_out_switch(void *opaque, int line, int level) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     switch (line) { | 
					
						
							|  |  |  |         case 0: | 
					
						
							|  |  |  |             fprintf(stderr, "blue LED %s.\n", level ? "on" : "off"); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case 1: | 
					
						
							|  |  |  |             fprintf(stderr, "green LED %s.\n", level ? "on" : "off"); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case 2: | 
					
						
							|  |  |  |             fprintf(stderr, "amber LED %s.\n", level ? "on" : "off"); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case 3: | 
					
						
							|  |  |  |             fprintf(stderr, "wlan LED %s.\n", level ? "on" : "off"); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             fprintf(stderr, "Uhandled out event: %d = %d\n", line, level); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-28 14:12:31 +01:00
										 |  |  | static void tosa_reset(void *opaque, int line, int level) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (level) { | 
					
						
							|  |  |  |         qemu_system_reset_request(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  | static void tosa_gpio_setup(PXA2xxState *cpu, | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |                 DeviceState *scp0, | 
					
						
							|  |  |  |                 DeviceState *scp1, | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  |                 TC6393xbState *tmio) | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-11-04 08:43:54 +00:00
										 |  |  |     qemu_irq *outsignals = qemu_allocate_irqs(tosa_out_switch, cpu, 4); | 
					
						
							| 
									
										
										
										
											2016-10-28 14:12:31 +01:00
										 |  |  |     qemu_irq reset; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  |     /* MMC/SD host */ | 
					
						
							|  |  |  |     pxa2xx_mmci_handlers(cpu->mmc, | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |                     qdev_get_gpio_in(scp0, TOSA_GPIO_SD_WP), | 
					
						
							| 
									
										
										
										
											2011-01-21 19:57:50 +03:00
										 |  |  |                     qemu_irq_invert(qdev_get_gpio_in(cpu->gpio, TOSA_GPIO_nSD_DETECT))); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Handle reset */ | 
					
						
							| 
									
										
										
										
											2016-10-28 14:12:31 +01:00
										 |  |  |     reset = qemu_allocate_irq(tosa_reset, cpu, 0); | 
					
						
							|  |  |  |     qdev_connect_gpio_out(cpu->gpio, TOSA_GPIO_ON_RESET, reset); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* PCMCIA signals: card's IRQ and Card-Detect */ | 
					
						
							|  |  |  |     pxa2xx_pcmcia_set_irq_cb(cpu->pcmcia[0], | 
					
						
							| 
									
										
										
										
											2011-01-21 19:57:50 +03:00
										 |  |  |                         qdev_get_gpio_in(cpu->gpio, TOSA_GPIO_CF_IRQ), | 
					
						
							|  |  |  |                         qdev_get_gpio_in(cpu->gpio, TOSA_GPIO_CF_CD)); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     pxa2xx_pcmcia_set_irq_cb(cpu->pcmcia[1], | 
					
						
							| 
									
										
										
										
											2011-01-21 19:57:50 +03:00
										 |  |  |                         qdev_get_gpio_in(cpu->gpio, TOSA_GPIO_JC_CF_IRQ), | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  |                         NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |     qdev_connect_gpio_out(scp1, TOSA_GPIO_BT_LED, outsignals[0]); | 
					
						
							|  |  |  |     qdev_connect_gpio_out(scp1, TOSA_GPIO_NOTE_LED, outsignals[1]); | 
					
						
							|  |  |  |     qdev_connect_gpio_out(scp1, TOSA_GPIO_CHRG_ERR_LED, outsignals[2]); | 
					
						
							|  |  |  |     qdev_connect_gpio_out(scp1, TOSA_GPIO_WLAN_LED, outsignals[3]); | 
					
						
							| 
									
										
										
										
											2008-11-04 09:04:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |     qdev_connect_gpio_out(scp1, TOSA_GPIO_TC6393XB_L3V_ON, tc6393xb_l3v_get(tmio)); | 
					
						
							| 
									
										
										
										
											2011-02-11 23:57:37 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* UDC Vbus */ | 
					
						
							|  |  |  |     qemu_irq_raise(qdev_get_gpio_in(cpu->gpio, TOSA_GPIO_USB_IN)); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | static uint32_t tosa_ssp_tansfer(SSISlave *dev, uint32_t value) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  |     fprintf(stderr, "TG: %d %02x\n", value >> 5, value & 0x1f); | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  | static void tosa_ssp_realize(SSISlave *dev, Error **errp) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  |     /* Nothing to do.  */ | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  | #define TYPE_TOSA_DAC "tosa_dac"
 | 
					
						
							|  |  |  | #define TOSA_DAC(obj) OBJECT_CHECK(TosaDACState, (obj), TYPE_TOSA_DAC)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-12 15:38:55 +01:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  |     I2CSlave parent_obj; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  |     int len; | 
					
						
							|  |  |  |     char buf[3]; | 
					
						
							| 
									
										
										
										
											2009-05-12 15:38:55 +01:00
										 |  |  | } TosaDACState; | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 20:28:27 -06:00
										 |  |  | static int tosa_dac_send(I2CSlave *i2c, uint8_t data) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  |     TosaDACState *s = TOSA_DAC(i2c); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  |     s->buf[s->len] = data; | 
					
						
							|  |  |  |     if (s->len ++ > 2) { | 
					
						
							|  |  |  | #ifdef VERBOSE
 | 
					
						
							|  |  |  |         fprintf(stderr, "%s: message too long (%i bytes)\n", __FUNCTION__, s->len); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |         return 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (s->len == 2) { | 
					
						
							|  |  |  |         fprintf(stderr, "dac: channel %d value 0x%02x\n", | 
					
						
							|  |  |  |                 s->buf[0], s->buf[1]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 20:28:27 -06:00
										 |  |  | static void tosa_dac_event(I2CSlave *i2c, enum i2c_event event) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  |     TosaDACState *s = TOSA_DAC(i2c); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  |     s->len = 0; | 
					
						
							|  |  |  |     switch (event) { | 
					
						
							|  |  |  |     case I2C_START_SEND: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case I2C_START_RECV: | 
					
						
							|  |  |  |         printf("%s: recv not supported!!!\n", __FUNCTION__); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case I2C_FINISH: | 
					
						
							|  |  |  | #ifdef VERBOSE
 | 
					
						
							|  |  |  |         if (s->len < 2) | 
					
						
							|  |  |  |             printf("%s: message too short (%i bytes)\n", __FUNCTION__, s->len); | 
					
						
							|  |  |  |         if (s->len > 2) | 
					
						
							|  |  |  |             printf("%s: message too long\n", __FUNCTION__); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 20:28:27 -06:00
										 |  |  | static int tosa_dac_recv(I2CSlave *s) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     printf("%s: recv not supported!!!\n", __FUNCTION__); | 
					
						
							|  |  |  |     return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 20:28:27 -06:00
										 |  |  | static int tosa_dac_init(I2CSlave *i2c) | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:08 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     /* Nothing to do.  */ | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  |     return 0; | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:08 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  | static void tosa_tg_init(PXA2xxState *cpu) | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-08-03 00:18:51 +02:00
										 |  |  |     I2CBus *bus = pxa2xx_i2c_bus(cpu->i2c[0]); | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  |     i2c_create_slave(bus, TYPE_TOSA_DAC, DAC_BASE); | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  |     ssi_create_slave(cpu->ssp[1], "tosa-ssp"); | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | static struct arm_boot_info tosa_binfo = { | 
					
						
							|  |  |  |     .loader_start = PXA2XX_SDRAM_BASE, | 
					
						
							|  |  |  |     .ram_size = 0x04000000, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-07 17:42:57 +03:00
										 |  |  | static void tosa_init(MachineState *machine) | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-05-07 17:42:57 +03:00
										 |  |  |     const char *cpu_model = machine->cpu_model; | 
					
						
							|  |  |  |     const char *kernel_filename = machine->kernel_filename; | 
					
						
							|  |  |  |     const char *kernel_cmdline = machine->kernel_cmdline; | 
					
						
							|  |  |  |     const char *initrd_filename = machine->initrd_filename; | 
					
						
							| 
									
										
										
										
											2011-08-11 16:07:19 -07:00
										 |  |  |     MemoryRegion *address_space_mem = get_system_memory(); | 
					
						
							| 
									
										
										
										
											2011-10-05 18:29:06 +02:00
										 |  |  |     MemoryRegion *rom = g_new(MemoryRegion, 1); | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |     PXA2xxState *mpu; | 
					
						
							| 
									
										
										
										
											2009-05-10 01:44:56 +01:00
										 |  |  |     TC6393xbState *tmio; | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |     DeviceState *scp0, *scp1; | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (!cpu_model) | 
					
						
							|  |  |  |         cpu_model = "pxa255"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |     mpu = pxa255_init(address_space_mem, tosa_binfo.ram_size); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Fix bad error handling after memory_region_init_ram()
Symptom:
    $ qemu-system-x86_64 -m 10000000
    Unexpected error in ram_block_add() at /work/armbru/qemu/exec.c:1456:
    upstream-qemu: cannot set up guest memory 'pc.ram': Cannot allocate memory
    Aborted (core dumped)
Root cause: commit ef701d7 screwed up handling of out-of-memory
conditions.  Before the commit, we report the error and exit(1), in
one place, ram_block_add().  The commit lifts the error handling up
the call chain some, to three places.  Fine.  Except it uses
&error_abort in these places, changing the behavior from exit(1) to
abort(), and thus undoing the work of commit 3922825 "exec: Don't
abort when we can't allocate guest memory".
The three places are:
* memory_region_init_ram()
  Commit 4994653 (right after commit ef701d7) lifted the error
  handling further, through memory_region_init_ram(), multiplying the
  incorrect use of &error_abort.  Later on, imitation of existing
  (bad) code may have created more.
* memory_region_init_ram_ptr()
  The &error_abort is still there.
* memory_region_init_rom_device()
  Doesn't need fixing, because commit 33e0eb5 (soon after commit
  ef701d7) lifted the error handling further, and in the process
  changed it from &error_abort to passing it up the call chain.
  Correct, because the callers are realize() methods.
Fix the error handling after memory_region_init_ram() with a
Coccinelle semantic patch:
    @r@
    expression mr, owner, name, size, err;
    position p;
    @@
            memory_region_init_ram(mr, owner, name, size,
    (
    -                              &error_abort
    +                              &error_fatal
    |
                                   err@p
    )
                                  );
    @script:python@
        p << r.p;
    @@
    print "%s:%s:%s" % (p[0].file, p[0].line, p[0].column)
When the last argument is &error_abort, it gets replaced by
&error_fatal.  This is the fix.
If the last argument is anything else, its position is reported.  This
lets us check the fix is complete.  Four positions get reported:
* ram_backend_memory_alloc()
  Error is passed up the call chain, ultimately through
  user_creatable_complete().  As far as I can tell, it's callers all
  handle the error sanely.
* fsl_imx25_realize(), fsl_imx31_realize(), dp8393x_realize()
  DeviceClass.realize() methods, errors handled sanely further up the
  call chain.
We're good.  Test case again behaves:
    $ qemu-system-x86_64 -m 10000000
    qemu-system-x86_64: cannot set up guest memory 'pc.ram': Cannot allocate memory
    [Exit 1 ]
The next commits will repair the rest of commit ef701d7's damage.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Message-Id: <1441983105-26376-3-git-send-email-armbru@redhat.com>
Reviewed-by: Peter Crosthwaite <crosthwaite.peter@gmail.com>
											
										 
											2015-09-11 16:51:43 +02:00
										 |  |  |     memory_region_init_ram(rom, NULL, "tosa.rom", TOSA_ROM, &error_fatal); | 
					
						
							| 
									
										
										
										
											2011-12-20 15:59:12 +02:00
										 |  |  |     vmstate_register_ram_global(rom); | 
					
						
							| 
									
										
										
										
											2011-10-05 18:29:06 +02:00
										 |  |  |     memory_region_set_readonly(rom, true); | 
					
						
							|  |  |  |     memory_region_add_subregion(address_space_mem, 0, rom); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-03 14:42:42 +02:00
										 |  |  |     tmio = tc6393xb_init(address_space_mem, 0x10000000, | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |             qdev_get_gpio_in(mpu->gpio, TOSA_GPIO_TC6393XB_INT)); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-20 18:52:27 +03:00
										 |  |  |     scp0 = sysbus_create_simple("scoop", 0x08800000, NULL); | 
					
						
							|  |  |  |     scp1 = sysbus_create_simple("scoop", 0x14800040, NULL); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |     tosa_gpio_setup(mpu, scp0, scp1, tmio); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |     tosa_microdrive_attach(mpu); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-14 01:24:05 +02:00
										 |  |  |     tosa_tg_init(mpu); | 
					
						
							| 
									
										
										
										
											2008-11-04 08:54:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  |     tosa_binfo.kernel_filename = kernel_filename; | 
					
						
							|  |  |  |     tosa_binfo.kernel_cmdline = kernel_cmdline; | 
					
						
							|  |  |  |     tosa_binfo.initrd_filename = initrd_filename; | 
					
						
							|  |  |  |     tosa_binfo.board_id = 0x208; | 
					
						
							| 
									
										
										
										
											2012-05-14 02:39:57 +02:00
										 |  |  |     arm_load_kernel(mpu->cpu, &tosa_binfo); | 
					
						
							| 
									
										
										
										
											2009-04-09 17:48:30 +00:00
										 |  |  |     sl_bootparam_write(SL_PXA_PARAM_BASE); | 
					
						
							| 
									
										
										
										
											2008-06-02 01:33:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-04 15:37:08 -03:00
										 |  |  | static void tosapda_machine_init(MachineClass *mc) | 
					
						
							| 
									
										
										
										
											2009-05-20 18:38:09 -05:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-10-16 11:14:53 +01:00
										 |  |  |     mc->desc = "Sharp SL-6000 (Tosa) PDA (PXA255)"; | 
					
						
							| 
									
										
										
										
											2015-09-04 15:37:08 -03:00
										 |  |  |     mc->init = tosa_init; | 
					
						
							| 
									
										
										
										
											2009-05-20 18:38:09 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-04 15:37:08 -03:00
										 |  |  | DEFINE_MACHINE("tosa", tosapda_machine_init) | 
					
						
							| 
									
										
										
										
											2009-05-20 18:38:09 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-04 20:39:20 -06:00
										 |  |  | static void tosa_dac_class_init(ObjectClass *klass, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     I2CSlaveClass *k = I2C_SLAVE_CLASS(klass); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     k->init = tosa_dac_init; | 
					
						
							|  |  |  |     k->event = tosa_dac_event; | 
					
						
							|  |  |  |     k->recv = tosa_dac_recv; | 
					
						
							|  |  |  |     k->send = tosa_dac_send; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-10 16:19:07 +01:00
										 |  |  | static const TypeInfo tosa_dac_info = { | 
					
						
							| 
									
										
										
										
											2013-12-19 21:51:29 +01:00
										 |  |  |     .name          = TYPE_TOSA_DAC, | 
					
						
							| 
									
										
										
										
											2011-12-07 21:34:16 -06:00
										 |  |  |     .parent        = TYPE_I2C_SLAVE, | 
					
						
							|  |  |  |     .instance_size = sizeof(TosaDACState), | 
					
						
							|  |  |  |     .class_init    = tosa_dac_class_init, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2011-12-16 13:36:39 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void tosa_ssp_class_init(ObjectClass *klass, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     SSISlaveClass *k = SSI_SLAVE_CLASS(klass); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-04 13:06:37 +01:00
										 |  |  |     k->realize = tosa_ssp_realize; | 
					
						
							| 
									
										
										
										
											2011-12-16 13:36:39 -06:00
										 |  |  |     k->transfer = tosa_ssp_tansfer; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-10 16:19:07 +01:00
										 |  |  | static const TypeInfo tosa_ssp_info = { | 
					
						
							| 
									
										
										
										
											2011-12-07 21:34:16 -06:00
										 |  |  |     .name          = "tosa-ssp", | 
					
						
							|  |  |  |     .parent        = TYPE_SSI_SLAVE, | 
					
						
							|  |  |  |     .instance_size = sizeof(SSISlave), | 
					
						
							|  |  |  |     .class_init    = tosa_ssp_class_init, | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:09 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-09 15:20:55 +01:00
										 |  |  | static void tosa_register_types(void) | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:08 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-07 21:34:16 -06:00
										 |  |  |     type_register_static(&tosa_dac_info); | 
					
						
							|  |  |  |     type_register_static(&tosa_ssp_info); | 
					
						
							| 
									
										
										
										
											2009-05-14 22:35:08 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-09 15:20:55 +01:00
										 |  |  | type_init(tosa_register_types) |