• R/O
  • HTTP
  • SSH
  • HTTPS

コミット

タグ
未設定

よく使われているワード(クリックで追加)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

コミットメタ情報

リビジョン68aa851aa21741ab0a3c019b641d6ce72f68b3d5 (tree)
日時2019-02-06 19:49:21
作者Sven Schnelle <svens@stac...>
コミッターRichard Henderson

ログメッセージ

target/hppa: fix PSW Q bit behaviour to match hardware

PA-RISC specification says: "Setting the PSW Q-bit, PSW{28}, to 1
with this instruction, if it was not already 1, is an undefined
operation." However, at least HP-UX 10.20 sets the Q bit from 0 to 1
with the SSM instruction. Tested this both on HP9000/712 and
HP9000/785/C3750, both machines set the Q bit from 0 to 1 without
exception. This makes HP-UX 10.20 progress a little bit further.

Signed-off-by: Sven Schnelle <svens@stackframe.org>
Message-Id: <20190129191402.29539-1-svens@stackframe.org>
[rth: Add a comment to the code as well.]
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

変更サマリ

差分

--- a/target/hppa/op_helper.c
+++ b/target/hppa/op_helper.c
@@ -665,11 +665,15 @@ void HELPER(reset)(CPUHPPAState *env)
665665 target_ureg HELPER(swap_system_mask)(CPUHPPAState *env, target_ureg nsm)
666666 {
667667 target_ulong psw = env->psw;
668- /* ??? On second reading this condition simply seems
669- to be undefined rather than a diagnosed trap. */
670- if (nsm & ~psw & PSW_Q) {
671- hppa_dynamic_excp(env, EXCP_ILL, GETPC());
672- }
668+ /*
669+ * Setting the PSW Q bit to 1, if it was not already 1, is an
670+ * undefined operation.
671+ *
672+ * However, HP-UX 10.20 does this with the SSM instruction.
673+ * Tested this on HP9000/712 and HP9000/785/C3750 and both
674+ * machines set the Q bit from 0 to 1 without an exception,
675+ * so let this go without comment.
676+ */
673677 env->psw = (psw & ~PSW_SM) | (nsm & PSW_SM);
674678 return psw & PSW_SM;
675679 }