1. 05 6月, 2017 1 次提交
  2. 19 4月, 2017 1 次提交
    • H
      [media] cec: Kconfig cleanup · 56a263aa
      Hans Verkuil 提交于
      The Kconfig options for the CEC subsystem were a bit messy. In
      addition there were two cec sources (cec-edid.c and cec-notifier.c)
      that were outside of the media/cec directory, which was weird.
      
      Move those sources to media/cec as well.
      
      The cec-edid and cec-notifier functionality is now part of the cec
      module and these are no longer separate modules.
      
      Also remove the MEDIA_CEC_EDID config option and include it with the
      main CEC config option (which defined CEC_EDID anyway).
      
      Added static inlines to cec-edid.h for dummy functions when CEC_CORE
      isn't defined.
      
      CEC drivers should now depend on CEC_CORE.
      
      CEC drivers that need the cec-notifier functionality must explicitly
      select CEC_NOTIFIER.
      
      The s5p-cec and stih-cec drivers depended on VIDEO_DEV instead of
      CEC_CORE, fix that as well.
      Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
      Acked-by: NBenjamin Gaignard <benjamin.gaignard@linaro.org>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      56a263aa
  3. 10 4月, 2017 1 次提交
  4. 19 11月, 2016 1 次提交
    • M
      [media] Kconfig: fix breakages when DVB_CORE is not selected · a4afb3ed
      Mauro Carvalho Chehab 提交于
      On some weird randconfigs, it is possible to select DVB
      drivers, without having the DVB_CORE:
      
      CONFIG_DVB_AU8522=m
      CONFIG_DVB_AU8522_V4L=m
      CONFIG_DVB_TUNER_DIB0090=m
      
      This was never supposed to work, but changeset 22a613e8
      ("[media] dvb_frontend: merge duplicate dvb_tuner_ops.release implementations")
      caused it to be exposed:
      
         drivers/built-in.o: In function `fc0011_attach':
         (.text+0x1598fb): undefined reference to `dvb_tuner_simple_release'
         drivers/built-in.o:(.rodata+0x55e58): undefined reference to `dvb_tuner_simple_release'
         drivers/built-in.o:(.rodata+0x57398): undefined reference to `dvb_tuner_simple_release'
      
      Fixes: 22a613e8 ("[media] dvb_frontend: merge duplicate dvb_tuner_ops.release implementations")
      Reported-by: Nkbuild test robot <fengguang.wu@intel.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
      a4afb3ed
  5. 17 11月, 2016 1 次提交
  6. 20 9月, 2016 2 次提交
  7. 09 7月, 2016 1 次提交
  8. 28 6月, 2016 1 次提交
  9. 11 1月, 2016 1 次提交
  10. 04 12月, 2015 1 次提交
  11. 18 6月, 2015 1 次提交
    • M
      Kconfig: disable Media Controller for DVB · 6cea28d0
      Mauro Carvalho Chehab 提交于
      Since when we start discussions about the usage Media Controller for
      complex hardware, one thing become clear: the way it is, MC fails to
      map anything different than capture/output/m2m video-only streaming.
      
      The point is that MC has entities named as devnodes, but the only
      devnode used (before the DVB patches) is MEDIA_ENT_T_DEVNODE_V4L.
      Due to the way MC got implemented, however, this entity actually
      doesn't represent the devnode, but the hardware I/O engine that
      receives data via DMA.
      
      By coincidence, such DMA is associated with the V4L device node
      on webcam hardware, but this is not true even for other V4L2
      devices. For example, on USB hardware, the DMA is done via the
      USB controller. The data passes though a in-kernel filter that
      strips off the URB headers. Other V4L2 devices like radio may not
      even have DMA. When it have, the DMA is done via ALSA, and not
      via the V4L devnode.
      
      In other words, MC is broken as a whole, but tagging it as BROKEN
      right now would do more harm than good.
      
      So, instead, let's mark, for now, the DVB part as broken and
      block all new changes to MC while we fix this mess, whith
      we hopefully will do for the next Kernel version.
      Requested-by: NLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
      Acked-by: NLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@osg.samsung.com>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      6cea28d0
  12. 09 5月, 2015 1 次提交
  13. 14 2月, 2015 1 次提交
  14. 17 12月, 2014 1 次提交
    • H
      [media] bq/c-qcam, w9966, pms: move to staging in preparation for removal · 427ae153
      Hans Verkuil 提交于
      These drivers haven't been tested in a long, long time. The hardware is
      ancient and hopelessly obsolete. These drivers also need to be converted
      to newer media frameworks but due to the lack of hardware that's going
      to be impossible. In addition, cheaper and vastly better hardware is
      available today.
      
      So these drivers are a prime candidate for removal. If someone is
      interested in working on these drivers to prevent their removal, then
      please contact the linux-media mailinglist.
      
      Let's be honest, the age of parallel port webcams and ISA video capture
      boards is really gone.
      Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@osg.samsung.com>
      427ae153
  15. 04 9月, 2014 1 次提交
  16. 22 7月, 2014 2 次提交
  17. 21 12月, 2013 1 次提交
    • M
      [media] subdev autoselect only works if I2C and I2C_MUX is selected · 347f7a37
      Mauro Carvalho Chehab 提交于
      As reported by the kbuild test robot <fengguang.wu@intel.com>:
      
      > warning: (VIDEO_EM28XX_DVB) selects DVB_M88DS3103 which has unmet direct dependencies (MEDIA_SUPPORT && DVB_CORE && I2C && I2C_MUX)
      >    drivers/built-in.o: In function `m88ds3103_release':
      > >> m88ds3103.c:(.text+0x1ab1af): undefined reference to `i2c_del_mux_adapter'
      >    drivers/built-in.o: In function `m88ds3103_attach':
      > >> (.text+0x1ab342): undefined reference to `i2c_add_mux_adapter'
      
      There are 3 possible ways to fix it:
      
      1) make em28xx dependent on I2C_MUX.
      
      That sounds wrong, as the em28xx bridge doesn't have i2c muxes on it,
      and just one frontend has.
      
      Well, subdevs could eventually be converted to, instead of using dvb
      i2c gate control, to use i2c mux support.
      
      That makes sense, but it takes time and lots of effort. Not sure if
      this will happen anytime soon.
      
      2) MEDIA_SUBDRV_AUTOSELECT can be dependent of I2C and I2C_MUX.
      
      That means that users will need to manually enable I2C_MUX on some
      distributions. Not sure about others, but, on Fedora, this option is
      disabled.
      
      So, it can end by generating a number of complains from users
      that their devices suddenly stopped working after a Kernel upgrade,
      at least until all distros that ship Kernels with I2C_MUX enabled.
      
      3) if MEDIA_SUBDRV_AUTOSELECT is selected, it will select I2C and I2C_MUX.
      
      Of course, MEDIA_SUBDRV_AUTOSELECT will need to inherit all dependencies
      that I2C and I2C_MUX have (only HAS_IOMEM).
      
      The disadvantage is that, if new dependencies are added on I2C, they'll
      also need to be added here.
      
      As the hole idea of autoselect is to let the user not bother about whatever
      frontend/tuner is used by a driver, IMHO, (3) is the better solution.
      Reported-by: Nkbuild test robot <fengguang.wu@intel.com>
      Signed-off-by: NMauro Carvalho Chehab <m.chehab@samsung.com>
      347f7a37
  18. 20 6月, 2013 1 次提交
    • M
      [media] Fix build when drivers are builtin and frontend modules · bb69ee27
      Mauro Carvalho Chehab 提交于
      There are a large number of reports that the media build is
      not compiling when some drivers are compiled as builtin, while
      the needed frontends are compiled as module.
      
      On the last one of such reports:
      	From: kbuild test robot <fengguang.wu@intel.com>
      	Subject: saa7134-dvb.c:undefined reference to `zl10039_attach'
      
      The .config file has:
      
      	CONFIG_VIDEO_SAA7134=y
      	CONFIG_VIDEO_SAA7134_DVB=y
      	# CONFIG_MEDIA_ATTACH is not set
      	CONFIG_DVB_ZL10039=m
      
      And it produces all those errors:
      
         drivers/built-in.o: In function `set_type':
         tuner-core.c:(.text+0x2f263e): undefined reference to `tea5767_attach'
         tuner-core.c:(.text+0x2f273e): undefined reference to `tda9887_attach'
         drivers/built-in.o: In function `tuner_probe':
         tuner-core.c:(.text+0x2f2d20): undefined reference to `tea5767_autodetection'
         drivers/built-in.o: In function `av7110_attach':
         av7110.c:(.text+0x330bda): undefined reference to `ves1x93_attach'
         av7110.c:(.text+0x330bf7): undefined reference to `stv0299_attach'
         av7110.c:(.text+0x330c63): undefined reference to `tda8083_attach'
         av7110.c:(.text+0x330d09): undefined reference to `ves1x93_attach'
         av7110.c:(.text+0x330d33): undefined reference to `tda8083_attach'
         av7110.c:(.text+0x330d5d): undefined reference to `stv0297_attach'
         av7110.c:(.text+0x330dbe): undefined reference to `stv0299_attach'
         drivers/built-in.o: In function `tuner_attach_dtt7520x':
         ngene-cards.c:(.text+0x3381cb): undefined reference to `dvb_pll_attach'
         drivers/built-in.o: In function `demod_attach_lg330x':
         ngene-cards.c:(.text+0x33828a): undefined reference to `lgdt330x_attach'
         drivers/built-in.o: In function `demod_attach_stv0900':
         ngene-cards.c:(.text+0x3383d5): undefined reference to `stv090x_attach'
         drivers/built-in.o: In function `cineS2_probe':
         ngene-cards.c:(.text+0x338b7f): undefined reference to `drxk_attach'
         drivers/built-in.o: In function `configure_tda827x_fe':
         saa7134-dvb.c:(.text+0x346ae7): undefined reference to `tda10046_attach'
         drivers/built-in.o: In function `dvb_init':
         saa7134-dvb.c:(.text+0x347283): undefined reference to `mt352_attach'
         saa7134-dvb.c:(.text+0x3472cd): undefined reference to `mt352_attach'
         saa7134-dvb.c:(.text+0x34731c): undefined reference to `tda10046_attach'
         saa7134-dvb.c:(.text+0x34733c): undefined reference to `tda10046_attach'
         saa7134-dvb.c:(.text+0x34735c): undefined reference to `tda10046_attach'
         saa7134-dvb.c:(.text+0x347378): undefined reference to `tda10046_attach'
         saa7134-dvb.c:(.text+0x3473db): undefined reference to `tda10046_attach'
         drivers/built-in.o:saa7134-dvb.c:(.text+0x347502): more undefined references to `tda10046_attach' follow
         drivers/built-in.o: In function `dvb_init':
         saa7134-dvb.c:(.text+0x347812): undefined reference to `mt352_attach'
         saa7134-dvb.c:(.text+0x347951): undefined reference to `mt312_attach'
         saa7134-dvb.c:(.text+0x3479a9): undefined reference to `mt312_attach'
      >> saa7134-dvb.c:(.text+0x3479c1): undefined reference to `zl10039_attach'
      
      This is happening because a builtin module can't use directly a symbol
      found on a module. By enabling CONFIG_MEDIA_ATTACH, the configuration
      becomes valid, as dvb_attach() macro loads the module if needed, making
      the symbol available to the builtin module.
      
      While this bug started to appear after the patches that use IS_DEFINED
      macro (like changeset 7b34be71), this
      bug is a way ancient than that.
      
      The thing is that, before the IS_DEFINED() patches, the logic used to be:
      
             && defined(MODULE))
      struct dvb_frontend *zl10039_attach(struct dvb_frontend *fe,
      					u8 i2c_addr,
      					struct i2c_adapter *i2c);
      static inline struct dvb_frontend *zl10039_attach(struct dvb_frontend *fe,
      					u8 i2c_addr,
      					struct i2c_adapter *i2c)
      {
      	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
      	return NULL;
      }
      
      The above code, with the .config file used, was evoluting to FALSE
      (instead of TRUE as it should be, as CONFIG_DVB_ZL10039 is 'm'),
      and were adding the static inline code at saa7134-dvb, instead
      of the external call. So, while it weren't producing any compilation
      error, the code weren't working either.
      
      So, as the overhead for using CONFIG_MEDIA_ATTACH is minimal, just
      enable it, if MODULES is defined.
      Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
      bb69ee27
  19. 12 1月, 2013 1 次提交
  20. 28 12月, 2012 2 次提交
  21. 18 10月, 2012 1 次提交
  22. 21 8月, 2012 3 次提交
  23. 16 8月, 2012 4 次提交
  24. 14 8月, 2012 9 次提交