Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

KVM: PPC: BOOKE: Emulate debug registers and exception

This patch emulates debug registers and debug exception
to support guest using debug resource. This enables running
gdb/kgdb etc in guest.

On BOOKE architecture we cannot share debug resources between QEMU and
guest because:
When QEMU is using debug resources then debug exception must
be always enabled. To achieve this we set MSR_DE and also set
MSRP_DEP so guest cannot change MSR_DE.

When emulating debug resource for guest we want guest
to control MSR_DE (enable/disable debug interrupt on need).

So above mentioned two configuration cannot be supported
at the same time. So the result is that we cannot share
debug resources between QEMU and Guest on BOOKE architecture.

In the current design QEMU gets priority over guest, this means that if
QEMU is using debug resources then guest cannot use them and if guest is
using debug resource then QEMU can overwrite them.

Signed-off-by: Bharat Bhushan <Bharat.Bhushan@freescale.com>
Signed-off-by: Alexander Graf <agraf@suse.de>

authored by

Bharat Bhushan and committed by
Alexander Graf
2f699a59 3840edc8

+194 -1
+3
arch/powerpc/include/asm/kvm_ppc.h
··· 206 206 extern int kvmppc_xics_int_on(struct kvm *kvm, u32 irq); 207 207 extern int kvmppc_xics_int_off(struct kvm *kvm, u32 irq); 208 208 209 + void kvmppc_core_dequeue_debug(struct kvm_vcpu *vcpu); 210 + void kvmppc_core_queue_debug(struct kvm_vcpu *vcpu); 211 + 209 212 union kvmppc_one_reg { 210 213 u32 wval; 211 214 u64 dval;
+2
arch/powerpc/include/asm/reg_booke.h
··· 319 319 * DBSR bits which have conflicting definitions on true Book E versus IBM 40x. 320 320 */ 321 321 #ifdef CONFIG_BOOKE 322 + #define DBSR_IDE 0x80000000 /* Imprecise Debug Event */ 323 + #define DBSR_MRR 0x30000000 /* Most Recent Reset */ 322 324 #define DBSR_IC 0x08000000 /* Instruction Completion */ 323 325 #define DBSR_BT 0x04000000 /* Branch Taken */ 324 326 #define DBSR_IRPT 0x02000000 /* Exception Debug Event */
+41 -1
arch/powerpc/kvm/booke.c
··· 335 335 clear_bit(BOOKE_IRQPRIO_WATCHDOG, &vcpu->arch.pending_exceptions); 336 336 } 337 337 338 + void kvmppc_core_queue_debug(struct kvm_vcpu *vcpu) 339 + { 340 + kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DEBUG); 341 + } 342 + 343 + void kvmppc_core_dequeue_debug(struct kvm_vcpu *vcpu) 344 + { 345 + clear_bit(BOOKE_IRQPRIO_DEBUG, &vcpu->arch.pending_exceptions); 346 + } 347 + 338 348 static void set_guest_srr(struct kvm_vcpu *vcpu, unsigned long srr0, u32 srr1) 339 349 { 340 350 kvmppc_set_srr0(vcpu, srr0); ··· 828 818 struct debug_reg *dbg_reg = &(vcpu->arch.dbg_reg); 829 819 u32 dbsr = vcpu->arch.dbsr; 830 820 831 - /* Clear guest dbsr (vcpu->arch.dbsr) */ 821 + if (vcpu->guest_debug == 0) { 822 + /* 823 + * Debug resources belong to Guest. 824 + * Imprecise debug event is not injected 825 + */ 826 + if (dbsr & DBSR_IDE) { 827 + dbsr &= ~DBSR_IDE; 828 + if (!dbsr) 829 + return RESUME_GUEST; 830 + } 831 + 832 + if (dbsr && (vcpu->arch.shared->msr & MSR_DE) && 833 + (vcpu->arch.dbg_reg.dbcr0 & DBCR0_IDM)) 834 + kvmppc_core_queue_debug(vcpu); 835 + 836 + /* Inject a program interrupt if trap debug is not allowed */ 837 + if ((dbsr & DBSR_TIE) && !(vcpu->arch.shared->msr & MSR_DE)) 838 + kvmppc_core_queue_program(vcpu, ESR_PTR); 839 + 840 + return RESUME_GUEST; 841 + } 842 + 843 + /* 844 + * Debug resource owned by userspace. 845 + * Clear guest dbsr (vcpu->arch.dbsr) 846 + */ 832 847 vcpu->arch.dbsr = 0; 833 848 run->debug.arch.status = 0; 834 849 run->debug.arch.address = vcpu->arch.pc; ··· 1385 1350 setup_timer(&vcpu->arch.wdt_timer, kvmppc_watchdog_func, 1386 1351 (unsigned long)vcpu); 1387 1352 1353 + /* 1354 + * Clear DBSR.MRR to avoid guest debug interrupt as 1355 + * this is of host interest 1356 + */ 1357 + mtspr(SPRN_DBSR, DBSR_MRR); 1388 1358 return 0; 1389 1359 } 1390 1360
+148
arch/powerpc/kvm/booke_emulate.c
··· 131 131 int kvmppc_booke_emulate_mtspr(struct kvm_vcpu *vcpu, int sprn, ulong spr_val) 132 132 { 133 133 int emulated = EMULATE_DONE; 134 + bool debug_inst = false; 134 135 135 136 switch (sprn) { 136 137 case SPRN_DEAR: ··· 146 145 case SPRN_CSRR1: 147 146 vcpu->arch.csrr1 = spr_val; 148 147 break; 148 + case SPRN_DSRR0: 149 + vcpu->arch.dsrr0 = spr_val; 150 + break; 151 + case SPRN_DSRR1: 152 + vcpu->arch.dsrr1 = spr_val; 153 + break; 154 + case SPRN_IAC1: 155 + /* 156 + * If userspace is debugging guest then guest 157 + * can not access debug registers. 158 + */ 159 + if (vcpu->guest_debug) 160 + break; 161 + 162 + debug_inst = true; 163 + vcpu->arch.dbg_reg.iac1 = spr_val; 164 + break; 165 + case SPRN_IAC2: 166 + /* 167 + * If userspace is debugging guest then guest 168 + * can not access debug registers. 169 + */ 170 + if (vcpu->guest_debug) 171 + break; 172 + 173 + debug_inst = true; 174 + vcpu->arch.dbg_reg.iac2 = spr_val; 175 + break; 176 + #if CONFIG_PPC_ADV_DEBUG_IACS > 2 177 + case SPRN_IAC3: 178 + /* 179 + * If userspace is debugging guest then guest 180 + * can not access debug registers. 181 + */ 182 + if (vcpu->guest_debug) 183 + break; 184 + 185 + debug_inst = true; 186 + vcpu->arch.dbg_reg.iac3 = spr_val; 187 + break; 188 + case SPRN_IAC4: 189 + /* 190 + * If userspace is debugging guest then guest 191 + * can not access debug registers. 192 + */ 193 + if (vcpu->guest_debug) 194 + break; 195 + 196 + debug_inst = true; 197 + vcpu->arch.dbg_reg.iac4 = spr_val; 198 + break; 199 + #endif 200 + case SPRN_DAC1: 201 + /* 202 + * If userspace is debugging guest then guest 203 + * can not access debug registers. 204 + */ 205 + if (vcpu->guest_debug) 206 + break; 207 + 208 + debug_inst = true; 209 + vcpu->arch.dbg_reg.dac1 = spr_val; 210 + break; 211 + case SPRN_DAC2: 212 + /* 213 + * If userspace is debugging guest then guest 214 + * can not access debug registers. 215 + */ 216 + if (vcpu->guest_debug) 217 + break; 218 + 219 + debug_inst = true; 220 + vcpu->arch.dbg_reg.dac2 = spr_val; 221 + break; 149 222 case SPRN_DBCR0: 223 + /* 224 + * If userspace is debugging guest then guest 225 + * can not access debug registers. 226 + */ 227 + if (vcpu->guest_debug) 228 + break; 229 + 230 + debug_inst = true; 231 + spr_val &= (DBCR0_IDM | DBCR0_IC | DBCR0_BT | DBCR0_TIE | 232 + DBCR0_IAC1 | DBCR0_IAC2 | DBCR0_IAC3 | DBCR0_IAC4 | 233 + DBCR0_DAC1R | DBCR0_DAC1W | DBCR0_DAC2R | DBCR0_DAC2W); 234 + 150 235 vcpu->arch.dbg_reg.dbcr0 = spr_val; 151 236 break; 152 237 case SPRN_DBCR1: 238 + /* 239 + * If userspace is debugging guest then guest 240 + * can not access debug registers. 241 + */ 242 + if (vcpu->guest_debug) 243 + break; 244 + 245 + debug_inst = true; 153 246 vcpu->arch.dbg_reg.dbcr1 = spr_val; 154 247 break; 248 + case SPRN_DBCR2: 249 + /* 250 + * If userspace is debugging guest then guest 251 + * can not access debug registers. 252 + */ 253 + if (vcpu->guest_debug) 254 + break; 255 + 256 + debug_inst = true; 257 + vcpu->arch.dbg_reg.dbcr2 = spr_val; 258 + break; 155 259 case SPRN_DBSR: 260 + /* 261 + * If userspace is debugging guest then guest 262 + * can not access debug registers. 263 + */ 264 + if (vcpu->guest_debug) 265 + break; 266 + 156 267 vcpu->arch.dbsr &= ~spr_val; 268 + if (!(vcpu->arch.dbsr & ~DBSR_IDE)) 269 + kvmppc_core_dequeue_debug(vcpu); 157 270 break; 158 271 case SPRN_TSR: 159 272 kvmppc_clr_tsr_bits(vcpu, spr_val); ··· 380 265 emulated = EMULATE_FAIL; 381 266 } 382 267 268 + if (debug_inst) { 269 + current->thread.debug = vcpu->arch.dbg_reg; 270 + switch_booke_debug_regs(&vcpu->arch.dbg_reg); 271 + } 383 272 return emulated; 384 273 } 385 274 ··· 410 291 case SPRN_CSRR1: 411 292 *spr_val = vcpu->arch.csrr1; 412 293 break; 294 + case SPRN_DSRR0: 295 + *spr_val = vcpu->arch.dsrr0; 296 + break; 297 + case SPRN_DSRR1: 298 + *spr_val = vcpu->arch.dsrr1; 299 + break; 300 + case SPRN_IAC1: 301 + *spr_val = vcpu->arch.dbg_reg.iac1; 302 + break; 303 + case SPRN_IAC2: 304 + *spr_val = vcpu->arch.dbg_reg.iac2; 305 + break; 306 + #if CONFIG_PPC_ADV_DEBUG_IACS > 2 307 + case SPRN_IAC3: 308 + *spr_val = vcpu->arch.dbg_reg.iac3; 309 + break; 310 + case SPRN_IAC4: 311 + *spr_val = vcpu->arch.dbg_reg.iac4; 312 + break; 313 + #endif 314 + case SPRN_DAC1: 315 + *spr_val = vcpu->arch.dbg_reg.dac1; 316 + break; 317 + case SPRN_DAC2: 318 + *spr_val = vcpu->arch.dbg_reg.dac2; 319 + break; 413 320 case SPRN_DBCR0: 414 321 *spr_val = vcpu->arch.dbg_reg.dbcr0; 415 322 if (vcpu->guest_debug) ··· 443 298 break; 444 299 case SPRN_DBCR1: 445 300 *spr_val = vcpu->arch.dbg_reg.dbcr1; 301 + break; 302 + case SPRN_DBCR2: 303 + *spr_val = vcpu->arch.dbg_reg.dbcr2; 446 304 break; 447 305 case SPRN_DBSR: 448 306 *spr_val = vcpu->arch.dbsr;