summaryrefslogtreecommitdiffstats
path: root/src/kernel/start.S
diff options
context:
space:
mode:
authorPatrick Williams <iawillia@us.ibm.com>2011-08-23 15:16:35 -0500
committerA. Patrick Williams III <iawillia@us.ibm.com>2011-08-31 13:39:51 -0500
commitf7b7b56dea28dd69a44a877f7b7073c4496ced9e (patch)
tree640fdb38b13df41c5f0835374033d53b21d163ca /src/kernel/start.S
parente6b1dcfdee1467cf7f43b64c8dddb87f13bf2f10 (diff)
downloadtalos-hostboot-f7b7b56dea28dd69a44a877f7b7073c4496ced9e.tar.gz
talos-hostboot-f7b7b56dea28dd69a44a877f7b7073c4496ced9e.zip
Ensure scratch operations happen on master core.
Change-Id: I970d645108de041d410599847edce877cb794015 Reviewed-on: http://gfw160.austin.ibm.com:8080/gerrit/275 Tested-by: Jenkins Server Reviewed-by: Daniel M. Crowell <dcrowell@us.ibm.com> Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/kernel/start.S')
-rw-r--r--src/kernel/start.S26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/kernel/start.S b/src/kernel/start.S
index 2bbe41184..332fe7796 100644
--- a/src/kernel/start.S
+++ b/src/kernel/start.S
@@ -401,14 +401,40 @@ system_call_fast_path:
3:
cmpi cr0, r3, 0x802
bne cr0, 4f
+ ;// Check for being on master processor.
+ mfsprg3 r6 ;// Get task structure.
+ ld r6, 0(r6) ;// Get CPU structure.
+ lbz r6, 12(r6) ;// Read master boolean.
+ cmpi cr0, r6, 0x0
+ beq cr0, 300f ;// Call TASK_MIGRATE_TO_MASTER if not on master.
+ ;// Read scratch.
mtspr 276, r4
isync
mfspr r3, 277
b 1f ;// Jump to exit point.
+ ;// Migrate task via TASK_MIGRATE_TO_MASTER
+300:
+ ;// Roll back NIA one instruction.
+ mfsrr0 r6
+ addi r6, r6, -4
+ mtsrr0 r6
+ ;// Move our syscall number to r6 (for TASK_MIGRATE_TO_MASTER handler).
+ mr r6, r3
+ ;// Set up TASK_MIGRATE_TO_MASTER syscall number.
+ li r3, 3
+ ;// Call back to syscall handler.
+ b intvect_system_call
;// Check if this is SCRATCH write (0x803).
4:
cmpi cr0, r3, 0x803
bne cr0, 5f
+ ;// Check for master processor.
+ mfsprg3 r6 ;// Get task structure.
+ ld r6, 0(r6) ;// Get CPU structure.
+ lbz r6, 12(r6) ;// Read master boolean.
+ cmpi cr0, r6, 0x0
+ beq cr0, 300b ;// Call TASK_MIGRATE_TO_MASTER if not on master.
+ ;// Write scratch.
mtspr 276, r4
isync
mtspr 277, r5
OpenPOWER on IntegriCloud