Lines Matching refs:feed

424 				  struct dmx_ts_feed *feed,  in dvb_dmxdev_ts_callback()  argument
427 struct dmxdev_filter *dmxdevfilter = feed->priv; in dvb_dmxdev_ts_callback()
480 struct dmxdev_feed *feed; in dvb_dmxdev_feed_stop() local
487 dmxdevfilter->feed.sec->stop_filtering(dmxdevfilter->feed.sec); in dvb_dmxdev_feed_stop()
490 list_for_each_entry(feed, &dmxdevfilter->feed.ts, next) in dvb_dmxdev_feed_stop()
491 feed->ts->stop_filtering(feed->ts); in dvb_dmxdev_feed_stop()
502 struct dmxdev_feed *feed; in dvb_dmxdev_feed_start() local
509 return filter->feed.sec->start_filtering(filter->feed.sec); in dvb_dmxdev_feed_start()
511 list_for_each_entry(feed, &filter->feed.ts, next) { in dvb_dmxdev_feed_start()
512 ret = feed->ts->start_filtering(feed->ts); in dvb_dmxdev_feed_start()
543 filter->feed.sec); in dvb_dmxdev_feed_restart()
550 struct dmxdev_feed *feed; in dvb_dmxdev_filter_stop() local
558 if (!dmxdevfilter->feed.sec) in dvb_dmxdev_filter_stop()
562 dmxdevfilter->feed.sec-> in dvb_dmxdev_filter_stop()
563 release_filter(dmxdevfilter->feed.sec, in dvb_dmxdev_filter_stop()
566 dmxdevfilter->feed.sec = NULL; in dvb_dmxdev_filter_stop()
571 list_for_each_entry(feed, &dmxdevfilter->feed.ts, next) { in dvb_dmxdev_filter_stop()
572 demux->release_ts_feed(demux, feed->ts); in dvb_dmxdev_filter_stop()
573 feed->ts = NULL; in dvb_dmxdev_filter_stop()
588 struct dmxdev_feed *feed, *tmp; in dvb_dmxdev_delete_pids() local
591 list_for_each_entry_safe(feed, tmp, &dmxdevfilter->feed.ts, next) { in dvb_dmxdev_delete_pids()
592 list_del(&feed->next); in dvb_dmxdev_delete_pids()
593 kfree(feed); in dvb_dmxdev_delete_pids()
596 BUG_ON(!list_empty(&dmxdevfilter->feed.ts)); in dvb_dmxdev_delete_pids()
614 struct dmxdev_feed *feed) in dvb_dmxdev_start_feed() argument
624 feed->ts = NULL; in dvb_dmxdev_start_feed()
641 ret = dmxdev->demux->allocate_ts_feed(dmxdev->demux, &feed->ts, in dvb_dmxdev_start_feed()
646 tsfeed = feed->ts; in dvb_dmxdev_start_feed()
649 ret = tsfeed->set(tsfeed, feed->pid, ts_type, ts_pes, timeout); in dvb_dmxdev_start_feed()
667 struct dmxdev_feed *feed; in dvb_dmxdev_filter_start() local
693 struct dmx_section_feed **secfeed = &filter->feed.sec; in dvb_dmxdev_filter_start()
704 *secfeed = dmxdev->filter[i].feed.sec; in dvb_dmxdev_filter_start()
757 ret = filter->feed.sec->start_filtering(filter->feed.sec); in dvb_dmxdev_filter_start()
765 list_for_each_entry(feed, &filter->feed.ts, next) { in dvb_dmxdev_filter_start()
766 ret = dvb_dmxdev_start_feed(dmxdev, filter, feed); in dvb_dmxdev_filter_start()
871 struct dmxdev_feed *feed; in dvb_dmxdev_add_pid() local
879 (!list_empty(&filter->feed.ts))) in dvb_dmxdev_add_pid()
882 feed = kzalloc(sizeof(struct dmxdev_feed), GFP_KERNEL); in dvb_dmxdev_add_pid()
883 if (feed == NULL) in dvb_dmxdev_add_pid()
886 feed->pid = pid; in dvb_dmxdev_add_pid()
887 list_add(&feed->next, &filter->feed.ts); in dvb_dmxdev_add_pid()
890 return dvb_dmxdev_start_feed(dmxdev, filter, feed); in dvb_dmxdev_add_pid()
898 struct dmxdev_feed *feed, *tmp; in dvb_dmxdev_remove_pid() local
904 list_for_each_entry_safe(feed, tmp, &filter->feed.ts, next) { in dvb_dmxdev_remove_pid()
905 if ((feed->pid == pid) && (feed->ts != NULL)) { in dvb_dmxdev_remove_pid()
906 feed->ts->stop_filtering(feed->ts); in dvb_dmxdev_remove_pid()
908 feed->ts); in dvb_dmxdev_remove_pid()
909 list_del(&feed->next); in dvb_dmxdev_remove_pid()
910 kfree(feed); in dvb_dmxdev_remove_pid()
953 INIT_LIST_HEAD(&dmxdevfilter->feed.ts); in dvb_dmxdev_pes_filter_set()