Re: [PATCH net-next 1/3] soc: fsl_qbman: use be16_to_cpu() in qm_sg_entry_get_off()

2024-10-30 Thread Breno Leitao
icted __be32 > warning: cast from restricted __be16 > > Signed-off-by: Vladimir Oltean Reviewed-by: Breno Leitao

Re: [PATCH net-next 3/3] net: dpaa_eth: extract hash using __be32 pointer in rx_default_dqrr()

2024-10-30 Thread Breno Leitao
tion. Suppress the > warning by using the correct __be32 type instead of u32. No functional > change. > > Signed-off-by: Vladimir Oltean Reviewed-by: Breno Leitao

Re: [PATCH net-next 5/5] soc: fsl: qbman: FSL_DPAA depends on COMPILE_TEST

2024-07-12 Thread Breno Leitao
On Fri, Jul 12, 2024 at 03:14:00PM +0300, Vladimir Oltean wrote: > On Thu, Jul 11, 2024 at 02:00:25AM +0300, Vladimir Oltean wrote: > > From: Breno Leitao > > > > As most of the drivers that depend on ARCH_LAYERSCAPE, make FSL_DPAA > > depend on COMPILE_TEST

Re: [PATCH net-next 1/5] net: dpaa: avoid on-stack arrays of NR_CPUS elements

2024-07-11 Thread Breno Leitao
up in stack > consumption with generic, as opposed to hand-crafted, .config files. > > A simple solution is to use dynamic allocation for num_possible_cpus() > elements (aka a small number determined at runtime). > > Link: https://lore.kernel.org/all/202406261920.l5pzm1rj-.

Re: [PATCH 1/4] soc: fsl: qbman: FSL_DPAA depends on COMPILE_TEST

2024-07-09 Thread Breno Leitao
Hello Vladimir, On Tue, Jul 09, 2024 at 04:58:11PM +0300, Vladimir Oltean wrote: > On Mon, Jul 08, 2024 at 12:08:05PM -0700, Breno Leitao wrote: > > I thought about a patch like the following (compile tested only). What > > do you think? > > To be honest, there are several

Re: [PATCH 1/4] soc: fsl: qbman: FSL_DPAA depends on COMPILE_TEST

2024-07-08 Thread Breno Leitao
Hello Vladimir, On Mon, Jul 08, 2024 at 04:37:46PM +0300, Vladimir Oltean wrote: > On Thu, Jun 27, 2024 at 11:40:24AM -0700, Breno Leitao wrote: > > > > 454 | static int dpaa_set_coalesce(struct net_device *dev, > > > > |^ >

Re: [PATCH 3/4] crypto: caam: Unembed net_dev structure from qi

2024-07-02 Thread Breno Leitao
Hello Simon, On Fri, Jun 28, 2024 at 05:32:26PM +0100, Simon Horman wrote: > On Mon, Jun 24, 2024 at 09:21:21AM -0700, Breno Leitao wrote: > > @@ -530,6 +530,7 @@ static void caam_qi_shutdown(void *data) > > > > if (kill_fq(qidev, per_cpu(

Re: [PATCH 1/4] soc: fsl: qbman: FSL_DPAA depends on COMPILE_TEST

2024-06-27 Thread Breno Leitao
Hello Vladimir, On Wed, Jun 26, 2024 at 05:06:23PM +0300, Vladimir Oltean wrote: > On Wed, Jun 26, 2024 at 08:09:53PM +0800, kernel test robot wrote: > > All warnings (new ones prefixed by >>): > > > > >> drivers/net/ethernet/freescale/dpaa/dpaa_eth.c:3280:12: warning: stack > > >> frame size (

[PATCH 4/4] crypto: caam: Unembed net_dev structure in dpaa2

2024-06-24 Thread Breno Leitao
alloc_netdev_dummy() to allocate the net_device object at dpaa2_dpseci_setup(). The free of the device occurs at dpaa2_dpseci_disable(). Link: https://lore.kernel.org/all/20240229225910.79e22...@kernel.org/ [1] Signed-off-by: Breno Leitao --- PS: Unfortunately due to lack of hardware, this was not

[PATCH 3/4] crypto: caam: Unembed net_dev structure from qi

2024-06-24 Thread Breno Leitao
alloc_netdev_dummy() to allocate the net_device object at caam_qi_init(). The free of the device occurs at caam_qi_shutdown(). Link: https://lore.kernel.org/all/20240229225910.79e22...@kernel.org/ [1] Signed-off-by: Breno Leitao --- PS: Unfortunately due to lack of hardware, this was not tested in real

[PATCH 1/4] soc: fsl: qbman: FSL_DPAA depends on COMPILE_TEST

2024-06-24 Thread Breno Leitao
As most of the drivers that depend on ARCH_LAYERSCAPE, make FSL_DPAA depend on COMPILE_TEST for compilation and testing. # grep -r depends.\*ARCH_LAYERSCAPE.\*COMPILE_TEST | wc -l 29 Signed-off-by: Breno Leitao --- drivers/soc/fsl/qbman/Kconfig | 2 +- 1 file changed, 1

[PATCH 2/4] crypto: caam: Depend on COMPILE_TEST also

2024-06-24 Thread Breno Leitao
As most of the drivers that depend on ARCH_LAYERSCAPE, make CRYPTO_DEV_FSL_CAAM depend on COMPILE_TEST for compilation and testing. # grep -r depends.\*ARCH_LAYERSCAPE.\*COMPILE_TEST | wc -l 29 Signed-off-by: Breno Leitao --- drivers/crypto/caam/Kconfig | 2 +- 1 file changed, 1

Re: [PATCH] powerpc/rtas: Prevent Spectre v1 gadget construction in sys_rtas()

2024-05-31 Thread Breno Leitao
On Fri, May 31, 2024 at 11:45:48AM -0500, Nathan Lynch wrote: > Breno Leitao writes: > > > On Thu, May 30, 2024 at 07:44:12PM -0500, Nathan Lynch via B4 Relay wrote: > >> From: Nathan Lynch > >> + nargs = array_index_nospec(nargs, ARRAY_SIZE(args.args)); > >

Re: [PATCH] powerpc/rtas: Prevent Spectre v1 gadget construction in sys_rtas()

2024-05-31 Thread Breno Leitao
peculative execution. > > Signed-off-by: Nathan Lynch > Reported-by: Breno Leitao Thanks for working on it. Reviewed-by: Breno Leitao > + nargs = array_index_nospec(nargs, ARRAY_SIZE(args.args)); > + nret = array_index_nospec(nret, ARRAY_SIZE(args.args) - nargs); On an

Re: [PATCH] powerpc/kernel: Fix potential spectre v1 in syscall

2024-03-12 Thread Breno Leitao
On Tue, Mar 12, 2024 at 10:07:54PM +1100, Michael Ellerman wrote: > Breno Leitao writes: > > On Tue, Mar 12, 2024 at 08:17:42AM +, Christophe Leroy wrote: > >> +Nathan as this is RTAS related. > >> > >> Le 21/08/2018 à 20:42, Breno Leitao a écrit : > &

Re: [PATCH] powerpc/kernel: Fix potential spectre v1 in syscall

2024-03-12 Thread Breno Leitao
On Tue, Mar 12, 2024 at 08:17:42AM +, Christophe Leroy wrote: > +Nathan as this is RTAS related. > > Le 21/08/2018 à 20:42, Breno Leitao a écrit : > > The rtas syscall reads a value from a user-provided structure and uses it > > to index an array, being a possible area fo

Re: [PATCH linux-next] crypto: nx: remove redundant variable rc

2022-08-31 Thread Breno Leitao
On Wed, Aug 31, 2022 at 02:02:48PM +, cgel@gmail.com wrote: > From: Jinpeng Cui > > Return value directly from set_msg_len() instead of > getting value from redundant variable rc. > > Reported-by: Zeal Robot > Signed-off-by: Jinpeng Cui Reviewed-by: Breno Leit

[PATCH V2] powerpc/ptrace: Mitigate potential Spectre v1

2019-01-30 Thread Breno Leitao
ps://marc.info/?l=linux-kernel&m=152449131114778&w=2 Signed-off-by: Breno Leitao --- arch/powerpc/kernel/ptrace.c | 8 +++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/arch/powerpc/kernel/ptrace.c b/arch/powerpc/kernel/ptrace.c index cdd5d1d3ae41..7535f89e08cd 10

Re: [PATCH] powerpc/ptrace: Mitigate potential Spectre v1

2019-01-29 Thread Breno Leitao
Hi Gustavo, On 1/24/19 3:25 PM, Gustavo A. R. Silva wrote: > > > On 1/24/19 8:01 AM, Breno Leitao wrote: >> 'regno' is directly controlled by user space, hence leading to a potential >> exploitation of the Spectre variant 1 vulnerability. >> >> On

[PATCH] powerpc/ptrace: Mitigate potential Spectre v1

2019-01-24 Thread Breno Leitao
ps://marc.info/?l=linux-kernel&m=152449131114778&w=2 Signed-off-by: Breno Leitao --- arch/powerpc/kernel/ptrace.c | 5 + 1 file changed, 5 insertions(+) diff --git a/arch/powerpc/kernel/ptrace.c b/arch/powerpc/kernel/ptrace.c index cdd5d1d3ae41..3eac38a29863 100644 --- a/arch/

[PATCH] Selftests/powerpc: Add a signal fuzzer selftest

2019-01-17 Thread Breno Leitao
options. This test does not check if the user context is being read and set properly by the kernel. Its purpose, at this time, is basically guaranteeing that the kernel does not crash on invalid scenarios. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/harness.c | 6

Re: [PATCH] powerpc/tm: Limit TM code inside PPC_TRANSACTIONAL_MEM

2019-01-17 Thread Breno Leitao
hi Sasha, On 1/16/19 11:35 AM, Sasha Levin wrote: > Hi, > > [This is an automated email] > > This commit has been processed because it contains a "Fixes:" tag, > fixing commit: e1c3743e1a20 powerpc/tm: Set MSR[TS] just prior to > recheckpoint. > > The bot has tested the following trees: v4.20.

[PATCH] powerpc/tm: Avoid machine crash on rt_sigreturn

2019-01-16 Thread Breno Leitao
s->msr will be replaced by the ucontext value, so, it is being flushed already. In this case, it is flushed earlier. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/signal_64.c | 27 ++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/arch/powerpc/kern

[PATCH] powerpc/tm: Limit TM code inside PPC_TRANSACTIONAL_MEM

2019-01-09 Thread Breno Leitao
kernel.org Reported-by: Christoph Biedl Fixes: e1c3743e1a20 ("powerpc/tm: Set MSR[TS] just prior to recheckpoint") Signed-off-by: Breno Leitao --- NB: Since stable kernels didn't cherry picked 5c784c8414fba ('powerpc/tm: Remove msr_tm_active()), MSR_TM_ACTIVE() is not defined as

Re: [PATCH v3 1/2] selftests/powerpc: Add MSR bits

2019-01-08 Thread Breno Leitao
On 1/8/19 9:14 AM, Christophe Leroy wrote: > Le 08/01/2019 à 12:11, Breno Leitao a écrit : >> Hi Michael, >> >> On 1/8/19 7:20 AM, Michael Ellerman wrote: >>> Breno Leitao writes: >>> >>>> hi Christophe, >>>> >>>

[PATCH v4] selftests/powerpc: New TM signal self test

2019-01-08 Thread Breno Leitao
res, causing the test to segfault, which is undesired because the test needs to rerun, so, there is a signal handler for SIGSEGV which will restart the test. v2: Uses the MADV_DONTNEED memory advice v3: Fix memcpy and 32-bits compilation v4: Does not define unused macros Signed-off-by: Breno Lei

Re: [PATCH v3 1/2] selftests/powerpc: Add MSR bits

2019-01-08 Thread Breno Leitao
Hi Michael, On 1/8/19 7:20 AM, Michael Ellerman wrote: > Breno Leitao writes: > >> hi Christophe, >> >> On 1/3/19 3:19 PM, LEROY Christophe wrote: >>> Breno Leitao a écrit : >>> >>>> This patch simply adds definitions for the

Re: [PATCH v3 1/2] selftests/powerpc: Add MSR bits

2019-01-07 Thread Breno Leitao
hi Christophe, On 1/7/19 10:47 AM, Christophe Leroy wrote: > Hi Breno, > > Le 07/01/2019 à 13:44, Breno Leitao a écrit : >> hi Christophe, >> >> On 1/3/19 3:19 PM, LEROY Christophe wrote: >>> Breno Leitao a écrit : >>> >>>> This patch si

Re: [PATCH v3 1/2] selftests/powerpc: Add MSR bits

2019-01-07 Thread Breno Leitao
hi Christophe, On 1/3/19 3:19 PM, LEROY Christophe wrote: > Breno Leitao a écrit : > >> This patch simply adds definitions for the MSR bits and some macros to >> test for MSR TM bits. >> >> This was copied from arch/powerpc/include/asm/reg.h generic MSR part. >

[PATCH v3 2/2] selftests/powerpc: New TM signal self test

2019-01-03 Thread Breno Leitao
res, causing the test to segfault, which is undesired because the test needs to rerun, so, there is a signal handler for SIGSEGV which will restart the test. v2: Uses the MADV_DONTNEED memory advice v3: Fix memcpy and 32-bits compilation Signed-off-by: Breno Leitao --- .../testing/selftests/powe

[PATCH v3 1/2] selftests/powerpc: Add MSR bits

2019-01-03 Thread Breno Leitao
This patch simply adds definitions for the MSR bits and some macros to test for MSR TM bits. This was copied from arch/powerpc/include/asm/reg.h generic MSR part. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/include/reg.h | 45 +++ 1 file changed, 45

Re: [PATCH] selftests/powerpc: New TM signal self test

2019-01-03 Thread Breno Leitao
Hi Michael, On 12/20/18 10:51 AM, Michael Ellerman wrote: > Breno Leitao writes: > >> A new self test that forces MSR[TS] to be set without calling any TM >> instruction. This test also tries to cause a page fault at a signal >> handler, exactly between MSR[TS]

Re: [PATCH] selftests/powerpc: New TM signal self test

2018-12-04 Thread Breno Leitao
Hi Mikey, On 11/29/18 12:11 AM, Michael Neuling wrote: > On Wed, 2018-11-28 at 11:23 -0200, Breno Leitao wrote: >> A new self test that forces MSR[TS] to be set without calling any TM >> instruction. This test also tries to cause a page fault at a signal >> handler, exactl

[PATCH] selftests/powerpc: New TM signal self test

2018-11-28 Thread Breno Leitao
the test. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/tm/.gitignore | 1 + tools/testing/selftests/powerpc/tm/Makefile | 3 +- .../powerpc/tm/tm-signal-force-msr.c | 115 ++ 3 files changed, 118 insertions(+), 1 deletion(-) create mode 100644 to

Re: [PATCH] powerpc/mm/hash: Hand user access of kernel address gracefully

2018-11-27 Thread Breno Leitao
t? (uid: 1000) > [ 225.100938] a.out[6067]: segfault (11) at c000dea0 nip > c000dea0 lr 129d507b0 code 1 > [ 225.100943] a.out[6067]: Bad NIP, not dumping instructions. > > Fixes: 2865d08dd9ea ("powerpc/mm: Move the DSISR_PROTFAULT sanity check

[PATCH 4/4] selftests/powerpc: Add checks for transactional sigreturn

2018-11-26 Thread Breno Leitao
handle this discrepancy instead of crashing. This code could be compiled and used to test 32 and 64-bits signal handlers. Signed-off-by: Breno Leitao Signed-off-by: Gustavo Romero --- tools/testing/selftests/powerpc/tm/.gitignore | 1 + tools/testing/selftests/powerpc/tm/Makefile | 2

[PATCH 3/4] powerpc/tm: Unset MSR[TS] if not recheckpointing

2018-11-26 Thread Breno Leitao
->msr[TS] should be zeroed. This patch also fixes a sparse warning related to lack of indentation when CONFIG_PPC_TRANSACTIONAL_MEM is set. Fixes: 2b0a576d15e0e ("powerpc: Add new transactional memory state to the signal context") CC: Stable # 3.10+ Signed-off-by: Breno Leitao ---

[PATCH 2/4] powerpc/tm: Print scratch value

2018-11-26 Thread Breno Leitao
transition that is causing the exception. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/traps.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/arch/powerpc/kernel/traps.c b/arch/powerpc/kernel/traps.c index 9a86572db1ef..00af2c4febf4 100644 --- a/arch/powerpc/kernel

[PATCH 1/4] powerpc/tm: Save MSR to PACA before RFID

2018-11-26 Thread Breno Leitao
As other exit points, move SRR1 (MSR) into paca->tm_scratch, so, if there is a TM Bad Thing in RFID, it is easy to understand what was the SRR1 value being used. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/entry_64.S | 4 1 file changed, 4 insertions(+) diff --git a/arch/powe

[PATCH] powerpc/pseries/cpuidle: Fix preempt warning

2018-11-23 Thread Breno Leitao
debug_smp_processor_id() call at get_paca(), instead of calling preempt_disable() before get_paca(). Signed-off-by: Breno Leitao --- drivers/cpuidle/cpuidle-pseries.c | 7 ++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/cpuidle/cpuidle-pseries.c b/drivers/cpuidle/cpuidle-pseries.c

Re: [PATCH] powerpc/tm: Set MSR[TS] just prior to recheckpoint

2018-11-22 Thread Breno Leitao
Hi Mikey, On 11/21/18 8:42 PM, Michael Neuling wrote: >> Do you mean in this part of code? >> >> SYSCALL_DEFINE0(rt_sigreturn) >> { >> >> if (__copy_from_user(&set, &uc->uc_sigmask, sizeof(set))) >> goto badframe; >> >> ... >> if (MSR_TM_SUSPENDED

[PATCH v2] powerpc/tm: Set MSR[TS] just prior to recheckpoint

2018-11-21 Thread Breno Leitao
tion in this chunk of code. Changes from v2: * Run the critical section with preempt_disable. Fixes: 87b4e5393af7 ("powerpc/tm: Fix return of active 64bit signals") Cc: sta...@vger.kernel.org (v3.9+) Signed-off-by: Breno Leitao diff --git a/arch/powerpc/kernel/signal_32.c b/arch/powerpc/ke

Re: [PATCH] powerpc/tm: Set MSR[TS] just prior to recheckpoint

2018-11-21 Thread Breno Leitao
hi Michael, On 11/20/18 8:34 AM, Michael Ellerman wrote: > Hi Breno, > > Thanks for chasing this one down. > > Breno Leitao writes: > >> On a signal handler return, the user could set a context with MSR[TS] bits >> set, and these bits would be copi

Re: [PATCH] powerpc/tm: Set MSR[TS] just prior to recheckpoint

2018-11-21 Thread Breno Leitao
hi Mikey, On 11/19/18 9:30 PM, Michael Neuling wrote: > On Mon, 2018-11-19 at 10:44 -0200, Breno Leitao wrote: >> On a signal handler return, the user could set a context with MSR[TS] bits >> set, and these bits would be copied to task regs->msr. >> >> At restore_t

[PATCH] powerpc/tm: Set MSR[TS] just prior to recheckpoint

2018-11-19 Thread Breno Leitao
pc/tm: Fix return of active 64bit signals") Cc: sta...@vger.kernel.org (v3.9+) Signed-off-by: Breno Leitao --- arch/powerpc/kernel/signal_64.c | 29 +++-- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/arch/powerpc/kernel/signal_64.c b/arch/powerpc/ke

Re: [PATCH] powerpc: Add KVM guest defconfig

2018-11-09 Thread Breno Leitao
hi Satheesh, On 11/09/2018 07:59 AM, Satheesh Rajendran wrote: > On Thu, Nov 08, 2018 at 04:23:07PM -0200, Breno Leitao wrote: >> hi Satheesh, >> >> On 11/08/2018 03:08 AM, sathn...@linux.vnet.ibm.com wrote: >>> --- /dev/null >>> +++ b/arch/powerpc

Re: [PATCH] powerpc: Add KVM guest defconfig

2018-11-08 Thread Breno Leitao
hi Satheesh, On 11/08/2018 03:08 AM, sathn...@linux.vnet.ibm.com wrote: > --- /dev/null > +++ b/arch/powerpc/configs/guest.config > @@ -0,0 +1,14 @@ > +CONFIG_VIRTIO_BLK=y > +CONFIG_VIRTIO_BLK_SCSI=y > +CONFIG_SCSI_VIRTIO=y > +CONFIG_VIRTIO_NET=y > +CONFIG_NET_FAILOVER=y > +CONFIG_VIRTIO_CONSOLE=y

[PATCH] powerpc/xmon: Fix invocation inside lock region

2018-11-08 Thread Breno Leitao
time. This would allow xmon to be possible invoked independent of devtree_lock being held or not. Signed-off-by: Breno Leitao --- arch/powerpc/xmon/xmon.c | 18 ++ 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/arch/powerpc/xmon/xmon.c b/arch/powerpc/xmon/xmon.c i

Re: [PATCH] powerpc: Mark variable `cpumsr` as unused

2018-11-08 Thread Breno Leitao
Hi Mathieu, Christophe Thanks for spotting and fixing this bug. On 11/08/2018 05:25 AM, Mathieu Malaterre wrote: > On Thu, Nov 8, 2018 at 7:09 AM Christophe Leroy > wrote: >> >> >> >> On 11/07/2018 08:26 PM, Mathieu Malaterre wrote: >>> Add gcc attribute unused for `cpumsr` variable. >>> >>> Fi

Re: [RFC PATCH v2 00/14] New TM Model

2018-11-06 Thread Breno Leitao
hi Florian, On 11/06/2018 04:32 PM, Florian Weimer wrote: > * Breno Leitao: > >> This patchset for the hardware transactional memory (TM) subsystem >> aims to avoid spending a lot of time on TM suspended mode in kernel >> space. It basically changes where the recl

[RFC PATCH 14/14] selftests/powerpc: Adapt tm-syscall test to no suspend

2018-11-06 Thread Breno Leitao
ssume that a syscall inside a suspended transaction will not be doomed, because kernel entrace will doom any suspended transaction now on. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/tm/tm-syscall.c | 6 -- 1 file changed, 6 deletions(-) diff --git a/tools/testing/selftes

[RFC PATCH 13/14] powerpc/tm: Do not restore TM without SPRs

2018-11-06 Thread Breno Leitao
rrent TM SPR from previous thread will be saved on the current thread, and might not have TEXASR[FS] set, for example. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/signal_64.c | 12 +++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/arch/powerpc/kernel/signal_64.c b

[RFC PATCH 12/14] powerpc/tm: Restore transactional SPRs

2018-11-06 Thread Breno Leitao
AMR, PPR, VRSAVE, VSCR, DSCR, and TAR. This patch only cares about PPR, TAR and DSCR, because others SPRS either volatiles, restored as part of facilities or not being handled currently as AMR/CRs. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/asm-offsets.c | 4 arch/powerpc/kernel/

[RFC PATCH 11/14] powerpc/tm: Save MSR to PACA before RFID

2018-11-06 Thread Breno Leitao
As other exit points, move SRR1 (MSR) into paca->tm_scratch, so, if there is a TM Bad Thing in RFID, it is easy to understand what was the SRR1 value being used. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/entry_64.S | 4 1 file changed, 4 insertions(+) diff --git a/arch/powe

[RFC PATCH 10/14] powerpc/tm: Improve TM debug information

2018-11-06 Thread Breno Leitao
Add some debug information into the TM subsystem. When enable, now it prints when there is a reclaim, recheckpoint or lazy TM disabling. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/process.c | 10 +- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/arch/powerpc

[RFC PATCH 09/14] powerpc/tm: Warn if state is transactional

2018-11-06 Thread Breno Leitao
Since every kernel entrance is calling TM_KERNEL_ENTRY, it is not expected to arrive at this point with a suspended transaction. If that is the case, cause a warning and reclaim the current thread in order to avoid a TM Bad Thing. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/process.c

[RFC PATCH 08/14] powerpc/tm: Recheckpoint at exit path

2018-11-06 Thread Breno Leitao
only way to do so. Signed-off-by: Breno Leitao --- arch/powerpc/include/asm/thread_info.h | 2 +- arch/powerpc/kernel/entry_64.S | 23 ++- 2 files changed, 15 insertions(+), 10 deletions(-) diff --git a/arch/powerpc/include/asm/thread_info.h b/arch/powerpc/include

[RFC PATCH 07/14] powerpc/tm: Do not reclaim on ptrace

2018-11-06 Thread Breno Leitao
Make sure that we are not suspended on ptrace and that the registers were already reclaimed. Since the data was already reclaimed, there is nothing to be done here except to restore the SPRs. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/ptrace.c | 16 +--- 1 file changed, 13

[RFC PATCH 05/14] powerpc/tm: Refactor the __switch_to_tm code

2018-11-06 Thread Breno Leitao
ugh if the task had TM enabled when it was de-scheduled. (Checking if a recheckpoint would be required will be done later, at restore_tm_state() stage.) On top of that, both tm_reclaim_task() and tm_recheckpoint_new_task() functions are not used anymore, removing them. Signed-off-by: Breno Le

[RFC PATCH 06/14] powerpc/tm: Do not recheckpoint at sigreturn

2018-11-06 Thread Breno Leitao
calling it is restore_tm_state(). Signed-off-by: Breno Leitao --- arch/powerpc/kernel/signal_32.c | 38 + arch/powerpc/kernel/signal_64.c | 30 -- 2 files changed, 19 insertions(+), 49 deletions(-) diff --git a/arch/powerpc/kernel/signal_32

[RFC PATCH 04/14] powerpc/tm: Always set TIF_RESTORE_TM on reclaim

2018-11-06 Thread Breno Leitao
task has TIF_RESTORE_TM tag set every time there is a reclaim, so, a recheckpoint will be executed later. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/process.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c index

[RFC PATCH 03/14] powerpc/tm: Recheckpoint when exiting from kernel

2018-11-06 Thread Breno Leitao
. the MSR will be the same that will be put into SRR1, which will be the MSR after RFID. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/process.c | 38 --- 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/arch/powerpc/kernel/process.c b/arch

[RFC PATCH 02/14] powerpc/tm: Reclaim on unavailable exception

2018-11-06 Thread Breno Leitao
in the exception entrance, and it will be recheckpointed by restore_tm_state later. Adding a WARN_ON() warning if we hit the _unavailable_tm() in suspended mode, i.e, the reclaim was not executed somehow in the trap entrance, and this is a bug. Signed-off-by: Breno Leitao --- arch/powerpc

[RFC PATCH 01/14] powerpc/tm: Reclaim transaction on kernel entry

2018-11-06 Thread Breno Leitao
r3 register, to specify if a reclaim was executed or not. This patchset is based on initial work done by Cyril: https://patchwork.ozlabs.org/cover/875341/ Signed-off-by: Breno Leitao --- arch/powerpc/include/asm/exception-64s.h | 46 arch/powerpc/kernel/entry_64.S

[RFC PATCH v2 00/14] New TM Model

2018-11-06 Thread Breno Leitao
n kernel entrance or exit path. tm_reclaim() is only called by TM_KERNEL_ENTRY and tm_recheckpoint is only called by restore_tm_state(). All the rest causes a warning. Regards, Breno [1] Documentation/powerpc/transactional_memory.txt [2] commit 4bb3c7a0208fc13ca70598efd109901a7cd45ae7 [3]

[PATCH] powerpc/mm: remove unused function prototype

2018-11-01 Thread Breno Leitao
Commit f384796c40dc ("powerpc/mm: Add support for handling > 512TB address in SLB miss") removed function slb_miss_bad_addr(struct pt_regs *regs), but kept its declaration in the prototype file. This patch simply removes the function definition. Signed-off-by: Breno Leitao ---

Re: [PATCH] selftests/powerpc: Fix compilation issue due to asm label

2018-10-31 Thread Breno Leitao
are being able to build again. I also tested the rfi_flush_test selftest as other tests (ptrace/ and tm/) and everything seems to be normal again. Thank you! >> Reported-by: Breno Leitao >> Signed-off-by: Naveen N. Rao Tested-by: Breno Leitao

Re: [PATCH 3/9] powerpc/mm: Remove extern from function definition

2018-10-31 Thread Breno Leitao
Hi Christophe, On 10/24/18 12:12 PM, LEROY Christophe wrote: > Breno Leitao a écrit : > >> hi Christophe, >> >> On 10/23/2018 12:38 PM, LEROY Christophe wrote: >>> Breno Leitao a écrit : >>>> >>>> This patch removes the keyword

[PATCH v2 3/3] selftests/powerpc: Skip test instead of failing

2018-10-31 Thread Breno Leitao
undesired failure. CC: Tyrel Datwyler CC: Thiago Jung Bauermann Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/ptrace/core-pkey.c | 5 + 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/tools/testing/selftests/powerpc/ptrace/core-pkey.c b/tools/testing/selftests

[PATCH v2 2/3] selftests/powerpc: Create a new SKIP_IF macro

2018-10-31 Thread Breno Leitao
This patch creates a new macro that skips a test and prints a message to stderr. This is useful to give an idea why the tests is being skipped, other than just skipping the test blindly. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/include/utils.h | 10 ++ 1 file

[PATCH v2 1/3] selftests/powerpc: Allocate base registers

2018-10-31 Thread Breno Leitao
. Signed-off-by: Breno Leitao Reviewed-by: Segher Boessenkool --- tools/testing/selftests/powerpc/ptrace/ptrace-gpr.c| 2 +- tools/testing/selftests/powerpc/ptrace/ptrace-tm-gpr.c | 4 ++-- tools/testing/selftests/powerpc/ptrace/ptrace-tm-spd-tar.c | 2 +- tools/testing/selftests/powerpc

[PATCH v2] powerpc/mm: Remove extern from function definition

2018-10-31 Thread Breno Leitao
c/mm/pgtable.c:232:12: warning: function 'huge_ptep_set_access_flags' with external linkage has definition This patch removes the keyword from the definition part. It also removes the extern keyword from the declaration part, since checkpatch --strict complains about it. Suggested-by: Chris

Re: [PATCH 3/9] powerpc/mm: Remove extern from function definition

2018-10-24 Thread Breno Leitao
hi Christophe, On 10/23/2018 12:38 PM, LEROY Christophe wrote: > Breno Leitao a écrit : >> >> This patch removes the keyword from the definition part, while keeps >> it in >> the declaration part. > > I think checkpatch also says that extern should be avoided

Re: [PATCH 2/2] selftests/powerpc: Skip test instead of failing

2018-10-24 Thread Breno Leitao
Hi Tyrel, On 10/23/2018 05:41 PM, Tyrel Datwyler wrote: >> --- a/tools/testing/selftests/powerpc/ptrace/core-pkey.c >> +++ b/tools/testing/selftests/powerpc/ptrace/core-pkey.c >> @@ -352,17 +352,11 @@ static int write_core_pattern(const char *core_pattern) >> FILE *f; >> >> f = fopen(cor

[PATCH 2/2] selftests/powerpc: Skip test instead of failing

2018-10-23 Thread Breno Leitao
undesired failure. CC: Thiago Jung Bauermann Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/ptrace/core-pkey.c | 10 ++ 1 file changed, 2 insertions(+), 8 deletions(-) diff --git a/tools/testing/selftests/powerpc/ptrace/core-pkey.c b/tools/testing/selftests/powerpc/ptrace

[PATCH 1/2] selftests/powerpc: Allocate base registers

2018-10-23 Thread Breno Leitao
tests. Signed-off-by: Breno Leitao --- tools/testing/selftests/powerpc/ptrace/ptrace-gpr.c| 2 +- tools/testing/selftests/powerpc/ptrace/ptrace-tm-gpr.c | 4 ++-- tools/testing/selftests/powerpc/ptrace/ptrace-tm-spd-tar.c | 2 +- tools/testing/selftests/powerpc/ptrace/ptrace-tm-spd-vsx.c

[PATCH] selftests/powerpc: Fix ptrace tm failure

2018-10-22 Thread Breno Leitao
hich specify that this register will be used as base, and r0 is not allowed to be used, avoiding this issue. Other than that, removing flt_2 register from the input operands, since it is not used by the inline assembly code at all. Cc: sta...@vger.kernel.org Signed-off-by: Breno Leitao --- tool

[PATCH 4/9] powerpc/xive: Define xive_do_source_eoi as static

2018-10-22 Thread Breno Leitao
nto static. Signed-off-by: Breno Leitao --- arch/powerpc/sysdev/xive/common.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/powerpc/sysdev/xive/common.c b/arch/powerpc/sysdev/xive/common.c index 959a2a62f233..6a6178357529 100644 --- a/arch/powerpc/sysdev/xive/common.c

[PATCH 2/9] powerpc/eeh: Declare pci_ers_result_name() as static

2018-10-22 Thread Breno Leitao
clares the function a static. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/eeh_driver.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/powerpc/kernel/eeh_driver.c b/arch/powerpc/kernel/eeh_driver.c index 67619b4b3f96..c325dedfee73 100644 --- a/arch/powerpc/kernel/ee

[PATCH 9/9] powerpc/pkey: Define functions as static

2018-10-22 Thread Breno Leitao
ss_permitted' was not declared. Should it be static? This patch fix al the warning, basically turning all global variables that are not declared as extern at asm/pkeys.h into static. It also includes asm/mmu_context.h header, which contains the definition of arch_vma_access_permitted. Signed

[PATCH 8/9] powerpc/perf: Declare static identifier a such

2018-10-22 Thread Breno Leitao
dds the 'static' storage-class definition to these symbols, thus, restricting their usage only in the imc-pmu.c file. Signed-off-by: Breno Leitao --- arch/powerpc/perf/imc-pmu.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/arch/powerpc/perf/imc-pmu.c b/arch/p

[PATCH 6/9] powerpc/lib: Declare static methods

2018-10-22 Thread Breno Leitao
arch/powerpc/lib/feature-fixups.c:171:6: warning: symbol 'do_stf_exit_barrier_fixups' was not declared. Should it be static? This patch declares both functions as static, as they are only called by do_stf_barrier_fixups(), which is in the same source code file. Signed-off-by: Bre

[PATCH 7/9] powerpc/scom: Return NULL instead of 0

2018-10-22 Thread Breno Leitao
as NULL pointer arch/powerpc/sysdev/scom.c:86:24: warning: Using plain integer as NULL pointer This patch simply replaces zero by NULL. Signed-off-by: Breno Leitao --- arch/powerpc/sysdev/scom.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/arch/powerpc/sysde

[PATCH 5/9] powerpc/xmon: Define static functions

2018-10-22 Thread Breno Leitao
rcu_dereference() instead of a straightforward dereference. Signed-off-by: Breno Leitao --- arch/powerpc/xmon/xmon.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/arch/powerpc/xmon/xmon.c b/arch/powerpc/xmon/xmon.c index 4264aedc7775..5c7187923a72 100644 --- a/arch/

[PATCH 1/9] powerpc/64s: Include cpu header

2018-10-22 Thread Breno Leitao
kernel/security.c:289:9: warning: symbol 'cpu_show_spec_store_bypass' was not declared. Should it be static? This patch simply includes the proper header (linux/cpu.h) to match function definition and declaration. Signed-off-by: Breno Leitao --- arch/powerpc/kernel/security.c | 1 + 1 file

[PATCH 3/9] powerpc/mm: Remove extern from function definition

2018-10-22 Thread Breno Leitao
c/mm/pgtable.c:232:12: warning: function 'huge_ptep_set_access_flags' with external linkage has definition This patch removes the keyword from the definition part, while keeps it in the declaration part. Signed-off-by: Breno Leitao --- arch/powerpc/mm/pgtable.c | 2 +- 1 file changed, 1 insert

[PATCH] selftests/powerpc: Add check for TM SPRS on coredump

2018-10-03 Thread Breno Leitao
-by: Breno Leitao Signed-off-by: Gustavo Romero --- tools/testing/selftests/powerpc/tm/Makefile | 3 +- tools/testing/selftests/powerpc/tm/tm-core.c | 480 +++ tools/testing/selftests/powerpc/tm/tm.h | 4 + 3 files changed, 486 insertions(+), 1 deletion(-) create mode

[PATCH 2/2] powerpc/tm: Avoid SPR flush if TM is disabled

2018-10-01 Thread Breno Leitao
SPRs, otherwise, the TM is lazily disabled and the thread value is already up-to-date and could be used directly, and saving is not required. Fixes: cd63f3cf1d5 ("powerpc/tm: Fix saving of TM SPRs in core dump") Signed-off-by: Breno Leitao --- arch/powerpc/kernel/ptrace.c | 7 +

[PATCH 1/2] powerpc/tm: Move tm_enable definition

2018-10-01 Thread Breno Leitao
ned-off-by: Breno Leitao --- arch/powerpc/include/asm/tm.h | 5 + arch/powerpc/kernel/process.c | 5 - arch/powerpc/kernel/traps.c | 5 - 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/arch/powerpc/include/asm/tm.h b/arch/powerpc/include/asm/tm.h index e94f6db5e367..64

Re: [RFC PATCH 11/11] selftests/powerpc: Adapt the test

2018-10-01 Thread Breno Leitao
Hi Mikey, On 09/28/2018 02:25 AM, Michael Neuling wrote: >> Perfect, and if the transaction fail, the CPU will rollback the changes and >> restore the checkpoint registers (replacing the r3 that contains the pid >> value), thus, it will be like "getpid" system call didn't execute. > > No. If we

Re: [RFC PATCH 08/11] powerpc/tm: Do not reclaim on ptrace

2018-09-30 Thread Breno Leitao
Hi Mikey, On 09/28/2018 02:36 AM, Michael Neuling wrote: + WARN_ON(MSR_TM_SUSPENDED(mfmsr())); + + tm_enable(); + tm_save_sprs(&(tsk->thread)); >>> >>> Do we need to check if TM was enabled in the task before saving the >>> TM SPRs? >>> >>> What happens if TM was lazily off and hence

Re: [RFC PATCH 08/11] powerpc/tm: Do not reclaim on ptrace

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/18/2018 02:36 AM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> Make sure that we are not suspended on ptrace and that the registers were >> already reclaimed. >> >> Since the data was already reclaimed, there

Re: [RFC PATCH 05/11] powerpc/tm: Function that updates the failure code

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/17/2018 10:29 PM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> Now the transaction reclaims happens very earlier in the trap handler, and >> it is impossible to know precisely, at that early time, what should be set >> as

Re: [RFC PATCH 11/11] selftests/powerpc: Adapt the test

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/18/2018 03:36 AM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> The Documentation/powerpc/transactional_memory.txt says: >> >> "Syscalls made from within a suspended transaction are performed as normal >&

Re: [RFC PATCH 10/11] powerpc/tm: Set failure summary

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/18/2018 02:50 AM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> Since the transaction will be doomed with treckpt., the TEXASR[FS] >> should be set, to reflect that the transaction is a failure. This patch >> ensures it b

Re: [RFC PATCH 09/11] powerpc/tm: Do not restore default DSCR

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/18/2018 02:41 AM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> In the previous TM code, trecheckpoint was being executed in the middle of >> an exception, thus, DSCR was being restored to default kernel DSCR value >> af

Re: [RFC PATCH 06/11] powerpc/tm: Refactor the __switch_to_tm code

2018-09-27 Thread Breno Leitao
hi Mikey On 09/18/2018 01:04 AM, Michael Neuling wrote: >> On top of that, both tm_reclaim_task() and tm_recheckpoint_new_task() >> functions are not used anymore, removing them. > > What about tm_reclaim_current(). This is being used in places like signals > which I would have thought we could

Re: [RFC PATCH 01/11] powerpc/tm: Reclaim transaction on kernel entry

2018-09-27 Thread Breno Leitao
Hi Mikey, On 09/17/2018 10:31 PM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> This patch creates a macro that will be invoked on all entrance to the >> kernel, so, in kernel space the transaction will be completely reclaimed >> and

Re: [RFC PATCH 00/11] New TM Model

2018-09-27 Thread Breno Leitao
Hi Mikey, First of all, thanks for you detailed review. I really appreciate your comments here. On 09/17/2018 02:25 AM, Michael Neuling wrote: > On Wed, 2018-09-12 at 16:40 -0300, Breno Leitao wrote: >> This patchset for the hardware transactional memory (TM) subsystem aims to >>

Re: [PATCH] powerpc/tm: Fix userspace r13 corruption

2018-09-25 Thread Breno Leitao
Hi Mikey, On 09/25/2018 02:24 AM, Michael Neuling wrote: > On Mon, 2018-09-24 at 11:32 -0300, Breno Leitao wrote: >> Hi Mikey, >> >> On 09/24/2018 04:27 AM, Michael Neuling wrote: >>> When we treclaim we store the userspace checkpointed r13 to a scratch >>>

  1   2   >