ARM: SoC fixes
A few fixes who have come in near or during the merge window: - Removal of a VLA usage in Marvell mpp platform code - Enable some IPMI options for ARM64 servers by default, helps testing - Enable PREEMPT on 32-bit ARMv7 defconfig - Minor fix for stm32 DT (removal of an unused DMA property) - Bugfix for TI OMAP1-based ams-delta (-EINVAL -> IRQ_NOTCONNECTED) -----BEGIN PGP SIGNATURE----- iQJDBAABCAAtFiEElf+HevZ4QCAJmMQ+jBrnPN6EHHcFAlvd6+YPHG9sb2ZAbGl4 b20ubmV0AAoJEIwa5zzehBx3xwUP/j3AFLgK7HPGzDHy6hqVBuezXaOtkMFDbfmS quIpp60zoellKREIGQag06VI44IMtetfJpcLe6GFNAtBNg7ofQ4/H3jq4eFqP+Gd abJC/iSzP86UKnAGoexkEQ4CxzYb+q6Okv3yBROWptFfvfDE9wyeKdl6SoSPYuvy yZPmZdq2HguvjWfKz7BLGvr6nzMdwwj1MpvqsSS3xLCiQTBSq1VVgKyCSWin67r2 FiD1I+c37WNaJQP0eQ+Eu6mCc++jK3cdHPAp6LzmJ7YNVOqPCwU2KroY/DKLhz3v oanKJENFlyNOunzdd2SuoM7TyFgo7rHDR1sQgKCbcLu3D32dPYg4T8+jr1xa3hRs CFLFj9JKl6grZK1sIB35blmZ+6DJ7WfN1SRwD7tfvRM8UNxCUEs/5/Pf2ySU2cGx k2ZiP2D+VS+eX41bZTiuJZOyX2Wsyis8TWTjCy8eT6uM1V4Zt4qiXigQW8qFg4RC ta3Y2rUxjk8FZCV1I4mrIwkqsSL47fWuxtVxDnJP4tkA5HuVS+NJj8aneAYyJKiY N6Gk1U8IJN40psk8OU7fwYUjJ6vhOgKxNo1nl7vf26Ddwl1fFsDHvFKgh9UmVDN5 boRSs+62AZVLTDdIpkz6hWSVPUO4lysi7n2Gi+qFjVifyE5TLH7ncSMZk6fbnLLI v90sz43w =mr8i -----END PGP SIGNATURE----- Merge tag 'armsoc-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc Pull ARM SoC fixes from Olof Johansson: "A few fixes who have come in near or during the merge window: - Removal of a VLA usage in Marvell mpp platform code - Enable some IPMI options for ARM64 servers by default, helps testing - Enable PREEMPT on 32-bit ARMv7 defconfig - Minor fix for stm32 DT (removal of an unused DMA property) - Bugfix for TI OMAP1-based ams-delta (-EINVAL -> IRQ_NOTCONNECTED)" * tag 'armsoc-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: ARM: dts: stm32: update HASH1 dmas property on stm32mp157c ARM: orion: avoid VLA in orion_mpp_conf ARM: defconfig: Update multi_v7 to use PREEMPT arm64: defconfig: Enable some IPMI configs soc: ti: QMSS: Fix usage of irq_set_affinity_hint ARM: OMAP1: ams-delta: Fix impossible .irq < 0
This commit is contained in:
commit
d2ff0ff2c2
|
@ -923,7 +923,7 @@
|
||||||
interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
clocks = <&rcc HASH1>;
|
clocks = <&rcc HASH1>;
|
||||||
resets = <&rcc HASH1_R>;
|
resets = <&rcc HASH1_R>;
|
||||||
dmas = <&mdma1 31 0x10 0x1000A02 0x0 0x0 0x0>;
|
dmas = <&mdma1 31 0x10 0x1000A02 0x0 0x0>;
|
||||||
dma-names = "in";
|
dma-names = "in";
|
||||||
dma-maxburst = <2>;
|
dma-maxburst = <2>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_NO_HZ=y
|
CONFIG_NO_HZ=y
|
||||||
CONFIG_HIGH_RES_TIMERS=y
|
CONFIG_HIGH_RES_TIMERS=y
|
||||||
|
CONFIG_PREEMPT=y
|
||||||
CONFIG_CGROUPS=y
|
CONFIG_CGROUPS=y
|
||||||
CONFIG_BLK_DEV_INITRD=y
|
CONFIG_BLK_DEV_INITRD=y
|
||||||
CONFIG_EMBEDDED=y
|
CONFIG_EMBEDDED=y
|
||||||
|
|
|
@ -773,7 +773,7 @@ static struct plat_serial8250_port ams_delta_modem_ports[] = {
|
||||||
{
|
{
|
||||||
.membase = IOMEM(MODEM_VIRT),
|
.membase = IOMEM(MODEM_VIRT),
|
||||||
.mapbase = MODEM_PHYS,
|
.mapbase = MODEM_PHYS,
|
||||||
.irq = -EINVAL, /* changed later */
|
.irq = IRQ_NOTCONNECTED, /* changed later */
|
||||||
.flags = UPF_BOOT_AUTOCONF,
|
.flags = UPF_BOOT_AUTOCONF,
|
||||||
.irqflags = IRQF_TRIGGER_RISING,
|
.irqflags = IRQF_TRIGGER_RISING,
|
||||||
.iotype = UPIO_MEM,
|
.iotype = UPIO_MEM,
|
||||||
|
@ -864,8 +864,7 @@ static int __init modem_nreset_init(void)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function expects MODEM IRQ number already assigned to the port
|
* This function expects MODEM IRQ number already assigned to the port.
|
||||||
* and fails if it's not.
|
|
||||||
* The MODEM device requires its RESET# pin kept high during probe.
|
* The MODEM device requires its RESET# pin kept high during probe.
|
||||||
* That requirement can be fulfilled in several ways:
|
* That requirement can be fulfilled in several ways:
|
||||||
* - with a descriptor of already functional modem_nreset regulator
|
* - with a descriptor of already functional modem_nreset regulator
|
||||||
|
@ -888,9 +887,6 @@ static int __init ams_delta_modem_init(void)
|
||||||
if (!machine_is_ams_delta())
|
if (!machine_is_ams_delta())
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if (ams_delta_modem_ports[0].irq < 0)
|
|
||||||
return ams_delta_modem_ports[0].irq;
|
|
||||||
|
|
||||||
omap_cfg_reg(M14_1510_GPIO2);
|
omap_cfg_reg(M14_1510_GPIO2);
|
||||||
|
|
||||||
/* Initialize the modem_nreset regulator consumer before use */
|
/* Initialize the modem_nreset regulator consumer before use */
|
||||||
|
|
|
@ -28,10 +28,15 @@ void __init orion_mpp_conf(unsigned int *mpp_list, unsigned int variant_mask,
|
||||||
unsigned int mpp_max, void __iomem *dev_bus)
|
unsigned int mpp_max, void __iomem *dev_bus)
|
||||||
{
|
{
|
||||||
unsigned int mpp_nr_regs = (1 + mpp_max/8);
|
unsigned int mpp_nr_regs = (1 + mpp_max/8);
|
||||||
u32 mpp_ctrl[mpp_nr_regs];
|
u32 mpp_ctrl[8];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
printk(KERN_DEBUG "initial MPP regs:");
|
printk(KERN_DEBUG "initial MPP regs:");
|
||||||
|
if (mpp_nr_regs > ARRAY_SIZE(mpp_ctrl)) {
|
||||||
|
printk(KERN_ERR "orion_mpp_conf: invalid mpp_max\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < mpp_nr_regs; i++) {
|
for (i = 0; i < mpp_nr_regs; i++) {
|
||||||
mpp_ctrl[i] = readl(mpp_ctrl_addr(i, dev_bus));
|
mpp_ctrl[i] = readl(mpp_ctrl_addr(i, dev_bus));
|
||||||
printk(" %08x", mpp_ctrl[i]);
|
printk(" %08x", mpp_ctrl[i]);
|
||||||
|
|
|
@ -308,6 +308,9 @@ CONFIG_SERIAL_XILINX_PS_UART_CONSOLE=y
|
||||||
CONFIG_SERIAL_MVEBU_UART=y
|
CONFIG_SERIAL_MVEBU_UART=y
|
||||||
CONFIG_SERIAL_DEV_BUS=y
|
CONFIG_SERIAL_DEV_BUS=y
|
||||||
CONFIG_VIRTIO_CONSOLE=y
|
CONFIG_VIRTIO_CONSOLE=y
|
||||||
|
CONFIG_IPMI_HANDLER=m
|
||||||
|
CONFIG_IPMI_DEVICE_INTERFACE=m
|
||||||
|
CONFIG_IPMI_SI=m
|
||||||
CONFIG_TCG_TPM=y
|
CONFIG_TCG_TPM=y
|
||||||
CONFIG_TCG_TIS_I2C_INFINEON=y
|
CONFIG_TCG_TIS_I2C_INFINEON=y
|
||||||
CONFIG_I2C_CHARDEV=y
|
CONFIG_I2C_CHARDEV=y
|
||||||
|
|
|
@ -330,7 +330,7 @@ struct knav_range_ops {
|
||||||
|
|
||||||
struct knav_irq_info {
|
struct knav_irq_info {
|
||||||
int irq;
|
int irq;
|
||||||
u32 cpu_map;
|
struct cpumask *cpu_mask;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct knav_range_info {
|
struct knav_range_info {
|
||||||
|
|
|
@ -205,18 +205,18 @@ static int knav_range_setup_acc_irq(struct knav_range_info *range,
|
||||||
{
|
{
|
||||||
struct knav_device *kdev = range->kdev;
|
struct knav_device *kdev = range->kdev;
|
||||||
struct knav_acc_channel *acc;
|
struct knav_acc_channel *acc;
|
||||||
unsigned long cpu_map;
|
struct cpumask *cpu_mask;
|
||||||
int ret = 0, irq;
|
int ret = 0, irq;
|
||||||
u32 old, new;
|
u32 old, new;
|
||||||
|
|
||||||
if (range->flags & RANGE_MULTI_QUEUE) {
|
if (range->flags & RANGE_MULTI_QUEUE) {
|
||||||
acc = range->acc;
|
acc = range->acc;
|
||||||
irq = range->irqs[0].irq;
|
irq = range->irqs[0].irq;
|
||||||
cpu_map = range->irqs[0].cpu_map;
|
cpu_mask = range->irqs[0].cpu_mask;
|
||||||
} else {
|
} else {
|
||||||
acc = range->acc + queue;
|
acc = range->acc + queue;
|
||||||
irq = range->irqs[queue].irq;
|
irq = range->irqs[queue].irq;
|
||||||
cpu_map = range->irqs[queue].cpu_map;
|
cpu_mask = range->irqs[queue].cpu_mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
old = acc->open_mask;
|
old = acc->open_mask;
|
||||||
|
@ -239,8 +239,8 @@ static int knav_range_setup_acc_irq(struct knav_range_info *range,
|
||||||
acc->name, acc->name);
|
acc->name, acc->name);
|
||||||
ret = request_irq(irq, knav_acc_int_handler, 0, acc->name,
|
ret = request_irq(irq, knav_acc_int_handler, 0, acc->name,
|
||||||
range);
|
range);
|
||||||
if (!ret && cpu_map) {
|
if (!ret && cpu_mask) {
|
||||||
ret = irq_set_affinity_hint(irq, to_cpumask(&cpu_map));
|
ret = irq_set_affinity_hint(irq, cpu_mask);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_warn(range->kdev->dev,
|
dev_warn(range->kdev->dev,
|
||||||
"Failed to set IRQ affinity\n");
|
"Failed to set IRQ affinity\n");
|
||||||
|
|
|
@ -118,19 +118,17 @@ static int knav_queue_setup_irq(struct knav_range_info *range,
|
||||||
struct knav_queue_inst *inst)
|
struct knav_queue_inst *inst)
|
||||||
{
|
{
|
||||||
unsigned queue = inst->id - range->queue_base;
|
unsigned queue = inst->id - range->queue_base;
|
||||||
unsigned long cpu_map;
|
|
||||||
int ret = 0, irq;
|
int ret = 0, irq;
|
||||||
|
|
||||||
if (range->flags & RANGE_HAS_IRQ) {
|
if (range->flags & RANGE_HAS_IRQ) {
|
||||||
irq = range->irqs[queue].irq;
|
irq = range->irqs[queue].irq;
|
||||||
cpu_map = range->irqs[queue].cpu_map;
|
|
||||||
ret = request_irq(irq, knav_queue_int_handler, 0,
|
ret = request_irq(irq, knav_queue_int_handler, 0,
|
||||||
inst->irq_name, inst);
|
inst->irq_name, inst);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
disable_irq(irq);
|
disable_irq(irq);
|
||||||
if (cpu_map) {
|
if (range->irqs[queue].cpu_mask) {
|
||||||
ret = irq_set_affinity_hint(irq, to_cpumask(&cpu_map));
|
ret = irq_set_affinity_hint(irq, range->irqs[queue].cpu_mask);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_warn(range->kdev->dev,
|
dev_warn(range->kdev->dev,
|
||||||
"Failed to set IRQ affinity\n");
|
"Failed to set IRQ affinity\n");
|
||||||
|
@ -1262,9 +1260,19 @@ static int knav_setup_queue_range(struct knav_device *kdev,
|
||||||
|
|
||||||
range->num_irqs++;
|
range->num_irqs++;
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_SMP) && oirq.args_count == 3)
|
if (IS_ENABLED(CONFIG_SMP) && oirq.args_count == 3) {
|
||||||
range->irqs[i].cpu_map =
|
unsigned long mask;
|
||||||
(oirq.args[2] & 0x0000ff00) >> 8;
|
int bit;
|
||||||
|
|
||||||
|
range->irqs[i].cpu_mask = devm_kzalloc(dev,
|
||||||
|
cpumask_size(), GFP_KERNEL);
|
||||||
|
if (!range->irqs[i].cpu_mask)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
mask = (oirq.args[2] & 0x0000ff00) >> 8;
|
||||||
|
for_each_set_bit(bit, &mask, BITS_PER_LONG)
|
||||||
|
cpumask_set_cpu(bit, range->irqs[i].cpu_mask);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
range->num_irqs = min(range->num_irqs, range->num_queues);
|
range->num_irqs = min(range->num_irqs, range->num_queues);
|
||||||
|
|
Loading…
Reference in New Issue