diff options
author | Patrick Williams <iawillia@us.ibm.com> | 2011-08-23 15:16:35 -0500 |
---|---|---|
committer | A. Patrick Williams III <iawillia@us.ibm.com> | 2011-08-31 13:39:51 -0500 |
commit | f7b7b56dea28dd69a44a877f7b7073c4496ced9e (patch) | |
tree | 640fdb38b13df41c5f0835374033d53b21d163ca /src/kernel/start.S | |
parent | e6b1dcfdee1467cf7f43b64c8dddb87f13bf2f10 (diff) | |
download | talos-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.S | 26 |
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 |