[Top] [All Lists]

[PATCH v2 0/3] Workaround the Out-of-order Issue of Loongson-2F

To: Ralf Baechle <>
Subject: [PATCH v2 0/3] Workaround the Out-of-order Issue of Loongson-2F
From: Wu Zhangjin <>
Date: Thu, 11 Mar 2010 11:05:01 +0800
Cc:, Sergei Shtylyov <>, Wu Zhangjin <>
Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed;; s=gamma; h=domainkey-signature:received:received:from:to:cc:subject:date :message-id:x-mailer:mime-version:content-type :content-transfer-encoding; bh=M+/1Nf6//C1Mhbr3obKmGo5Tb9r0JGT/4+1EJGzfUzM=; b=gdE2Hu8IlccXs0N8YhLoLiB+dE0aULgO0se/TcECOWenLfyTFO1SfCd/GuVo/kZKdn dVlQ8V05lHKvXP2izIzLZhNXA+98VOOxxaoJbKL2yTwvyvbMz5dUDWWEJmDc4kNo55Td 2vkPTbrLCQK0f1vtUdePA8d+VxbIA9t7q7qrM=
Domainkey-signature: a=rsa-sha1; c=nofws;; s=gamma; h=from:to:cc:subject:date:message-id:x-mailer:mime-version :content-type:content-transfer-encoding; b=cPuE2CLki/9FS0Mn2cQs5Q+hIrD2EuZT1JR4hJEMxSXyl5KQImtG2/EuNb3MFAn/xi zilN3gL3/euCbri3scmBwa5WcUfQufa3/eD++arGgcugAS3hRw1jyamh4NqevDFUiEZW 729AZ5F4bLT4UQI6FlICTlO6otIdQpEesGvrg=
Original-recipient: rfc822;
From: Wu Zhangjin <>

Changes from old version:

  o Cleanup some comments and align some instructions.

As the Chapter 15: "Errata: Issue of Out-of-order in loongson"[1] shows, to
workaround the Issue of Loongson-2F,We need to do:

  o When switching from user model to kernel model, you should flush the branch
  target history such as BTB and RAS.
  o Doing some tricks to the indirect branch target to make sure that the
  indirect branch target can not be in the I/O region.

This patchset applied the above methods and for the binutils patch[3] have been
merged into binutils 2.20.1, so, it's time to upstream this patchset now.
without this patch, the machines will hang when the instruction sequence hit
the Out-of-order Issue of Loongson-2F, therefore, this patchset is very urgent
for both 2.6.33 and 2.6.34.

[1] Chinese Version:
[2] English Version of Chapter 15:

        Wu Zhangjin

Wu Zhangjin (3):
  Loongson-2F: Flush the branch target history such as BTB and RAS
  Loongson-2F: Enable fixups of binutils 2.20.1
  Loongson-2F: Fixup of problems introduced by -mfix-loongson2f-jump of
    binutils 2.20.1

 arch/mips/Makefile                 |    4 +++-
 arch/mips/include/asm/stackframe.h |   19 +++++++++++++++++++
 arch/mips/loongson/common/reset.c  |   11 ++++++++++-
 3 files changed, 32 insertions(+), 2 deletions(-)

<Prev in Thread] Current Thread [Next in Thread>