2 * PXA270-based Intel Mainstone platforms.
5 * Copyright (c) 2007 by Armin Kuster <akuster@kama-aina.net> or
8 * This code is licensed under the GNU GPL v2.
11 #include "mainstone.h"
13 /* Mainstone FPGA for extern irqs */
14 #define FPGA_GPIO_PIN 0
15 #define MST_NUM_IRQS 16
16 #define MST_LEDDAT1 0x10
17 #define MST_LEDDAT2 0x14
18 #define MST_LEDCTRL 0x40
19 #define MST_GPSWR 0x60
20 #define MST_MSCWR1 0x80
21 #define MST_MSCWR2 0x84
22 #define MST_MSCWR3 0x88
23 #define MST_MSCRD 0x90
24 #define MST_INTMSKENA 0xc0
25 #define MST_INTSETCLR 0xd0
26 #define MST_PCMCIA0 0xe0
27 #define MST_PCMCIA1 0xe4
29 typedef struct mst_irq_state
{
49 mst_fpga_update_gpio(mst_irq_state
*s
)
53 level
= s
->prev_level
^ s
->intsetclr
;
55 for (diff
= s
->prev_level
^ level
; diff
; diff
^= 1 << bit
) {
57 qemu_set_irq(s
->pins
[bit
], (level
>> bit
) & 1 );
59 s
->prev_level
= level
;
63 mst_fpga_set_irq(void *opaque
, int irq
, int level
)
65 mst_irq_state
*s
= (mst_irq_state
*)opaque
;
68 s
->prev_level
|= 1u << irq
;
70 s
->prev_level
&= ~(1u << irq
);
72 if(s
->intmskena
& (1u << irq
)) {
73 s
->intsetclr
= 1u << irq
;
74 qemu_set_irq(s
->parent
, level
);
80 mst_fpga_readb(void *opaque
, target_phys_addr_t addr
)
82 mst_irq_state
*s
= (mst_irq_state
*) opaque
;
110 printf("Mainstone - mst_fpga_readb: Bad register offset "
111 "0x" TARGET_FMT_plx
" \n", addr
);
117 mst_fpga_writeb(void *opaque
, target_phys_addr_t addr
, uint32_t value
)
119 mst_irq_state
*s
= (mst_irq_state
*) opaque
;
147 case MST_INTMSKENA
: /* Mask interupt */
148 s
->intmskena
= (value
& 0xFEEFF);
149 mst_fpga_update_gpio(s
);
151 case MST_INTSETCLR
: /* clear or set interrupt */
152 s
->intsetclr
= (value
& 0xFEEFF);
161 printf("Mainstone - mst_fpga_writeb: Bad register offset "
162 "0x" TARGET_FMT_plx
" \n", addr
);
166 static CPUReadMemoryFunc
* const mst_fpga_readfn
[] = {
171 static CPUWriteMemoryFunc
* const mst_fpga_writefn
[] = {
178 mst_fpga_save(QEMUFile
*f
, void *opaque
)
180 struct mst_irq_state
*s
= (mst_irq_state
*) opaque
;
182 qemu_put_be32s(f
, &s
->prev_level
);
183 qemu_put_be32s(f
, &s
->leddat1
);
184 qemu_put_be32s(f
, &s
->leddat2
);
185 qemu_put_be32s(f
, &s
->ledctrl
);
186 qemu_put_be32s(f
, &s
->gpswr
);
187 qemu_put_be32s(f
, &s
->mscwr1
);
188 qemu_put_be32s(f
, &s
->mscwr2
);
189 qemu_put_be32s(f
, &s
->mscwr3
);
190 qemu_put_be32s(f
, &s
->mscrd
);
191 qemu_put_be32s(f
, &s
->intmskena
);
192 qemu_put_be32s(f
, &s
->intsetclr
);
193 qemu_put_be32s(f
, &s
->pcmcia0
);
194 qemu_put_be32s(f
, &s
->pcmcia1
);
198 mst_fpga_load(QEMUFile
*f
, void *opaque
, int version_id
)
200 mst_irq_state
*s
= (mst_irq_state
*) opaque
;
202 qemu_get_be32s(f
, &s
->prev_level
);
203 qemu_get_be32s(f
, &s
->leddat1
);
204 qemu_get_be32s(f
, &s
->leddat2
);
205 qemu_get_be32s(f
, &s
->ledctrl
);
206 qemu_get_be32s(f
, &s
->gpswr
);
207 qemu_get_be32s(f
, &s
->mscwr1
);
208 qemu_get_be32s(f
, &s
->mscwr2
);
209 qemu_get_be32s(f
, &s
->mscwr3
);
210 qemu_get_be32s(f
, &s
->mscrd
);
211 qemu_get_be32s(f
, &s
->intmskena
);
212 qemu_get_be32s(f
, &s
->intsetclr
);
213 qemu_get_be32s(f
, &s
->pcmcia0
);
214 qemu_get_be32s(f
, &s
->pcmcia1
);
218 qemu_irq
*mst_irq_init(uint32_t base
, qemu_irq irq
)
224 s
= (mst_irq_state
*)
225 qemu_mallocz(sizeof(mst_irq_state
));
229 /* alloc the external 16 irqs */
230 qi
= qemu_allocate_irqs(mst_fpga_set_irq
, s
, MST_NUM_IRQS
);
233 iomemtype
= cpu_register_io_memory(mst_fpga_readfn
,
234 mst_fpga_writefn
, s
, DEVICE_NATIVE_ENDIAN
);
235 cpu_register_physical_memory(base
, 0x00100000, iomemtype
);
236 register_savevm(NULL
, "mainstone_fpga", 0, 0, mst_fpga_save
,