login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2008
»
August
»
14
Re: [PATCH 2.6.27] [POWERPC] Invalidate all TLB entries in a specified range
view
thread
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
[view in full thread]
From: Benjamin Herrenschmidt
Subject:
Re: [PATCH 2.6.27] [POWERPC] Invalidate all TLB entries in a specified range
Date: Thursday, August 14, 2008 - 3:28 pm
On Thu, 2008-08-14 at 07:11 -0600, Rocky Craig wrote:
quoted text
> From: Rocky Craig <rocky.craig@hp.com> > > The apparent intent of "flush_tlbs" is to invalidate TLB entries that > might match in the address range 0 to 0x00400000. A loop counter is > set up at the high value and decremented by page size. However, the > loop is only done once as the sense of the conditional branch at the > loop end does not match the setup/decrement. > > Signed-off-by: Rocky Craig <rocky.craig@hp.com> > --- > > Source is from 2.6.27 development, but the bug appears as far back as 2.4.0. > The small user-space program below demonstrates the loop behavior. It was > compiled via crosstool gcc 3.4.5 / glibc 2.3.6 for an MPC8347 target.
Heh nice, that's a bug as old as the port I would say :-) Ben.
quoted text
> int main() > { > long endval; // 16(r31) > > __asm__ __volatile__( > " lis 10,0x40\n" > "1: addic. 10,10,-0x1000\n" > " bgt 1b\n" > " stw 10,16(31)\n"); // endval > > printf("end value = 0x%08lx\n", endval); > } > > This might win the prize for "Smallest actual code patch ever". > > --- a/arch/powerpc/kernel/head_32.S.orig 2008-07-24 19:25:09.000000000 -0600 > +++ a/arch/powerpc/kernel/head_32.S 2008-07-24 19:25:22.000000000 -0600 > @@ -1155,7 +1155,7 @@ flush_tlbs: > lis r10, 0x40 > 1: addic. r10, r10, -0x1000 > tlbie r10 > - blt 1b > + bgt 1b > sync > blr > > >
--
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
Messages in current thread:
[PATCH 2.6.27] [POWERPC] Invalidate all TLB entries in a s ...
, Rocky Craig
, (Thu Aug 14, 6:11 am)
Re: [PATCH 2.6.27] [POWERPC] Invalidate all TLB entries in ...
, Benjamin Herrenschmidt
, (Thu Aug 14, 3:28 pm)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Fortier,Vincent [Montreal]
2.6.21.5 june 30th to july 1st date hang?
Jeff Dike
[ PATCH 2/6 ] UML - Formatting fixes around os_{read_write}_file callers
Liam Girdwood
[PATCH 07/13] regulator: regulator test harness
Oleg Nesterov
Re: Getting the new RxRPC patches upstream
Stefan Seyfried
Re: 2.6.19-rc5: grub is much slower resuming from suspend-to-disk than in 2.6.18
linux-netdev
:
Arnaud Ebalard
Re: [REGRESSION,BISECTED] MIPv6 support broken by f4f914b58019f0
Jan Engelhardt
Re: [PATCH iptables] extension: add xt_cpu match
Jarek Poplawski
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
Sebastian Andrzej Siewior
[PATCH 8/8] net/emergency: remove locking from reycling pool if emergncy pools are...
David Miller
Re: [PATCH] qlcnic: dont assume NET_IP_ALIGN is 2
git
:
Jakub Narebski
Re: git on MacOSX and files with decomposed utf-8 file names
Brandon Casey
Re: Thunderbird and patches (was Re: [PATCH v2] Enable setting attach as the def...
Christian Couder
[PATCH 1/3] rev-parse: add test script for "--verify"
Ramkumar Ramachandra
Re: [GSoC update] git-remote-svn: The final one
Junio C Hamano
Re: git-rm isn't the inverse action of git-add
openbsd-misc
:
Joachim Schipper
Re: UVC Webcams
Florin Andrei
SOLVED [was: firewall is very slow, something's wrong]
Todd Alan Smith
Re: Microsoft gets the Most Secure Operating Systems award
Neal Hogan
Re: Need Advice: Thinkpad T60 or T61?
Sam Fourman Jr.
Re: Real men don't attack straw men
git-commits-head
:
Linux Kernel Mailing List
ACPI: Disable ARB_DISABLE on platforms where it is not needed
Linux Kernel Mailing List
m68knommu: add read_barrier_depends() and irqs_disabled_flags()
Linux Kernel Mailing List
[MTD] Add mtd panic_write function pointer
Linux Kernel Mailing List
[ARM] pxa: remove duplicate select statements from Kconfig
Linux Kernel Mailing List
mlx4_core: Don't read reserved fields in mlx4_QUERY_ADAPTER()
Colocation donated by:
Syndicate