/*
* Copyright (c) 2014 MediaTek Inc.
* Author: Flora Fu, MediaTek
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#ifndef _DT_BINDINGS_RESET_CONTROLLER_MT8173
#define _DT_BINDINGS_RESET_CONTROLLER_MT8173
/* INFRACFG resets */
#define MT8173_INFRA_EMI_REG_RST 0
#define MT8173_INFRA_DRAMC0_A0_RST 1
#define MT8173_INFRA_APCIRQ_EINT_RST 3
#define MT8173_INFRA_APXGPT_RST 4
#define MT8173_INFRA_SCPSYS_RST 5
#define MT8173_INFRA_KP_RST 6
#define MT8173_INFRA_PMIC_WRAP_RST 7
#define MT8173_INFRA_MPIP_RST 8
#define MT8173_INFRA_CEC_RST 9
#define MT8173_INFRA_EMI_RST 32
#define MT8173_INFRA_DRAMC0_RST 34
#define MT8173_INFRA_APMIXEDSYS_RST 35
#define MT8173_INFRA_MIPI_DSI_RST 36
#define MT8173_INFRA_TRNG_RST 37
#define MT8173_INFRA_SYSIRQ_RST 38
#define MT8173_INFRA_MIPI_CSI_RST 39
#define MT8173_INFRA_GCE_FAXI_RST 40
#define MT8173_INFRA_MMIOMMURST 47
/* PERICFG resets */
#define MT8173_PERI_UART0_SW_RST 0
#define MT8173_PERI_UART1_SW_RST 1
#define MT8173_PERI_UART2_SW_RST 2
#define MT8173_PERI_UART3_SW_RST 3
#define MT8173_PERI_IRRX_SW_RST 4
#define MT8173_PERI_PWM_SW_RST 8
#define MT8173_PERI_AUXADC_SW_RST 10
#define MT8173_PERI_DMA_SW_RST 11
#define MT8173_PERI_I2C6_SW_RST 13
#define MT8173_PERI_NFI_SW_RST 14
#define MT8173_PERI_THERM_SW_RST 16
#define MT8173_PERI_MSDC2_SW_RST 17
#define MT8173_PERI_MSDC3_SW_RST 18
#define MT8173_PERI_MSDC0_SW_RST 19
#define MT8173_PERI_MSDC1_SW_RST 20
#define MT8173_PERI_I2C0_SW_RST 22
#define MT8173_PERI_I2C1_SW_RST 23
#define MT8173_PERI_I2C2_SW_RST 24
#define MT8173_PERI_I2C3_SW_RST 25
#define MT8173_PERI_I2C4_SW_RST 26
#define MT8173_PERI_HDMI_SW_RST 29
#define MT8173_PERI_SPI0_SW_RST 33
#endif /* _DT_BINDINGS_RESET_CONTROLLER_MT8173 */
='grep'>log msg
Liam R. Howlett says:
====================
sparc64: Recover from userspace non-resumable PIO & MEM errors
A non-resumable error from userspace is able to cause a kernel panic or trap
loop due to the setup and handling of the queued traps once in the kernel.
This patch series addresses both of these issues.
The queues are fixed by simply zeroing the memory before use.
PIO errors from userspace will result in a SIGBUS being sent to the user
process.
The MEM errors form userspace will result in a SIGKILL and also cause the
offending pages to be claimed so they are no longer used in future tasks.
SIGKILL is used to ensure that the process does not try to coredump and result
in an attempt to read the memory again from within kernel space. Although
there is a HV call to scrub the memory (mem_scrub), there is no easy way to
guarantee that the real memory address(es) are not used by other tasks.
Clearing the error with mem_scrub would zero the memory and cause the other
processes to proceed with bad data.
The handling of other non-resumable errors remain unchanged and will cause a
panic.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ieee802154/6lowpan/core.c')