Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						b704d63d09 
					 
					
						
						
							
							pckbd: remove legacy i8042_mm_init() function  
						
						... 
						
						
						
						This legacy function is only used during the initialisation of the MIPS magnum
machine, so inline its functionality directly into mips_jazz_init() and then
remove it.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-41-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						46e9783fbe 
					 
					
						
						
							
							ps2: remove unused legacy ps2_mouse_init() function  
						
						... 
						
						
						
						Now that the legacy ps2_mouse_init() function is no longer used, it can be completely
removed along with its associated trace-event.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-40-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						9d1a425037 
					 
					
						
						
							
							pckbd: don't use legacy ps2_mouse_init() function  
						
						... 
						
						
						
						Instantiate the PS2 mouse device within KBDState using
object_initialize_child() in i8042_initfn() and i8042_mmio_init() and realize
it in i8042_realizefn() and i8042_mmio_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-39-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						5e8312ab8e 
					 
					
						
						
							
							ps2: remove unused legacy ps2_kbd_init() function  
						
						... 
						
						
						
						Now that the legacy ps2_kbd_init() function is no longer used, it can be completely
removed along with its associated trace-event.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-38-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						652fbff420 
					 
					
						
						
							
							pckbd: don't use legacy ps2_kbd_init() function  
						
						... 
						
						
						
						Instantiate the PS2 keyboard device within KBDState using
object_initialize_child() in i8042_initfn() and i8042_mmio_init() and realize
it in i8042_realizefn() and i8042_mmio_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-37-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						d316983c7f 
					 
					
						
						
							
							lasips2: don't use legacy ps2_mouse_init() function  
						
						... 
						
						
						
						Instantiate the PS2 mouse device within LASIPS2MousePort using
object_initialize_child() in lasips2_mouse_port_init() and realize it in
lasips2_mouse_port_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-34-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						e2b50aea03 
					 
					
						
						
							
							lasips2: don't use legacy ps2_kbd_init() function  
						
						... 
						
						
						
						Instantiate the PS2 keyboard device within LASIPS2KbdPort using
object_initialize_child() in lasips2_kbd_port_init() and realize it in
lasips2_kbd_port_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-33-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						01f6c54626 
					 
					
						
						
							
							lasips2: rename LASIPS2Port parent pointer to lasips2  
						
						... 
						
						
						
						This makes it clearer that the pointer is a reference to the LASIPS2 container
device rather than an implied part of the QOM hierarchy.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-30-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						212a300303 
					 
					
						
						
							
							lasips2: switch to using port-based IRQs  
						
						... 
						
						
						
						Now we can implement port-based IRQs by wiring the PS2 device IRQs to the
LASI2Port named input gpios rather than directly to the LASIPS2 device, and
generate the LASIPS2 output IRQ from the int_status bitmap representing the
individual port IRQs instead of the birq boolean.
This enables us to remove the separate PS2 keyboard and PS2 mouse named input
gpios from the LASIPS2 device and simplify the register implementation to
drive the port IRQ using qemu_set_irq() rather than accessing the LASIPS2
device IRQs directly. As a consequence the IRQ level logic in lasips2_set_irq()
can also be simplified accordingly.
For now this patch ignores adding the int_status bitmap and simply drops the
birq boolean from the vmstate_lasips2 VMStateDescription. This is because the
migration stream is already missing some required LASIPS2 fields, and as this
series already introduces a migration break for the lasips2 device it is
easiest to fix this in a follow-up patch.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220712215251.7944-29-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						ca735a81b2 
					 
					
						
						
							
							lasips2: add named input gpio to handle incoming port IRQs  
						
						... 
						
						
						
						The LASIPS2 device named input gpio is soon to be connected to the port output
IRQs. Add a new int_status field to LASIPS2State which is a bitmap representing
the port input IRQ status which will be enabled in the next patch.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220712215251.7944-28-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						d0af5d6a40 
					 
					
						
						
							
							lasips2: add named input gpio to port for downstream PS2 device IRQ  
						
						... 
						
						
						
						The named input gpio is to be connected to the IRQ output of the downstream
PS2 device and used to drive the port IRQ. Initialise the named input gpio
in lasips2_port_init() and add new lasips2_port_class_init() and
lasips2_port_realize() functions to connect the PS2 device output gpio to
the new named input gpio.
Note that the reference to lasips2_port_realize() is stored in
LASIPS2PortDeviceClass but not yet used.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-27-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						62201e4336 
					 
					
						
						
							
							lasips2: introduce LASIPS2PortDeviceClass for the LASIPS2_PORT device  
						
						... 
						
						
						
						This will soon be used to store the reference to the LASIPS2_PORT parent device
for LASIPS2_KBD_PORT and LASIPS2_MOUSE_PORT.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-26-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						8db817be78 
					 
					
						
						
							
							lasips2: introduce port IRQ and new lasips2_port_init() function  
						
						... 
						
						
						
						Introduce a new lasips2_port_init() QOM init function for the LASIPS2_PORT type
and use it to initialise a new gpio for use as a port IRQ. Add a new qemu_irq
representing the gpio as a new irq field within LASIPS2Port.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-25-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						c553d6c054 
					 
					
						
						
							
							lasips2: rename LASIPS2Port irq field to birq  
						
						... 
						
						
						
						The existing boolean irq field in LASIPS2Port will soon be replaced by a proper
qemu_irq, so rename the field to birq to allow the upcoming qemu_irq to use the
irq name.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-24-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						a088ce9b4b 
					 
					
						
						
							
							lasips2: move mouse port initialisation to new lasips2_mouse_port_init() function  
						
						... 
						
						
						
						Move the initialisation of the mouse port from lasips2_init() to
a new lasips2_mouse_port_init() function which will be invoked using
object_initialize_child() during the LASIPS2 device init.
Update LASIPS2State so that it now holds the new LASIPS2MousePort child object and
ensure that it is realised in lasips2_realize().
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-21-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						b7047733dc 
					 
					
						
						
							
							lasips2: move keyboard port initialisation to new lasips2_kbd_port_init() function  
						
						... 
						
						
						
						Move the initialisation of the keyboard port from lasips2_init() to
a new lasips2_kbd_port_init() function which will be invoked using
object_initialize_child() during the LASIPS2 device init.
Update LASIPS2State so that it now holds the new LASIPS2KbdPort child object and
ensure that it is realised in lasips2_realize().
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-20-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						cb5827cee3 
					 
					
						
						
							
							lasips2: introduce new LASIPS2_MOUSE_PORT QOM type  
						
						... 
						
						
						
						This will be soon be used to hold the underlying PS2_MOUSE_DEVICE object.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-19-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						ef90a06f99 
					 
					
						
						
							
							lasips2: introduce new LASIPS2_KBD_PORT QOM type  
						
						... 
						
						
						
						This will be soon be used to hold the underlying PS2_KBD_DEVICE object.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-18-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						f8d89a7da4 
					 
					
						
						
							
							lasips2: QOMify LASIPS2Port  
						
						... 
						
						
						
						This becomes an abstract QOM type which will be a parent type for separate
keyboard and mouse port types.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-17-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						f4907cb5cf 
					 
					
						
						
							
							lasips2: change LASIPS2State dev pointer from void to PS2State  
						
						... 
						
						
						
						This allows the compiler to enforce that the PS2 device pointer is always of
type PS2State. Update the name of the pointer from dev to ps2dev to emphasise
this type change.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-16-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						92bd278c3b 
					 
					
						
						
							
							lasips2: remove legacy lasips2_initfn() function  
						
						... 
						
						
						
						There is only one user of the legacy lasips2_initfn() function which is in
machine_hppa_init(), so inline its functionality into machine_hppa_init() and
then remove it.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-15-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						4040ee5bdd 
					 
					
						
						
							
							lasips2: remove the qdev base property and the lasips2_properties array  
						
						... 
						
						
						
						The base property was only needed for use by vmstate_register() in order to
preserve migration compatibility. Now that the lasips2 migration state is
registered through the DeviceClass vmsd field, the base property and also
the lasips2_properties array can be removed completely as they are no longer
required.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-14-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						6f9f245b93 
					 
					
						
						
							
							pl050: don't use legacy ps2_mouse_init() function  
						
						... 
						
						
						
						Instantiate the PS2 mouse device within PL050MouseState using
object_initialize_child() in pl050_mouse_init() and realize it in
pl050_mouse_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-12-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:46 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						6a05d0b3d1 
					 
					
						
						
							
							pl050: don't use legacy ps2_kbd_init() function  
						
						... 
						
						
						
						Instantiate the PS2 keyboard device within PL050KbdState using
object_initialize_child() in pl050_kbd_init() and realize it in
pl050_kbd_realize() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-11-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						475a4d463b 
					 
					
						
						
							
							pl050: introduce PL050DeviceClass for the PL050 device  
						
						... 
						
						
						
						This will soon be used to store the reference to the PL050 parent device
for PL050_KBD_DEVICE and PL050_MOUSE_DEVICE.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-8-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						0a3c1e1bf8 
					 
					
						
						
							
							pl050: introduce new PL050_MOUSE_DEVICE QOM type  
						
						... 
						
						
						
						This will be soon be used to hold the underlying PS2_MOUSE_DEVICE object.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-6-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						1d59315d97 
					 
					
						
						
							
							pl050: introduce new PL050_KBD_DEVICE QOM type  
						
						... 
						
						
						
						This will be soon be used to hold the underlying PS2_KBD_DEVICE object.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-5-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						33e0958e7e 
					 
					
						
						
							
							pl050: change PL050State dev pointer from void to PS2State  
						
						... 
						
						
						
						This allows the compiler to enforce that the PS2 device pointer is always of
type PS2State. Update the name of the pointer from dev to ps2dev to emphasise
this type change.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-4-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						bce0e9c1ec 
					 
					
						
						
							
							pl050: move PL050State from pl050.c to new pl050.h header file  
						
						... 
						
						
						
						This allows the QOM types in pl050.c to be used elsewhere by simply including
pl050.h.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Tested-by: Helge Deller <deller@gmx.de >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220712215251.7944-2-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org > 
						
						
					 
					
						2022-07-18 19:28:45 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						7227de94ad 
					 
					
						
						
							
							ps2: remove update_irq() function and update_arg parameter  
						
						... 
						
						
						
						Now that all the PS2 devices have been converted to use GPIOs the update_irq()
callback function and the update_arg parameter can be removed.
This allows these arguments to be completely removed from ps2_kbd_init() and
ps2_mouse_init(), along with the transitional logic that was added to
ps2_raise_irq() and ps2_lower_irq().
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-55-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						38f426b8af 
					 
					
						
						
							
							pckbd: add QEMU interface comment for I8042 device  
						
						... 
						
						
						
						This describes the I8042 device interface implemented within QEMU.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Message-Id: <20220624134109.881989-54-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						57de3c1d35 
					 
					
						
						
							
							pckbd: add QEMU interface comment for I8042_MMIO device  
						
						... 
						
						
						
						This describes the I8042_MMIO device interface implemented within QEMU.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Message-Id: <20220624134109.881989-51-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						501f062e91 
					 
					
						
						
							
							lasips2: add QEMU interface comment  
						
						... 
						
						
						
						This describes the LASI PS2 device interface implemented within QEMU.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Message-Id: <20220624134109.881989-49-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						42119fdb2e 
					 
					
						
						
							
							lasips2: add base property  
						
						... 
						
						
						
						This is in preparation for handling vmstate_register() within the device.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-45-mark.cave-ayland@ilande.co.uk >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						6479296fe5 
					 
					
						
						
							
							lasips2: move mapping of LASIPS2 registers to HPPA machine  
						
						... 
						
						
						
						Now that the register memory regions are exposed as SysBus memory regions, move
the mapping of the LASIPS2 registers from lasips2_initfn() to the HPPA machine
(which is its only user).
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-43-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						5cbf35d20f 
					 
					
						
						
							
							lasips2: rename lasips2_init() to lasips2_initfn() and update it to return the LASIPS2 device  
						
						... 
						
						
						
						When QOMifying a device it is typical to use _init() as the suffix for an
instance_init function, however this name is already in use by the legacy LASIPS2
wrapper function. Eventually the wrapper function will be removed, but for now
rename it to lasips2_initfn() to avoid a naming collision.
At the same time update lasips2_initfn() return the LASIPS2 device so that it
can later be accessed using qdev APIs by the HPPA machine.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-41-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						07c68b5010 
					 
					
						
						
							
							lasips2: move lasips2 QOM types from lasips2.c to lasips2.h  
						
						... 
						
						
						
						This allows the QOM types in lasips2.c to be used elsewhere by simply including
lasips2.h.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-40-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						c2b1747973 
					 
					
						
						
							
							pckbd: replace irq_kbd and irq_mouse with qemu_irq array in KBDState  
						
						... 
						
						
						
						This allows both IRQs to be declared as a single qdev gpio array.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-36-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						6beb79e11a 
					 
					
						
						
							
							ps2: add gpio for output IRQ and optionally use it in ps2_raise_irq() and ps2_lower_irq()  
						
						... 
						
						
						
						Define the gpio for the PS2 output IRQ in ps2_init() and add logic to optionally
use it in ps2_raise_irq() and ps2_lower_irq() if the gpio is connected. If the
gpio is not connected then call the legacy update_irq() function as before.
This allows the incremental conversion of devices from the legacy update_irq()
function to use gpios instead.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-35-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						52b28f76dd 
					 
					
						
						
							
							ps2: make ps2_raise_irq() function static  
						
						... 
						
						
						
						This function is no longer used outside of ps2.c and so can be declared static.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-32-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						01d924dce8 
					 
					
						
						
							
							pckbd: move mapping of I8042_MMIO registers to MIPS magnum machine  
						
						... 
						
						
						
						Now that the register memory region is exposed as a SysBus memory region, move
the mapping of the I8042_MMIO registers from i8042_mm_init() to the MIPS magnum
machine (which is its only user).
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-29-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						903dd0e49b 
					 
					
						
						
							
							pckbd: alter i8042_mm_init() to return a I8042_MMIO device  
						
						... 
						
						
						
						This exposes the I8042_MMIO device to the caller to allow the register memory
region to be mapped outside of i8042_mm_init().
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-28-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						f4de68d1d4 
					 
					
						
						
							
							pckbd: implement i8042_mmio_realize() function  
						
						... 
						
						
						
						Move the initialisation of the register memory region to the I8042_MMIO device
realize function and expose it using sysbus_init_mmio().
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-26-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						7b9fff290c 
					 
					
						
						
							
							pckbd: add size qdev property to I8042_MMIO device  
						
						... 
						
						
						
						This will soon be used to set the size of the register memory region using a
qdev property.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-25-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:12 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						150ee013ed 
					 
					
						
						
							
							pckbd: introduce new I8042_MMIO QOM type  
						
						... 
						
						
						
						Currently i8042_mm_init() creates a new KBDState directly which is used by the MIPS
magnum machine. Introduce a new I8042_MMIO QOM type that will soon be used to
allow the MIPS magnum machine to be wired up using standard qdev GPIOs.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Acked-by: Helge Deller <deller@gmx.de >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20220624134109.881989-22-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						c9849a71b9 
					 
					
						
						
							
							pckbd: move ISAKBDState from pckbd.c to i8042.h  
						
						... 
						
						
						
						This allows the QOM types in pckbd.c to be used elsewhere by simply including
i8042.h.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-21-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						77adda52ef 
					 
					
						
						
							
							pckbd: move KBDState from pckbd.c to i8042.h  
						
						... 
						
						
						
						This allows the QOM types in pckbd.c to be used elsewhere by simply including
i8042.h.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-20-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						108cb22e48 
					 
					
						
						
							
							ps2: implement ps2_reset() for the PS2_DEVICE QOM type based upon ps2_common_reset()  
						
						... 
						
						
						
						The functionality of ps2_common_reset() can be moved into a new ps2_reset() function
for the PS2_DEVICE QOM type. Update PS2DeviceClass to hold a reference to the parent
reset function and update the PS2_KBD_DEVICE and PS2_MOUSE_DEVICE types to use
device_class_set_parent_reset() accordingly.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-9-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						494145b286 
					 
					
						
						
							
							ps2: introduce PS2DeviceClass  
						
						... 
						
						
						
						This is in preparation for allowing the new PS2_KBD_DEVICE and PS2_MOUSE_DEVICE
QOM types to reference the parent PS2_DEVICE device reset() function.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-8-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00 
						 
				 
			
				
					
						
							
							
								Mark Cave-Ayland 
							
						 
					 
					
						
						
							
						
						54334e7387 
					 
					
						
						
							
							ps2: improve function prototypes in ps2.c and ps2.h  
						
						... 
						
						
						
						With the latest changes it is now possible to improve some of the function
prototypes in ps2.c and ps.h to use the appropriate PS2KbdState or
PS2MouseState type instead of being a void opaque.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk >
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Acked-by: Helge Deller <deller@gmx.de >
Message-Id: <20220624134109.881989-7-mark.cave-ayland@ilande.co.uk > 
						
						
					 
					
						2022-06-26 18:40:11 +01:00