e500_emulate.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  1. /*
  2. * Copyright (C) 2008-2011 Freescale Semiconductor, Inc. All rights reserved.
  3. *
  4. * Author: Yu Liu, <yu.liu@freescale.com>
  5. *
  6. * Description:
  7. * This file is derived from arch/powerpc/kvm/44x_emulate.c,
  8. * by Hollis Blanchard <hollisb@us.ibm.com>.
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License, version 2, as
  12. * published by the Free Software Foundation.
  13. */
  14. #include <asm/kvm_ppc.h>
  15. #include <asm/disassemble.h>
  16. #include <asm/dbell.h>
  17. #include "booke.h"
  18. #include "e500.h"
  19. #define XOP_DCBTLS 166
  20. #define XOP_MSGSND 206
  21. #define XOP_MSGCLR 238
  22. #define XOP_TLBIVAX 786
  23. #define XOP_TLBSX 914
  24. #define XOP_TLBRE 946
  25. #define XOP_TLBWE 978
  26. #define XOP_TLBILX 18
  27. #define XOP_EHPRIV 270
  28. #ifdef CONFIG_KVM_E500MC
  29. static int dbell2prio(ulong param)
  30. {
  31. int msg = param & PPC_DBELL_TYPE_MASK;
  32. int prio = -1;
  33. switch (msg) {
  34. case PPC_DBELL_TYPE(PPC_DBELL):
  35. prio = BOOKE_IRQPRIO_DBELL;
  36. break;
  37. case PPC_DBELL_TYPE(PPC_DBELL_CRIT):
  38. prio = BOOKE_IRQPRIO_DBELL_CRIT;
  39. break;
  40. default:
  41. break;
  42. }
  43. return prio;
  44. }
  45. static int kvmppc_e500_emul_msgclr(struct kvm_vcpu *vcpu, int rb)
  46. {
  47. ulong param = vcpu->arch.gpr[rb];
  48. int prio = dbell2prio(param);
  49. if (prio < 0)
  50. return EMULATE_FAIL;
  51. clear_bit(prio, &vcpu->arch.pending_exceptions);
  52. return EMULATE_DONE;
  53. }
  54. static int kvmppc_e500_emul_msgsnd(struct kvm_vcpu *vcpu, int rb)
  55. {
  56. ulong param = vcpu->arch.gpr[rb];
  57. int prio = dbell2prio(rb);
  58. int pir = param & PPC_DBELL_PIR_MASK;
  59. int i;
  60. struct kvm_vcpu *cvcpu;
  61. if (prio < 0)
  62. return EMULATE_FAIL;
  63. kvm_for_each_vcpu(i, cvcpu, vcpu->kvm) {
  64. int cpir = cvcpu->arch.shared->pir;
  65. if ((param & PPC_DBELL_MSG_BRDCAST) || (cpir == pir)) {
  66. set_bit(prio, &cvcpu->arch.pending_exceptions);
  67. kvm_vcpu_kick(cvcpu);
  68. }
  69. }
  70. return EMULATE_DONE;
  71. }
  72. #endif
  73. static int kvmppc_e500_emul_ehpriv(struct kvm_run *run, struct kvm_vcpu *vcpu,
  74. unsigned int inst, int *advance)
  75. {
  76. int emulated = EMULATE_DONE;
  77. switch (get_oc(inst)) {
  78. case EHPRIV_OC_DEBUG:
  79. run->exit_reason = KVM_EXIT_DEBUG;
  80. run->debug.arch.address = vcpu->arch.pc;
  81. run->debug.arch.status = 0;
  82. kvmppc_account_exit(vcpu, DEBUG_EXITS);
  83. emulated = EMULATE_EXIT_USER;
  84. *advance = 0;
  85. break;
  86. default:
  87. emulated = EMULATE_FAIL;
  88. }
  89. return emulated;
  90. }
  91. static int kvmppc_e500_emul_dcbtls(struct kvm_vcpu *vcpu)
  92. {
  93. struct kvmppc_vcpu_e500 *vcpu_e500 = to_e500(vcpu);
  94. /* Always fail to lock the cache */
  95. vcpu_e500->l1csr0 |= L1CSR0_CUL;
  96. return EMULATE_DONE;
  97. }
  98. int kvmppc_core_emulate_op_e500(struct kvm_run *run, struct kvm_vcpu *vcpu,
  99. unsigned int inst, int *advance)
  100. {
  101. int emulated = EMULATE_DONE;
  102. int ra = get_ra(inst);
  103. int rb = get_rb(inst);
  104. int rt = get_rt(inst);
  105. gva_t ea;
  106. switch (get_op(inst)) {
  107. case 31:
  108. switch (get_xop(inst)) {
  109. case XOP_DCBTLS:
  110. emulated = kvmppc_e500_emul_dcbtls(vcpu);
  111. break;
  112. #ifdef CONFIG_KVM_E500MC
  113. case XOP_MSGSND:
  114. emulated = kvmppc_e500_emul_msgsnd(vcpu, rb);
  115. break;
  116. case XOP_MSGCLR:
  117. emulated = kvmppc_e500_emul_msgclr(vcpu, rb);
  118. break;
  119. #endif
  120. case XOP_TLBRE:
  121. emulated = kvmppc_e500_emul_tlbre(vcpu);
  122. break;
  123. case XOP_TLBWE:
  124. emulated = kvmppc_e500_emul_tlbwe(vcpu);
  125. break;
  126. case XOP_TLBSX:
  127. ea = kvmppc_get_ea_indexed(vcpu, ra, rb);
  128. emulated = kvmppc_e500_emul_tlbsx(vcpu, ea);
  129. break;
  130. case XOP_TLBILX: {
  131. int type = rt & 0x3;
  132. ea = kvmppc_get_ea_indexed(vcpu, ra, rb);
  133. emulated = kvmppc_e500_emul_tlbilx(vcpu, type, ea);
  134. break;
  135. }
  136. case XOP_TLBIVAX:
  137. ea = kvmppc_get_ea_indexed(vcpu, ra, rb);
  138. emulated = kvmppc_e500_emul_tlbivax(vcpu, ea);
  139. break;
  140. case XOP_EHPRIV:
  141. emulated = kvmppc_e500_emul_ehpriv(run, vcpu, inst,
  142. advance);
  143. break;
  144. default:
  145. emulated = EMULATE_FAIL;
  146. }
  147. break;
  148. default:
  149. emulated = EMULATE_FAIL;
  150. }
  151. if (emulated == EMULATE_FAIL)
  152. emulated = kvmppc_booke_emulate_op(run, vcpu, inst, advance);
  153. return emulated;
  154. }
  155. int kvmppc_core_emulate_mtspr_e500(struct kvm_vcpu *vcpu, int sprn, ulong spr_val)
  156. {
  157. struct kvmppc_vcpu_e500 *vcpu_e500 = to_e500(vcpu);
  158. int emulated = EMULATE_DONE;
  159. switch (sprn) {
  160. #ifndef CONFIG_KVM_BOOKE_HV
  161. case SPRN_PID:
  162. kvmppc_set_pid(vcpu, spr_val);
  163. break;
  164. case SPRN_PID1:
  165. if (spr_val != 0)
  166. return EMULATE_FAIL;
  167. vcpu_e500->pid[1] = spr_val;
  168. break;
  169. case SPRN_PID2:
  170. if (spr_val != 0)
  171. return EMULATE_FAIL;
  172. vcpu_e500->pid[2] = spr_val;
  173. break;
  174. case SPRN_MAS0:
  175. vcpu->arch.shared->mas0 = spr_val;
  176. break;
  177. case SPRN_MAS1:
  178. vcpu->arch.shared->mas1 = spr_val;
  179. break;
  180. case SPRN_MAS2:
  181. vcpu->arch.shared->mas2 = spr_val;
  182. break;
  183. case SPRN_MAS3:
  184. vcpu->arch.shared->mas7_3 &= ~(u64)0xffffffff;
  185. vcpu->arch.shared->mas7_3 |= spr_val;
  186. break;
  187. case SPRN_MAS4:
  188. vcpu->arch.shared->mas4 = spr_val;
  189. break;
  190. case SPRN_MAS6:
  191. vcpu->arch.shared->mas6 = spr_val;
  192. break;
  193. case SPRN_MAS7:
  194. vcpu->arch.shared->mas7_3 &= (u64)0xffffffff;
  195. vcpu->arch.shared->mas7_3 |= (u64)spr_val << 32;
  196. break;
  197. #endif
  198. case SPRN_L1CSR0:
  199. vcpu_e500->l1csr0 = spr_val;
  200. vcpu_e500->l1csr0 &= ~(L1CSR0_DCFI | L1CSR0_CLFC);
  201. break;
  202. case SPRN_L1CSR1:
  203. vcpu_e500->l1csr1 = spr_val;
  204. vcpu_e500->l1csr1 &= ~(L1CSR1_ICFI | L1CSR1_ICLFR);
  205. break;
  206. case SPRN_HID0:
  207. vcpu_e500->hid0 = spr_val;
  208. break;
  209. case SPRN_HID1:
  210. vcpu_e500->hid1 = spr_val;
  211. break;
  212. case SPRN_MMUCSR0:
  213. emulated = kvmppc_e500_emul_mt_mmucsr0(vcpu_e500,
  214. spr_val);
  215. break;
  216. /* extra exceptions */
  217. case SPRN_IVOR32:
  218. vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_UNAVAIL] = spr_val;
  219. break;
  220. case SPRN_IVOR33:
  221. vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_FP_DATA] = spr_val;
  222. break;
  223. case SPRN_IVOR34:
  224. vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_FP_ROUND] = spr_val;
  225. break;
  226. case SPRN_IVOR35:
  227. vcpu->arch.ivor[BOOKE_IRQPRIO_PERFORMANCE_MONITOR] = spr_val;
  228. break;
  229. #ifdef CONFIG_KVM_BOOKE_HV
  230. case SPRN_IVOR36:
  231. vcpu->arch.ivor[BOOKE_IRQPRIO_DBELL] = spr_val;
  232. break;
  233. case SPRN_IVOR37:
  234. vcpu->arch.ivor[BOOKE_IRQPRIO_DBELL_CRIT] = spr_val;
  235. break;
  236. #endif
  237. default:
  238. emulated = kvmppc_booke_emulate_mtspr(vcpu, sprn, spr_val);
  239. }
  240. return emulated;
  241. }
  242. int kvmppc_core_emulate_mfspr_e500(struct kvm_vcpu *vcpu, int sprn, ulong *spr_val)
  243. {
  244. struct kvmppc_vcpu_e500 *vcpu_e500 = to_e500(vcpu);
  245. int emulated = EMULATE_DONE;
  246. switch (sprn) {
  247. #ifndef CONFIG_KVM_BOOKE_HV
  248. case SPRN_PID:
  249. *spr_val = vcpu_e500->pid[0];
  250. break;
  251. case SPRN_PID1:
  252. *spr_val = vcpu_e500->pid[1];
  253. break;
  254. case SPRN_PID2:
  255. *spr_val = vcpu_e500->pid[2];
  256. break;
  257. case SPRN_MAS0:
  258. *spr_val = vcpu->arch.shared->mas0;
  259. break;
  260. case SPRN_MAS1:
  261. *spr_val = vcpu->arch.shared->mas1;
  262. break;
  263. case SPRN_MAS2:
  264. *spr_val = vcpu->arch.shared->mas2;
  265. break;
  266. case SPRN_MAS3:
  267. *spr_val = (u32)vcpu->arch.shared->mas7_3;
  268. break;
  269. case SPRN_MAS4:
  270. *spr_val = vcpu->arch.shared->mas4;
  271. break;
  272. case SPRN_MAS6:
  273. *spr_val = vcpu->arch.shared->mas6;
  274. break;
  275. case SPRN_MAS7:
  276. *spr_val = vcpu->arch.shared->mas7_3 >> 32;
  277. break;
  278. #endif
  279. case SPRN_DECAR:
  280. *spr_val = vcpu->arch.decar;
  281. break;
  282. case SPRN_TLB0CFG:
  283. *spr_val = vcpu->arch.tlbcfg[0];
  284. break;
  285. case SPRN_TLB1CFG:
  286. *spr_val = vcpu->arch.tlbcfg[1];
  287. break;
  288. case SPRN_TLB0PS:
  289. if (!has_feature(vcpu, VCPU_FTR_MMU_V2))
  290. return EMULATE_FAIL;
  291. *spr_val = vcpu->arch.tlbps[0];
  292. break;
  293. case SPRN_TLB1PS:
  294. if (!has_feature(vcpu, VCPU_FTR_MMU_V2))
  295. return EMULATE_FAIL;
  296. *spr_val = vcpu->arch.tlbps[1];
  297. break;
  298. case SPRN_L1CSR0:
  299. *spr_val = vcpu_e500->l1csr0;
  300. break;
  301. case SPRN_L1CSR1:
  302. *spr_val = vcpu_e500->l1csr1;
  303. break;
  304. case SPRN_HID0:
  305. *spr_val = vcpu_e500->hid0;
  306. break;
  307. case SPRN_HID1:
  308. *spr_val = vcpu_e500->hid1;
  309. break;
  310. case SPRN_SVR:
  311. *spr_val = vcpu_e500->svr;
  312. break;
  313. case SPRN_MMUCSR0:
  314. *spr_val = 0;
  315. break;
  316. case SPRN_MMUCFG:
  317. *spr_val = vcpu->arch.mmucfg;
  318. break;
  319. case SPRN_EPTCFG:
  320. if (!has_feature(vcpu, VCPU_FTR_MMU_V2))
  321. return EMULATE_FAIL;
  322. /*
  323. * Legacy Linux guests access EPTCFG register even if the E.PT
  324. * category is disabled in the VM. Give them a chance to live.
  325. */
  326. *spr_val = vcpu->arch.eptcfg;
  327. break;
  328. /* extra exceptions */
  329. case SPRN_IVOR32:
  330. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_UNAVAIL];
  331. break;
  332. case SPRN_IVOR33:
  333. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_FP_DATA];
  334. break;
  335. case SPRN_IVOR34:
  336. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_FP_ROUND];
  337. break;
  338. case SPRN_IVOR35:
  339. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_PERFORMANCE_MONITOR];
  340. break;
  341. #ifdef CONFIG_KVM_BOOKE_HV
  342. case SPRN_IVOR36:
  343. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_DBELL];
  344. break;
  345. case SPRN_IVOR37:
  346. *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_DBELL_CRIT];
  347. break;
  348. #endif
  349. default:
  350. emulated = kvmppc_booke_emulate_mfspr(vcpu, sprn, spr_val);
  351. }
  352. return emulated;
  353. }