Commit 2271cf12 authored by Axel Lin's avatar Axel Lin Committed by Mark Brown

spi: coldfire-qspi: Prevent NULL pointer dereference

If pdata->cs_control is NULL, we will hit NULL pointer dereference in
mcfqspi_cs_select() and mcfqspi_cs_deselect(). Thus add NULL test for
pdata->cs_control in probe().
Signed-off-by: default avatarAxel Lin <axel.lin@ingics.com>
Signed-off-by: default avatarMark Brown <broonie@linaro.org>
parent 2aa237f4
...@@ -133,13 +133,13 @@ static void mcfqspi_cs_deselect(struct mcfqspi *mcfqspi, u8 chip_select, ...@@ -133,13 +133,13 @@ static void mcfqspi_cs_deselect(struct mcfqspi *mcfqspi, u8 chip_select,
static int mcfqspi_cs_setup(struct mcfqspi *mcfqspi) static int mcfqspi_cs_setup(struct mcfqspi *mcfqspi)
{ {
return (mcfqspi->cs_control && mcfqspi->cs_control->setup) ? return (mcfqspi->cs_control->setup) ?
mcfqspi->cs_control->setup(mcfqspi->cs_control) : 0; mcfqspi->cs_control->setup(mcfqspi->cs_control) : 0;
} }
static void mcfqspi_cs_teardown(struct mcfqspi *mcfqspi) static void mcfqspi_cs_teardown(struct mcfqspi *mcfqspi)
{ {
if (mcfqspi->cs_control && mcfqspi->cs_control->teardown) if (mcfqspi->cs_control->teardown)
mcfqspi->cs_control->teardown(mcfqspi->cs_control); mcfqspi->cs_control->teardown(mcfqspi->cs_control);
} }
...@@ -372,6 +372,11 @@ static int mcfqspi_probe(struct platform_device *pdev) ...@@ -372,6 +372,11 @@ static int mcfqspi_probe(struct platform_device *pdev)
return -ENOENT; return -ENOENT;
} }
if (!pdata->cs_control) {
dev_dbg(&pdev->dev, "pdata->cs_control is NULL\n");
return -EINVAL;
}
master = spi_alloc_master(&pdev->dev, sizeof(*mcfqspi)); master = spi_alloc_master(&pdev->dev, sizeof(*mcfqspi));
if (master == NULL) { if (master == NULL) {
dev_dbg(&pdev->dev, "spi_alloc_master failed\n"); dev_dbg(&pdev->dev, "spi_alloc_master failed\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment