Lines Matching refs:feed

388 				  struct dmx_ts_feed *feed)  in dvb_dmxdev_ts_callback()  argument
390 struct dmxdev_filter *dmxdevfilter = feed->priv; in dvb_dmxdev_ts_callback()
423 struct dmxdev_feed *feed; in dvb_dmxdev_feed_stop() local
430 dmxdevfilter->feed.sec->stop_filtering(dmxdevfilter->feed.sec); in dvb_dmxdev_feed_stop()
433 list_for_each_entry(feed, &dmxdevfilter->feed.ts, next) in dvb_dmxdev_feed_stop()
434 feed->ts->stop_filtering(feed->ts); in dvb_dmxdev_feed_stop()
445 struct dmxdev_feed *feed; in dvb_dmxdev_feed_start() local
452 return filter->feed.sec->start_filtering(filter->feed.sec); in dvb_dmxdev_feed_start()
454 list_for_each_entry(feed, &filter->feed.ts, next) { in dvb_dmxdev_feed_start()
455 ret = feed->ts->start_filtering(feed->ts); in dvb_dmxdev_feed_start()
486 filter->feed.sec); in dvb_dmxdev_feed_restart()
493 struct dmxdev_feed *feed; in dvb_dmxdev_filter_stop() local
501 if (!dmxdevfilter->feed.sec) in dvb_dmxdev_filter_stop()
505 dmxdevfilter->feed.sec-> in dvb_dmxdev_filter_stop()
506 release_filter(dmxdevfilter->feed.sec, in dvb_dmxdev_filter_stop()
509 dmxdevfilter->feed.sec = NULL; in dvb_dmxdev_filter_stop()
514 list_for_each_entry(feed, &dmxdevfilter->feed.ts, next) { in dvb_dmxdev_filter_stop()
515 demux->release_ts_feed(demux, feed->ts); in dvb_dmxdev_filter_stop()
516 feed->ts = NULL; in dvb_dmxdev_filter_stop()
531 struct dmxdev_feed *feed, *tmp; in dvb_dmxdev_delete_pids() local
534 list_for_each_entry_safe(feed, tmp, &dmxdevfilter->feed.ts, next) { in dvb_dmxdev_delete_pids()
535 list_del(&feed->next); in dvb_dmxdev_delete_pids()
536 kfree(feed); in dvb_dmxdev_delete_pids()
539 BUG_ON(!list_empty(&dmxdevfilter->feed.ts)); in dvb_dmxdev_delete_pids()
557 struct dmxdev_feed *feed) in dvb_dmxdev_start_feed() argument
567 feed->ts = NULL; in dvb_dmxdev_start_feed()
584 ret = dmxdev->demux->allocate_ts_feed(dmxdev->demux, &feed->ts, in dvb_dmxdev_start_feed()
589 tsfeed = feed->ts; in dvb_dmxdev_start_feed()
592 ret = tsfeed->set(tsfeed, feed->pid, ts_type, ts_pes, 32768, timeout); in dvb_dmxdev_start_feed()
610 struct dmxdev_feed *feed; in dvb_dmxdev_filter_start() local
636 struct dmx_section_feed **secfeed = &filter->feed.sec; in dvb_dmxdev_filter_start()
647 *secfeed = dmxdev->filter[i].feed.sec; in dvb_dmxdev_filter_start()
678 filter->feed.sec->start_filtering(*secfeed); in dvb_dmxdev_filter_start()
700 ret = filter->feed.sec->start_filtering(filter->feed.sec); in dvb_dmxdev_filter_start()
708 list_for_each_entry(feed, &filter->feed.ts, next) { in dvb_dmxdev_filter_start()
709 ret = dvb_dmxdev_start_feed(dmxdev, filter, feed); in dvb_dmxdev_filter_start()
797 struct dmxdev_feed *feed; in dvb_dmxdev_add_pid() local
805 (!list_empty(&filter->feed.ts))) in dvb_dmxdev_add_pid()
808 feed = kzalloc(sizeof(struct dmxdev_feed), GFP_KERNEL); in dvb_dmxdev_add_pid()
809 if (feed == NULL) in dvb_dmxdev_add_pid()
812 feed->pid = pid; in dvb_dmxdev_add_pid()
813 list_add(&feed->next, &filter->feed.ts); in dvb_dmxdev_add_pid()
816 return dvb_dmxdev_start_feed(dmxdev, filter, feed); in dvb_dmxdev_add_pid()
824 struct dmxdev_feed *feed, *tmp; in dvb_dmxdev_remove_pid() local
830 list_for_each_entry_safe(feed, tmp, &filter->feed.ts, next) { in dvb_dmxdev_remove_pid()
831 if ((feed->pid == pid) && (feed->ts != NULL)) { in dvb_dmxdev_remove_pid()
832 feed->ts->stop_filtering(feed->ts); in dvb_dmxdev_remove_pid()
834 feed->ts); in dvb_dmxdev_remove_pid()
835 list_del(&feed->next); in dvb_dmxdev_remove_pid()
836 kfree(feed); in dvb_dmxdev_remove_pid()
879 INIT_LIST_HEAD(&dmxdevfilter->feed.ts); in dvb_dmxdev_pes_filter_set()