STi c8sectpfe device is only used on B2120 boards, which support has
been withdrawn in commit dee546e1adef ("ARM: sti: drop B2120 board
support").
Signed-off-by: Raphael Gallais-Pou <rgallaispou@gmail.com>
---
MAINTAINERS | 1 -
drivers/media/platform/st/Makefile | 1 -
drivers/media/platform/st/sti/Kconfig | 1 -
drivers/media/platform/st/sti/Makefile | 1 -
drivers/media/platform/st/sti/c8sectpfe/Kconfig | 28 -
drivers/media/platform/st/sti/c8sectpfe/Makefile | 11 -
.../platform/st/sti/c8sectpfe/c8sectpfe-common.c | 262 -----
.../platform/st/sti/c8sectpfe/c8sectpfe-common.h | 60 -
.../platform/st/sti/c8sectpfe/c8sectpfe-core.c | 1158 --------------------
.../platform/st/sti/c8sectpfe/c8sectpfe-core.h | 287 -----
.../platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c | 244 -----
.../platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h | 23 -
.../platform/st/sti/c8sectpfe/c8sectpfe-dvb.c | 235 ----
.../platform/st/sti/c8sectpfe/c8sectpfe-dvb.h | 17 -
14 files changed, 2329 deletions(-)
diff --git a/MAINTAINERS b/MAINTAINERS
index 7b7396ed28a700a2aab318553ce8ba1788312bff..ed5bc86ec5638ed6e0635b8ce0120f8f27435ff0 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -3413,7 +3413,6 @@ F: drivers/clocksource/clksrc_st_lpc.c
F: drivers/cpufreq/sti-cpufreq.c
F: drivers/dma/st_fdma*
F: drivers/i2c/busses/i2c-st.c
-F: drivers/media/platform/st/sti/c8sectpfe/
F: drivers/media/rc/st_rc.c
F: drivers/mmc/host/sdhci-st.c
F: drivers/phy/st/phy-miphy28lp.c
diff --git a/drivers/media/platform/st/Makefile b/drivers/media/platform/st/Makefile
index a1f75b2a822583c931f2696e3fffd7981d87917b..615a93d62662105c51af076345da7f3bdc86227c 100644
--- a/drivers/media/platform/st/Makefile
+++ b/drivers/media/platform/st/Makefile
@@ -1,7 +1,6 @@
# SPDX-License-Identifier: GPL-2.0-only
obj-y += sti/bdisp/
-obj-y += sti/c8sectpfe/
obj-y += sti/delta/
obj-y += sti/hva/
obj-y += stm32/
diff --git a/drivers/media/platform/st/sti/Kconfig b/drivers/media/platform/st/sti/Kconfig
index 60068e8b47b8651e0c2e64121441faef9061933c..91ca0950ff7308d9414d75bfbb2a0e815e7a2104 100644
--- a/drivers/media/platform/st/sti/Kconfig
+++ b/drivers/media/platform/st/sti/Kconfig
@@ -1,5 +1,4 @@
# SPDX-License-Identifier: GPL-2.0-only
source "drivers/media/platform/st/sti/bdisp/Kconfig"
-source "drivers/media/platform/st/sti/c8sectpfe/Kconfig"
source "drivers/media/platform/st/sti/delta/Kconfig"
source "drivers/media/platform/st/sti/hva/Kconfig"
diff --git a/drivers/media/platform/st/sti/Makefile b/drivers/media/platform/st/sti/Makefile
index f9ce8169b0404cef2a7de8f1c7377f8abe511829..3328d50fb6cf2ed2daae2c0640a6596fdd140be5 100644
--- a/drivers/media/platform/st/sti/Makefile
+++ b/drivers/media/platform/st/sti/Makefile
@@ -1,6 +1,5 @@
# SPDX-License-Identifier: GPL-2.0-only
obj-y += bdisp/
-obj-y += c8sectpfe/
obj-y += delta/
obj-y += hva/
obj-y += stm32/
diff --git a/drivers/media/platform/st/sti/c8sectpfe/Kconfig b/drivers/media/platform/st/sti/c8sectpfe/Kconfig
deleted file mode 100644
index 01c33d9c9ec37ddc9dfc94991e2e9d3b720111e7..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/Kconfig
+++ /dev/null
@@ -1,28 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only
-config DVB_C8SECTPFE
- tristate "STMicroelectronics C8SECTPFE DVB support"
- depends on DVB_PLATFORM_DRIVERS
- depends on PINCTRL && DVB_CORE && I2C
- depends on ARCH_STI || ARCH_MULTIPLATFORM || COMPILE_TEST
- select FW_LOADER
- select DVB_LNBP21 if MEDIA_SUBDRV_AUTOSELECT
- select DVB_STV090x if MEDIA_SUBDRV_AUTOSELECT
- select DVB_STB6100 if MEDIA_SUBDRV_AUTOSELECT
- select DVB_STV6110 if MEDIA_SUBDRV_AUTOSELECT
- select DVB_STV0900 if MEDIA_SUBDRV_AUTOSELECT
- select DVB_STV0367 if MEDIA_SUBDRV_AUTOSELECT
- select MEDIA_TUNER_TDA18212 if MEDIA_SUBDRV_AUTOSELECT
-
- help
- This adds support for DVB front-end cards connected
- to TS inputs of STiH407/410 SoC.
-
- The driver currently supports C8SECTPFE's TS input block,
- memdma engine, and HW PID filtering.
-
- Supported DVB front-end cards are:
- - STMicroelectronics DVB-T B2100A (STV0367 + TDA18212)
- - STMicroelectronics DVB-S/S2 STV0903 + STV6110 + LNBP24 board
-
- To compile this driver as a module, choose M here: the
- module will be called c8sectpfe.
diff --git a/drivers/media/platform/st/sti/c8sectpfe/Makefile b/drivers/media/platform/st/sti/c8sectpfe/Makefile
deleted file mode 100644
index 99425137ee0a9e48b997d62215d4378075024c69..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/Makefile
+++ /dev/null
@@ -1,11 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0
-c8sectpfe-y += c8sectpfe-core.o c8sectpfe-common.o c8sectpfe-dvb.o
-
-ifneq ($(CONFIG_DEBUG_FS),)
-c8sectpfe-y += c8sectpfe-debugfs.o
-endif
-
-obj-$(CONFIG_DVB_C8SECTPFE) += c8sectpfe.o
-
-ccflags-y += -I $(srctree)/drivers/media/dvb-frontends/
-ccflags-y += -I $(srctree)/drivers/media/tuners/
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c
deleted file mode 100644
index 5df67da25525cbfec8b5890fdd626f634408a6f0..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c
+++ /dev/null
@@ -1,262 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * c8sectpfe-common.c - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author: Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#include <linux/completion.h>
-#include <linux/delay.h>
-#include <linux/device.h>
-#include <linux/dvb/dmx.h>
-#include <linux/errno.h>
-#include <linux/init.h>
-#include <linux/interrupt.h>
-#include <linux/io.h>
-#include <linux/ioport.h>
-#include <linux/module.h>
-#include <linux/slab.h>
-#include <linux/time.h>
-#include <linux/wait.h>
-
-#include <media/dmxdev.h>
-#include <media/dvbdev.h>
-#include <media/dvb_demux.h>
-#include <media/dvb_frontend.h>
-#include <media/dvb_net.h>
-
-#include "c8sectpfe-common.h"
-#include "c8sectpfe-core.h"
-#include "c8sectpfe-dvb.h"
-
-static int register_dvb(struct stdemux *demux, struct dvb_adapter *adap,
- void *start_feed, void *stop_feed,
- struct c8sectpfei *fei)
-{
- int result;
-
- demux->dvb_demux.dmx.capabilities = DMX_TS_FILTERING |
- DMX_SECTION_FILTERING |
- DMX_MEMORY_BASED_FILTERING;
-
- demux->dvb_demux.priv = demux;
- demux->dvb_demux.filternum = C8SECTPFE_MAXCHANNEL;
- demux->dvb_demux.feednum = C8SECTPFE_MAXCHANNEL;
-
- demux->dvb_demux.start_feed = start_feed;
- demux->dvb_demux.stop_feed = stop_feed;
- demux->dvb_demux.write_to_decoder = NULL;
-
- result = dvb_dmx_init(&demux->dvb_demux);
- if (result < 0) {
- dev_err(fei->dev, "dvb_dmx_init failed (errno = %d)\n",
- result);
- goto err_dmx;
- }
-
- demux->dmxdev.filternum = demux->dvb_demux.filternum;
- demux->dmxdev.demux = &demux->dvb_demux.dmx;
- demux->dmxdev.capabilities = 0;
-
- result = dvb_dmxdev_init(&demux->dmxdev, adap);
- if (result < 0) {
- dev_err(fei->dev, "dvb_dmxdev_init failed (errno = %d)\n",
- result);
-
- goto err_dmxdev;
- }
-
- demux->hw_frontend.source = DMX_FRONTEND_0 + demux->tsin_index;
-
- result = demux->dvb_demux.dmx.add_frontend(&demux->dvb_demux.dmx,
- &demux->hw_frontend);
- if (result < 0) {
- dev_err(fei->dev, "add_frontend failed (errno = %d)\n", result);
- goto err_fe_hw;
- }
-
- demux->mem_frontend.source = DMX_MEMORY_FE;
- result = demux->dvb_demux.dmx.add_frontend(&demux->dvb_demux.dmx,
- &demux->mem_frontend);
- if (result < 0) {
- dev_err(fei->dev, "add_frontend failed (%d)\n", result);
- goto err_fe_mem;
- }
-
- result = demux->dvb_demux.dmx.connect_frontend(&demux->dvb_demux.dmx,
- &demux->hw_frontend);
- if (result < 0) {
- dev_err(fei->dev, "connect_frontend (%d)\n", result);
- goto err_fe_con;
- }
-
- return 0;
-
-err_fe_con:
- demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
- &demux->mem_frontend);
-err_fe_mem:
- demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
- &demux->hw_frontend);
-err_fe_hw:
- dvb_dmxdev_release(&demux->dmxdev);
-err_dmxdev:
- dvb_dmx_release(&demux->dvb_demux);
-err_dmx:
- return result;
-
-}
-
-static void unregister_dvb(struct stdemux *demux)
-{
-
- demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
- &demux->mem_frontend);
-
- demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
- &demux->hw_frontend);
-
- dvb_dmxdev_release(&demux->dmxdev);
-
- dvb_dmx_release(&demux->dvb_demux);
-}
-
-static struct c8sectpfe *c8sectpfe_create(struct c8sectpfei *fei,
- void *start_feed,
- void *stop_feed)
-{
- struct c8sectpfe *c8sectpfe;
- int result;
- int i, j;
-
- short int ids[] = { -1 };
-
- c8sectpfe = kzalloc(sizeof(struct c8sectpfe), GFP_KERNEL);
- if (!c8sectpfe)
- goto err1;
-
- mutex_init(&c8sectpfe->lock);
-
- c8sectpfe->device = fei->dev;
-
- result = dvb_register_adapter(&c8sectpfe->adapter, "STi c8sectpfe",
- THIS_MODULE, fei->dev, ids);
- if (result < 0) {
- dev_err(fei->dev, "dvb_register_adapter failed (errno = %d)\n",
- result);
- goto err2;
- }
-
- c8sectpfe->adapter.priv = fei;
-
- for (i = 0; i < fei->tsin_count; i++) {
-
- c8sectpfe->demux[i].tsin_index = i;
- c8sectpfe->demux[i].c8sectpfei = fei;
-
- result = register_dvb(&c8sectpfe->demux[i], &c8sectpfe->adapter,
- start_feed, stop_feed, fei);
- if (result < 0) {
- dev_err(fei->dev,
- "register_dvb feed=%d failed (errno = %d)\n",
- result, i);
-
- /* we take a all or nothing approach */
- for (j = 0; j < i; j++)
- unregister_dvb(&c8sectpfe->demux[j]);
- goto err3;
- }
- }
-
- c8sectpfe->num_feeds = fei->tsin_count;
-
- return c8sectpfe;
-err3:
- dvb_unregister_adapter(&c8sectpfe->adapter);
-err2:
- kfree(c8sectpfe);
-err1:
- return NULL;
-};
-
-static void c8sectpfe_delete(struct c8sectpfe *c8sectpfe)
-{
- int i;
-
- if (!c8sectpfe)
- return;
-
- for (i = 0; i < c8sectpfe->num_feeds; i++)
- unregister_dvb(&c8sectpfe->demux[i]);
-
- dvb_unregister_adapter(&c8sectpfe->adapter);
-
- kfree(c8sectpfe);
-};
-
-void c8sectpfe_tuner_unregister_frontend(struct c8sectpfe *c8sectpfe,
- struct c8sectpfei *fei)
-{
- int n;
- struct channel_info *tsin;
-
- for (n = 0; n < fei->tsin_count; n++) {
-
- tsin = fei->channel_data[n];
-
- if (tsin) {
- if (tsin->frontend) {
- dvb_unregister_frontend(tsin->frontend);
- dvb_frontend_detach(tsin->frontend);
- }
-
- i2c_put_adapter(tsin->i2c_adapter);
-
- if (tsin->i2c_client) {
- module_put(tsin->i2c_client->dev.driver->owner);
- i2c_unregister_device(tsin->i2c_client);
- }
- }
- }
-
- c8sectpfe_delete(c8sectpfe);
-};
-
-int c8sectpfe_tuner_register_frontend(struct c8sectpfe **c8sectpfe,
- struct c8sectpfei *fei,
- void *start_feed,
- void *stop_feed)
-{
- struct channel_info *tsin;
- struct dvb_frontend *frontend;
- int n, res;
-
- *c8sectpfe = c8sectpfe_create(fei, start_feed, stop_feed);
- if (!*c8sectpfe)
- return -ENOMEM;
-
- for (n = 0; n < fei->tsin_count; n++) {
- tsin = fei->channel_data[n];
-
- res = c8sectpfe_frontend_attach(&frontend, *c8sectpfe, tsin, n);
- if (res)
- goto err;
-
- res = dvb_register_frontend(&c8sectpfe[0]->adapter, frontend);
- if (res < 0) {
- dev_err(fei->dev, "dvb_register_frontend failed (%d)\n",
- res);
- goto err;
- }
-
- tsin->frontend = frontend;
- }
-
- return 0;
-
-err:
- c8sectpfe_tuner_unregister_frontend(*c8sectpfe, fei);
- return res;
-}
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h
deleted file mode 100644
index f8d97841f366e32d1087d135bdda8edbb14c1399..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h
+++ /dev/null
@@ -1,60 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/*
- * c8sectpfe-common.h - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author: Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#ifndef _C8SECTPFE_COMMON_H_
-#define _C8SECTPFE_COMMON_H_
-
-#include <linux/dvb/dmx.h>
-#include <linux/dvb/frontend.h>
-#include <linux/gpio.h>
-
-#include <media/dmxdev.h>
-#include <media/dvb_demux.h>
-#include <media/dvb_frontend.h>
-#include <media/dvb_net.h>
-
-/* Maximum number of channels */
-#define C8SECTPFE_MAXADAPTER (4)
-#define C8SECTPFE_MAXCHANNEL 64
-#define STPTI_MAXCHANNEL 64
-
-#define MAX_INPUTBLOCKS 7
-
-struct c8sectpfe;
-struct stdemux;
-
-struct stdemux {
- struct dvb_demux dvb_demux;
- struct dmxdev dmxdev;
- struct dmx_frontend hw_frontend;
- struct dmx_frontend mem_frontend;
- int tsin_index;
- int running_feed_count;
- struct c8sectpfei *c8sectpfei;
-};
-
-struct c8sectpfe {
- struct stdemux demux[MAX_INPUTBLOCKS];
- struct mutex lock;
- struct dvb_adapter adapter;
- struct device *device;
- int mapping;
- int num_feeds;
-};
-
-/* Channel registration */
-int c8sectpfe_tuner_register_frontend(struct c8sectpfe **c8sectpfe,
- struct c8sectpfei *fei,
- void *start_feed,
- void *stop_feed);
-
-void c8sectpfe_tuner_unregister_frontend(struct c8sectpfe *c8sectpfe,
- struct c8sectpfei *fei);
-
-#endif
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c
deleted file mode 100644
index 89bd15a4d26a95be5576ba5f666fa20f4d010728..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c
+++ /dev/null
@@ -1,1158 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * c8sectpfe-core.c - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author:Peter Bennett <peter.bennett@st.com>
- * Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#include <linux/atomic.h>
-#include <linux/clk.h>
-#include <linux/completion.h>
-#include <linux/delay.h>
-#include <linux/device.h>
-#include <linux/dma-mapping.h>
-#include <linux/dvb/dmx.h>
-#include <linux/dvb/frontend.h>
-#include <linux/err.h>
-#include <linux/errno.h>
-#include <linux/firmware.h>
-#include <linux/gpio/consumer.h>
-#include <linux/init.h>
-#include <linux/interrupt.h>
-#include <linux/io.h>
-#include <linux/module.h>
-#include <linux/of_platform.h>
-#include <linux/pinctrl/consumer.h>
-#include <linux/pinctrl/pinctrl.h>
-#include <linux/platform_device.h>
-#include <linux/slab.h>
-#include <linux/time.h>
-#include <linux/usb.h>
-#include <linux/wait.h>
-
-#include "c8sectpfe-common.h"
-#include "c8sectpfe-core.h"
-#include "c8sectpfe-debugfs.h"
-
-#include <media/dmxdev.h>
-#include <media/dvb_demux.h>
-#include <media/dvb_frontend.h>
-#include <media/dvb_net.h>
-
-#define FIRMWARE_MEMDMA "pti_memdma_h407.elf"
-MODULE_FIRMWARE(FIRMWARE_MEMDMA);
-
-#define PID_TABLE_SIZE 1024
-#define POLL_MSECS 50
-
-static int load_c8sectpfe_fw(struct c8sectpfei *fei);
-
-#define TS_PKT_SIZE 188
-#define HEADER_SIZE (4)
-#define PACKET_SIZE (TS_PKT_SIZE+HEADER_SIZE)
-
-#define FEI_ALIGNMENT (32)
-/* hw requires minimum of 8*PACKET_SIZE and padded to 8byte boundary */
-#define FEI_BUFFER_SIZE (8*PACKET_SIZE*340)
-
-#define FIFO_LEN 1024
-
-static void c8sectpfe_timer_interrupt(struct timer_list *t)
-{
- struct c8sectpfei *fei = timer_container_of(fei, t, timer);
- struct channel_info *channel;
- int chan_num;
-
- /* iterate through input block channels */
- for (chan_num = 0; chan_num < fei->tsin_count; chan_num++) {
- channel = fei->channel_data[chan_num];
-
- /* is this descriptor initialised and TP enabled */
- if (channel->irec && readl(channel->irec + DMA_PRDS_TPENABLE))
- queue_work(system_bh_wq, &channel->bh_work);
- }
-
- fei->timer.expires = jiffies + msecs_to_jiffies(POLL_MSECS);
- add_timer(&fei->timer);
-}
-
-static void channel_swdemux_bh_work(struct work_struct *t)
-{
- struct channel_info *channel = from_work(channel, t, bh_work);
- struct c8sectpfei *fei;
- unsigned long wp, rp;
- int pos, num_packets, n, size;
- u8 *buf;
-
- if (unlikely(!channel || !channel->irec))
- return;
-
- fei = channel->fei;
-
- wp = readl(channel->irec + DMA_PRDS_BUSWP_TP(0));
- rp = readl(channel->irec + DMA_PRDS_BUSRP_TP(0));
-
- pos = rp - channel->back_buffer_busaddr;
-
- /* has it wrapped */
- if (wp < rp)
- wp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE;
-
- size = wp - rp;
- num_packets = size / PACKET_SIZE;
-
- /* manage cache so data is visible to CPU */
- dma_sync_single_for_cpu(fei->dev,
- rp,
- size,
- DMA_FROM_DEVICE);
-
- buf = channel->back_buffer_aligned;
-
- dev_dbg(fei->dev,
- "chan=%d channel=%p num_packets = %d, buf = %p, pos = 0x%x\n\trp=0x%lx, wp=0x%lx\n",
- channel->tsin_id, channel, num_packets, buf, pos, rp, wp);
-
- for (n = 0; n < num_packets; n++) {
- dvb_dmx_swfilter_packets(
- &fei->c8sectpfe[0]->
- demux[channel->demux_mapping].dvb_demux,
- &buf[pos], 1);
-
- pos += PACKET_SIZE;
- }
-
- /* advance the read pointer */
- if (wp == (channel->back_buffer_busaddr + FEI_BUFFER_SIZE))
- writel(channel->back_buffer_busaddr, channel->irec +
- DMA_PRDS_BUSRP_TP(0));
- else
- writel(wp, channel->irec + DMA_PRDS_BUSRP_TP(0));
-}
-
-static int c8sectpfe_start_feed(struct dvb_demux_feed *dvbdmxfeed)
-{
- struct dvb_demux *demux = dvbdmxfeed->demux;
- struct stdemux *stdemux = demux->priv;
- struct c8sectpfei *fei = stdemux->c8sectpfei;
- struct channel_info *channel;
- u32 tmp;
- unsigned long *bitmap;
- int ret;
-
- switch (dvbdmxfeed->type) {
- case DMX_TYPE_TS:
- break;
- case DMX_TYPE_SEC:
- break;
- default:
- dev_err(fei->dev, "%s:%d Error bailing\n"
- , __func__, __LINE__);
- return -EINVAL;
- }
-
- if (dvbdmxfeed->type == DMX_TYPE_TS) {
- switch (dvbdmxfeed->pes_type) {
- case DMX_PES_VIDEO:
- case DMX_PES_AUDIO:
- case DMX_PES_TELETEXT:
- case DMX_PES_PCR:
- case DMX_PES_OTHER:
- break;
- default:
- dev_err(fei->dev, "%s:%d Error bailing\n"
- , __func__, __LINE__);
- return -EINVAL;
- }
- }
-
- if (!atomic_read(&fei->fw_loaded)) {
- ret = load_c8sectpfe_fw(fei);
- if (ret)
- return ret;
- }
-
- mutex_lock(&fei->lock);
-
- channel = fei->channel_data[stdemux->tsin_index];
-
- bitmap = channel->pid_buffer_aligned;
-
- /* 8192 is a special PID */
- if (dvbdmxfeed->pid == 8192) {
- tmp = readl(fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
- tmp &= ~C8SECTPFE_PID_ENABLE;
- writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
-
- } else {
- bitmap_set(bitmap, dvbdmxfeed->pid, 1);
- }
-
- /* manage cache so PID bitmap is visible to HW */
- dma_sync_single_for_device(fei->dev,
- channel->pid_buffer_busaddr,
- PID_TABLE_SIZE,
- DMA_TO_DEVICE);
-
- channel->active = 1;
-
- if (fei->global_feed_count == 0) {
- fei->timer.expires = jiffies +
- msecs_to_jiffies(msecs_to_jiffies(POLL_MSECS));
-
- add_timer(&fei->timer);
- }
-
- if (stdemux->running_feed_count == 0) {
-
- dev_dbg(fei->dev, "Starting channel=%p\n", channel);
-
- INIT_WORK(&channel->bh_work, channel_swdemux_bh_work);
-
- /* Reset the internal inputblock sram pointers */
- writel(channel->fifo,
- fei->io + C8SECTPFE_IB_BUFF_STRT(channel->tsin_id));
- writel(channel->fifo + FIFO_LEN - 1,
- fei->io + C8SECTPFE_IB_BUFF_END(channel->tsin_id));
-
- writel(channel->fifo,
- fei->io + C8SECTPFE_IB_READ_PNT(channel->tsin_id));
- writel(channel->fifo,
- fei->io + C8SECTPFE_IB_WRT_PNT(channel->tsin_id));
-
-
- /* reset read / write memdma ptrs for this channel */
- writel(channel->back_buffer_busaddr, channel->irec +
- DMA_PRDS_BUSBASE_TP(0));
-
- tmp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
- writel(tmp, channel->irec + DMA_PRDS_BUSTOP_TP(0));
-
- writel(channel->back_buffer_busaddr, channel->irec +
- DMA_PRDS_BUSWP_TP(0));
-
- /* Issue a reset and enable InputBlock */
- writel(C8SECTPFE_SYS_ENABLE | C8SECTPFE_SYS_RESET
- , fei->io + C8SECTPFE_IB_SYS(channel->tsin_id));
-
- /* and enable the tp */
- writel(0x1, channel->irec + DMA_PRDS_TPENABLE);
-
- dev_dbg(fei->dev, "%s:%d Starting DMA feed on stdemux=%p\n"
- , __func__, __LINE__, stdemux);
- }
-
- stdemux->running_feed_count++;
- fei->global_feed_count++;
-
- mutex_unlock(&fei->lock);
-
- return 0;
-}
-
-static int c8sectpfe_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
-{
-
- struct dvb_demux *demux = dvbdmxfeed->demux;
- struct stdemux *stdemux = demux->priv;
- struct c8sectpfei *fei = stdemux->c8sectpfei;
- struct channel_info *channel;
- int idlereq;
- u32 tmp;
- int ret;
- unsigned long *bitmap;
-
- if (!atomic_read(&fei->fw_loaded)) {
- ret = load_c8sectpfe_fw(fei);
- if (ret)
- return ret;
- }
-
- mutex_lock(&fei->lock);
-
- channel = fei->channel_data[stdemux->tsin_index];
-
- bitmap = channel->pid_buffer_aligned;
-
- if (dvbdmxfeed->pid == 8192) {
- tmp = readl(fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
- tmp |= C8SECTPFE_PID_ENABLE;
- writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
- } else {
- bitmap_clear(bitmap, dvbdmxfeed->pid, 1);
- }
-
- /* manage cache so data is visible to HW */
- dma_sync_single_for_device(fei->dev,
- channel->pid_buffer_busaddr,
- PID_TABLE_SIZE,
- DMA_TO_DEVICE);
-
- if (--stdemux->running_feed_count == 0) {
-
- channel = fei->channel_data[stdemux->tsin_index];
-
- /* TP re-configuration on page 168 of functional spec */
-
- /* disable IB (prevents more TS data going to memdma) */
- writel(0, fei->io + C8SECTPFE_IB_SYS(channel->tsin_id));
-
- /* disable this channels descriptor */
- writel(0, channel->irec + DMA_PRDS_TPENABLE);
-
- disable_work_sync(&channel->bh_work);
-
- /* now request memdma channel goes idle */
- idlereq = (1 << channel->tsin_id) | IDLEREQ;
- writel(idlereq, fei->io + DMA_IDLE_REQ);
-
- /* wait for idle irq handler to signal completion */
- ret = wait_for_completion_timeout(&channel->idle_completion,
- msecs_to_jiffies(100));
-
- if (ret == 0)
- dev_warn(fei->dev,
- "Timeout waiting for idle irq on tsin%d\n",
- channel->tsin_id);
-
- reinit_completion(&channel->idle_completion);
-
- /* reset read / write ptrs for this channel */
-
- writel(channel->back_buffer_busaddr,
- channel->irec + DMA_PRDS_BUSBASE_TP(0));
-
- tmp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
- writel(tmp, channel->irec + DMA_PRDS_BUSTOP_TP(0));
-
- writel(channel->back_buffer_busaddr,
- channel->irec + DMA_PRDS_BUSWP_TP(0));
-
- dev_dbg(fei->dev,
- "%s:%d stopping DMA feed on stdemux=%p channel=%d\n",
- __func__, __LINE__, stdemux, channel->tsin_id);
-
- /* turn off all PIDS in the bitmap */
- memset(channel->pid_buffer_aligned, 0, PID_TABLE_SIZE);
-
- /* manage cache so data is visible to HW */
- dma_sync_single_for_device(fei->dev,
- channel->pid_buffer_busaddr,
- PID_TABLE_SIZE,
- DMA_TO_DEVICE);
-
- channel->active = 0;
- }
-
- if (--fei->global_feed_count == 0) {
- dev_dbg(fei->dev, "%s:%d global_feed_count=%d\n"
- , __func__, __LINE__, fei->global_feed_count);
-
- timer_delete(&fei->timer);
- }
-
- mutex_unlock(&fei->lock);
-
- return 0;
-}
-
-static struct channel_info *find_channel(struct c8sectpfei *fei, int tsin_num)
-{
- int i;
-
- for (i = 0; i < C8SECTPFE_MAX_TSIN_CHAN; i++) {
- if (!fei->channel_data[i])
- continue;
-
- if (fei->channel_data[i]->tsin_id == tsin_num)
- return fei->channel_data[i];
- }
-
- return NULL;
-}
-
-static void c8sectpfe_getconfig(struct c8sectpfei *fei)
-{
- struct c8sectpfe_hw *hw = &fei->hw_stats;
-
- hw->num_ib = readl(fei->io + SYS_CFG_NUM_IB);
- hw->num_mib = readl(fei->io + SYS_CFG_NUM_MIB);
- hw->num_swts = readl(fei->io + SYS_CFG_NUM_SWTS);
- hw->num_tsout = readl(fei->io + SYS_CFG_NUM_TSOUT);
- hw->num_ccsc = readl(fei->io + SYS_CFG_NUM_CCSC);
- hw->num_ram = readl(fei->io + SYS_CFG_NUM_RAM);
- hw->num_tp = readl(fei->io + SYS_CFG_NUM_TP);
-
- dev_info(fei->dev, "C8SECTPFE hw supports the following:\n");
- dev_info(fei->dev, "Input Blocks: %d\n", hw->num_ib);
- dev_info(fei->dev, "Merged Input Blocks: %d\n", hw->num_mib);
- dev_info(fei->dev, "Software Transport Stream Inputs: %d\n"
- , hw->num_swts);
- dev_info(fei->dev, "Transport Stream Output: %d\n", hw->num_tsout);
- dev_info(fei->dev, "Cable Card Converter: %d\n", hw->num_ccsc);
- dev_info(fei->dev, "RAMs supported by C8SECTPFE: %d\n", hw->num_ram);
- dev_info(fei->dev, "Tango TPs supported by C8SECTPFE: %d\n"
- , hw->num_tp);
-}
-
-static irqreturn_t c8sectpfe_idle_irq_handler(int irq, void *priv)
-{
- struct c8sectpfei *fei = priv;
- struct channel_info *chan;
- int bit;
- unsigned long tmp = readl(fei->io + DMA_IDLE_REQ);
-
- /* page 168 of functional spec: Clear the idle request
- by writing 0 to the C8SECTPFE_DMA_IDLE_REQ register. */
-
- /* signal idle completion */
- for_each_set_bit(bit, &tmp, fei->hw_stats.num_ib) {
-
- chan = find_channel(fei, bit);
-
- if (chan)
- complete(&chan->idle_completion);
- }
-
- writel(0, fei->io + DMA_IDLE_REQ);
-
- return IRQ_HANDLED;
-}
-
-
-static void free_input_block(struct c8sectpfei *fei, struct channel_info *tsin)
-{
- if (!fei || !tsin)
- return;
-
- if (tsin->back_buffer_busaddr)
- if (!dma_mapping_error(fei->dev, tsin->back_buffer_busaddr))
- dma_unmap_single(fei->dev, tsin->back_buffer_busaddr,
- FEI_BUFFER_SIZE, DMA_BIDIRECTIONAL);
-
- kfree(tsin->back_buffer_start);
-
- if (tsin->pid_buffer_busaddr)
- if (!dma_mapping_error(fei->dev, tsin->pid_buffer_busaddr))
- dma_unmap_single(fei->dev, tsin->pid_buffer_busaddr,
- PID_TABLE_SIZE, DMA_BIDIRECTIONAL);
-
- kfree(tsin->pid_buffer_start);
-}
-
-#define MAX_NAME 20
-
-static int configure_memdma_and_inputblock(struct c8sectpfei *fei,
- struct channel_info *tsin)
-{
- int ret;
- u32 tmp;
- char tsin_pin_name[MAX_NAME];
-
- if (!fei || !tsin)
- return -EINVAL;
-
- dev_dbg(fei->dev, "%s:%d Configuring channel=%p tsin=%d\n"
- , __func__, __LINE__, tsin, tsin->tsin_id);
-
- init_completion(&tsin->idle_completion);
-
- tsin->back_buffer_start = kzalloc(FEI_BUFFER_SIZE + FEI_ALIGNMENT, GFP_KERNEL);
- if (!tsin->back_buffer_start) {
- ret = -ENOMEM;
- goto err_unmap;
- }
-
- /* Ensure backbuffer is 32byte aligned */
- tsin->back_buffer_aligned = tsin->back_buffer_start + FEI_ALIGNMENT;
-
- tsin->back_buffer_aligned = PTR_ALIGN(tsin->back_buffer_aligned, FEI_ALIGNMENT);
-
- tsin->back_buffer_busaddr = dma_map_single(fei->dev,
- tsin->back_buffer_aligned,
- FEI_BUFFER_SIZE,
- DMA_BIDIRECTIONAL);
-
- if (dma_mapping_error(fei->dev, tsin->back_buffer_busaddr)) {
- dev_err(fei->dev, "failed to map back_buffer\n");
- ret = -EFAULT;
- goto err_unmap;
- }
-
- /*
- * The pid buffer can be configured (in hw) for byte or bit
- * per pid. By powers of deduction we conclude stih407 family
- * is configured (at SoC design stage) for bit per pid.
- */
- tsin->pid_buffer_start = kzalloc(PID_TABLE_SIZE + PID_TABLE_SIZE, GFP_KERNEL);
- if (!tsin->pid_buffer_start) {
- ret = -ENOMEM;
- goto err_unmap;
- }
-
- /*
- * PID buffer needs to be aligned to size of the pid table
- * which at bit per pid is 1024 bytes (8192 pids / 8).
- * PIDF_BASE register enforces this alignment when writing
- * the register.
- */
-
- tsin->pid_buffer_aligned = tsin->pid_buffer_start + PID_TABLE_SIZE;
-
- tsin->pid_buffer_aligned = PTR_ALIGN(tsin->pid_buffer_aligned, PID_TABLE_SIZE);
-
- tsin->pid_buffer_busaddr = dma_map_single(fei->dev,
- tsin->pid_buffer_aligned,
- PID_TABLE_SIZE,
- DMA_BIDIRECTIONAL);
-
- if (dma_mapping_error(fei->dev, tsin->pid_buffer_busaddr)) {
- dev_err(fei->dev, "failed to map pid_bitmap\n");
- ret = -EFAULT;
- goto err_unmap;
- }
-
- /* manage cache so pid bitmap is visible to HW */
- dma_sync_single_for_device(fei->dev,
- tsin->pid_buffer_busaddr,
- PID_TABLE_SIZE,
- DMA_TO_DEVICE);
-
- snprintf(tsin_pin_name, MAX_NAME, "tsin%d-%s", tsin->tsin_id,
- (tsin->serial_not_parallel ? "serial" : "parallel"));
-
- tsin->pstate = pinctrl_lookup_state(fei->pinctrl, tsin_pin_name);
- if (IS_ERR(tsin->pstate)) {
- dev_err(fei->dev, "%s: pinctrl_lookup_state couldn't find %s state\n"
- , __func__, tsin_pin_name);
- ret = PTR_ERR(tsin->pstate);
- goto err_unmap;
- }
-
- ret = pinctrl_select_state(fei->pinctrl, tsin->pstate);
-
- if (ret) {
- dev_err(fei->dev, "%s: pinctrl_select_state failed\n"
- , __func__);
- goto err_unmap;
- }
-
- /* Enable this input block */
- tmp = readl(fei->io + SYS_INPUT_CLKEN);
- tmp |= BIT(tsin->tsin_id);
- writel(tmp, fei->io + SYS_INPUT_CLKEN);
-
- if (tsin->serial_not_parallel)
- tmp |= C8SECTPFE_SERIAL_NOT_PARALLEL;
-
- if (tsin->invert_ts_clk)
- tmp |= C8SECTPFE_INVERT_TSCLK;
-
- if (tsin->async_not_sync)
- tmp |= C8SECTPFE_ASYNC_NOT_SYNC;
-
- tmp |= C8SECTPFE_ALIGN_BYTE_SOP | C8SECTPFE_BYTE_ENDIANNESS_MSB;
-
- writel(tmp, fei->io + C8SECTPFE_IB_IP_FMT_CFG(tsin->tsin_id));
-
- writel(C8SECTPFE_SYNC(0x9) |
- C8SECTPFE_DROP(0x9) |
- C8SECTPFE_TOKEN(0x47),
- fei->io + C8SECTPFE_IB_SYNCLCKDRP_CFG(tsin->tsin_id));
-
- writel(TS_PKT_SIZE, fei->io + C8SECTPFE_IB_PKT_LEN(tsin->tsin_id));
-
- /* Place the FIFO's at the end of the irec descriptors */
-
- tsin->fifo = (tsin->tsin_id * FIFO_LEN);
-
- writel(tsin->fifo, fei->io + C8SECTPFE_IB_BUFF_STRT(tsin->tsin_id));
- writel(tsin->fifo + FIFO_LEN - 1,
- fei->io + C8SECTPFE_IB_BUFF_END(tsin->tsin_id));
-
- writel(tsin->fifo, fei->io + C8SECTPFE_IB_READ_PNT(tsin->tsin_id));
- writel(tsin->fifo, fei->io + C8SECTPFE_IB_WRT_PNT(tsin->tsin_id));
-
- writel(tsin->pid_buffer_busaddr,
- fei->io + PIDF_BASE(tsin->tsin_id));
-
- dev_dbg(fei->dev, "chan=%d PIDF_BASE=0x%x pid_bus_addr=%pad\n",
- tsin->tsin_id, readl(fei->io + PIDF_BASE(tsin->tsin_id)),
- &tsin->pid_buffer_busaddr);
-
- /* Configure and enable HW PID filtering */
-
- /*
- * The PID value is created by assembling the first 8 bytes of
- * the TS packet into a 64-bit word in big-endian format. A
- * slice of that 64-bit word is taken from
- * (PID_OFFSET+PID_NUM_BITS-1) to PID_OFFSET.
- */
- tmp = (C8SECTPFE_PID_ENABLE | C8SECTPFE_PID_NUMBITS(13)
- | C8SECTPFE_PID_OFFSET(40));
-
- writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(tsin->tsin_id));
-
- dev_dbg(fei->dev, "chan=%d setting wp: %d, rp: %d, buf: %d-%d\n",
- tsin->tsin_id,
- readl(fei->io + C8SECTPFE_IB_WRT_PNT(tsin->tsin_id)),
- readl(fei->io + C8SECTPFE_IB_READ_PNT(tsin->tsin_id)),
- readl(fei->io + C8SECTPFE_IB_BUFF_STRT(tsin->tsin_id)),
- readl(fei->io + C8SECTPFE_IB_BUFF_END(tsin->tsin_id)));
-
- /* Get base addpress of pointer record block from DMEM */
- tsin->irec = fei->io + DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET +
- readl(fei->io + DMA_PTRREC_BASE);
-
- /* fill out pointer record data structure */
-
- /* advance pointer record block to our channel */
- tsin->irec += (tsin->tsin_id * DMA_PRDS_SIZE);
-
- writel(tsin->fifo, tsin->irec + DMA_PRDS_MEMBASE);
-
- writel(tsin->fifo + FIFO_LEN - 1, tsin->irec + DMA_PRDS_MEMTOP);
-
- writel((188 + 7)&~7, tsin->irec + DMA_PRDS_PKTSIZE);
-
- writel(0x1, tsin->irec + DMA_PRDS_TPENABLE);
-
- /* read/write pointers with physical bus address */
-
- writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSBASE_TP(0));
-
- tmp = tsin->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
- writel(tmp, tsin->irec + DMA_PRDS_BUSTOP_TP(0));
-
- writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSWP_TP(0));
- writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSRP_TP(0));
-
- /* initialize bh work */
- INIT_WORK(&tsin->bh_work, channel_swdemux_bh_work);
-
- return 0;
-
-err_unmap:
- free_input_block(fei, tsin);
- return ret;
-}
-
-static irqreturn_t c8sectpfe_error_irq_handler(int irq, void *priv)
-{
- struct c8sectpfei *fei = priv;
-
- dev_err(fei->dev, "%s: error handling not yet implemented\n"
- , __func__);
-
- /*
- * TODO FIXME we should detect some error conditions here
- * and ideally do something about them!
- */
-
- return IRQ_HANDLED;
-}
-
-static int c8sectpfe_probe(struct platform_device *pdev)
-{
- struct device *dev = &pdev->dev;
- struct device_node *np = dev->of_node;
- struct c8sectpfei *fei;
- struct resource *res;
- int ret, index = 0;
- struct channel_info *tsin;
-
- /* Allocate the c8sectpfei structure */
- fei = devm_kzalloc(dev, sizeof(struct c8sectpfei), GFP_KERNEL);
- if (!fei)
- return -ENOMEM;
-
- fei->dev = dev;
-
- res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "c8sectpfe");
- fei->io = devm_ioremap_resource(dev, res);
- if (IS_ERR(fei->io))
- return PTR_ERR(fei->io);
-
- res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
- "c8sectpfe-ram");
- fei->sram = devm_ioremap_resource(dev, res);
- if (IS_ERR(fei->sram))
- return PTR_ERR(fei->sram);
-
- fei->sram_size = resource_size(res);
-
- fei->idle_irq = platform_get_irq_byname(pdev, "c8sectpfe-idle-irq");
- if (fei->idle_irq < 0)
- return fei->idle_irq;
-
- fei->error_irq = platform_get_irq_byname(pdev, "c8sectpfe-error-irq");
- if (fei->error_irq < 0)
- return fei->error_irq;
-
- platform_set_drvdata(pdev, fei);
-
- fei->c8sectpfeclk = devm_clk_get_enabled(dev, "c8sectpfe");
- if (IS_ERR(fei->c8sectpfeclk)) {
- dev_err(dev, "Failed to enable c8sectpfe clock\n");
- return PTR_ERR(fei->c8sectpfeclk);
- }
-
- /* to save power disable all IP's (on by default) */
- writel(0, fei->io + SYS_INPUT_CLKEN);
-
- /* Enable memdma clock */
- writel(MEMDMAENABLE, fei->io + SYS_OTHER_CLKEN);
-
- /* clear internal sram */
- memset_io(fei->sram, 0x0, fei->sram_size);
-
- c8sectpfe_getconfig(fei);
-
- ret = devm_request_irq(dev, fei->idle_irq, c8sectpfe_idle_irq_handler,
- 0, "c8sectpfe-idle-irq", fei);
- if (ret) {
- dev_err(dev, "Can't register c8sectpfe-idle-irq IRQ.\n");
- return ret;
- }
-
- ret = devm_request_irq(dev, fei->error_irq,
- c8sectpfe_error_irq_handler, 0,
- "c8sectpfe-error-irq", fei);
- if (ret) {
- dev_err(dev, "Can't register c8sectpfe-error-irq IRQ.\n");
- return ret;
- }
-
- fei->tsin_count = of_get_child_count(np);
-
- if (fei->tsin_count > C8SECTPFE_MAX_TSIN_CHAN ||
- fei->tsin_count > fei->hw_stats.num_ib) {
-
- dev_err(dev, "More tsin declared than exist on SoC!\n");
- return -EINVAL;
- }
-
- fei->pinctrl = devm_pinctrl_get(dev);
-
- if (IS_ERR(fei->pinctrl)) {
- dev_err(dev, "Error getting tsin pins\n");
- return PTR_ERR(fei->pinctrl);
- }
-
- for_each_child_of_node_scoped(np, child) {
- struct device_node *i2c_bus;
-
- fei->channel_data[index] = devm_kzalloc(dev,
- sizeof(struct channel_info),
- GFP_KERNEL);
-
- if (!fei->channel_data[index])
- return -ENOMEM;
-
- tsin = fei->channel_data[index];
-
- tsin->fei = fei;
-
- ret = of_property_read_u32(child, "tsin-num", &tsin->tsin_id);
- if (ret) {
- dev_err(&pdev->dev, "No tsin_num found\n");
- return ret;
- }
-
- /* sanity check value */
- if (tsin->tsin_id > fei->hw_stats.num_ib) {
- dev_err(&pdev->dev,
- "tsin-num %d specified greater than number\n\tof input block hw in SoC! (%d)",
- tsin->tsin_id, fei->hw_stats.num_ib);
- return -EINVAL;
- }
-
- tsin->invert_ts_clk = of_property_read_bool(child,
- "invert-ts-clk");
-
- tsin->serial_not_parallel = of_property_read_bool(child,
- "serial-not-parallel");
-
- tsin->async_not_sync = of_property_read_bool(child,
- "async-not-sync");
-
- ret = of_property_read_u32(child, "dvb-card",
- &tsin->dvb_card);
- if (ret) {
- dev_err(&pdev->dev, "No dvb-card found\n");
- return ret;
- }
-
- i2c_bus = of_parse_phandle(child, "i2c-bus", 0);
- if (!i2c_bus) {
- dev_err(&pdev->dev, "No i2c-bus found\n");
- return -ENODEV;
- }
- tsin->i2c_adapter =
- of_find_i2c_adapter_by_node(i2c_bus);
- of_node_put(i2c_bus);
- if (!tsin->i2c_adapter) {
- dev_err(&pdev->dev, "No i2c adapter found\n");
- return -ENODEV;
- }
-
- /* Acquire reset GPIO and activate it */
- tsin->rst_gpio = devm_fwnode_gpiod_get(dev,
- of_fwnode_handle(child),
- "reset", GPIOD_OUT_HIGH,
- "NIM reset");
- ret = PTR_ERR_OR_ZERO(tsin->rst_gpio);
- if (ret && ret != -EBUSY) {
- dev_err(dev, "Can't request tsin%d reset gpio\n",
- fei->channel_data[index]->tsin_id);
- return ret;
- }
-
- if (!ret) {
- /* wait for the chip to reset */
- usleep_range(3500, 5000);
- /* release the reset line */
- gpiod_set_value_cansleep(tsin->rst_gpio, 0);
- usleep_range(3000, 5000);
- }
-
- tsin->demux_mapping = index;
-
- dev_dbg(fei->dev,
- "channel=%p n=%d tsin_num=%d, invert-ts-clk=%d\n\tserial-not-parallel=%d pkt-clk-valid=%d dvb-card=%d\n",
- fei->channel_data[index], index,
- tsin->tsin_id, tsin->invert_ts_clk,
- tsin->serial_not_parallel, tsin->async_not_sync,
- tsin->dvb_card);
-
- index++;
- }
-
- /* Setup timer interrupt */
- timer_setup(&fei->timer, c8sectpfe_timer_interrupt, 0);
-
- mutex_init(&fei->lock);
-
- /* Get the configuration information about the tuners */
- ret = c8sectpfe_tuner_register_frontend(&fei->c8sectpfe[0],
- (void *)fei,
- c8sectpfe_start_feed,
- c8sectpfe_stop_feed);
- if (ret) {
- dev_err(dev, "c8sectpfe_tuner_register_frontend failed (%d)\n",
- ret);
- return ret;
- }
-
- c8sectpfe_debugfs_init(fei);
-
- return 0;
-}
-
-static void c8sectpfe_remove(struct platform_device *pdev)
-{
- struct c8sectpfei *fei = platform_get_drvdata(pdev);
- struct channel_info *channel;
- int i;
-
- wait_for_completion(&fei->fw_ack);
-
- c8sectpfe_tuner_unregister_frontend(fei->c8sectpfe[0], fei);
-
- /*
- * Now loop through and un-configure each of the InputBlock resources
- */
- for (i = 0; i < fei->tsin_count; i++) {
- channel = fei->channel_data[i];
- free_input_block(fei, channel);
- }
-
- c8sectpfe_debugfs_exit(fei);
-
- dev_info(fei->dev, "Stopping memdma SLIM core\n");
- if (readl(fei->io + DMA_CPU_RUN))
- writel(0x0, fei->io + DMA_CPU_RUN);
-
- /* unclock all internal IP's */
- if (readl(fei->io + SYS_INPUT_CLKEN))
- writel(0, fei->io + SYS_INPUT_CLKEN);
-
- if (readl(fei->io + SYS_OTHER_CLKEN))
- writel(0, fei->io + SYS_OTHER_CLKEN);
-}
-
-
-static int configure_channels(struct c8sectpfei *fei)
-{
- int index = 0, ret;
- struct device_node *np = fei->dev->of_node;
-
- /* iterate round each tsin and configure memdma descriptor and IB hw */
- for_each_child_of_node_scoped(np, child) {
- ret = configure_memdma_and_inputblock(fei,
- fei->channel_data[index]);
- if (ret) {
- dev_err(fei->dev,
- "configure_memdma_and_inputblock failed\n");
- goto err_unmap;
- }
- index++;
- }
-
- return 0;
-
-err_unmap:
- while (--index >= 0)
- free_input_block(fei, fei->channel_data[index]);
-
- return ret;
-}
-
-static int
-c8sectpfe_elf_sanity_check(struct c8sectpfei *fei, const struct firmware *fw)
-{
- struct elf32_hdr *ehdr;
- char class;
-
- if (!fw) {
- dev_err(fei->dev, "failed to load %s\n", FIRMWARE_MEMDMA);
- return -EINVAL;
- }
-
- if (fw->size < sizeof(struct elf32_hdr)) {
- dev_err(fei->dev, "Image is too small\n");
- return -EINVAL;
- }
-
- ehdr = (struct elf32_hdr *)fw->data;
-
- /* We only support ELF32 at this point */
- class = ehdr->e_ident[EI_CLASS];
- if (class != ELFCLASS32) {
- dev_err(fei->dev, "Unsupported class: %d\n", class);
- return -EINVAL;
- }
-
- if (ehdr->e_ident[EI_DATA] != ELFDATA2LSB) {
- dev_err(fei->dev, "Unsupported firmware endianness\n");
- return -EINVAL;
- }
-
- if (fw->size < ehdr->e_shoff + sizeof(struct elf32_shdr)) {
- dev_err(fei->dev, "Image is too small\n");
- return -EINVAL;
- }
-
- if (memcmp(ehdr->e_ident, ELFMAG, SELFMAG)) {
- dev_err(fei->dev, "Image is corrupted (bad magic)\n");
- return -EINVAL;
- }
-
- /* Check ELF magic */
- ehdr = (Elf32_Ehdr *)fw->data;
- if (ehdr->e_ident[EI_MAG0] != ELFMAG0 ||
- ehdr->e_ident[EI_MAG1] != ELFMAG1 ||
- ehdr->e_ident[EI_MAG2] != ELFMAG2 ||
- ehdr->e_ident[EI_MAG3] != ELFMAG3) {
- dev_err(fei->dev, "Invalid ELF magic\n");
- return -EINVAL;
- }
-
- if (ehdr->e_type != ET_EXEC) {
- dev_err(fei->dev, "Unsupported ELF header type\n");
- return -EINVAL;
- }
-
- if (ehdr->e_phoff > fw->size) {
- dev_err(fei->dev, "Firmware size is too small\n");
- return -EINVAL;
- }
-
- return 0;
-}
-
-
-static void load_imem_segment(struct c8sectpfei *fei, Elf32_Phdr *phdr,
- const struct firmware *fw, u8 __iomem *dest,
- int seg_num)
-{
- const u8 *imem_src = fw->data + phdr->p_offset;
- int i;
-
- /*
- * For IMEM segments, the segment contains 24-bit
- * instructions which must be padded to 32-bit
- * instructions before being written. The written
- * segment is padded with NOP instructions.
- */
-
- dev_dbg(fei->dev,
- "Loading IMEM segment %d 0x%08x\n\t (0x%x bytes) -> 0x%p (0x%x bytes)\n",
- seg_num, phdr->p_paddr, phdr->p_filesz, dest,
- phdr->p_memsz + phdr->p_memsz / 3);
-
- for (i = 0; i < phdr->p_filesz; i++) {
-
- writeb(readb((void __iomem *)imem_src), (void __iomem *)dest);
-
- /* Every 3 bytes, add an additional
- * padding zero in destination */
- if (i % 3 == 2) {
- dest++;
- writeb(0x00, (void __iomem *)dest);
- }
-
- dest++;
- imem_src++;
- }
-}
-
-static void load_dmem_segment(struct c8sectpfei *fei, Elf32_Phdr *phdr,
- const struct firmware *fw, u8 __iomem *dst, int seg_num)
-{
- /*
- * For DMEM segments copy the segment data from the ELF
- * file and pad segment with zeroes
- */
-
- dev_dbg(fei->dev,
- "Loading DMEM segment %d 0x%08x\n\t(0x%x bytes) -> 0x%p (0x%x bytes)\n",
- seg_num, phdr->p_paddr, phdr->p_filesz,
- dst, phdr->p_memsz);
-
- memcpy((void __force *)dst, (void *)fw->data + phdr->p_offset,
- phdr->p_filesz);
-
- memset((void __force *)dst + phdr->p_filesz, 0,
- phdr->p_memsz - phdr->p_filesz);
-}
-
-static int load_slim_core_fw(const struct firmware *fw, struct c8sectpfei *fei)
-{
- Elf32_Ehdr *ehdr;
- Elf32_Phdr *phdr;
- u8 __iomem *dst;
- int err = 0, i;
-
- if (!fw || !fei)
- return -EINVAL;
-
- ehdr = (Elf32_Ehdr *)fw->data;
- phdr = (Elf32_Phdr *)(fw->data + ehdr->e_phoff);
-
- /* go through the available ELF segments */
- for (i = 0; i < ehdr->e_phnum; i++, phdr++) {
-
- /* Only consider LOAD segments */
- if (phdr->p_type != PT_LOAD)
- continue;
-
- /*
- * Check segment is contained within the fw->data buffer
- */
- if (phdr->p_offset + phdr->p_filesz > fw->size) {
- dev_err(fei->dev,
- "Segment %d is outside of firmware file\n", i);
- err = -EINVAL;
- break;
- }
-
- /*
- * MEMDMA IMEM has executable flag set, otherwise load
- * this segment into DMEM.
- *
- */
-
- if (phdr->p_flags & PF_X) {
- dst = (u8 __iomem *) fei->io + DMA_MEMDMA_IMEM;
- /*
- * The Slim ELF file uses 32-bit word addressing for
- * load offsets.
- */
- dst += (phdr->p_paddr & 0xFFFFF) * sizeof(unsigned int);
- load_imem_segment(fei, phdr, fw, dst, i);
- } else {
- dst = (u8 __iomem *) fei->io + DMA_MEMDMA_DMEM;
- /*
- * The Slim ELF file uses 32-bit word addressing for
- * load offsets.
- */
- dst += (phdr->p_paddr & 0xFFFFF) * sizeof(unsigned int);
- load_dmem_segment(fei, phdr, fw, dst, i);
- }
- }
-
- return err;
-}
-
-static int load_c8sectpfe_fw(struct c8sectpfei *fei)
-{
- const struct firmware *fw;
- int err;
-
- dev_info(fei->dev, "Loading firmware: %s\n", FIRMWARE_MEMDMA);
-
- err = request_firmware(&fw, FIRMWARE_MEMDMA, fei->dev);
- if (err)
- return err;
-
- err = c8sectpfe_elf_sanity_check(fei, fw);
- if (err) {
- dev_err(fei->dev, "c8sectpfe_elf_sanity_check failed err=(%d)\n"
- , err);
- release_firmware(fw);
- return err;
- }
-
- err = load_slim_core_fw(fw, fei);
- release_firmware(fw);
- if (err) {
- dev_err(fei->dev, "load_slim_core_fw failed err=(%d)\n", err);
- return err;
- }
-
- /* now the firmware is loaded configure the input blocks */
- err = configure_channels(fei);
- if (err) {
- dev_err(fei->dev, "configure_channels failed err=(%d)\n", err);
- return err;
- }
-
- /*
- * STBus target port can access IMEM and DMEM ports
- * without waiting for CPU
- */
- writel(0x1, fei->io + DMA_PER_STBUS_SYNC);
-
- dev_info(fei->dev, "Boot the memdma SLIM core\n");
- writel(0x1, fei->io + DMA_CPU_RUN);
-
- atomic_set(&fei->fw_loaded, 1);
-
- return 0;
-}
-
-static const struct of_device_id c8sectpfe_match[] = {
- { .compatible = "st,stih407-c8sectpfe" },
- { /* sentinel */ },
-};
-MODULE_DEVICE_TABLE(of, c8sectpfe_match);
-
-static struct platform_driver c8sectpfe_driver = {
- .driver = {
- .name = "c8sectpfe",
- .of_match_table = c8sectpfe_match,
- },
- .probe = c8sectpfe_probe,
- .remove = c8sectpfe_remove,
-};
-
-module_platform_driver(c8sectpfe_driver);
-
-MODULE_AUTHOR("Peter Bennett <peter.bennett@st.com>");
-MODULE_AUTHOR("Peter Griffin <peter.griffin@linaro.org>");
-MODULE_DESCRIPTION("C8SECTPFE STi DVB Driver");
-MODULE_LICENSE("GPL");
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h
deleted file mode 100644
index c1b124c6ef128a6fe3fd5cbe5f5f3aee1b034af1..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h
+++ /dev/null
@@ -1,287 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/*
- * c8sectpfe-core.h - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author:Peter Bennett <peter.bennett@st.com>
- * Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#ifndef _C8SECTPFE_CORE_H_
-#define _C8SECTPFE_CORE_H_
-
-#define C8SECTPFEI_MAXCHANNEL 16
-#define C8SECTPFEI_MAXADAPTER 3
-
-#define C8SECTPFE_MAX_TSIN_CHAN 8
-
-struct gpio_desc;
-
-struct channel_info {
-
- int tsin_id;
- bool invert_ts_clk;
- bool serial_not_parallel;
- bool async_not_sync;
- int i2c;
- int dvb_card;
-
- struct gpio_desc *rst_gpio;
-
- struct i2c_adapter *i2c_adapter;
- struct i2c_adapter *tuner_i2c;
- struct i2c_adapter *lnb_i2c;
- struct i2c_client *i2c_client;
- struct dvb_frontend *frontend;
-
- struct pinctrl_state *pstate;
-
- int demux_mapping;
- int active;
-
- void *back_buffer_start;
- void *back_buffer_aligned;
- dma_addr_t back_buffer_busaddr;
-
- void *pid_buffer_start;
- void *pid_buffer_aligned;
- dma_addr_t pid_buffer_busaddr;
-
- unsigned long fifo;
-
- struct completion idle_completion;
- struct work_struct bh_work;
-
- struct c8sectpfei *fei;
- void __iomem *irec;
-
-};
-
-struct c8sectpfe_hw {
- int num_ib;
- int num_mib;
- int num_swts;
- int num_tsout;
- int num_ccsc;
- int num_ram;
- int num_tp;
-};
-
-struct c8sectpfei {
-
- struct device *dev;
- struct pinctrl *pinctrl;
-
- struct dentry *root;
- struct debugfs_regset32 *regset;
- struct completion fw_ack;
- atomic_t fw_loaded;
-
- int tsin_count;
-
- struct c8sectpfe_hw hw_stats;
-
- struct c8sectpfe *c8sectpfe[C8SECTPFEI_MAXADAPTER];
-
- int mapping[C8SECTPFEI_MAXCHANNEL];
-
- struct mutex lock;
-
- struct timer_list timer; /* timer interrupts for outputs */
-
- void __iomem *io;
- void __iomem *sram;
-
- unsigned long sram_size;
-
- struct channel_info *channel_data[C8SECTPFE_MAX_TSIN_CHAN];
-
- struct clk *c8sectpfeclk;
- int nima_rst_gpio;
- int nimb_rst_gpio;
-
- int idle_irq;
- int error_irq;
-
- int global_feed_count;
-};
-
-/* C8SECTPFE SYS Regs list */
-
-#define SYS_INPUT_ERR_STATUS 0x0
-#define SYS_OTHER_ERR_STATUS 0x8
-#define SYS_INPUT_ERR_MASK 0x10
-#define SYS_OTHER_ERR_MASK 0x18
-#define SYS_DMA_ROUTE 0x20
-#define SYS_INPUT_CLKEN 0x30
-#define IBENABLE_MASK 0x7F
-
-#define SYS_OTHER_CLKEN 0x38
-#define TSDMAENABLE BIT(1)
-#define MEMDMAENABLE BIT(0)
-
-#define SYS_CFG_NUM_IB 0x200
-#define SYS_CFG_NUM_MIB 0x204
-#define SYS_CFG_NUM_SWTS 0x208
-#define SYS_CFG_NUM_TSOUT 0x20C
-#define SYS_CFG_NUM_CCSC 0x210
-#define SYS_CFG_NUM_RAM 0x214
-#define SYS_CFG_NUM_TP 0x218
-
-/* Input Block Regs */
-
-#define C8SECTPFE_INPUTBLK_OFFSET 0x1000
-#define C8SECTPFE_CHANNEL_OFFSET(x) ((x*0x40) + C8SECTPFE_INPUTBLK_OFFSET)
-
-#define C8SECTPFE_IB_IP_FMT_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x00)
-#define C8SECTPFE_IGNORE_ERR_AT_SOP BIT(7)
-#define C8SECTPFE_IGNORE_ERR_IN_PKT BIT(6)
-#define C8SECTPFE_IGNORE_ERR_IN_BYTE BIT(5)
-#define C8SECTPFE_INVERT_TSCLK BIT(4)
-#define C8SECTPFE_ALIGN_BYTE_SOP BIT(3)
-#define C8SECTPFE_ASYNC_NOT_SYNC BIT(2)
-#define C8SECTPFE_BYTE_ENDIANNESS_MSB BIT(1)
-#define C8SECTPFE_SERIAL_NOT_PARALLEL BIT(0)
-
-#define C8SECTPFE_IB_SYNCLCKDRP_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x04)
-#define C8SECTPFE_SYNC(x) (x & 0xf)
-#define C8SECTPFE_DROP(x) ((x<<4) & 0xf)
-#define C8SECTPFE_TOKEN(x) ((x<<8) & 0xff00)
-#define C8SECTPFE_SLDENDIANNESS BIT(16)
-
-#define C8SECTPFE_IB_TAGBYTES_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x08)
-#define C8SECTPFE_TAG_HEADER(x) (x << 16)
-#define C8SECTPFE_TAG_COUNTER(x) ((x<<1) & 0x7fff)
-#define C8SECTPFE_TAG_ENABLE BIT(0)
-
-#define C8SECTPFE_IB_PID_SET(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x0C)
-#define C8SECTPFE_PID_OFFSET(x) (x & 0x3f)
-#define C8SECTPFE_PID_NUMBITS(x) ((x << 6) & 0xfff)
-#define C8SECTPFE_PID_ENABLE BIT(31)
-
-#define C8SECTPFE_IB_PKT_LEN(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x10)
-
-#define C8SECTPFE_IB_BUFF_STRT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x14)
-#define C8SECTPFE_IB_BUFF_END(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x18)
-#define C8SECTPFE_IB_READ_PNT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x1C)
-#define C8SECTPFE_IB_WRT_PNT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x20)
-
-#define C8SECTPFE_IB_PRI_THRLD(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x24)
-#define C8SECTPFE_PRI_VALUE(x) (x & 0x7fffff)
-#define C8SECTPFE_PRI_LOWPRI(x) ((x & 0xf) << 24)
-#define C8SECTPFE_PRI_HIGHPRI(x) ((x & 0xf) << 28)
-
-#define C8SECTPFE_IB_STAT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x28)
-#define C8SECTPFE_STAT_FIFO_OVERFLOW(x) (x & 0x1)
-#define C8SECTPFE_STAT_BUFFER_OVERFLOW(x) (x & 0x2)
-#define C8SECTPFE_STAT_OUTOFORDERRP(x) (x & 0x4)
-#define C8SECTPFE_STAT_PID_OVERFLOW(x) (x & 0x8)
-#define C8SECTPFE_STAT_PKT_OVERFLOW(x) (x & 0x10)
-#define C8SECTPFE_STAT_ERROR_PACKETS(x) ((x >> 8) & 0xf)
-#define C8SECTPFE_STAT_SHORT_PACKETS(x) ((x >> 12) & 0xf)
-
-#define C8SECTPFE_IB_MASK(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x2C)
-#define C8SECTPFE_MASK_FIFO_OVERFLOW BIT(0)
-#define C8SECTPFE_MASK_BUFFER_OVERFLOW BIT(1)
-#define C8SECTPFE_MASK_OUTOFORDERRP(x) BIT(2)
-#define C8SECTPFE_MASK_PID_OVERFLOW(x) BIT(3)
-#define C8SECTPFE_MASK_PKT_OVERFLOW(x) BIT(4)
-#define C8SECTPFE_MASK_ERROR_PACKETS(x) ((x & 0xf) << 8)
-#define C8SECTPFE_MASK_SHORT_PACKETS(x) ((x & 0xf) >> 12)
-
-#define C8SECTPFE_IB_SYS(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x30)
-#define C8SECTPFE_SYS_RESET BIT(1)
-#define C8SECTPFE_SYS_ENABLE BIT(0)
-
-/*
- * Pointer record data structure required for each input block
- * see Table 82 on page 167 of functional specification.
- */
-
-#define DMA_PRDS_MEMBASE 0x0 /* Internal sram base address */
-#define DMA_PRDS_MEMTOP 0x4 /* Internal sram top address */
-
-/*
- * TS packet size, including tag bytes added by input block,
- * rounded up to the next multiple of 8 bytes. The packet size,
- * including any tagging bytes and rounded up to the nearest
- * multiple of 8 bytes must be less than 255 bytes.
- */
-#define DMA_PRDS_PKTSIZE 0x8
-#define DMA_PRDS_TPENABLE 0xc
-
-#define TP0_OFFSET 0x10
-#define DMA_PRDS_BUSBASE_TP(x) ((0x10*x) + TP0_OFFSET)
-#define DMA_PRDS_BUSTOP_TP(x) ((0x10*x) + TP0_OFFSET + 0x4)
-#define DMA_PRDS_BUSWP_TP(x) ((0x10*x) + TP0_OFFSET + 0x8)
-#define DMA_PRDS_BUSRP_TP(x) ((0x10*x) + TP0_OFFSET + 0xc)
-
-#define DMA_PRDS_SIZE (0x20)
-
-#define DMA_MEMDMA_OFFSET 0x4000
-#define DMA_IMEM_OFFSET 0x0
-#define DMA_DMEM_OFFSET 0x4000
-#define DMA_CPU 0x8000
-#define DMA_PER_OFFSET 0xb000
-
-#define DMA_MEMDMA_DMEM (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET)
-#define DMA_MEMDMA_IMEM (DMA_MEMDMA_OFFSET + DMA_IMEM_OFFSET)
-
-/* XP70 Slim core regs */
-#define DMA_CPU_ID (DMA_MEMDMA_OFFSET + DMA_CPU + 0x0)
-#define DMA_CPU_VCR (DMA_MEMDMA_OFFSET + DMA_CPU + 0x4)
-#define DMA_CPU_RUN (DMA_MEMDMA_OFFSET + DMA_CPU + 0x8)
-#define DMA_CPU_CLOCKGATE (DMA_MEMDMA_OFFSET + DMA_CPU + 0xc)
-#define DMA_CPU_PC (DMA_MEMDMA_OFFSET + DMA_CPU + 0x20)
-
-/* Enable Interrupt for a IB */
-#define DMA_PER_TPn_DREQ_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xd00)
-/* Ack interrupt by setting corresponding bit */
-#define DMA_PER_TPn_DACK_SET (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xd80)
-#define DMA_PER_TPn_DREQ (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xe00)
-#define DMA_PER_TPn_DACK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xe80)
-#define DMA_PER_DREQ_MODE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf80)
-#define DMA_PER_STBUS_SYNC (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf88)
-#define DMA_PER_STBUS_ACCESS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf8c)
-#define DMA_PER_STBUS_ADDRESS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf90)
-#define DMA_PER_IDLE_INT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfa8)
-#define DMA_PER_PRIORITY (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfac)
-#define DMA_PER_MAX_OPCODE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfb0)
-#define DMA_PER_MAX_CHUNK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfb4)
-#define DMA_PER_PAGE_SIZE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfbc)
-#define DMA_PER_MBOX_STATUS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfc0)
-#define DMA_PER_MBOX_SET (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfc8)
-#define DMA_PER_MBOX_CLEAR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfd0)
-#define DMA_PER_MBOX_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfd8)
-#define DMA_PER_INJECT_PKT_SRC (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe0)
-#define DMA_PER_INJECT_PKT_DEST (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe4)
-#define DMA_PER_INJECT_PKT_ADDR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe8)
-#define DMA_PER_INJECT_PKT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfec)
-#define DMA_PER_PAT_PTR_INIT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff0)
-#define DMA_PER_PAT_PTR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff4)
-#define DMA_PER_SLEEP_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff8)
-#define DMA_PER_SLEEP_COUNTER (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xffc)
-/* #define DMA_RF_CPUREGn DMA_RFBASEADDR n=0 to 15) slim regsa */
-
-/* The following are from DMA_DMEM_BaseAddress */
-#define DMA_FIRMWARE_VERSION (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x0)
-#define DMA_PTRREC_BASE (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x4)
-#define DMA_PTRREC_INPUT_OFFSET (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x8)
-#define DMA_ERRREC_BASE (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0xc)
-#define DMA_ERROR_RECORD(n) ((n*4) + DMA_ERRREC_BASE + 0x4)
-#define DMA_IDLE_REQ (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x10)
-#define IDLEREQ BIT(31)
-
-#define DMA_FIRMWARE_CONFIG (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x14)
-
-/* Regs for PID Filter */
-
-#define PIDF_OFFSET 0x2800
-#define PIDF_BASE(n) ((n*4) + PIDF_OFFSET)
-#define PIDF_LEAK_ENABLE (PIDF_OFFSET + 0x100)
-#define PIDF_LEAK_STATUS (PIDF_OFFSET + 0x108)
-#define PIDF_LEAK_COUNT_RESET (PIDF_OFFSET + 0x110)
-#define PIDF_LEAK_COUNTER (PIDF_OFFSET + 0x114)
-
-#endif /* _C8SECTPFE_CORE_H_ */
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c
deleted file mode 100644
index 301fa10f419b6a7c9a1b50d759fd0fbbfc0f7692..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c
+++ /dev/null
@@ -1,244 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * c8sectpfe-debugfs.c - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author: Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#include <linux/debugfs.h>
-#include <linux/device.h>
-#include <linux/interrupt.h>
-#include <linux/io.h>
-#include <linux/kernel.h>
-#include <linux/seq_file.h>
-#include <linux/slab.h>
-#include <linux/types.h>
-
-#include "c8sectpfe-debugfs.h"
-
-#define dump_register(nm ...) \
-{ \
- .name = #nm, \
- .offset = nm, \
-}
-
-static const struct debugfs_reg32 fei_sys_regs[] = {
- dump_register(SYS_INPUT_ERR_STATUS),
- dump_register(SYS_OTHER_ERR_STATUS),
- dump_register(SYS_INPUT_ERR_MASK),
- dump_register(SYS_DMA_ROUTE),
- dump_register(SYS_INPUT_CLKEN),
- dump_register(IBENABLE_MASK),
- dump_register(SYS_OTHER_CLKEN),
- dump_register(SYS_CFG_NUM_IB),
- dump_register(SYS_CFG_NUM_MIB),
- dump_register(SYS_CFG_NUM_SWTS),
- dump_register(SYS_CFG_NUM_TSOUT),
- dump_register(SYS_CFG_NUM_CCSC),
- dump_register(SYS_CFG_NUM_RAM),
- dump_register(SYS_CFG_NUM_TP),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(0)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(0)),
- dump_register(C8SECTPFE_IB_PID_SET(0)),
- dump_register(C8SECTPFE_IB_PKT_LEN(0)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(0)),
- dump_register(C8SECTPFE_IB_BUFF_END(0)),
- dump_register(C8SECTPFE_IB_READ_PNT(0)),
- dump_register(C8SECTPFE_IB_WRT_PNT(0)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(0)),
- dump_register(C8SECTPFE_IB_STAT(0)),
- dump_register(C8SECTPFE_IB_MASK(0)),
- dump_register(C8SECTPFE_IB_SYS(0)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(1)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(1)),
- dump_register(C8SECTPFE_IB_PID_SET(1)),
- dump_register(C8SECTPFE_IB_PKT_LEN(1)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(1)),
- dump_register(C8SECTPFE_IB_BUFF_END(1)),
- dump_register(C8SECTPFE_IB_READ_PNT(1)),
- dump_register(C8SECTPFE_IB_WRT_PNT(1)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(1)),
- dump_register(C8SECTPFE_IB_STAT(1)),
- dump_register(C8SECTPFE_IB_MASK(1)),
- dump_register(C8SECTPFE_IB_SYS(1)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(2)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(2)),
- dump_register(C8SECTPFE_IB_PID_SET(2)),
- dump_register(C8SECTPFE_IB_PKT_LEN(2)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(2)),
- dump_register(C8SECTPFE_IB_BUFF_END(2)),
- dump_register(C8SECTPFE_IB_READ_PNT(2)),
- dump_register(C8SECTPFE_IB_WRT_PNT(2)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(2)),
- dump_register(C8SECTPFE_IB_STAT(2)),
- dump_register(C8SECTPFE_IB_MASK(2)),
- dump_register(C8SECTPFE_IB_SYS(2)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(3)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(3)),
- dump_register(C8SECTPFE_IB_PID_SET(3)),
- dump_register(C8SECTPFE_IB_PKT_LEN(3)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(3)),
- dump_register(C8SECTPFE_IB_BUFF_END(3)),
- dump_register(C8SECTPFE_IB_READ_PNT(3)),
- dump_register(C8SECTPFE_IB_WRT_PNT(3)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(3)),
- dump_register(C8SECTPFE_IB_STAT(3)),
- dump_register(C8SECTPFE_IB_MASK(3)),
- dump_register(C8SECTPFE_IB_SYS(3)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(4)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(4)),
- dump_register(C8SECTPFE_IB_PID_SET(4)),
- dump_register(C8SECTPFE_IB_PKT_LEN(4)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(4)),
- dump_register(C8SECTPFE_IB_BUFF_END(4)),
- dump_register(C8SECTPFE_IB_READ_PNT(4)),
- dump_register(C8SECTPFE_IB_WRT_PNT(4)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(4)),
- dump_register(C8SECTPFE_IB_STAT(4)),
- dump_register(C8SECTPFE_IB_MASK(4)),
- dump_register(C8SECTPFE_IB_SYS(4)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(5)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(5)),
- dump_register(C8SECTPFE_IB_PID_SET(5)),
- dump_register(C8SECTPFE_IB_PKT_LEN(5)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(5)),
- dump_register(C8SECTPFE_IB_BUFF_END(5)),
- dump_register(C8SECTPFE_IB_READ_PNT(5)),
- dump_register(C8SECTPFE_IB_WRT_PNT(5)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(5)),
- dump_register(C8SECTPFE_IB_STAT(5)),
- dump_register(C8SECTPFE_IB_MASK(5)),
- dump_register(C8SECTPFE_IB_SYS(5)),
-
- dump_register(C8SECTPFE_IB_IP_FMT_CFG(6)),
- dump_register(C8SECTPFE_IB_TAGBYTES_CFG(6)),
- dump_register(C8SECTPFE_IB_PID_SET(6)),
- dump_register(C8SECTPFE_IB_PKT_LEN(6)),
- dump_register(C8SECTPFE_IB_BUFF_STRT(6)),
- dump_register(C8SECTPFE_IB_BUFF_END(6)),
- dump_register(C8SECTPFE_IB_READ_PNT(6)),
- dump_register(C8SECTPFE_IB_WRT_PNT(6)),
- dump_register(C8SECTPFE_IB_PRI_THRLD(6)),
- dump_register(C8SECTPFE_IB_STAT(6)),
- dump_register(C8SECTPFE_IB_MASK(6)),
- dump_register(C8SECTPFE_IB_SYS(6)),
-
- dump_register(DMA_CPU_ID),
- dump_register(DMA_CPU_VCR),
- dump_register(DMA_CPU_RUN),
- dump_register(DMA_CPU_PC),
-
- dump_register(DMA_PER_TPn_DREQ_MASK),
- dump_register(DMA_PER_TPn_DACK_SET),
- dump_register(DMA_PER_TPn_DREQ),
- dump_register(DMA_PER_TPn_DACK),
- dump_register(DMA_PER_DREQ_MODE),
- dump_register(DMA_PER_STBUS_SYNC),
- dump_register(DMA_PER_STBUS_ACCESS),
- dump_register(DMA_PER_STBUS_ADDRESS),
- dump_register(DMA_PER_IDLE_INT),
- dump_register(DMA_PER_PRIORITY),
- dump_register(DMA_PER_MAX_OPCODE),
- dump_register(DMA_PER_MAX_CHUNK),
- dump_register(DMA_PER_PAGE_SIZE),
- dump_register(DMA_PER_MBOX_STATUS),
- dump_register(DMA_PER_MBOX_SET),
- dump_register(DMA_PER_MBOX_CLEAR),
- dump_register(DMA_PER_MBOX_MASK),
- dump_register(DMA_PER_INJECT_PKT_SRC),
- dump_register(DMA_PER_INJECT_PKT_DEST),
- dump_register(DMA_PER_INJECT_PKT_ADDR),
- dump_register(DMA_PER_INJECT_PKT),
- dump_register(DMA_PER_PAT_PTR_INIT),
- dump_register(DMA_PER_PAT_PTR),
- dump_register(DMA_PER_SLEEP_MASK),
- dump_register(DMA_PER_SLEEP_COUNTER),
-
- dump_register(DMA_FIRMWARE_VERSION),
- dump_register(DMA_PTRREC_BASE),
- dump_register(DMA_PTRREC_INPUT_OFFSET),
- dump_register(DMA_ERRREC_BASE),
-
- dump_register(DMA_ERROR_RECORD(0)),
- dump_register(DMA_ERROR_RECORD(1)),
- dump_register(DMA_ERROR_RECORD(2)),
- dump_register(DMA_ERROR_RECORD(3)),
- dump_register(DMA_ERROR_RECORD(4)),
- dump_register(DMA_ERROR_RECORD(5)),
- dump_register(DMA_ERROR_RECORD(6)),
- dump_register(DMA_ERROR_RECORD(7)),
- dump_register(DMA_ERROR_RECORD(8)),
- dump_register(DMA_ERROR_RECORD(9)),
- dump_register(DMA_ERROR_RECORD(10)),
- dump_register(DMA_ERROR_RECORD(11)),
- dump_register(DMA_ERROR_RECORD(12)),
- dump_register(DMA_ERROR_RECORD(13)),
- dump_register(DMA_ERROR_RECORD(14)),
- dump_register(DMA_ERROR_RECORD(15)),
- dump_register(DMA_ERROR_RECORD(16)),
- dump_register(DMA_ERROR_RECORD(17)),
- dump_register(DMA_ERROR_RECORD(18)),
- dump_register(DMA_ERROR_RECORD(19)),
- dump_register(DMA_ERROR_RECORD(20)),
- dump_register(DMA_ERROR_RECORD(21)),
- dump_register(DMA_ERROR_RECORD(22)),
-
- dump_register(DMA_IDLE_REQ),
- dump_register(DMA_FIRMWARE_CONFIG),
-
- dump_register(PIDF_BASE(0)),
- dump_register(PIDF_BASE(1)),
- dump_register(PIDF_BASE(2)),
- dump_register(PIDF_BASE(3)),
- dump_register(PIDF_BASE(4)),
- dump_register(PIDF_BASE(5)),
- dump_register(PIDF_BASE(6)),
- dump_register(PIDF_BASE(7)),
- dump_register(PIDF_BASE(8)),
- dump_register(PIDF_BASE(9)),
- dump_register(PIDF_BASE(10)),
- dump_register(PIDF_BASE(11)),
- dump_register(PIDF_BASE(12)),
- dump_register(PIDF_BASE(13)),
- dump_register(PIDF_BASE(14)),
- dump_register(PIDF_BASE(15)),
- dump_register(PIDF_BASE(16)),
- dump_register(PIDF_BASE(17)),
- dump_register(PIDF_BASE(18)),
- dump_register(PIDF_BASE(19)),
- dump_register(PIDF_BASE(20)),
- dump_register(PIDF_BASE(21)),
- dump_register(PIDF_BASE(22)),
- dump_register(PIDF_LEAK_ENABLE),
- dump_register(PIDF_LEAK_STATUS),
- dump_register(PIDF_LEAK_COUNT_RESET),
- dump_register(PIDF_LEAK_COUNTER),
-};
-
-void c8sectpfe_debugfs_init(struct c8sectpfei *fei)
-{
- fei->regset = devm_kzalloc(fei->dev, sizeof(*fei->regset), GFP_KERNEL);
- if (!fei->regset)
- return;
-
- fei->regset->regs = fei_sys_regs;
- fei->regset->nregs = ARRAY_SIZE(fei_sys_regs);
- fei->regset->base = fei->io;
-
- fei->root = debugfs_create_dir("c8sectpfe", NULL);
- debugfs_create_regset32("registers", S_IRUGO, fei->root, fei->regset);
-}
-
-void c8sectpfe_debugfs_exit(struct c8sectpfei *fei)
-{
- debugfs_remove_recursive(fei->root);
- fei->root = NULL;
-}
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h
deleted file mode 100644
index 3fe177b59b16d2789cde2438367d6f4cbfd9c832..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h
+++ /dev/null
@@ -1,23 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/*
- * c8sectpfe-debugfs.h - C8SECTPFE STi DVB driver debugfs header
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Authors: Peter Griffin <peter.griffin@linaro.org>
- */
-
-#ifndef __C8SECTPFE_DEBUG_H
-#define __C8SECTPFE_DEBUG_H
-
-#include "c8sectpfe-core.h"
-
-#if defined(CONFIG_DEBUG_FS)
-void c8sectpfe_debugfs_init(struct c8sectpfei *);
-void c8sectpfe_debugfs_exit(struct c8sectpfei *);
-#else
-static inline void c8sectpfe_debugfs_init(struct c8sectpfei *fei) {};
-static inline void c8sectpfe_debugfs_exit(struct c8sectpfei *fei) {};
-#endif
-
-#endif /* __C8SECTPFE_DEBUG_H */
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c
deleted file mode 100644
index feb48cb546d7f11efb62339b8389187f5cec43c9..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c
+++ /dev/null
@@ -1,235 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * c8sectpfe-dvb.c - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#include <linux/completion.h>
-#include <linux/delay.h>
-#include <linux/i2c.h>
-#include <linux/interrupt.h>
-
-#include <dt-bindings/media/c8sectpfe.h>
-
-#include "c8sectpfe-common.h"
-#include "c8sectpfe-core.h"
-#include "c8sectpfe-dvb.h"
-
-#include "dvb-pll.h"
-#include "lnbh24.h"
-#include "stv0367.h"
-#include "stv0367_priv.h"
-#include "stv6110x.h"
-#include "stv090x.h"
-#include "tda18212.h"
-
-static inline const char *dvb_card_str(unsigned int c)
-{
- switch (c) {
- case STV0367_TDA18212_NIMA_1: return "STV0367_TDA18212_NIMA_1";
- case STV0367_TDA18212_NIMA_2: return "STV0367_TDA18212_NIMA_2";
- case STV0367_TDA18212_NIMB_1: return "STV0367_TDA18212_NIMB_1";
- case STV0367_TDA18212_NIMB_2: return "STV0367_TDA18212_NIMB_2";
- case STV0903_6110_LNB24_NIMA: return "STV0903_6110_LNB24_NIMA";
- case STV0903_6110_LNB24_NIMB: return "STV0903_6110_LNB24_NIMB";
- default: return "unknown dvb frontend card";
- }
-}
-
-static struct stv090x_config stv090x_config = {
- .device = STV0903,
- .demod_mode = STV090x_SINGLE,
- .clk_mode = STV090x_CLK_EXT,
- .xtal = 16000000,
- .address = 0x69,
-
- .ts1_mode = STV090x_TSMODE_SERIAL_CONTINUOUS,
- .ts2_mode = STV090x_TSMODE_SERIAL_CONTINUOUS,
-
- .repeater_level = STV090x_RPTLEVEL_64,
-
- .tuner_init = NULL,
- .tuner_set_mode = NULL,
- .tuner_set_frequency = NULL,
- .tuner_get_frequency = NULL,
- .tuner_set_bandwidth = NULL,
- .tuner_get_bandwidth = NULL,
- .tuner_set_bbgain = NULL,
- .tuner_get_bbgain = NULL,
- .tuner_set_refclk = NULL,
- .tuner_get_status = NULL,
-};
-
-static struct stv6110x_config stv6110x_config = {
- .addr = 0x60,
- .refclk = 16000000,
-};
-
-#define NIMA 0
-#define NIMB 1
-
-static struct stv0367_config stv0367_tda18212_config[] = {
- {
- .demod_address = 0x1c,
- .xtal = 16000000,
- .if_khz = 4500,
- .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
- .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
- .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
- }, {
- .demod_address = 0x1d,
- .xtal = 16000000,
- .if_khz = 4500,
- .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
- .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
- .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
- }, {
- .demod_address = 0x1e,
- .xtal = 16000000,
- .if_khz = 4500,
- .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
- .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
- .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
- },
-};
-
-static struct tda18212_config tda18212_conf = {
- .if_dvbt_6 = 4150,
- .if_dvbt_7 = 4150,
- .if_dvbt_8 = 4500,
- .if_dvbc = 5000,
-};
-
-int c8sectpfe_frontend_attach(struct dvb_frontend **fe,
- struct c8sectpfe *c8sectpfe,
- struct channel_info *tsin, int chan_num)
-{
- struct tda18212_config *tda18212;
- const struct stv6110x_devctl *fe2;
- struct i2c_client *client;
- struct i2c_board_info tda18212_info = {
- .type = "tda18212",
- .addr = 0x60,
- };
-
- if (!tsin)
- return -EINVAL;
-
- switch (tsin->dvb_card) {
-
- case STV0367_TDA18212_NIMA_1:
- case STV0367_TDA18212_NIMA_2:
- case STV0367_TDA18212_NIMB_1:
- case STV0367_TDA18212_NIMB_2:
- if (tsin->dvb_card == STV0367_TDA18212_NIMA_1)
- *fe = dvb_attach(stv0367ter_attach,
- &stv0367_tda18212_config[0],
- tsin->i2c_adapter);
- else if (tsin->dvb_card == STV0367_TDA18212_NIMB_1)
- *fe = dvb_attach(stv0367ter_attach,
- &stv0367_tda18212_config[1],
- tsin->i2c_adapter);
- else
- *fe = dvb_attach(stv0367ter_attach,
- &stv0367_tda18212_config[2],
- tsin->i2c_adapter);
-
- if (!*fe) {
- dev_err(c8sectpfe->device,
- "%s: stv0367ter_attach failed for NIM card %s\n"
- , __func__, dvb_card_str(tsin->dvb_card));
- return -ENODEV;
- }
-
- /*
- * init the demod so that i2c gate_ctrl
- * to the tuner works correctly
- */
- (*fe)->ops.init(*fe);
-
- /* Allocate the tda18212 structure */
- tda18212 = devm_kzalloc(c8sectpfe->device,
- sizeof(struct tda18212_config),
- GFP_KERNEL);
- if (!tda18212) {
- dev_err(c8sectpfe->device,
- "%s: devm_kzalloc failed\n", __func__);
- return -ENOMEM;
- }
-
- memcpy(tda18212, &tda18212_conf,
- sizeof(struct tda18212_config));
-
- tda18212->fe = (*fe);
-
- tda18212_info.platform_data = tda18212;
-
- /* attach tuner */
- request_module("tda18212");
- client = i2c_new_client_device(tsin->i2c_adapter,
- &tda18212_info);
- if (!i2c_client_has_driver(client)) {
- dvb_frontend_detach(*fe);
- return -ENODEV;
- }
-
- if (!try_module_get(client->dev.driver->owner)) {
- i2c_unregister_device(client);
- dvb_frontend_detach(*fe);
- return -ENODEV;
- }
-
- tsin->i2c_client = client;
-
- break;
-
- case STV0903_6110_LNB24_NIMA:
- *fe = dvb_attach(stv090x_attach, &stv090x_config,
- tsin->i2c_adapter, STV090x_DEMODULATOR_0);
- if (!*fe) {
- dev_err(c8sectpfe->device, "%s: stv090x_attach failed\n"
- "\tfor NIM card %s\n",
- __func__, dvb_card_str(tsin->dvb_card));
- return -ENODEV;
- }
-
- fe2 = dvb_attach(stv6110x_attach, *fe,
- &stv6110x_config, tsin->i2c_adapter);
- if (!fe2) {
- dev_err(c8sectpfe->device,
- "%s: stv6110x_attach failed for NIM card %s\n"
- , __func__, dvb_card_str(tsin->dvb_card));
- return -ENODEV;
- }
-
- stv090x_config.tuner_init = fe2->tuner_init;
- stv090x_config.tuner_set_mode = fe2->tuner_set_mode;
- stv090x_config.tuner_set_frequency = fe2->tuner_set_frequency;
- stv090x_config.tuner_get_frequency = fe2->tuner_get_frequency;
- stv090x_config.tuner_set_bandwidth = fe2->tuner_set_bandwidth;
- stv090x_config.tuner_get_bandwidth = fe2->tuner_get_bandwidth;
- stv090x_config.tuner_set_bbgain = fe2->tuner_set_bbgain;
- stv090x_config.tuner_get_bbgain = fe2->tuner_get_bbgain;
- stv090x_config.tuner_set_refclk = fe2->tuner_set_refclk;
- stv090x_config.tuner_get_status = fe2->tuner_get_status;
-
- dvb_attach(lnbh24_attach, *fe, tsin->i2c_adapter, 0, 0, 0x9);
- break;
-
- default:
- dev_err(c8sectpfe->device,
- "%s: DVB frontend card %s not yet supported\n",
- __func__, dvb_card_str(tsin->dvb_card));
- return -ENODEV;
- }
-
- (*fe)->id = chan_num;
-
- dev_info(c8sectpfe->device,
- "DVB frontend card %s successfully attached",
- dvb_card_str(tsin->dvb_card));
- return 0;
-}
diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h
deleted file mode 100644
index 3d87a9ae8702d40629a8aa0a0ee76ddf1ad815b8..0000000000000000000000000000000000000000
--- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h
+++ /dev/null
@@ -1,17 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0 */
-/*
- * c8sectpfe-common.h - C8SECTPFE STi DVB driver
- *
- * Copyright (c) STMicroelectronics 2015
- *
- * Author: Peter Griffin <peter.griffin@linaro.org>
- *
- */
-#ifndef _C8SECTPFE_DVB_H_
-#define _C8SECTPFE_DVB_H_
-
-int c8sectpfe_frontend_attach(struct dvb_frontend **fe,
- struct c8sectpfe *c8sectpfe, struct channel_info *tsin,
- int chan_num);
-
-#endif
--
2.51.0
On 9/12/25 13:36, Raphael Gallais-Pou wrote:
> STi c8sectpfe device is only used on B2120 boards, which support has
> been withdrawn in commit dee546e1adef ("ARM: sti: drop B2120 board
> support").
>
> Signed-off-by: Raphael Gallais-Pou <rgallaispou@gmail.com>
> ---
> MAINTAINERS | 1 -
> drivers/media/platform/st/Makefile | 1 -
> drivers/media/platform/st/sti/Kconfig | 1 -
> drivers/media/platform/st/sti/Makefile | 1 -
> drivers/media/platform/st/sti/c8sectpfe/Kconfig | 28 -
> drivers/media/platform/st/sti/c8sectpfe/Makefile | 11 -
> .../platform/st/sti/c8sectpfe/c8sectpfe-common.c | 262 -----
> .../platform/st/sti/c8sectpfe/c8sectpfe-common.h | 60 -
> .../platform/st/sti/c8sectpfe/c8sectpfe-core.c | 1158 --------------------
> .../platform/st/sti/c8sectpfe/c8sectpfe-core.h | 287 -----
> .../platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c | 244 -----
> .../platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h | 23 -
> .../platform/st/sti/c8sectpfe/c8sectpfe-dvb.c | 235 ----
> .../platform/st/sti/c8sectpfe/c8sectpfe-dvb.h | 17 -
> 14 files changed, 2329 deletions(-)
>
> diff --git a/MAINTAINERS b/MAINTAINERS
> index 7b7396ed28a700a2aab318553ce8ba1788312bff..ed5bc86ec5638ed6e0635b8ce0120f8f27435ff0 100644
> --- a/MAINTAINERS
> +++ b/MAINTAINERS
> @@ -3413,7 +3413,6 @@ F: drivers/clocksource/clksrc_st_lpc.c
> F: drivers/cpufreq/sti-cpufreq.c
> F: drivers/dma/st_fdma*
> F: drivers/i2c/busses/i2c-st.c
> -F: drivers/media/platform/st/sti/c8sectpfe/
> F: drivers/media/rc/st_rc.c
> F: drivers/mmc/host/sdhci-st.c
> F: drivers/phy/st/phy-miphy28lp.c
> diff --git a/drivers/media/platform/st/Makefile b/drivers/media/platform/st/Makefile
> index a1f75b2a822583c931f2696e3fffd7981d87917b..615a93d62662105c51af076345da7f3bdc86227c 100644
> --- a/drivers/media/platform/st/Makefile
> +++ b/drivers/media/platform/st/Makefile
> @@ -1,7 +1,6 @@
> # SPDX-License-Identifier: GPL-2.0-only
>
> obj-y += sti/bdisp/
> -obj-y += sti/c8sectpfe/
> obj-y += sti/delta/
> obj-y += sti/hva/
> obj-y += stm32/
> diff --git a/drivers/media/platform/st/sti/Kconfig b/drivers/media/platform/st/sti/Kconfig
> index 60068e8b47b8651e0c2e64121441faef9061933c..91ca0950ff7308d9414d75bfbb2a0e815e7a2104 100644
> --- a/drivers/media/platform/st/sti/Kconfig
> +++ b/drivers/media/platform/st/sti/Kconfig
> @@ -1,5 +1,4 @@
> # SPDX-License-Identifier: GPL-2.0-only
> source "drivers/media/platform/st/sti/bdisp/Kconfig"
> -source "drivers/media/platform/st/sti/c8sectpfe/Kconfig"
> source "drivers/media/platform/st/sti/delta/Kconfig"
> source "drivers/media/platform/st/sti/hva/Kconfig"
> diff --git a/drivers/media/platform/st/sti/Makefile b/drivers/media/platform/st/sti/Makefile
> index f9ce8169b0404cef2a7de8f1c7377f8abe511829..3328d50fb6cf2ed2daae2c0640a6596fdd140be5 100644
> --- a/drivers/media/platform/st/sti/Makefile
> +++ b/drivers/media/platform/st/sti/Makefile
> @@ -1,6 +1,5 @@
> # SPDX-License-Identifier: GPL-2.0-only
> obj-y += bdisp/
> -obj-y += c8sectpfe/
> obj-y += delta/
> obj-y += hva/
> obj-y += stm32/
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/Kconfig b/drivers/media/platform/st/sti/c8sectpfe/Kconfig
> deleted file mode 100644
> index 01c33d9c9ec37ddc9dfc94991e2e9d3b720111e7..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/Kconfig
> +++ /dev/null
> @@ -1,28 +0,0 @@
> -# SPDX-License-Identifier: GPL-2.0-only
> -config DVB_C8SECTPFE
> - tristate "STMicroelectronics C8SECTPFE DVB support"
> - depends on DVB_PLATFORM_DRIVERS
> - depends on PINCTRL && DVB_CORE && I2C
> - depends on ARCH_STI || ARCH_MULTIPLATFORM || COMPILE_TEST
> - select FW_LOADER
> - select DVB_LNBP21 if MEDIA_SUBDRV_AUTOSELECT
> - select DVB_STV090x if MEDIA_SUBDRV_AUTOSELECT
> - select DVB_STB6100 if MEDIA_SUBDRV_AUTOSELECT
> - select DVB_STV6110 if MEDIA_SUBDRV_AUTOSELECT
> - select DVB_STV0900 if MEDIA_SUBDRV_AUTOSELECT
> - select DVB_STV0367 if MEDIA_SUBDRV_AUTOSELECT
> - select MEDIA_TUNER_TDA18212 if MEDIA_SUBDRV_AUTOSELECT
> -
> - help
> - This adds support for DVB front-end cards connected
> - to TS inputs of STiH407/410 SoC.
> -
> - The driver currently supports C8SECTPFE's TS input block,
> - memdma engine, and HW PID filtering.
> -
> - Supported DVB front-end cards are:
> - - STMicroelectronics DVB-T B2100A (STV0367 + TDA18212)
> - - STMicroelectronics DVB-S/S2 STV0903 + STV6110 + LNBP24 board
> -
> - To compile this driver as a module, choose M here: the
> - module will be called c8sectpfe.
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/Makefile b/drivers/media/platform/st/sti/c8sectpfe/Makefile
> deleted file mode 100644
> index 99425137ee0a9e48b997d62215d4378075024c69..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/Makefile
> +++ /dev/null
> @@ -1,11 +0,0 @@
> -# SPDX-License-Identifier: GPL-2.0
> -c8sectpfe-y += c8sectpfe-core.o c8sectpfe-common.o c8sectpfe-dvb.o
> -
> -ifneq ($(CONFIG_DEBUG_FS),)
> -c8sectpfe-y += c8sectpfe-debugfs.o
> -endif
> -
> -obj-$(CONFIG_DVB_C8SECTPFE) += c8sectpfe.o
> -
> -ccflags-y += -I $(srctree)/drivers/media/dvb-frontends/
> -ccflags-y += -I $(srctree)/drivers/media/tuners/
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c
> deleted file mode 100644
> index 5df67da25525cbfec8b5890fdd626f634408a6f0..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.c
> +++ /dev/null
> @@ -1,262 +0,0 @@
> -// SPDX-License-Identifier: GPL-2.0
> -/*
> - * c8sectpfe-common.c - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author: Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#include <linux/completion.h>
> -#include <linux/delay.h>
> -#include <linux/device.h>
> -#include <linux/dvb/dmx.h>
> -#include <linux/errno.h>
> -#include <linux/init.h>
> -#include <linux/interrupt.h>
> -#include <linux/io.h>
> -#include <linux/ioport.h>
> -#include <linux/module.h>
> -#include <linux/slab.h>
> -#include <linux/time.h>
> -#include <linux/wait.h>
> -
> -#include <media/dmxdev.h>
> -#include <media/dvbdev.h>
> -#include <media/dvb_demux.h>
> -#include <media/dvb_frontend.h>
> -#include <media/dvb_net.h>
> -
> -#include "c8sectpfe-common.h"
> -#include "c8sectpfe-core.h"
> -#include "c8sectpfe-dvb.h"
> -
> -static int register_dvb(struct stdemux *demux, struct dvb_adapter *adap,
> - void *start_feed, void *stop_feed,
> - struct c8sectpfei *fei)
> -{
> - int result;
> -
> - demux->dvb_demux.dmx.capabilities = DMX_TS_FILTERING |
> - DMX_SECTION_FILTERING |
> - DMX_MEMORY_BASED_FILTERING;
> -
> - demux->dvb_demux.priv = demux;
> - demux->dvb_demux.filternum = C8SECTPFE_MAXCHANNEL;
> - demux->dvb_demux.feednum = C8SECTPFE_MAXCHANNEL;
> -
> - demux->dvb_demux.start_feed = start_feed;
> - demux->dvb_demux.stop_feed = stop_feed;
> - demux->dvb_demux.write_to_decoder = NULL;
> -
> - result = dvb_dmx_init(&demux->dvb_demux);
> - if (result < 0) {
> - dev_err(fei->dev, "dvb_dmx_init failed (errno = %d)\n",
> - result);
> - goto err_dmx;
> - }
> -
> - demux->dmxdev.filternum = demux->dvb_demux.filternum;
> - demux->dmxdev.demux = &demux->dvb_demux.dmx;
> - demux->dmxdev.capabilities = 0;
> -
> - result = dvb_dmxdev_init(&demux->dmxdev, adap);
> - if (result < 0) {
> - dev_err(fei->dev, "dvb_dmxdev_init failed (errno = %d)\n",
> - result);
> -
> - goto err_dmxdev;
> - }
> -
> - demux->hw_frontend.source = DMX_FRONTEND_0 + demux->tsin_index;
> -
> - result = demux->dvb_demux.dmx.add_frontend(&demux->dvb_demux.dmx,
> - &demux->hw_frontend);
> - if (result < 0) {
> - dev_err(fei->dev, "add_frontend failed (errno = %d)\n", result);
> - goto err_fe_hw;
> - }
> -
> - demux->mem_frontend.source = DMX_MEMORY_FE;
> - result = demux->dvb_demux.dmx.add_frontend(&demux->dvb_demux.dmx,
> - &demux->mem_frontend);
> - if (result < 0) {
> - dev_err(fei->dev, "add_frontend failed (%d)\n", result);
> - goto err_fe_mem;
> - }
> -
> - result = demux->dvb_demux.dmx.connect_frontend(&demux->dvb_demux.dmx,
> - &demux->hw_frontend);
> - if (result < 0) {
> - dev_err(fei->dev, "connect_frontend (%d)\n", result);
> - goto err_fe_con;
> - }
> -
> - return 0;
> -
> -err_fe_con:
> - demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
> - &demux->mem_frontend);
> -err_fe_mem:
> - demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
> - &demux->hw_frontend);
> -err_fe_hw:
> - dvb_dmxdev_release(&demux->dmxdev);
> -err_dmxdev:
> - dvb_dmx_release(&demux->dvb_demux);
> -err_dmx:
> - return result;
> -
> -}
> -
> -static void unregister_dvb(struct stdemux *demux)
> -{
> -
> - demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
> - &demux->mem_frontend);
> -
> - demux->dvb_demux.dmx.remove_frontend(&demux->dvb_demux.dmx,
> - &demux->hw_frontend);
> -
> - dvb_dmxdev_release(&demux->dmxdev);
> -
> - dvb_dmx_release(&demux->dvb_demux);
> -}
> -
> -static struct c8sectpfe *c8sectpfe_create(struct c8sectpfei *fei,
> - void *start_feed,
> - void *stop_feed)
> -{
> - struct c8sectpfe *c8sectpfe;
> - int result;
> - int i, j;
> -
> - short int ids[] = { -1 };
> -
> - c8sectpfe = kzalloc(sizeof(struct c8sectpfe), GFP_KERNEL);
> - if (!c8sectpfe)
> - goto err1;
> -
> - mutex_init(&c8sectpfe->lock);
> -
> - c8sectpfe->device = fei->dev;
> -
> - result = dvb_register_adapter(&c8sectpfe->adapter, "STi c8sectpfe",
> - THIS_MODULE, fei->dev, ids);
> - if (result < 0) {
> - dev_err(fei->dev, "dvb_register_adapter failed (errno = %d)\n",
> - result);
> - goto err2;
> - }
> -
> - c8sectpfe->adapter.priv = fei;
> -
> - for (i = 0; i < fei->tsin_count; i++) {
> -
> - c8sectpfe->demux[i].tsin_index = i;
> - c8sectpfe->demux[i].c8sectpfei = fei;
> -
> - result = register_dvb(&c8sectpfe->demux[i], &c8sectpfe->adapter,
> - start_feed, stop_feed, fei);
> - if (result < 0) {
> - dev_err(fei->dev,
> - "register_dvb feed=%d failed (errno = %d)\n",
> - result, i);
> -
> - /* we take a all or nothing approach */
> - for (j = 0; j < i; j++)
> - unregister_dvb(&c8sectpfe->demux[j]);
> - goto err3;
> - }
> - }
> -
> - c8sectpfe->num_feeds = fei->tsin_count;
> -
> - return c8sectpfe;
> -err3:
> - dvb_unregister_adapter(&c8sectpfe->adapter);
> -err2:
> - kfree(c8sectpfe);
> -err1:
> - return NULL;
> -};
> -
> -static void c8sectpfe_delete(struct c8sectpfe *c8sectpfe)
> -{
> - int i;
> -
> - if (!c8sectpfe)
> - return;
> -
> - for (i = 0; i < c8sectpfe->num_feeds; i++)
> - unregister_dvb(&c8sectpfe->demux[i]);
> -
> - dvb_unregister_adapter(&c8sectpfe->adapter);
> -
> - kfree(c8sectpfe);
> -};
> -
> -void c8sectpfe_tuner_unregister_frontend(struct c8sectpfe *c8sectpfe,
> - struct c8sectpfei *fei)
> -{
> - int n;
> - struct channel_info *tsin;
> -
> - for (n = 0; n < fei->tsin_count; n++) {
> -
> - tsin = fei->channel_data[n];
> -
> - if (tsin) {
> - if (tsin->frontend) {
> - dvb_unregister_frontend(tsin->frontend);
> - dvb_frontend_detach(tsin->frontend);
> - }
> -
> - i2c_put_adapter(tsin->i2c_adapter);
> -
> - if (tsin->i2c_client) {
> - module_put(tsin->i2c_client->dev.driver->owner);
> - i2c_unregister_device(tsin->i2c_client);
> - }
> - }
> - }
> -
> - c8sectpfe_delete(c8sectpfe);
> -};
> -
> -int c8sectpfe_tuner_register_frontend(struct c8sectpfe **c8sectpfe,
> - struct c8sectpfei *fei,
> - void *start_feed,
> - void *stop_feed)
> -{
> - struct channel_info *tsin;
> - struct dvb_frontend *frontend;
> - int n, res;
> -
> - *c8sectpfe = c8sectpfe_create(fei, start_feed, stop_feed);
> - if (!*c8sectpfe)
> - return -ENOMEM;
> -
> - for (n = 0; n < fei->tsin_count; n++) {
> - tsin = fei->channel_data[n];
> -
> - res = c8sectpfe_frontend_attach(&frontend, *c8sectpfe, tsin, n);
> - if (res)
> - goto err;
> -
> - res = dvb_register_frontend(&c8sectpfe[0]->adapter, frontend);
> - if (res < 0) {
> - dev_err(fei->dev, "dvb_register_frontend failed (%d)\n",
> - res);
> - goto err;
> - }
> -
> - tsin->frontend = frontend;
> - }
> -
> - return 0;
> -
> -err:
> - c8sectpfe_tuner_unregister_frontend(*c8sectpfe, fei);
> - return res;
> -}
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h
> deleted file mode 100644
> index f8d97841f366e32d1087d135bdda8edbb14c1399..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-common.h
> +++ /dev/null
> @@ -1,60 +0,0 @@
> -/* SPDX-License-Identifier: GPL-2.0 */
> -/*
> - * c8sectpfe-common.h - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author: Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#ifndef _C8SECTPFE_COMMON_H_
> -#define _C8SECTPFE_COMMON_H_
> -
> -#include <linux/dvb/dmx.h>
> -#include <linux/dvb/frontend.h>
> -#include <linux/gpio.h>
> -
> -#include <media/dmxdev.h>
> -#include <media/dvb_demux.h>
> -#include <media/dvb_frontend.h>
> -#include <media/dvb_net.h>
> -
> -/* Maximum number of channels */
> -#define C8SECTPFE_MAXADAPTER (4)
> -#define C8SECTPFE_MAXCHANNEL 64
> -#define STPTI_MAXCHANNEL 64
> -
> -#define MAX_INPUTBLOCKS 7
> -
> -struct c8sectpfe;
> -struct stdemux;
> -
> -struct stdemux {
> - struct dvb_demux dvb_demux;
> - struct dmxdev dmxdev;
> - struct dmx_frontend hw_frontend;
> - struct dmx_frontend mem_frontend;
> - int tsin_index;
> - int running_feed_count;
> - struct c8sectpfei *c8sectpfei;
> -};
> -
> -struct c8sectpfe {
> - struct stdemux demux[MAX_INPUTBLOCKS];
> - struct mutex lock;
> - struct dvb_adapter adapter;
> - struct device *device;
> - int mapping;
> - int num_feeds;
> -};
> -
> -/* Channel registration */
> -int c8sectpfe_tuner_register_frontend(struct c8sectpfe **c8sectpfe,
> - struct c8sectpfei *fei,
> - void *start_feed,
> - void *stop_feed);
> -
> -void c8sectpfe_tuner_unregister_frontend(struct c8sectpfe *c8sectpfe,
> - struct c8sectpfei *fei);
> -
> -#endif
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c
> deleted file mode 100644
> index 89bd15a4d26a95be5576ba5f666fa20f4d010728..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.c
> +++ /dev/null
> @@ -1,1158 +0,0 @@
> -// SPDX-License-Identifier: GPL-2.0
> -/*
> - * c8sectpfe-core.c - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author:Peter Bennett <peter.bennett@st.com>
> - * Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#include <linux/atomic.h>
> -#include <linux/clk.h>
> -#include <linux/completion.h>
> -#include <linux/delay.h>
> -#include <linux/device.h>
> -#include <linux/dma-mapping.h>
> -#include <linux/dvb/dmx.h>
> -#include <linux/dvb/frontend.h>
> -#include <linux/err.h>
> -#include <linux/errno.h>
> -#include <linux/firmware.h>
> -#include <linux/gpio/consumer.h>
> -#include <linux/init.h>
> -#include <linux/interrupt.h>
> -#include <linux/io.h>
> -#include <linux/module.h>
> -#include <linux/of_platform.h>
> -#include <linux/pinctrl/consumer.h>
> -#include <linux/pinctrl/pinctrl.h>
> -#include <linux/platform_device.h>
> -#include <linux/slab.h>
> -#include <linux/time.h>
> -#include <linux/usb.h>
> -#include <linux/wait.h>
> -
> -#include "c8sectpfe-common.h"
> -#include "c8sectpfe-core.h"
> -#include "c8sectpfe-debugfs.h"
> -
> -#include <media/dmxdev.h>
> -#include <media/dvb_demux.h>
> -#include <media/dvb_frontend.h>
> -#include <media/dvb_net.h>
> -
> -#define FIRMWARE_MEMDMA "pti_memdma_h407.elf"
> -MODULE_FIRMWARE(FIRMWARE_MEMDMA);
> -
> -#define PID_TABLE_SIZE 1024
> -#define POLL_MSECS 50
> -
> -static int load_c8sectpfe_fw(struct c8sectpfei *fei);
> -
> -#define TS_PKT_SIZE 188
> -#define HEADER_SIZE (4)
> -#define PACKET_SIZE (TS_PKT_SIZE+HEADER_SIZE)
> -
> -#define FEI_ALIGNMENT (32)
> -/* hw requires minimum of 8*PACKET_SIZE and padded to 8byte boundary */
> -#define FEI_BUFFER_SIZE (8*PACKET_SIZE*340)
> -
> -#define FIFO_LEN 1024
> -
> -static void c8sectpfe_timer_interrupt(struct timer_list *t)
> -{
> - struct c8sectpfei *fei = timer_container_of(fei, t, timer);
> - struct channel_info *channel;
> - int chan_num;
> -
> - /* iterate through input block channels */
> - for (chan_num = 0; chan_num < fei->tsin_count; chan_num++) {
> - channel = fei->channel_data[chan_num];
> -
> - /* is this descriptor initialised and TP enabled */
> - if (channel->irec && readl(channel->irec + DMA_PRDS_TPENABLE))
> - queue_work(system_bh_wq, &channel->bh_work);
> - }
> -
> - fei->timer.expires = jiffies + msecs_to_jiffies(POLL_MSECS);
> - add_timer(&fei->timer);
> -}
> -
> -static void channel_swdemux_bh_work(struct work_struct *t)
> -{
> - struct channel_info *channel = from_work(channel, t, bh_work);
> - struct c8sectpfei *fei;
> - unsigned long wp, rp;
> - int pos, num_packets, n, size;
> - u8 *buf;
> -
> - if (unlikely(!channel || !channel->irec))
> - return;
> -
> - fei = channel->fei;
> -
> - wp = readl(channel->irec + DMA_PRDS_BUSWP_TP(0));
> - rp = readl(channel->irec + DMA_PRDS_BUSRP_TP(0));
> -
> - pos = rp - channel->back_buffer_busaddr;
> -
> - /* has it wrapped */
> - if (wp < rp)
> - wp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE;
> -
> - size = wp - rp;
> - num_packets = size / PACKET_SIZE;
> -
> - /* manage cache so data is visible to CPU */
> - dma_sync_single_for_cpu(fei->dev,
> - rp,
> - size,
> - DMA_FROM_DEVICE);
> -
> - buf = channel->back_buffer_aligned;
> -
> - dev_dbg(fei->dev,
> - "chan=%d channel=%p num_packets = %d, buf = %p, pos = 0x%x\n\trp=0x%lx, wp=0x%lx\n",
> - channel->tsin_id, channel, num_packets, buf, pos, rp, wp);
> -
> - for (n = 0; n < num_packets; n++) {
> - dvb_dmx_swfilter_packets(
> - &fei->c8sectpfe[0]->
> - demux[channel->demux_mapping].dvb_demux,
> - &buf[pos], 1);
> -
> - pos += PACKET_SIZE;
> - }
> -
> - /* advance the read pointer */
> - if (wp == (channel->back_buffer_busaddr + FEI_BUFFER_SIZE))
> - writel(channel->back_buffer_busaddr, channel->irec +
> - DMA_PRDS_BUSRP_TP(0));
> - else
> - writel(wp, channel->irec + DMA_PRDS_BUSRP_TP(0));
> -}
> -
> -static int c8sectpfe_start_feed(struct dvb_demux_feed *dvbdmxfeed)
> -{
> - struct dvb_demux *demux = dvbdmxfeed->demux;
> - struct stdemux *stdemux = demux->priv;
> - struct c8sectpfei *fei = stdemux->c8sectpfei;
> - struct channel_info *channel;
> - u32 tmp;
> - unsigned long *bitmap;
> - int ret;
> -
> - switch (dvbdmxfeed->type) {
> - case DMX_TYPE_TS:
> - break;
> - case DMX_TYPE_SEC:
> - break;
> - default:
> - dev_err(fei->dev, "%s:%d Error bailing\n"
> - , __func__, __LINE__);
> - return -EINVAL;
> - }
> -
> - if (dvbdmxfeed->type == DMX_TYPE_TS) {
> - switch (dvbdmxfeed->pes_type) {
> - case DMX_PES_VIDEO:
> - case DMX_PES_AUDIO:
> - case DMX_PES_TELETEXT:
> - case DMX_PES_PCR:
> - case DMX_PES_OTHER:
> - break;
> - default:
> - dev_err(fei->dev, "%s:%d Error bailing\n"
> - , __func__, __LINE__);
> - return -EINVAL;
> - }
> - }
> -
> - if (!atomic_read(&fei->fw_loaded)) {
> - ret = load_c8sectpfe_fw(fei);
> - if (ret)
> - return ret;
> - }
> -
> - mutex_lock(&fei->lock);
> -
> - channel = fei->channel_data[stdemux->tsin_index];
> -
> - bitmap = channel->pid_buffer_aligned;
> -
> - /* 8192 is a special PID */
> - if (dvbdmxfeed->pid == 8192) {
> - tmp = readl(fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
> - tmp &= ~C8SECTPFE_PID_ENABLE;
> - writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
> -
> - } else {
> - bitmap_set(bitmap, dvbdmxfeed->pid, 1);
> - }
> -
> - /* manage cache so PID bitmap is visible to HW */
> - dma_sync_single_for_device(fei->dev,
> - channel->pid_buffer_busaddr,
> - PID_TABLE_SIZE,
> - DMA_TO_DEVICE);
> -
> - channel->active = 1;
> -
> - if (fei->global_feed_count == 0) {
> - fei->timer.expires = jiffies +
> - msecs_to_jiffies(msecs_to_jiffies(POLL_MSECS));
> -
> - add_timer(&fei->timer);
> - }
> -
> - if (stdemux->running_feed_count == 0) {
> -
> - dev_dbg(fei->dev, "Starting channel=%p\n", channel);
> -
> - INIT_WORK(&channel->bh_work, channel_swdemux_bh_work);
> -
> - /* Reset the internal inputblock sram pointers */
> - writel(channel->fifo,
> - fei->io + C8SECTPFE_IB_BUFF_STRT(channel->tsin_id));
> - writel(channel->fifo + FIFO_LEN - 1,
> - fei->io + C8SECTPFE_IB_BUFF_END(channel->tsin_id));
> -
> - writel(channel->fifo,
> - fei->io + C8SECTPFE_IB_READ_PNT(channel->tsin_id));
> - writel(channel->fifo,
> - fei->io + C8SECTPFE_IB_WRT_PNT(channel->tsin_id));
> -
> -
> - /* reset read / write memdma ptrs for this channel */
> - writel(channel->back_buffer_busaddr, channel->irec +
> - DMA_PRDS_BUSBASE_TP(0));
> -
> - tmp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
> - writel(tmp, channel->irec + DMA_PRDS_BUSTOP_TP(0));
> -
> - writel(channel->back_buffer_busaddr, channel->irec +
> - DMA_PRDS_BUSWP_TP(0));
> -
> - /* Issue a reset and enable InputBlock */
> - writel(C8SECTPFE_SYS_ENABLE | C8SECTPFE_SYS_RESET
> - , fei->io + C8SECTPFE_IB_SYS(channel->tsin_id));
> -
> - /* and enable the tp */
> - writel(0x1, channel->irec + DMA_PRDS_TPENABLE);
> -
> - dev_dbg(fei->dev, "%s:%d Starting DMA feed on stdemux=%p\n"
> - , __func__, __LINE__, stdemux);
> - }
> -
> - stdemux->running_feed_count++;
> - fei->global_feed_count++;
> -
> - mutex_unlock(&fei->lock);
> -
> - return 0;
> -}
> -
> -static int c8sectpfe_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
> -{
> -
> - struct dvb_demux *demux = dvbdmxfeed->demux;
> - struct stdemux *stdemux = demux->priv;
> - struct c8sectpfei *fei = stdemux->c8sectpfei;
> - struct channel_info *channel;
> - int idlereq;
> - u32 tmp;
> - int ret;
> - unsigned long *bitmap;
> -
> - if (!atomic_read(&fei->fw_loaded)) {
> - ret = load_c8sectpfe_fw(fei);
> - if (ret)
> - return ret;
> - }
> -
> - mutex_lock(&fei->lock);
> -
> - channel = fei->channel_data[stdemux->tsin_index];
> -
> - bitmap = channel->pid_buffer_aligned;
> -
> - if (dvbdmxfeed->pid == 8192) {
> - tmp = readl(fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
> - tmp |= C8SECTPFE_PID_ENABLE;
> - writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(channel->tsin_id));
> - } else {
> - bitmap_clear(bitmap, dvbdmxfeed->pid, 1);
> - }
> -
> - /* manage cache so data is visible to HW */
> - dma_sync_single_for_device(fei->dev,
> - channel->pid_buffer_busaddr,
> - PID_TABLE_SIZE,
> - DMA_TO_DEVICE);
> -
> - if (--stdemux->running_feed_count == 0) {
> -
> - channel = fei->channel_data[stdemux->tsin_index];
> -
> - /* TP re-configuration on page 168 of functional spec */
> -
> - /* disable IB (prevents more TS data going to memdma) */
> - writel(0, fei->io + C8SECTPFE_IB_SYS(channel->tsin_id));
> -
> - /* disable this channels descriptor */
> - writel(0, channel->irec + DMA_PRDS_TPENABLE);
> -
> - disable_work_sync(&channel->bh_work);
> -
> - /* now request memdma channel goes idle */
> - idlereq = (1 << channel->tsin_id) | IDLEREQ;
> - writel(idlereq, fei->io + DMA_IDLE_REQ);
> -
> - /* wait for idle irq handler to signal completion */
> - ret = wait_for_completion_timeout(&channel->idle_completion,
> - msecs_to_jiffies(100));
> -
> - if (ret == 0)
> - dev_warn(fei->dev,
> - "Timeout waiting for idle irq on tsin%d\n",
> - channel->tsin_id);
> -
> - reinit_completion(&channel->idle_completion);
> -
> - /* reset read / write ptrs for this channel */
> -
> - writel(channel->back_buffer_busaddr,
> - channel->irec + DMA_PRDS_BUSBASE_TP(0));
> -
> - tmp = channel->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
> - writel(tmp, channel->irec + DMA_PRDS_BUSTOP_TP(0));
> -
> - writel(channel->back_buffer_busaddr,
> - channel->irec + DMA_PRDS_BUSWP_TP(0));
> -
> - dev_dbg(fei->dev,
> - "%s:%d stopping DMA feed on stdemux=%p channel=%d\n",
> - __func__, __LINE__, stdemux, channel->tsin_id);
> -
> - /* turn off all PIDS in the bitmap */
> - memset(channel->pid_buffer_aligned, 0, PID_TABLE_SIZE);
> -
> - /* manage cache so data is visible to HW */
> - dma_sync_single_for_device(fei->dev,
> - channel->pid_buffer_busaddr,
> - PID_TABLE_SIZE,
> - DMA_TO_DEVICE);
> -
> - channel->active = 0;
> - }
> -
> - if (--fei->global_feed_count == 0) {
> - dev_dbg(fei->dev, "%s:%d global_feed_count=%d\n"
> - , __func__, __LINE__, fei->global_feed_count);
> -
> - timer_delete(&fei->timer);
> - }
> -
> - mutex_unlock(&fei->lock);
> -
> - return 0;
> -}
> -
> -static struct channel_info *find_channel(struct c8sectpfei *fei, int tsin_num)
> -{
> - int i;
> -
> - for (i = 0; i < C8SECTPFE_MAX_TSIN_CHAN; i++) {
> - if (!fei->channel_data[i])
> - continue;
> -
> - if (fei->channel_data[i]->tsin_id == tsin_num)
> - return fei->channel_data[i];
> - }
> -
> - return NULL;
> -}
> -
> -static void c8sectpfe_getconfig(struct c8sectpfei *fei)
> -{
> - struct c8sectpfe_hw *hw = &fei->hw_stats;
> -
> - hw->num_ib = readl(fei->io + SYS_CFG_NUM_IB);
> - hw->num_mib = readl(fei->io + SYS_CFG_NUM_MIB);
> - hw->num_swts = readl(fei->io + SYS_CFG_NUM_SWTS);
> - hw->num_tsout = readl(fei->io + SYS_CFG_NUM_TSOUT);
> - hw->num_ccsc = readl(fei->io + SYS_CFG_NUM_CCSC);
> - hw->num_ram = readl(fei->io + SYS_CFG_NUM_RAM);
> - hw->num_tp = readl(fei->io + SYS_CFG_NUM_TP);
> -
> - dev_info(fei->dev, "C8SECTPFE hw supports the following:\n");
> - dev_info(fei->dev, "Input Blocks: %d\n", hw->num_ib);
> - dev_info(fei->dev, "Merged Input Blocks: %d\n", hw->num_mib);
> - dev_info(fei->dev, "Software Transport Stream Inputs: %d\n"
> - , hw->num_swts);
> - dev_info(fei->dev, "Transport Stream Output: %d\n", hw->num_tsout);
> - dev_info(fei->dev, "Cable Card Converter: %d\n", hw->num_ccsc);
> - dev_info(fei->dev, "RAMs supported by C8SECTPFE: %d\n", hw->num_ram);
> - dev_info(fei->dev, "Tango TPs supported by C8SECTPFE: %d\n"
> - , hw->num_tp);
> -}
> -
> -static irqreturn_t c8sectpfe_idle_irq_handler(int irq, void *priv)
> -{
> - struct c8sectpfei *fei = priv;
> - struct channel_info *chan;
> - int bit;
> - unsigned long tmp = readl(fei->io + DMA_IDLE_REQ);
> -
> - /* page 168 of functional spec: Clear the idle request
> - by writing 0 to the C8SECTPFE_DMA_IDLE_REQ register. */
> -
> - /* signal idle completion */
> - for_each_set_bit(bit, &tmp, fei->hw_stats.num_ib) {
> -
> - chan = find_channel(fei, bit);
> -
> - if (chan)
> - complete(&chan->idle_completion);
> - }
> -
> - writel(0, fei->io + DMA_IDLE_REQ);
> -
> - return IRQ_HANDLED;
> -}
> -
> -
> -static void free_input_block(struct c8sectpfei *fei, struct channel_info *tsin)
> -{
> - if (!fei || !tsin)
> - return;
> -
> - if (tsin->back_buffer_busaddr)
> - if (!dma_mapping_error(fei->dev, tsin->back_buffer_busaddr))
> - dma_unmap_single(fei->dev, tsin->back_buffer_busaddr,
> - FEI_BUFFER_SIZE, DMA_BIDIRECTIONAL);
> -
> - kfree(tsin->back_buffer_start);
> -
> - if (tsin->pid_buffer_busaddr)
> - if (!dma_mapping_error(fei->dev, tsin->pid_buffer_busaddr))
> - dma_unmap_single(fei->dev, tsin->pid_buffer_busaddr,
> - PID_TABLE_SIZE, DMA_BIDIRECTIONAL);
> -
> - kfree(tsin->pid_buffer_start);
> -}
> -
> -#define MAX_NAME 20
> -
> -static int configure_memdma_and_inputblock(struct c8sectpfei *fei,
> - struct channel_info *tsin)
> -{
> - int ret;
> - u32 tmp;
> - char tsin_pin_name[MAX_NAME];
> -
> - if (!fei || !tsin)
> - return -EINVAL;
> -
> - dev_dbg(fei->dev, "%s:%d Configuring channel=%p tsin=%d\n"
> - , __func__, __LINE__, tsin, tsin->tsin_id);
> -
> - init_completion(&tsin->idle_completion);
> -
> - tsin->back_buffer_start = kzalloc(FEI_BUFFER_SIZE + FEI_ALIGNMENT, GFP_KERNEL);
> - if (!tsin->back_buffer_start) {
> - ret = -ENOMEM;
> - goto err_unmap;
> - }
> -
> - /* Ensure backbuffer is 32byte aligned */
> - tsin->back_buffer_aligned = tsin->back_buffer_start + FEI_ALIGNMENT;
> -
> - tsin->back_buffer_aligned = PTR_ALIGN(tsin->back_buffer_aligned, FEI_ALIGNMENT);
> -
> - tsin->back_buffer_busaddr = dma_map_single(fei->dev,
> - tsin->back_buffer_aligned,
> - FEI_BUFFER_SIZE,
> - DMA_BIDIRECTIONAL);
> -
> - if (dma_mapping_error(fei->dev, tsin->back_buffer_busaddr)) {
> - dev_err(fei->dev, "failed to map back_buffer\n");
> - ret = -EFAULT;
> - goto err_unmap;
> - }
> -
> - /*
> - * The pid buffer can be configured (in hw) for byte or bit
> - * per pid. By powers of deduction we conclude stih407 family
> - * is configured (at SoC design stage) for bit per pid.
> - */
> - tsin->pid_buffer_start = kzalloc(PID_TABLE_SIZE + PID_TABLE_SIZE, GFP_KERNEL);
> - if (!tsin->pid_buffer_start) {
> - ret = -ENOMEM;
> - goto err_unmap;
> - }
> -
> - /*
> - * PID buffer needs to be aligned to size of the pid table
> - * which at bit per pid is 1024 bytes (8192 pids / 8).
> - * PIDF_BASE register enforces this alignment when writing
> - * the register.
> - */
> -
> - tsin->pid_buffer_aligned = tsin->pid_buffer_start + PID_TABLE_SIZE;
> -
> - tsin->pid_buffer_aligned = PTR_ALIGN(tsin->pid_buffer_aligned, PID_TABLE_SIZE);
> -
> - tsin->pid_buffer_busaddr = dma_map_single(fei->dev,
> - tsin->pid_buffer_aligned,
> - PID_TABLE_SIZE,
> - DMA_BIDIRECTIONAL);
> -
> - if (dma_mapping_error(fei->dev, tsin->pid_buffer_busaddr)) {
> - dev_err(fei->dev, "failed to map pid_bitmap\n");
> - ret = -EFAULT;
> - goto err_unmap;
> - }
> -
> - /* manage cache so pid bitmap is visible to HW */
> - dma_sync_single_for_device(fei->dev,
> - tsin->pid_buffer_busaddr,
> - PID_TABLE_SIZE,
> - DMA_TO_DEVICE);
> -
> - snprintf(tsin_pin_name, MAX_NAME, "tsin%d-%s", tsin->tsin_id,
> - (tsin->serial_not_parallel ? "serial" : "parallel"));
> -
> - tsin->pstate = pinctrl_lookup_state(fei->pinctrl, tsin_pin_name);
> - if (IS_ERR(tsin->pstate)) {
> - dev_err(fei->dev, "%s: pinctrl_lookup_state couldn't find %s state\n"
> - , __func__, tsin_pin_name);
> - ret = PTR_ERR(tsin->pstate);
> - goto err_unmap;
> - }
> -
> - ret = pinctrl_select_state(fei->pinctrl, tsin->pstate);
> -
> - if (ret) {
> - dev_err(fei->dev, "%s: pinctrl_select_state failed\n"
> - , __func__);
> - goto err_unmap;
> - }
> -
> - /* Enable this input block */
> - tmp = readl(fei->io + SYS_INPUT_CLKEN);
> - tmp |= BIT(tsin->tsin_id);
> - writel(tmp, fei->io + SYS_INPUT_CLKEN);
> -
> - if (tsin->serial_not_parallel)
> - tmp |= C8SECTPFE_SERIAL_NOT_PARALLEL;
> -
> - if (tsin->invert_ts_clk)
> - tmp |= C8SECTPFE_INVERT_TSCLK;
> -
> - if (tsin->async_not_sync)
> - tmp |= C8SECTPFE_ASYNC_NOT_SYNC;
> -
> - tmp |= C8SECTPFE_ALIGN_BYTE_SOP | C8SECTPFE_BYTE_ENDIANNESS_MSB;
> -
> - writel(tmp, fei->io + C8SECTPFE_IB_IP_FMT_CFG(tsin->tsin_id));
> -
> - writel(C8SECTPFE_SYNC(0x9) |
> - C8SECTPFE_DROP(0x9) |
> - C8SECTPFE_TOKEN(0x47),
> - fei->io + C8SECTPFE_IB_SYNCLCKDRP_CFG(tsin->tsin_id));
> -
> - writel(TS_PKT_SIZE, fei->io + C8SECTPFE_IB_PKT_LEN(tsin->tsin_id));
> -
> - /* Place the FIFO's at the end of the irec descriptors */
> -
> - tsin->fifo = (tsin->tsin_id * FIFO_LEN);
> -
> - writel(tsin->fifo, fei->io + C8SECTPFE_IB_BUFF_STRT(tsin->tsin_id));
> - writel(tsin->fifo + FIFO_LEN - 1,
> - fei->io + C8SECTPFE_IB_BUFF_END(tsin->tsin_id));
> -
> - writel(tsin->fifo, fei->io + C8SECTPFE_IB_READ_PNT(tsin->tsin_id));
> - writel(tsin->fifo, fei->io + C8SECTPFE_IB_WRT_PNT(tsin->tsin_id));
> -
> - writel(tsin->pid_buffer_busaddr,
> - fei->io + PIDF_BASE(tsin->tsin_id));
> -
> - dev_dbg(fei->dev, "chan=%d PIDF_BASE=0x%x pid_bus_addr=%pad\n",
> - tsin->tsin_id, readl(fei->io + PIDF_BASE(tsin->tsin_id)),
> - &tsin->pid_buffer_busaddr);
> -
> - /* Configure and enable HW PID filtering */
> -
> - /*
> - * The PID value is created by assembling the first 8 bytes of
> - * the TS packet into a 64-bit word in big-endian format. A
> - * slice of that 64-bit word is taken from
> - * (PID_OFFSET+PID_NUM_BITS-1) to PID_OFFSET.
> - */
> - tmp = (C8SECTPFE_PID_ENABLE | C8SECTPFE_PID_NUMBITS(13)
> - | C8SECTPFE_PID_OFFSET(40));
> -
> - writel(tmp, fei->io + C8SECTPFE_IB_PID_SET(tsin->tsin_id));
> -
> - dev_dbg(fei->dev, "chan=%d setting wp: %d, rp: %d, buf: %d-%d\n",
> - tsin->tsin_id,
> - readl(fei->io + C8SECTPFE_IB_WRT_PNT(tsin->tsin_id)),
> - readl(fei->io + C8SECTPFE_IB_READ_PNT(tsin->tsin_id)),
> - readl(fei->io + C8SECTPFE_IB_BUFF_STRT(tsin->tsin_id)),
> - readl(fei->io + C8SECTPFE_IB_BUFF_END(tsin->tsin_id)));
> -
> - /* Get base addpress of pointer record block from DMEM */
> - tsin->irec = fei->io + DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET +
> - readl(fei->io + DMA_PTRREC_BASE);
> -
> - /* fill out pointer record data structure */
> -
> - /* advance pointer record block to our channel */
> - tsin->irec += (tsin->tsin_id * DMA_PRDS_SIZE);
> -
> - writel(tsin->fifo, tsin->irec + DMA_PRDS_MEMBASE);
> -
> - writel(tsin->fifo + FIFO_LEN - 1, tsin->irec + DMA_PRDS_MEMTOP);
> -
> - writel((188 + 7)&~7, tsin->irec + DMA_PRDS_PKTSIZE);
> -
> - writel(0x1, tsin->irec + DMA_PRDS_TPENABLE);
> -
> - /* read/write pointers with physical bus address */
> -
> - writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSBASE_TP(0));
> -
> - tmp = tsin->back_buffer_busaddr + FEI_BUFFER_SIZE - 1;
> - writel(tmp, tsin->irec + DMA_PRDS_BUSTOP_TP(0));
> -
> - writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSWP_TP(0));
> - writel(tsin->back_buffer_busaddr, tsin->irec + DMA_PRDS_BUSRP_TP(0));
> -
> - /* initialize bh work */
> - INIT_WORK(&tsin->bh_work, channel_swdemux_bh_work);
> -
> - return 0;
> -
> -err_unmap:
> - free_input_block(fei, tsin);
> - return ret;
> -}
> -
> -static irqreturn_t c8sectpfe_error_irq_handler(int irq, void *priv)
> -{
> - struct c8sectpfei *fei = priv;
> -
> - dev_err(fei->dev, "%s: error handling not yet implemented\n"
> - , __func__);
> -
> - /*
> - * TODO FIXME we should detect some error conditions here
> - * and ideally do something about them!
> - */
> -
> - return IRQ_HANDLED;
> -}
> -
> -static int c8sectpfe_probe(struct platform_device *pdev)
> -{
> - struct device *dev = &pdev->dev;
> - struct device_node *np = dev->of_node;
> - struct c8sectpfei *fei;
> - struct resource *res;
> - int ret, index = 0;
> - struct channel_info *tsin;
> -
> - /* Allocate the c8sectpfei structure */
> - fei = devm_kzalloc(dev, sizeof(struct c8sectpfei), GFP_KERNEL);
> - if (!fei)
> - return -ENOMEM;
> -
> - fei->dev = dev;
> -
> - res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "c8sectpfe");
> - fei->io = devm_ioremap_resource(dev, res);
> - if (IS_ERR(fei->io))
> - return PTR_ERR(fei->io);
> -
> - res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
> - "c8sectpfe-ram");
> - fei->sram = devm_ioremap_resource(dev, res);
> - if (IS_ERR(fei->sram))
> - return PTR_ERR(fei->sram);
> -
> - fei->sram_size = resource_size(res);
> -
> - fei->idle_irq = platform_get_irq_byname(pdev, "c8sectpfe-idle-irq");
> - if (fei->idle_irq < 0)
> - return fei->idle_irq;
> -
> - fei->error_irq = platform_get_irq_byname(pdev, "c8sectpfe-error-irq");
> - if (fei->error_irq < 0)
> - return fei->error_irq;
> -
> - platform_set_drvdata(pdev, fei);
> -
> - fei->c8sectpfeclk = devm_clk_get_enabled(dev, "c8sectpfe");
> - if (IS_ERR(fei->c8sectpfeclk)) {
> - dev_err(dev, "Failed to enable c8sectpfe clock\n");
> - return PTR_ERR(fei->c8sectpfeclk);
> - }
> -
> - /* to save power disable all IP's (on by default) */
> - writel(0, fei->io + SYS_INPUT_CLKEN);
> -
> - /* Enable memdma clock */
> - writel(MEMDMAENABLE, fei->io + SYS_OTHER_CLKEN);
> -
> - /* clear internal sram */
> - memset_io(fei->sram, 0x0, fei->sram_size);
> -
> - c8sectpfe_getconfig(fei);
> -
> - ret = devm_request_irq(dev, fei->idle_irq, c8sectpfe_idle_irq_handler,
> - 0, "c8sectpfe-idle-irq", fei);
> - if (ret) {
> - dev_err(dev, "Can't register c8sectpfe-idle-irq IRQ.\n");
> - return ret;
> - }
> -
> - ret = devm_request_irq(dev, fei->error_irq,
> - c8sectpfe_error_irq_handler, 0,
> - "c8sectpfe-error-irq", fei);
> - if (ret) {
> - dev_err(dev, "Can't register c8sectpfe-error-irq IRQ.\n");
> - return ret;
> - }
> -
> - fei->tsin_count = of_get_child_count(np);
> -
> - if (fei->tsin_count > C8SECTPFE_MAX_TSIN_CHAN ||
> - fei->tsin_count > fei->hw_stats.num_ib) {
> -
> - dev_err(dev, "More tsin declared than exist on SoC!\n");
> - return -EINVAL;
> - }
> -
> - fei->pinctrl = devm_pinctrl_get(dev);
> -
> - if (IS_ERR(fei->pinctrl)) {
> - dev_err(dev, "Error getting tsin pins\n");
> - return PTR_ERR(fei->pinctrl);
> - }
> -
> - for_each_child_of_node_scoped(np, child) {
> - struct device_node *i2c_bus;
> -
> - fei->channel_data[index] = devm_kzalloc(dev,
> - sizeof(struct channel_info),
> - GFP_KERNEL);
> -
> - if (!fei->channel_data[index])
> - return -ENOMEM;
> -
> - tsin = fei->channel_data[index];
> -
> - tsin->fei = fei;
> -
> - ret = of_property_read_u32(child, "tsin-num", &tsin->tsin_id);
> - if (ret) {
> - dev_err(&pdev->dev, "No tsin_num found\n");
> - return ret;
> - }
> -
> - /* sanity check value */
> - if (tsin->tsin_id > fei->hw_stats.num_ib) {
> - dev_err(&pdev->dev,
> - "tsin-num %d specified greater than number\n\tof input block hw in SoC! (%d)",
> - tsin->tsin_id, fei->hw_stats.num_ib);
> - return -EINVAL;
> - }
> -
> - tsin->invert_ts_clk = of_property_read_bool(child,
> - "invert-ts-clk");
> -
> - tsin->serial_not_parallel = of_property_read_bool(child,
> - "serial-not-parallel");
> -
> - tsin->async_not_sync = of_property_read_bool(child,
> - "async-not-sync");
> -
> - ret = of_property_read_u32(child, "dvb-card",
> - &tsin->dvb_card);
> - if (ret) {
> - dev_err(&pdev->dev, "No dvb-card found\n");
> - return ret;
> - }
> -
> - i2c_bus = of_parse_phandle(child, "i2c-bus", 0);
> - if (!i2c_bus) {
> - dev_err(&pdev->dev, "No i2c-bus found\n");
> - return -ENODEV;
> - }
> - tsin->i2c_adapter =
> - of_find_i2c_adapter_by_node(i2c_bus);
> - of_node_put(i2c_bus);
> - if (!tsin->i2c_adapter) {
> - dev_err(&pdev->dev, "No i2c adapter found\n");
> - return -ENODEV;
> - }
> -
> - /* Acquire reset GPIO and activate it */
> - tsin->rst_gpio = devm_fwnode_gpiod_get(dev,
> - of_fwnode_handle(child),
> - "reset", GPIOD_OUT_HIGH,
> - "NIM reset");
> - ret = PTR_ERR_OR_ZERO(tsin->rst_gpio);
> - if (ret && ret != -EBUSY) {
> - dev_err(dev, "Can't request tsin%d reset gpio\n",
> - fei->channel_data[index]->tsin_id);
> - return ret;
> - }
> -
> - if (!ret) {
> - /* wait for the chip to reset */
> - usleep_range(3500, 5000);
> - /* release the reset line */
> - gpiod_set_value_cansleep(tsin->rst_gpio, 0);
> - usleep_range(3000, 5000);
> - }
> -
> - tsin->demux_mapping = index;
> -
> - dev_dbg(fei->dev,
> - "channel=%p n=%d tsin_num=%d, invert-ts-clk=%d\n\tserial-not-parallel=%d pkt-clk-valid=%d dvb-card=%d\n",
> - fei->channel_data[index], index,
> - tsin->tsin_id, tsin->invert_ts_clk,
> - tsin->serial_not_parallel, tsin->async_not_sync,
> - tsin->dvb_card);
> -
> - index++;
> - }
> -
> - /* Setup timer interrupt */
> - timer_setup(&fei->timer, c8sectpfe_timer_interrupt, 0);
> -
> - mutex_init(&fei->lock);
> -
> - /* Get the configuration information about the tuners */
> - ret = c8sectpfe_tuner_register_frontend(&fei->c8sectpfe[0],
> - (void *)fei,
> - c8sectpfe_start_feed,
> - c8sectpfe_stop_feed);
> - if (ret) {
> - dev_err(dev, "c8sectpfe_tuner_register_frontend failed (%d)\n",
> - ret);
> - return ret;
> - }
> -
> - c8sectpfe_debugfs_init(fei);
> -
> - return 0;
> -}
> -
> -static void c8sectpfe_remove(struct platform_device *pdev)
> -{
> - struct c8sectpfei *fei = platform_get_drvdata(pdev);
> - struct channel_info *channel;
> - int i;
> -
> - wait_for_completion(&fei->fw_ack);
> -
> - c8sectpfe_tuner_unregister_frontend(fei->c8sectpfe[0], fei);
> -
> - /*
> - * Now loop through and un-configure each of the InputBlock resources
> - */
> - for (i = 0; i < fei->tsin_count; i++) {
> - channel = fei->channel_data[i];
> - free_input_block(fei, channel);
> - }
> -
> - c8sectpfe_debugfs_exit(fei);
> -
> - dev_info(fei->dev, "Stopping memdma SLIM core\n");
> - if (readl(fei->io + DMA_CPU_RUN))
> - writel(0x0, fei->io + DMA_CPU_RUN);
> -
> - /* unclock all internal IP's */
> - if (readl(fei->io + SYS_INPUT_CLKEN))
> - writel(0, fei->io + SYS_INPUT_CLKEN);
> -
> - if (readl(fei->io + SYS_OTHER_CLKEN))
> - writel(0, fei->io + SYS_OTHER_CLKEN);
> -}
> -
> -
> -static int configure_channels(struct c8sectpfei *fei)
> -{
> - int index = 0, ret;
> - struct device_node *np = fei->dev->of_node;
> -
> - /* iterate round each tsin and configure memdma descriptor and IB hw */
> - for_each_child_of_node_scoped(np, child) {
> - ret = configure_memdma_and_inputblock(fei,
> - fei->channel_data[index]);
> - if (ret) {
> - dev_err(fei->dev,
> - "configure_memdma_and_inputblock failed\n");
> - goto err_unmap;
> - }
> - index++;
> - }
> -
> - return 0;
> -
> -err_unmap:
> - while (--index >= 0)
> - free_input_block(fei, fei->channel_data[index]);
> -
> - return ret;
> -}
> -
> -static int
> -c8sectpfe_elf_sanity_check(struct c8sectpfei *fei, const struct firmware *fw)
> -{
> - struct elf32_hdr *ehdr;
> - char class;
> -
> - if (!fw) {
> - dev_err(fei->dev, "failed to load %s\n", FIRMWARE_MEMDMA);
> - return -EINVAL;
> - }
> -
> - if (fw->size < sizeof(struct elf32_hdr)) {
> - dev_err(fei->dev, "Image is too small\n");
> - return -EINVAL;
> - }
> -
> - ehdr = (struct elf32_hdr *)fw->data;
> -
> - /* We only support ELF32 at this point */
> - class = ehdr->e_ident[EI_CLASS];
> - if (class != ELFCLASS32) {
> - dev_err(fei->dev, "Unsupported class: %d\n", class);
> - return -EINVAL;
> - }
> -
> - if (ehdr->e_ident[EI_DATA] != ELFDATA2LSB) {
> - dev_err(fei->dev, "Unsupported firmware endianness\n");
> - return -EINVAL;
> - }
> -
> - if (fw->size < ehdr->e_shoff + sizeof(struct elf32_shdr)) {
> - dev_err(fei->dev, "Image is too small\n");
> - return -EINVAL;
> - }
> -
> - if (memcmp(ehdr->e_ident, ELFMAG, SELFMAG)) {
> - dev_err(fei->dev, "Image is corrupted (bad magic)\n");
> - return -EINVAL;
> - }
> -
> - /* Check ELF magic */
> - ehdr = (Elf32_Ehdr *)fw->data;
> - if (ehdr->e_ident[EI_MAG0] != ELFMAG0 ||
> - ehdr->e_ident[EI_MAG1] != ELFMAG1 ||
> - ehdr->e_ident[EI_MAG2] != ELFMAG2 ||
> - ehdr->e_ident[EI_MAG3] != ELFMAG3) {
> - dev_err(fei->dev, "Invalid ELF magic\n");
> - return -EINVAL;
> - }
> -
> - if (ehdr->e_type != ET_EXEC) {
> - dev_err(fei->dev, "Unsupported ELF header type\n");
> - return -EINVAL;
> - }
> -
> - if (ehdr->e_phoff > fw->size) {
> - dev_err(fei->dev, "Firmware size is too small\n");
> - return -EINVAL;
> - }
> -
> - return 0;
> -}
> -
> -
> -static void load_imem_segment(struct c8sectpfei *fei, Elf32_Phdr *phdr,
> - const struct firmware *fw, u8 __iomem *dest,
> - int seg_num)
> -{
> - const u8 *imem_src = fw->data + phdr->p_offset;
> - int i;
> -
> - /*
> - * For IMEM segments, the segment contains 24-bit
> - * instructions which must be padded to 32-bit
> - * instructions before being written. The written
> - * segment is padded with NOP instructions.
> - */
> -
> - dev_dbg(fei->dev,
> - "Loading IMEM segment %d 0x%08x\n\t (0x%x bytes) -> 0x%p (0x%x bytes)\n",
> - seg_num, phdr->p_paddr, phdr->p_filesz, dest,
> - phdr->p_memsz + phdr->p_memsz / 3);
> -
> - for (i = 0; i < phdr->p_filesz; i++) {
> -
> - writeb(readb((void __iomem *)imem_src), (void __iomem *)dest);
> -
> - /* Every 3 bytes, add an additional
> - * padding zero in destination */
> - if (i % 3 == 2) {
> - dest++;
> - writeb(0x00, (void __iomem *)dest);
> - }
> -
> - dest++;
> - imem_src++;
> - }
> -}
> -
> -static void load_dmem_segment(struct c8sectpfei *fei, Elf32_Phdr *phdr,
> - const struct firmware *fw, u8 __iomem *dst, int seg_num)
> -{
> - /*
> - * For DMEM segments copy the segment data from the ELF
> - * file and pad segment with zeroes
> - */
> -
> - dev_dbg(fei->dev,
> - "Loading DMEM segment %d 0x%08x\n\t(0x%x bytes) -> 0x%p (0x%x bytes)\n",
> - seg_num, phdr->p_paddr, phdr->p_filesz,
> - dst, phdr->p_memsz);
> -
> - memcpy((void __force *)dst, (void *)fw->data + phdr->p_offset,
> - phdr->p_filesz);
> -
> - memset((void __force *)dst + phdr->p_filesz, 0,
> - phdr->p_memsz - phdr->p_filesz);
> -}
> -
> -static int load_slim_core_fw(const struct firmware *fw, struct c8sectpfei *fei)
> -{
> - Elf32_Ehdr *ehdr;
> - Elf32_Phdr *phdr;
> - u8 __iomem *dst;
> - int err = 0, i;
> -
> - if (!fw || !fei)
> - return -EINVAL;
> -
> - ehdr = (Elf32_Ehdr *)fw->data;
> - phdr = (Elf32_Phdr *)(fw->data + ehdr->e_phoff);
> -
> - /* go through the available ELF segments */
> - for (i = 0; i < ehdr->e_phnum; i++, phdr++) {
> -
> - /* Only consider LOAD segments */
> - if (phdr->p_type != PT_LOAD)
> - continue;
> -
> - /*
> - * Check segment is contained within the fw->data buffer
> - */
> - if (phdr->p_offset + phdr->p_filesz > fw->size) {
> - dev_err(fei->dev,
> - "Segment %d is outside of firmware file\n", i);
> - err = -EINVAL;
> - break;
> - }
> -
> - /*
> - * MEMDMA IMEM has executable flag set, otherwise load
> - * this segment into DMEM.
> - *
> - */
> -
> - if (phdr->p_flags & PF_X) {
> - dst = (u8 __iomem *) fei->io + DMA_MEMDMA_IMEM;
> - /*
> - * The Slim ELF file uses 32-bit word addressing for
> - * load offsets.
> - */
> - dst += (phdr->p_paddr & 0xFFFFF) * sizeof(unsigned int);
> - load_imem_segment(fei, phdr, fw, dst, i);
> - } else {
> - dst = (u8 __iomem *) fei->io + DMA_MEMDMA_DMEM;
> - /*
> - * The Slim ELF file uses 32-bit word addressing for
> - * load offsets.
> - */
> - dst += (phdr->p_paddr & 0xFFFFF) * sizeof(unsigned int);
> - load_dmem_segment(fei, phdr, fw, dst, i);
> - }
> - }
> -
> - return err;
> -}
> -
> -static int load_c8sectpfe_fw(struct c8sectpfei *fei)
> -{
> - const struct firmware *fw;
> - int err;
> -
> - dev_info(fei->dev, "Loading firmware: %s\n", FIRMWARE_MEMDMA);
> -
> - err = request_firmware(&fw, FIRMWARE_MEMDMA, fei->dev);
> - if (err)
> - return err;
> -
> - err = c8sectpfe_elf_sanity_check(fei, fw);
> - if (err) {
> - dev_err(fei->dev, "c8sectpfe_elf_sanity_check failed err=(%d)\n"
> - , err);
> - release_firmware(fw);
> - return err;
> - }
> -
> - err = load_slim_core_fw(fw, fei);
> - release_firmware(fw);
> - if (err) {
> - dev_err(fei->dev, "load_slim_core_fw failed err=(%d)\n", err);
> - return err;
> - }
> -
> - /* now the firmware is loaded configure the input blocks */
> - err = configure_channels(fei);
> - if (err) {
> - dev_err(fei->dev, "configure_channels failed err=(%d)\n", err);
> - return err;
> - }
> -
> - /*
> - * STBus target port can access IMEM and DMEM ports
> - * without waiting for CPU
> - */
> - writel(0x1, fei->io + DMA_PER_STBUS_SYNC);
> -
> - dev_info(fei->dev, "Boot the memdma SLIM core\n");
> - writel(0x1, fei->io + DMA_CPU_RUN);
> -
> - atomic_set(&fei->fw_loaded, 1);
> -
> - return 0;
> -}
> -
> -static const struct of_device_id c8sectpfe_match[] = {
> - { .compatible = "st,stih407-c8sectpfe" },
> - { /* sentinel */ },
> -};
> -MODULE_DEVICE_TABLE(of, c8sectpfe_match);
> -
> -static struct platform_driver c8sectpfe_driver = {
> - .driver = {
> - .name = "c8sectpfe",
> - .of_match_table = c8sectpfe_match,
> - },
> - .probe = c8sectpfe_probe,
> - .remove = c8sectpfe_remove,
> -};
> -
> -module_platform_driver(c8sectpfe_driver);
> -
> -MODULE_AUTHOR("Peter Bennett <peter.bennett@st.com>");
> -MODULE_AUTHOR("Peter Griffin <peter.griffin@linaro.org>");
> -MODULE_DESCRIPTION("C8SECTPFE STi DVB Driver");
> -MODULE_LICENSE("GPL");
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h
> deleted file mode 100644
> index c1b124c6ef128a6fe3fd5cbe5f5f3aee1b034af1..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-core.h
> +++ /dev/null
> @@ -1,287 +0,0 @@
> -/* SPDX-License-Identifier: GPL-2.0 */
> -/*
> - * c8sectpfe-core.h - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author:Peter Bennett <peter.bennett@st.com>
> - * Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#ifndef _C8SECTPFE_CORE_H_
> -#define _C8SECTPFE_CORE_H_
> -
> -#define C8SECTPFEI_MAXCHANNEL 16
> -#define C8SECTPFEI_MAXADAPTER 3
> -
> -#define C8SECTPFE_MAX_TSIN_CHAN 8
> -
> -struct gpio_desc;
> -
> -struct channel_info {
> -
> - int tsin_id;
> - bool invert_ts_clk;
> - bool serial_not_parallel;
> - bool async_not_sync;
> - int i2c;
> - int dvb_card;
> -
> - struct gpio_desc *rst_gpio;
> -
> - struct i2c_adapter *i2c_adapter;
> - struct i2c_adapter *tuner_i2c;
> - struct i2c_adapter *lnb_i2c;
> - struct i2c_client *i2c_client;
> - struct dvb_frontend *frontend;
> -
> - struct pinctrl_state *pstate;
> -
> - int demux_mapping;
> - int active;
> -
> - void *back_buffer_start;
> - void *back_buffer_aligned;
> - dma_addr_t back_buffer_busaddr;
> -
> - void *pid_buffer_start;
> - void *pid_buffer_aligned;
> - dma_addr_t pid_buffer_busaddr;
> -
> - unsigned long fifo;
> -
> - struct completion idle_completion;
> - struct work_struct bh_work;
> -
> - struct c8sectpfei *fei;
> - void __iomem *irec;
> -
> -};
> -
> -struct c8sectpfe_hw {
> - int num_ib;
> - int num_mib;
> - int num_swts;
> - int num_tsout;
> - int num_ccsc;
> - int num_ram;
> - int num_tp;
> -};
> -
> -struct c8sectpfei {
> -
> - struct device *dev;
> - struct pinctrl *pinctrl;
> -
> - struct dentry *root;
> - struct debugfs_regset32 *regset;
> - struct completion fw_ack;
> - atomic_t fw_loaded;
> -
> - int tsin_count;
> -
> - struct c8sectpfe_hw hw_stats;
> -
> - struct c8sectpfe *c8sectpfe[C8SECTPFEI_MAXADAPTER];
> -
> - int mapping[C8SECTPFEI_MAXCHANNEL];
> -
> - struct mutex lock;
> -
> - struct timer_list timer; /* timer interrupts for outputs */
> -
> - void __iomem *io;
> - void __iomem *sram;
> -
> - unsigned long sram_size;
> -
> - struct channel_info *channel_data[C8SECTPFE_MAX_TSIN_CHAN];
> -
> - struct clk *c8sectpfeclk;
> - int nima_rst_gpio;
> - int nimb_rst_gpio;
> -
> - int idle_irq;
> - int error_irq;
> -
> - int global_feed_count;
> -};
> -
> -/* C8SECTPFE SYS Regs list */
> -
> -#define SYS_INPUT_ERR_STATUS 0x0
> -#define SYS_OTHER_ERR_STATUS 0x8
> -#define SYS_INPUT_ERR_MASK 0x10
> -#define SYS_OTHER_ERR_MASK 0x18
> -#define SYS_DMA_ROUTE 0x20
> -#define SYS_INPUT_CLKEN 0x30
> -#define IBENABLE_MASK 0x7F
> -
> -#define SYS_OTHER_CLKEN 0x38
> -#define TSDMAENABLE BIT(1)
> -#define MEMDMAENABLE BIT(0)
> -
> -#define SYS_CFG_NUM_IB 0x200
> -#define SYS_CFG_NUM_MIB 0x204
> -#define SYS_CFG_NUM_SWTS 0x208
> -#define SYS_CFG_NUM_TSOUT 0x20C
> -#define SYS_CFG_NUM_CCSC 0x210
> -#define SYS_CFG_NUM_RAM 0x214
> -#define SYS_CFG_NUM_TP 0x218
> -
> -/* Input Block Regs */
> -
> -#define C8SECTPFE_INPUTBLK_OFFSET 0x1000
> -#define C8SECTPFE_CHANNEL_OFFSET(x) ((x*0x40) + C8SECTPFE_INPUTBLK_OFFSET)
> -
> -#define C8SECTPFE_IB_IP_FMT_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x00)
> -#define C8SECTPFE_IGNORE_ERR_AT_SOP BIT(7)
> -#define C8SECTPFE_IGNORE_ERR_IN_PKT BIT(6)
> -#define C8SECTPFE_IGNORE_ERR_IN_BYTE BIT(5)
> -#define C8SECTPFE_INVERT_TSCLK BIT(4)
> -#define C8SECTPFE_ALIGN_BYTE_SOP BIT(3)
> -#define C8SECTPFE_ASYNC_NOT_SYNC BIT(2)
> -#define C8SECTPFE_BYTE_ENDIANNESS_MSB BIT(1)
> -#define C8SECTPFE_SERIAL_NOT_PARALLEL BIT(0)
> -
> -#define C8SECTPFE_IB_SYNCLCKDRP_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x04)
> -#define C8SECTPFE_SYNC(x) (x & 0xf)
> -#define C8SECTPFE_DROP(x) ((x<<4) & 0xf)
> -#define C8SECTPFE_TOKEN(x) ((x<<8) & 0xff00)
> -#define C8SECTPFE_SLDENDIANNESS BIT(16)
> -
> -#define C8SECTPFE_IB_TAGBYTES_CFG(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x08)
> -#define C8SECTPFE_TAG_HEADER(x) (x << 16)
> -#define C8SECTPFE_TAG_COUNTER(x) ((x<<1) & 0x7fff)
> -#define C8SECTPFE_TAG_ENABLE BIT(0)
> -
> -#define C8SECTPFE_IB_PID_SET(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x0C)
> -#define C8SECTPFE_PID_OFFSET(x) (x & 0x3f)
> -#define C8SECTPFE_PID_NUMBITS(x) ((x << 6) & 0xfff)
> -#define C8SECTPFE_PID_ENABLE BIT(31)
> -
> -#define C8SECTPFE_IB_PKT_LEN(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x10)
> -
> -#define C8SECTPFE_IB_BUFF_STRT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x14)
> -#define C8SECTPFE_IB_BUFF_END(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x18)
> -#define C8SECTPFE_IB_READ_PNT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x1C)
> -#define C8SECTPFE_IB_WRT_PNT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x20)
> -
> -#define C8SECTPFE_IB_PRI_THRLD(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x24)
> -#define C8SECTPFE_PRI_VALUE(x) (x & 0x7fffff)
> -#define C8SECTPFE_PRI_LOWPRI(x) ((x & 0xf) << 24)
> -#define C8SECTPFE_PRI_HIGHPRI(x) ((x & 0xf) << 28)
> -
> -#define C8SECTPFE_IB_STAT(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x28)
> -#define C8SECTPFE_STAT_FIFO_OVERFLOW(x) (x & 0x1)
> -#define C8SECTPFE_STAT_BUFFER_OVERFLOW(x) (x & 0x2)
> -#define C8SECTPFE_STAT_OUTOFORDERRP(x) (x & 0x4)
> -#define C8SECTPFE_STAT_PID_OVERFLOW(x) (x & 0x8)
> -#define C8SECTPFE_STAT_PKT_OVERFLOW(x) (x & 0x10)
> -#define C8SECTPFE_STAT_ERROR_PACKETS(x) ((x >> 8) & 0xf)
> -#define C8SECTPFE_STAT_SHORT_PACKETS(x) ((x >> 12) & 0xf)
> -
> -#define C8SECTPFE_IB_MASK(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x2C)
> -#define C8SECTPFE_MASK_FIFO_OVERFLOW BIT(0)
> -#define C8SECTPFE_MASK_BUFFER_OVERFLOW BIT(1)
> -#define C8SECTPFE_MASK_OUTOFORDERRP(x) BIT(2)
> -#define C8SECTPFE_MASK_PID_OVERFLOW(x) BIT(3)
> -#define C8SECTPFE_MASK_PKT_OVERFLOW(x) BIT(4)
> -#define C8SECTPFE_MASK_ERROR_PACKETS(x) ((x & 0xf) << 8)
> -#define C8SECTPFE_MASK_SHORT_PACKETS(x) ((x & 0xf) >> 12)
> -
> -#define C8SECTPFE_IB_SYS(x) (C8SECTPFE_CHANNEL_OFFSET(x) + 0x30)
> -#define C8SECTPFE_SYS_RESET BIT(1)
> -#define C8SECTPFE_SYS_ENABLE BIT(0)
> -
> -/*
> - * Pointer record data structure required for each input block
> - * see Table 82 on page 167 of functional specification.
> - */
> -
> -#define DMA_PRDS_MEMBASE 0x0 /* Internal sram base address */
> -#define DMA_PRDS_MEMTOP 0x4 /* Internal sram top address */
> -
> -/*
> - * TS packet size, including tag bytes added by input block,
> - * rounded up to the next multiple of 8 bytes. The packet size,
> - * including any tagging bytes and rounded up to the nearest
> - * multiple of 8 bytes must be less than 255 bytes.
> - */
> -#define DMA_PRDS_PKTSIZE 0x8
> -#define DMA_PRDS_TPENABLE 0xc
> -
> -#define TP0_OFFSET 0x10
> -#define DMA_PRDS_BUSBASE_TP(x) ((0x10*x) + TP0_OFFSET)
> -#define DMA_PRDS_BUSTOP_TP(x) ((0x10*x) + TP0_OFFSET + 0x4)
> -#define DMA_PRDS_BUSWP_TP(x) ((0x10*x) + TP0_OFFSET + 0x8)
> -#define DMA_PRDS_BUSRP_TP(x) ((0x10*x) + TP0_OFFSET + 0xc)
> -
> -#define DMA_PRDS_SIZE (0x20)
> -
> -#define DMA_MEMDMA_OFFSET 0x4000
> -#define DMA_IMEM_OFFSET 0x0
> -#define DMA_DMEM_OFFSET 0x4000
> -#define DMA_CPU 0x8000
> -#define DMA_PER_OFFSET 0xb000
> -
> -#define DMA_MEMDMA_DMEM (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET)
> -#define DMA_MEMDMA_IMEM (DMA_MEMDMA_OFFSET + DMA_IMEM_OFFSET)
> -
> -/* XP70 Slim core regs */
> -#define DMA_CPU_ID (DMA_MEMDMA_OFFSET + DMA_CPU + 0x0)
> -#define DMA_CPU_VCR (DMA_MEMDMA_OFFSET + DMA_CPU + 0x4)
> -#define DMA_CPU_RUN (DMA_MEMDMA_OFFSET + DMA_CPU + 0x8)
> -#define DMA_CPU_CLOCKGATE (DMA_MEMDMA_OFFSET + DMA_CPU + 0xc)
> -#define DMA_CPU_PC (DMA_MEMDMA_OFFSET + DMA_CPU + 0x20)
> -
> -/* Enable Interrupt for a IB */
> -#define DMA_PER_TPn_DREQ_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xd00)
> -/* Ack interrupt by setting corresponding bit */
> -#define DMA_PER_TPn_DACK_SET (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xd80)
> -#define DMA_PER_TPn_DREQ (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xe00)
> -#define DMA_PER_TPn_DACK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xe80)
> -#define DMA_PER_DREQ_MODE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf80)
> -#define DMA_PER_STBUS_SYNC (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf88)
> -#define DMA_PER_STBUS_ACCESS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf8c)
> -#define DMA_PER_STBUS_ADDRESS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xf90)
> -#define DMA_PER_IDLE_INT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfa8)
> -#define DMA_PER_PRIORITY (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfac)
> -#define DMA_PER_MAX_OPCODE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfb0)
> -#define DMA_PER_MAX_CHUNK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfb4)
> -#define DMA_PER_PAGE_SIZE (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfbc)
> -#define DMA_PER_MBOX_STATUS (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfc0)
> -#define DMA_PER_MBOX_SET (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfc8)
> -#define DMA_PER_MBOX_CLEAR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfd0)
> -#define DMA_PER_MBOX_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfd8)
> -#define DMA_PER_INJECT_PKT_SRC (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe0)
> -#define DMA_PER_INJECT_PKT_DEST (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe4)
> -#define DMA_PER_INJECT_PKT_ADDR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfe8)
> -#define DMA_PER_INJECT_PKT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xfec)
> -#define DMA_PER_PAT_PTR_INIT (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff0)
> -#define DMA_PER_PAT_PTR (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff4)
> -#define DMA_PER_SLEEP_MASK (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xff8)
> -#define DMA_PER_SLEEP_COUNTER (DMA_MEMDMA_OFFSET + DMA_PER_OFFSET + 0xffc)
> -/* #define DMA_RF_CPUREGn DMA_RFBASEADDR n=0 to 15) slim regsa */
> -
> -/* The following are from DMA_DMEM_BaseAddress */
> -#define DMA_FIRMWARE_VERSION (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x0)
> -#define DMA_PTRREC_BASE (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x4)
> -#define DMA_PTRREC_INPUT_OFFSET (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x8)
> -#define DMA_ERRREC_BASE (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0xc)
> -#define DMA_ERROR_RECORD(n) ((n*4) + DMA_ERRREC_BASE + 0x4)
> -#define DMA_IDLE_REQ (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x10)
> -#define IDLEREQ BIT(31)
> -
> -#define DMA_FIRMWARE_CONFIG (DMA_MEMDMA_OFFSET + DMA_DMEM_OFFSET + 0x14)
> -
> -/* Regs for PID Filter */
> -
> -#define PIDF_OFFSET 0x2800
> -#define PIDF_BASE(n) ((n*4) + PIDF_OFFSET)
> -#define PIDF_LEAK_ENABLE (PIDF_OFFSET + 0x100)
> -#define PIDF_LEAK_STATUS (PIDF_OFFSET + 0x108)
> -#define PIDF_LEAK_COUNT_RESET (PIDF_OFFSET + 0x110)
> -#define PIDF_LEAK_COUNTER (PIDF_OFFSET + 0x114)
> -
> -#endif /* _C8SECTPFE_CORE_H_ */
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c
> deleted file mode 100644
> index 301fa10f419b6a7c9a1b50d759fd0fbbfc0f7692..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.c
> +++ /dev/null
> @@ -1,244 +0,0 @@
> -// SPDX-License-Identifier: GPL-2.0
> -/*
> - * c8sectpfe-debugfs.c - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author: Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#include <linux/debugfs.h>
> -#include <linux/device.h>
> -#include <linux/interrupt.h>
> -#include <linux/io.h>
> -#include <linux/kernel.h>
> -#include <linux/seq_file.h>
> -#include <linux/slab.h>
> -#include <linux/types.h>
> -
> -#include "c8sectpfe-debugfs.h"
> -
> -#define dump_register(nm ...) \
> -{ \
> - .name = #nm, \
> - .offset = nm, \
> -}
> -
> -static const struct debugfs_reg32 fei_sys_regs[] = {
> - dump_register(SYS_INPUT_ERR_STATUS),
> - dump_register(SYS_OTHER_ERR_STATUS),
> - dump_register(SYS_INPUT_ERR_MASK),
> - dump_register(SYS_DMA_ROUTE),
> - dump_register(SYS_INPUT_CLKEN),
> - dump_register(IBENABLE_MASK),
> - dump_register(SYS_OTHER_CLKEN),
> - dump_register(SYS_CFG_NUM_IB),
> - dump_register(SYS_CFG_NUM_MIB),
> - dump_register(SYS_CFG_NUM_SWTS),
> - dump_register(SYS_CFG_NUM_TSOUT),
> - dump_register(SYS_CFG_NUM_CCSC),
> - dump_register(SYS_CFG_NUM_RAM),
> - dump_register(SYS_CFG_NUM_TP),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(0)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(0)),
> - dump_register(C8SECTPFE_IB_PID_SET(0)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(0)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(0)),
> - dump_register(C8SECTPFE_IB_BUFF_END(0)),
> - dump_register(C8SECTPFE_IB_READ_PNT(0)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(0)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(0)),
> - dump_register(C8SECTPFE_IB_STAT(0)),
> - dump_register(C8SECTPFE_IB_MASK(0)),
> - dump_register(C8SECTPFE_IB_SYS(0)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(1)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(1)),
> - dump_register(C8SECTPFE_IB_PID_SET(1)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(1)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(1)),
> - dump_register(C8SECTPFE_IB_BUFF_END(1)),
> - dump_register(C8SECTPFE_IB_READ_PNT(1)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(1)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(1)),
> - dump_register(C8SECTPFE_IB_STAT(1)),
> - dump_register(C8SECTPFE_IB_MASK(1)),
> - dump_register(C8SECTPFE_IB_SYS(1)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(2)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(2)),
> - dump_register(C8SECTPFE_IB_PID_SET(2)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(2)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(2)),
> - dump_register(C8SECTPFE_IB_BUFF_END(2)),
> - dump_register(C8SECTPFE_IB_READ_PNT(2)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(2)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(2)),
> - dump_register(C8SECTPFE_IB_STAT(2)),
> - dump_register(C8SECTPFE_IB_MASK(2)),
> - dump_register(C8SECTPFE_IB_SYS(2)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(3)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(3)),
> - dump_register(C8SECTPFE_IB_PID_SET(3)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(3)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(3)),
> - dump_register(C8SECTPFE_IB_BUFF_END(3)),
> - dump_register(C8SECTPFE_IB_READ_PNT(3)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(3)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(3)),
> - dump_register(C8SECTPFE_IB_STAT(3)),
> - dump_register(C8SECTPFE_IB_MASK(3)),
> - dump_register(C8SECTPFE_IB_SYS(3)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(4)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(4)),
> - dump_register(C8SECTPFE_IB_PID_SET(4)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(4)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(4)),
> - dump_register(C8SECTPFE_IB_BUFF_END(4)),
> - dump_register(C8SECTPFE_IB_READ_PNT(4)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(4)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(4)),
> - dump_register(C8SECTPFE_IB_STAT(4)),
> - dump_register(C8SECTPFE_IB_MASK(4)),
> - dump_register(C8SECTPFE_IB_SYS(4)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(5)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(5)),
> - dump_register(C8SECTPFE_IB_PID_SET(5)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(5)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(5)),
> - dump_register(C8SECTPFE_IB_BUFF_END(5)),
> - dump_register(C8SECTPFE_IB_READ_PNT(5)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(5)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(5)),
> - dump_register(C8SECTPFE_IB_STAT(5)),
> - dump_register(C8SECTPFE_IB_MASK(5)),
> - dump_register(C8SECTPFE_IB_SYS(5)),
> -
> - dump_register(C8SECTPFE_IB_IP_FMT_CFG(6)),
> - dump_register(C8SECTPFE_IB_TAGBYTES_CFG(6)),
> - dump_register(C8SECTPFE_IB_PID_SET(6)),
> - dump_register(C8SECTPFE_IB_PKT_LEN(6)),
> - dump_register(C8SECTPFE_IB_BUFF_STRT(6)),
> - dump_register(C8SECTPFE_IB_BUFF_END(6)),
> - dump_register(C8SECTPFE_IB_READ_PNT(6)),
> - dump_register(C8SECTPFE_IB_WRT_PNT(6)),
> - dump_register(C8SECTPFE_IB_PRI_THRLD(6)),
> - dump_register(C8SECTPFE_IB_STAT(6)),
> - dump_register(C8SECTPFE_IB_MASK(6)),
> - dump_register(C8SECTPFE_IB_SYS(6)),
> -
> - dump_register(DMA_CPU_ID),
> - dump_register(DMA_CPU_VCR),
> - dump_register(DMA_CPU_RUN),
> - dump_register(DMA_CPU_PC),
> -
> - dump_register(DMA_PER_TPn_DREQ_MASK),
> - dump_register(DMA_PER_TPn_DACK_SET),
> - dump_register(DMA_PER_TPn_DREQ),
> - dump_register(DMA_PER_TPn_DACK),
> - dump_register(DMA_PER_DREQ_MODE),
> - dump_register(DMA_PER_STBUS_SYNC),
> - dump_register(DMA_PER_STBUS_ACCESS),
> - dump_register(DMA_PER_STBUS_ADDRESS),
> - dump_register(DMA_PER_IDLE_INT),
> - dump_register(DMA_PER_PRIORITY),
> - dump_register(DMA_PER_MAX_OPCODE),
> - dump_register(DMA_PER_MAX_CHUNK),
> - dump_register(DMA_PER_PAGE_SIZE),
> - dump_register(DMA_PER_MBOX_STATUS),
> - dump_register(DMA_PER_MBOX_SET),
> - dump_register(DMA_PER_MBOX_CLEAR),
> - dump_register(DMA_PER_MBOX_MASK),
> - dump_register(DMA_PER_INJECT_PKT_SRC),
> - dump_register(DMA_PER_INJECT_PKT_DEST),
> - dump_register(DMA_PER_INJECT_PKT_ADDR),
> - dump_register(DMA_PER_INJECT_PKT),
> - dump_register(DMA_PER_PAT_PTR_INIT),
> - dump_register(DMA_PER_PAT_PTR),
> - dump_register(DMA_PER_SLEEP_MASK),
> - dump_register(DMA_PER_SLEEP_COUNTER),
> -
> - dump_register(DMA_FIRMWARE_VERSION),
> - dump_register(DMA_PTRREC_BASE),
> - dump_register(DMA_PTRREC_INPUT_OFFSET),
> - dump_register(DMA_ERRREC_BASE),
> -
> - dump_register(DMA_ERROR_RECORD(0)),
> - dump_register(DMA_ERROR_RECORD(1)),
> - dump_register(DMA_ERROR_RECORD(2)),
> - dump_register(DMA_ERROR_RECORD(3)),
> - dump_register(DMA_ERROR_RECORD(4)),
> - dump_register(DMA_ERROR_RECORD(5)),
> - dump_register(DMA_ERROR_RECORD(6)),
> - dump_register(DMA_ERROR_RECORD(7)),
> - dump_register(DMA_ERROR_RECORD(8)),
> - dump_register(DMA_ERROR_RECORD(9)),
> - dump_register(DMA_ERROR_RECORD(10)),
> - dump_register(DMA_ERROR_RECORD(11)),
> - dump_register(DMA_ERROR_RECORD(12)),
> - dump_register(DMA_ERROR_RECORD(13)),
> - dump_register(DMA_ERROR_RECORD(14)),
> - dump_register(DMA_ERROR_RECORD(15)),
> - dump_register(DMA_ERROR_RECORD(16)),
> - dump_register(DMA_ERROR_RECORD(17)),
> - dump_register(DMA_ERROR_RECORD(18)),
> - dump_register(DMA_ERROR_RECORD(19)),
> - dump_register(DMA_ERROR_RECORD(20)),
> - dump_register(DMA_ERROR_RECORD(21)),
> - dump_register(DMA_ERROR_RECORD(22)),
> -
> - dump_register(DMA_IDLE_REQ),
> - dump_register(DMA_FIRMWARE_CONFIG),
> -
> - dump_register(PIDF_BASE(0)),
> - dump_register(PIDF_BASE(1)),
> - dump_register(PIDF_BASE(2)),
> - dump_register(PIDF_BASE(3)),
> - dump_register(PIDF_BASE(4)),
> - dump_register(PIDF_BASE(5)),
> - dump_register(PIDF_BASE(6)),
> - dump_register(PIDF_BASE(7)),
> - dump_register(PIDF_BASE(8)),
> - dump_register(PIDF_BASE(9)),
> - dump_register(PIDF_BASE(10)),
> - dump_register(PIDF_BASE(11)),
> - dump_register(PIDF_BASE(12)),
> - dump_register(PIDF_BASE(13)),
> - dump_register(PIDF_BASE(14)),
> - dump_register(PIDF_BASE(15)),
> - dump_register(PIDF_BASE(16)),
> - dump_register(PIDF_BASE(17)),
> - dump_register(PIDF_BASE(18)),
> - dump_register(PIDF_BASE(19)),
> - dump_register(PIDF_BASE(20)),
> - dump_register(PIDF_BASE(21)),
> - dump_register(PIDF_BASE(22)),
> - dump_register(PIDF_LEAK_ENABLE),
> - dump_register(PIDF_LEAK_STATUS),
> - dump_register(PIDF_LEAK_COUNT_RESET),
> - dump_register(PIDF_LEAK_COUNTER),
> -};
> -
> -void c8sectpfe_debugfs_init(struct c8sectpfei *fei)
> -{
> - fei->regset = devm_kzalloc(fei->dev, sizeof(*fei->regset), GFP_KERNEL);
> - if (!fei->regset)
> - return;
> -
> - fei->regset->regs = fei_sys_regs;
> - fei->regset->nregs = ARRAY_SIZE(fei_sys_regs);
> - fei->regset->base = fei->io;
> -
> - fei->root = debugfs_create_dir("c8sectpfe", NULL);
> - debugfs_create_regset32("registers", S_IRUGO, fei->root, fei->regset);
> -}
> -
> -void c8sectpfe_debugfs_exit(struct c8sectpfei *fei)
> -{
> - debugfs_remove_recursive(fei->root);
> - fei->root = NULL;
> -}
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h
> deleted file mode 100644
> index 3fe177b59b16d2789cde2438367d6f4cbfd9c832..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-debugfs.h
> +++ /dev/null
> @@ -1,23 +0,0 @@
> -/* SPDX-License-Identifier: GPL-2.0 */
> -/*
> - * c8sectpfe-debugfs.h - C8SECTPFE STi DVB driver debugfs header
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Authors: Peter Griffin <peter.griffin@linaro.org>
> - */
> -
> -#ifndef __C8SECTPFE_DEBUG_H
> -#define __C8SECTPFE_DEBUG_H
> -
> -#include "c8sectpfe-core.h"
> -
> -#if defined(CONFIG_DEBUG_FS)
> -void c8sectpfe_debugfs_init(struct c8sectpfei *);
> -void c8sectpfe_debugfs_exit(struct c8sectpfei *);
> -#else
> -static inline void c8sectpfe_debugfs_init(struct c8sectpfei *fei) {};
> -static inline void c8sectpfe_debugfs_exit(struct c8sectpfei *fei) {};
> -#endif
> -
> -#endif /* __C8SECTPFE_DEBUG_H */
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c
> deleted file mode 100644
> index feb48cb546d7f11efb62339b8389187f5cec43c9..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.c
> +++ /dev/null
> @@ -1,235 +0,0 @@
> -// SPDX-License-Identifier: GPL-2.0
> -/*
> - * c8sectpfe-dvb.c - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#include <linux/completion.h>
> -#include <linux/delay.h>
> -#include <linux/i2c.h>
> -#include <linux/interrupt.h>
> -
> -#include <dt-bindings/media/c8sectpfe.h>
> -
> -#include "c8sectpfe-common.h"
> -#include "c8sectpfe-core.h"
> -#include "c8sectpfe-dvb.h"
> -
> -#include "dvb-pll.h"
> -#include "lnbh24.h"
> -#include "stv0367.h"
> -#include "stv0367_priv.h"
> -#include "stv6110x.h"
> -#include "stv090x.h"
> -#include "tda18212.h"
> -
> -static inline const char *dvb_card_str(unsigned int c)
> -{
> - switch (c) {
> - case STV0367_TDA18212_NIMA_1: return "STV0367_TDA18212_NIMA_1";
> - case STV0367_TDA18212_NIMA_2: return "STV0367_TDA18212_NIMA_2";
> - case STV0367_TDA18212_NIMB_1: return "STV0367_TDA18212_NIMB_1";
> - case STV0367_TDA18212_NIMB_2: return "STV0367_TDA18212_NIMB_2";
> - case STV0903_6110_LNB24_NIMA: return "STV0903_6110_LNB24_NIMA";
> - case STV0903_6110_LNB24_NIMB: return "STV0903_6110_LNB24_NIMB";
> - default: return "unknown dvb frontend card";
> - }
> -}
> -
> -static struct stv090x_config stv090x_config = {
> - .device = STV0903,
> - .demod_mode = STV090x_SINGLE,
> - .clk_mode = STV090x_CLK_EXT,
> - .xtal = 16000000,
> - .address = 0x69,
> -
> - .ts1_mode = STV090x_TSMODE_SERIAL_CONTINUOUS,
> - .ts2_mode = STV090x_TSMODE_SERIAL_CONTINUOUS,
> -
> - .repeater_level = STV090x_RPTLEVEL_64,
> -
> - .tuner_init = NULL,
> - .tuner_set_mode = NULL,
> - .tuner_set_frequency = NULL,
> - .tuner_get_frequency = NULL,
> - .tuner_set_bandwidth = NULL,
> - .tuner_get_bandwidth = NULL,
> - .tuner_set_bbgain = NULL,
> - .tuner_get_bbgain = NULL,
> - .tuner_set_refclk = NULL,
> - .tuner_get_status = NULL,
> -};
> -
> -static struct stv6110x_config stv6110x_config = {
> - .addr = 0x60,
> - .refclk = 16000000,
> -};
> -
> -#define NIMA 0
> -#define NIMB 1
> -
> -static struct stv0367_config stv0367_tda18212_config[] = {
> - {
> - .demod_address = 0x1c,
> - .xtal = 16000000,
> - .if_khz = 4500,
> - .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
> - .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
> - .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
> - }, {
> - .demod_address = 0x1d,
> - .xtal = 16000000,
> - .if_khz = 4500,
> - .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
> - .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
> - .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
> - }, {
> - .demod_address = 0x1e,
> - .xtal = 16000000,
> - .if_khz = 4500,
> - .if_iq_mode = FE_TER_NORMAL_IF_TUNER,
> - .ts_mode = STV0367_SERIAL_PUNCT_CLOCK,
> - .clk_pol = STV0367_CLOCKPOLARITY_DEFAULT,
> - },
> -};
> -
> -static struct tda18212_config tda18212_conf = {
> - .if_dvbt_6 = 4150,
> - .if_dvbt_7 = 4150,
> - .if_dvbt_8 = 4500,
> - .if_dvbc = 5000,
> -};
> -
> -int c8sectpfe_frontend_attach(struct dvb_frontend **fe,
> - struct c8sectpfe *c8sectpfe,
> - struct channel_info *tsin, int chan_num)
> -{
> - struct tda18212_config *tda18212;
> - const struct stv6110x_devctl *fe2;
> - struct i2c_client *client;
> - struct i2c_board_info tda18212_info = {
> - .type = "tda18212",
> - .addr = 0x60,
> - };
> -
> - if (!tsin)
> - return -EINVAL;
> -
> - switch (tsin->dvb_card) {
> -
> - case STV0367_TDA18212_NIMA_1:
> - case STV0367_TDA18212_NIMA_2:
> - case STV0367_TDA18212_NIMB_1:
> - case STV0367_TDA18212_NIMB_2:
> - if (tsin->dvb_card == STV0367_TDA18212_NIMA_1)
> - *fe = dvb_attach(stv0367ter_attach,
> - &stv0367_tda18212_config[0],
> - tsin->i2c_adapter);
> - else if (tsin->dvb_card == STV0367_TDA18212_NIMB_1)
> - *fe = dvb_attach(stv0367ter_attach,
> - &stv0367_tda18212_config[1],
> - tsin->i2c_adapter);
> - else
> - *fe = dvb_attach(stv0367ter_attach,
> - &stv0367_tda18212_config[2],
> - tsin->i2c_adapter);
> -
> - if (!*fe) {
> - dev_err(c8sectpfe->device,
> - "%s: stv0367ter_attach failed for NIM card %s\n"
> - , __func__, dvb_card_str(tsin->dvb_card));
> - return -ENODEV;
> - }
> -
> - /*
> - * init the demod so that i2c gate_ctrl
> - * to the tuner works correctly
> - */
> - (*fe)->ops.init(*fe);
> -
> - /* Allocate the tda18212 structure */
> - tda18212 = devm_kzalloc(c8sectpfe->device,
> - sizeof(struct tda18212_config),
> - GFP_KERNEL);
> - if (!tda18212) {
> - dev_err(c8sectpfe->device,
> - "%s: devm_kzalloc failed\n", __func__);
> - return -ENOMEM;
> - }
> -
> - memcpy(tda18212, &tda18212_conf,
> - sizeof(struct tda18212_config));
> -
> - tda18212->fe = (*fe);
> -
> - tda18212_info.platform_data = tda18212;
> -
> - /* attach tuner */
> - request_module("tda18212");
> - client = i2c_new_client_device(tsin->i2c_adapter,
> - &tda18212_info);
> - if (!i2c_client_has_driver(client)) {
> - dvb_frontend_detach(*fe);
> - return -ENODEV;
> - }
> -
> - if (!try_module_get(client->dev.driver->owner)) {
> - i2c_unregister_device(client);
> - dvb_frontend_detach(*fe);
> - return -ENODEV;
> - }
> -
> - tsin->i2c_client = client;
> -
> - break;
> -
> - case STV0903_6110_LNB24_NIMA:
> - *fe = dvb_attach(stv090x_attach, &stv090x_config,
> - tsin->i2c_adapter, STV090x_DEMODULATOR_0);
> - if (!*fe) {
> - dev_err(c8sectpfe->device, "%s: stv090x_attach failed\n"
> - "\tfor NIM card %s\n",
> - __func__, dvb_card_str(tsin->dvb_card));
> - return -ENODEV;
> - }
> -
> - fe2 = dvb_attach(stv6110x_attach, *fe,
> - &stv6110x_config, tsin->i2c_adapter);
> - if (!fe2) {
> - dev_err(c8sectpfe->device,
> - "%s: stv6110x_attach failed for NIM card %s\n"
> - , __func__, dvb_card_str(tsin->dvb_card));
> - return -ENODEV;
> - }
> -
> - stv090x_config.tuner_init = fe2->tuner_init;
> - stv090x_config.tuner_set_mode = fe2->tuner_set_mode;
> - stv090x_config.tuner_set_frequency = fe2->tuner_set_frequency;
> - stv090x_config.tuner_get_frequency = fe2->tuner_get_frequency;
> - stv090x_config.tuner_set_bandwidth = fe2->tuner_set_bandwidth;
> - stv090x_config.tuner_get_bandwidth = fe2->tuner_get_bandwidth;
> - stv090x_config.tuner_set_bbgain = fe2->tuner_set_bbgain;
> - stv090x_config.tuner_get_bbgain = fe2->tuner_get_bbgain;
> - stv090x_config.tuner_set_refclk = fe2->tuner_set_refclk;
> - stv090x_config.tuner_get_status = fe2->tuner_get_status;
> -
> - dvb_attach(lnbh24_attach, *fe, tsin->i2c_adapter, 0, 0, 0x9);
> - break;
> -
> - default:
> - dev_err(c8sectpfe->device,
> - "%s: DVB frontend card %s not yet supported\n",
> - __func__, dvb_card_str(tsin->dvb_card));
> - return -ENODEV;
> - }
> -
> - (*fe)->id = chan_num;
> -
> - dev_info(c8sectpfe->device,
> - "DVB frontend card %s successfully attached",
> - dvb_card_str(tsin->dvb_card));
> - return 0;
> -}
> diff --git a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h b/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h
> deleted file mode 100644
> index 3d87a9ae8702d40629a8aa0a0ee76ddf1ad815b8..0000000000000000000000000000000000000000
> --- a/drivers/media/platform/st/sti/c8sectpfe/c8sectpfe-dvb.h
> +++ /dev/null
> @@ -1,17 +0,0 @@
> -/* SPDX-License-Identifier: GPL-2.0 */
> -/*
> - * c8sectpfe-common.h - C8SECTPFE STi DVB driver
> - *
> - * Copyright (c) STMicroelectronics 2015
> - *
> - * Author: Peter Griffin <peter.griffin@linaro.org>
> - *
> - */
> -#ifndef _C8SECTPFE_DVB_H_
> -#define _C8SECTPFE_DVB_H_
> -
> -int c8sectpfe_frontend_attach(struct dvb_frontend **fe,
> - struct c8sectpfe *c8sectpfe, struct channel_info *tsin,
> - int chan_num);
> -
> -#endif
>
Hi Raphael
Reviewed-by: Patrice Chotard <patrice.chotard@foss.st.com>
Thanks
Patrice
© 2016 - 2026 Red Hat, Inc.