1. 15 Oct, 2020 40 commits
    • Mauro Carvalho Chehab's avatar
      docs: conf.py: change the Sphinx 3.x+ text · 14059a38
      Mauro Carvalho Chehab authored
      After the build fix patches, it is believed that the output
      with Sphinx 3.x won't be a problem. Still, the C domain
      support was re-written, and this can have caused hidden
      issues.
      
      So, let's keep the warning, changing it to a lighter
      warning text.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      14059a38
    • Mauro Carvalho Chehab's avatar
      docs: conf.py: fix c:function support with Sphinx 3.x · b34b86d7
      Mauro Carvalho Chehab authored
      Sphinx C parser for the C domain is now more pedantic when
      trying to identify the function types. That prevents scope
      macros to be used as type defines.
      
      Yet, since 3.0.2, it is possible to provide it a list of
      such macros. Add them, in order to solve several Sphinx 3.x
      warnings.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      b34b86d7
    • Mauro Carvalho Chehab's avatar
      docs: basics.rst: avoid duplicated C function declaration · a57c3522
      Mauro Carvalho Chehab authored
      pci_device_id is already documented at pci.rst:
      
      	./Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'PCI/pci'.
      	Declaration is 'pci_device_id'.
      
      The kstrtol and kstrtoul are already at kernel-api:
      
      	./Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'kstrtoul'.
      	./Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'kstrtol'.
      
      And the printk is already defined at printk-basics:
      
      	./Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/printk-basics'.
      	Declaration is 'printk'.
      
      So, exclude those identifiers from basirs.rst.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      a57c3522
    • Mauro Carvalho Chehab's avatar
      docs: mei.rst: fix a C expression markup · ccf12273
      Mauro Carvalho Chehab authored
      Sphinx 3.x doesn't allow expressions using :c:func markup:
      
      	./Documentation/driver-api/mei/mei.rst:41: WARNING: Unparseable C cross-reference: 'close(int fd)'
      	Invalid C declaration: Expected end of definition. [error at 5]
      	  close(int fd)
      	  -----^
      
      So, convert it into a :c:expr.
      Acked-by: default avatarTomas Winkler <tomas.winkler@intel.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      ccf12273
    • Mauro Carvalho Chehab's avatar
      docs: it_IT: hacking.rst: fix a typo on a markup · 366a0765
      Mauro Carvalho Chehab authored
      There's a missing "`", causing this warning:
      	./Documentation/translations/it_IT/kernel-hacking/hacking.rst:404: WARNING: Unparseable C cross-reference: 'cpu_to_be32p(), che prende un puntatore\nad un tipo, e ritorna il valore convertito. L\'altra variante per\nla famiglia di conversioni "in-situ", come :c:func:`cpu_to_be32s'
      	Invalid C declaration: Expected end of definition. [error at 14]
      	  cpu_to_be32p(), che prende un puntatore
      	ad un tipo, e ritorna il valore convertito. L'altra variante per
      	la famiglia di conversioni "in-situ", come :c:func:`cpu_to_be32s
      	  --------------^
      Acked-by: default avatarFederico Vaga <federico.vaga@vaga.pv.it>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      366a0765
    • Mauro Carvalho Chehab's avatar
      docs: devices.rst: fix a C reference markup · 2f27ed75
      Mauro Carvalho Chehab authored
      The C domain parser of Sphinx3 expects just function names
      for :c:func: markups:
      
      	./Documentation/driver-api/pm/devices.rst:413: WARNING: Unparseable C cross-reference: 'device_may_wakeup(dev)'
      	Invalid C declaration: Expected end of definition. [error at 17]
      	  device_may_wakeup(dev)
      	  -----------------^
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      2f27ed75
    • Mauro Carvalho Chehab's avatar
      docs: gpu: i915.rst: Fix several C duplication warnings · 11604da2
      Mauro Carvalho Chehab authored
      As reported by Sphinx:
      
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:1147: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_wait_unlocked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:1169: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_poll_wait'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:1189: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_read'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:2669: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_stream_enable'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:2734: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_stream_disable'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:2820: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_oa_stream_init'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3010: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_read'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3098: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_poll_locked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3129: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_poll'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3152: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_enable_locked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3181: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_disable_locked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3273: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_ioctl'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3296: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_destroy_locked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3321: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_release'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3379: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_open_ioctl_locked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3534: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'read_properties_unlocked'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3717: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_open_ioctl'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3760: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_register'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:3789: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_unregister'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:4009: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_add_config_ioctl'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:4162: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_remove_config_ioctl'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:4260: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_init'.
      	./Documentation/gpu/i915:646: ./drivers/gpu/drm/i915/i915_perf.c:4423: WARNING: Duplicate C declaration, also defined in 'gpu/i915'.
      	Declaration is 'i915_perf_fini'.
      
      With Sphinx 3, C declarations can't be duplicated anymore,
      so let's exclude those from the other internals found on
      i915_perf.c file.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      11604da2
    • Mauro Carvalho Chehab's avatar
      docs: infrastructure.rst: don't include firmware kernel-doc · afe178ad
      Mauro Carvalho Chehab authored
      Those are already documented at:
      
      	Documentation/driver-api/firmware/request_firmware.rst
      
      Including it twice is causing lots of warnings:
      
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'request_firmware'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'firmware_request_nowarn'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'request_firmware_direct'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'firmware_request_platform'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'firmware_request_cache'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'request_firmware_into_buf'.
      	./Documentation/driver-api/infrastructure.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/firmware/request_firmware'.
      	Declaration is 'request_firmware_nowait'.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      afe178ad
    • Mauro Carvalho Chehab's avatar
      docs: libata.rst: fix a wrong usage of :c:type: tag · b989451b
      Mauro Carvalho Chehab authored
      The usage of :c:type: to reference to a struct member is wrong,
      as pointed by Sphinx 3:
      
      	./Documentation/driver-api/libata.rst:511: WARNING: Unparseable C cross-reference: 'qc->complete_fn'
      	Invalid C declaration: Expected end of definition. [error at 2]
      	  qc->complete_fn
      	  --^
      
      Instead, let's use :c:expr: for such purpose.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      b989451b
    • Mauro Carvalho Chehab's avatar
      docs: kgdb.rst: fix :c:type: usages · 365ff56f
      Mauro Carvalho Chehab authored
      Which Sphinx 3, :c:type:  can't be used anymore for structs,
      as this should be used only for typedefs.
      
      Rely on automarkup.py for struct references.
      
      This file has an special case, though: it uses the tag also
      to point to an array. Let's use, instead, :c:expr: for such
      purpose, as it should do the right thing.
      
      This should fix this warning:
      
      	./Documentation/dev-tools/kgdb.rst:875: WARNING: Unparseable C cross-reference: 'kdb_poll_funcs[]'
      	Invalid C declaration: Expected end of definition. [error at 14]
      	  kdb_poll_funcs[]
      	  --------------^
      Acked-by: default avatarDaniel Thompson <daniel.thompson@linaro.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      365ff56f
    • Mauro Carvalho Chehab's avatar
      docs: fpga: replace :c:member: macros · 64d41516
      Mauro Carvalho Chehab authored
      Those macros are not doing the right thing with Sphinx 3,
      causing parse errors:
      
      	./Documentation/driver-api/fpga/fpga-mgr.rst:104: WARNING: Unparseable C cross-reference: 'fpga_manager->state'
      	Invalid C declaration: Expected end of definition. [error at 12]
      	  fpga_manager->state
      	  ------------^
      	./Documentation/driver-api/fpga/fpga-programming.rst:18: WARNING: Unparseable C cross-reference: 'fpga_region->info'
      	Invalid C declaration: Expected end of definition. [error at 11]
      	  fpga_region->info
      	  -----------^
      	./Documentation/driver-api/fpga/fpga-region.rst:62: WARNING: Unparseable C cross-reference: 'fpga_region->bridge_list'
      	Invalid C declaration: Expected end of definition. [error at 11]
      	  fpga_region->bridge_list
      	  -----------^
      	./Documentation/driver-api/fpga/fpga-region.rst:62: WARNING: Unparseable C cross-reference: 'fpga_region->get_bridges'
      	Invalid C declaration: Expected end of definition. [error at 11]
      	  fpga_region->get_bridges
      	  -----------^
      
      Replace them by :c:expr:, with does what's desired.
      Reviewed-by: default avatarMoritz Fischer <mdf@kernel.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      64d41516
    • Mauro Carvalho Chehab's avatar
      docs: writing-an-alsa-driver.rst: fix some bad c:func: markups · 4d9d18ad
      Mauro Carvalho Chehab authored
      Some such markups are invalid, as reported by Sphinx:
      
      	./Documentation/sound/kernel-api/writing-an-alsa-driver.rst:3317: WARNING: Unparseable C cross-reference: 'snd_rawmidi_transmit*'
      	Invalid C declaration: Expected end of definition. [error at 20]
      	  snd_rawmidi_transmit*
      	  --------------------^
      	./Documentation/sound/kernel-api/writing-an-alsa-driver.rst:3917: WARNING: Unparseable C cross-reference: 'copy_from/to_user'
      	Invalid C declaration: Expected end of definition. [error at 9]
      	  copy_from/to_user
      	  ---------^
      
      The first case seems to be better replaced by a literal.
      
      For the second one, let's generate cross-references, by
      spliting it in two.
      Reviewed-by: default avatarTakashi Iwai <tiwai@suse.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      4d9d18ad
    • Mauro Carvalho Chehab's avatar
      docs: block: blk-mq.rst: get rid of :c:type · 8ac86734
      Mauro Carvalho Chehab authored
      The :c:type macros are not used properly there, as reported
      by Sphinx 3:
      
      	./Documentation/block/blk-mq.rst:112: WARNING: Unparseable C cross-reference: 'hctx->dispatch'
      	Invalid C declaration: Expected end of definition. [error at 4]
      	  hctx->dispatch
      	  ----^
      
      Also, they won't be generating any cross references.
      
      So, replace them by a literal markup.
      Reviewed-by: default avatarAndré Almeida <andrealmeid@collabora.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      8ac86734
    • Mauro Carvalho Chehab's avatar
      docs: sound: writing-an-alsa-driver.rst: get rid of :c:type · 68735902
      Mauro Carvalho Chehab authored
      the :c:type shouldn't be used with structs with Sphinx 3,
      as the C domain there uses .. c:struct for structs.
      
      As we have the automarkup extension, let's just get rid of
      all :c:type as a whole, as those will be automagically
      marked as such.
      
      This solves a bunch of warnings with Sphinx 3, like those:
      
      	.../Documentation/sound/kernel-api/writing-an-alsa-driver.rst:490: WARNING: Unparseable C cross-reference: 'calling snd_card_free'
      	Invalid C declaration: Expected end of definition. [error at 8]
      	  calling snd_card_free
      	  --------^
      	.../Documentation/sound/kernel-api/writing-an-alsa-driver.rst:3328: WARNING: Unparseable C cross-reference: 'snd_rawmidi_transmit*'
      	Invalid C declaration: Expected end of definition. [error at 20]
      	  snd_rawmidi_transmit*
      	  --------------------^
      	.../Documentation/sound/kernel-api/writing-an-alsa-driver.rst:3928: WARNING: Unparseable C cross-reference: 'copy_from/to_user'
      	Invalid C declaration: Expected end of definition. [error at 9]
      	  copy_from/to_user
      	  ---------^
      Reviewed-by: default avatarTakashi Iwai <tiwai@suse.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      68735902
    • Mauro Carvalho Chehab's avatar
      docs: devices.rst: get rid of :c:type macros · 6624d64d
      Mauro Carvalho Chehab authored
      There's no need to use macros to use :c:type on this file,
      as automarkup.py should do this automatically.
      
      Also, this breaks compatibility with Sphinx 3.x, as there,
      structs should be declared using .. c:struct.
      
      So, get rid of them.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      6624d64d
    • Mauro Carvalho Chehab's avatar
      docs: fs: fscrypt.rst: get rid of :c:type: tags · 74e2f8d3
      Mauro Carvalho Chehab authored
      The :c:type: tag has problems with Sphinx 3.x, as structs
      there should be declared with c:struct.
      
      So, remove them, relying at automarkup.py extension to
      convert them into cross-references.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      74e2f8d3
    • Mauro Carvalho Chehab's avatar
      docs: pstore-blk.rst: fix kernel-doc tags · b30fd8e9
      Mauro Carvalho Chehab authored
      There is currently a problem with kernel-doc tags from blk.c:
      
      	.../Documentation/admin-guide/pstore-blk:239: ./fs/pstore/blk.c:175: WARNING: Duplicate C declaration, also defined in 'admin-guide/pstore-blk'.
      	Declaration is 'register_pstore_device'.
      	.../Documentation/admin-guide/pstore-blk:239: ./fs/pstore/blk.c:432: WARNING: Duplicate C declaration, also defined in 'admin-guide/pstore-blk'.
      	Declaration is 'register_pstore_blk'.
      	.../Documentation/admin-guide/pstore-blk:242: ./include/linux/pstore_blk.h:43: WARNING: Duplicate C declaration, also defined in 'admin-guide/pstore-blk'.
      	Declaration is 'pstore_device_info'.
      
      Basically, the internal parts is shown with :export:, instead
      of :internal:. Yet, there are some other exported docs that
      aren't at the document, because they lack :identifiers:.
      
      So, instead, let's just use :export: at the kAPI part of
      the documentation.
      Acked-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      b30fd8e9
    • Mauro Carvalho Chehab's avatar
      docs: basics.rst: get rid of rcu kernel-doc macros · 044248db
      Mauro Carvalho Chehab authored
      Those are already defined at kernel-api.rst, as part of the
      synchronization primitives chapter.
      
      This solves several Sphinx 3 warnings, like:
      
      	.../Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'rcu_idle_enter'.
      	.../Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'rcu_idle_exit'.
      	.../Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'rcu_is_watching'.
      	.../Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'call_rcu'.
      	.../Documentation/driver-api/basics.rst: WARNING: Duplicate C declaration, also defined in 'core-api/kernel-api'.
      	Declaration is 'synchronize_rcu'.
      	...
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      044248db
    • Mauro Carvalho Chehab's avatar
      docs: device_link.rst: remove duplicated kernel-doc include · 58bc57b0
      Mauro Carvalho Chehab authored
      The infrastructure.rst file already includes the external
      symbols from drivers/base/core.c.
      
      Duplicating 3 functions there causes namespace collisions:
      
      	Documentation/driver-api/device_link.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/infrastructure'.
      	Declaration is 'device_link_state'.
      	Documentation/driver-api/device_link.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/infrastructure'.
      	Declaration is 'device_link_add'.
      	Documentation/driver-api/device_link.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/infrastructure'.
      	Declaration is 'device_link_del'.
      	Documentation/driver-api/device_link.rst: WARNING: Duplicate C declaration, also defined in 'driver-api/infrastructure'.
      	Declaration is 'device_link_remove'.
      
      So, drop the reference, adding just a mention to the functions
      associated with device_link.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      58bc57b0
    • Mauro Carvalho Chehab's avatar
      docs: scsi: target.rst: remove iSCSI transport class kernel-doc markup · 3048ba60
      Mauro Carvalho Chehab authored
      This is already included at scsi.rst. So, remove the duplication,
      in order to avoid Sphinx warnings.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      3048ba60
    • Mauro Carvalho Chehab's avatar
      docs: basics.rst: move kernel-doc workqueue markups to workqueue.rst · c9e3d519
      Mauro Carvalho Chehab authored
      As there's already a rst file with workqueue markups, containing
      part of them, move the other definitions, in order to avoid
      warnings with Sphinx.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      c9e3d519
    • Mauro Carvalho Chehab's avatar
      docs: remove sound API duplication · 1842c96b
      Mauro Carvalho Chehab authored
      The sound API is documented on two different parts:
      under Documentation/driver-api/sound.rst and under
      Documentation/sound/kernel-api/alsa-driver-api.rst.
      
      The alsa-driver-api.rst seems more complete, and APIs
      are split per type. There's just one missing kernel-doc
      markup there.
      
      Add it and drop the duplicated one.
      Reviewed-by: default avatarTakashi Iwai <tiwai@suse.de>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      1842c96b
    • Mauro Carvalho Chehab's avatar
      docs: kernel-api.rst: drop kernel/irq/manage.c kernel-doc tag · f182e7fd
      Mauro Carvalho Chehab authored
      This is already included at genericirq.rst. Adding it twice
      causes C namespace duplication:
      
      	.../Documentation/core-api/kernel-api:237: ../kernel/irq/manage.c:100: WARNING: Duplicate C declaration, also defined in 'genericirq'.
      	Declaration is 'synchronize_hardirq'.
      	.../Documentation/core-api/kernel-api:237: ../kernel/irq/manage.c:128: WARNING: Duplicate C declaration, also defined in 'genericirq'.
      	Declaration is 'synchronize_irq'.
      	.../Documentation/core-api/kernel-api:237: ../kernel/irq/manage.c:443: WARNING: Duplicate C declaration, also defined in 'genericirq'.
      	Declaration is 'irq_set_affinity_notifier'.
      	...
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      f182e7fd
    • Mauro Carvalho Chehab's avatar
      docs: genericirq.rst: don't document chip.c functions twice · 9b9b0bda
      Mauro Carvalho Chehab authored
      Currently, kernel/irq/chip.c is included twice, one for
      export functions, and then for internal ones. However, as
      the :export:  and :internal: tags are missing, they ended
      being included twice.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      9b9b0bda
    • Mauro Carvalho Chehab's avatar
      docs: net: ieee802154.rst: fix C expressions · 640e3f80
      Mauro Carvalho Chehab authored
      There are some warnings produced with Sphinx 3.x:
      
      	Documentation/networking/ieee802154.rst:29: WARNING: Error in declarator or parameters
      	Invalid C declaration: Expecting "(" in parameters. [error at 7]
      	  int sd = socket(PF_IEEE802154, SOCK_DGRAM, 0);
      	  -------^
      	Documentation/networking/ieee802154.rst:134: WARNING: Invalid C declaration: Expected end of definition. [error at 81]
      	  void ieee802154_rx_irqsafe(struct ieee802154_hw *hw, struct sk_buff *skb, u8 lqi):
      	  ---------------------------------------------------------------------------------^
      	Documentation/networking/ieee802154.rst:139: WARNING: Invalid C declaration: Expected end of definition. [error at 95]
      	  void ieee802154_xmit_complete(struct ieee802154_hw *hw, struct sk_buff *skb, bool ifs_handling):
      	  -----------------------------------------------------------------------------------------------^
      	Documentation/networking/ieee802154.rst:158: WARNING: Invalid C declaration: Expected end of definition. [error at 35]
      	  int start(struct ieee802154_hw *hw):
      	  -----------------------------------^
      	Documentation/networking/ieee802154.rst:162: WARNING: Invalid C declaration: Expected end of definition. [error at 35]
      	  void stop(struct ieee802154_hw *hw):
      	  -----------------------------------^
      	Documentation/networking/ieee802154.rst:166: WARNING: Invalid C declaration: Expected end of definition. [error at 61]
      	  int xmit_async(struct ieee802154_hw *hw, struct sk_buff *skb):
      	  -------------------------------------------------------------^
      	Documentation/networking/ieee802154.rst:171: WARNING: Invalid C declaration: Expected end of definition. [error at 43]
      	  int ed(struct ieee802154_hw *hw, u8 *level):
      	  -------------------------------------------^
      	Documentation/networking/ieee802154.rst:176: WARNING: Invalid C declaration: Expected end of definition. [error at 62]
      	  int set_channel(struct ieee802154_hw *hw, u8 page, u8 channel):
      	  --------------------------------------------------------------^
      
      Caused by some bad c:function: prototypes. Fix them.
      Acked-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      640e3f80
    • Mauro Carvalho Chehab's avatar
      docs: it_IT: fix namespace collisions at locking.rst · 71a8156e
      Mauro Carvalho Chehab authored
      The C domain functions there collide with the English ones,
      due to namespace collision, generating lots of warnings with
      Sphinx 3.x:
      
      	./include/linux/mutex.h:121: WARNING: Duplicate C declaration, also defined in 'translations/it_IT/kernel-hacking/locking'.
      	Declaration is 'mutex_init'.
      	./include/linux/mutex.h:152: WARNING: Duplicate C declaration, also defined in 'translations/it_IT/kernel-hacking/locking'.
      	Declaration is 'mutex_is_locked'.
      	./include/linux/mutex.h:226: WARNING: Duplicate C declaration, also defined in 'translations/it_IT/kernel-hacking/locking'.
      	Declaration is 'mutex_trylock_recursive'.
      	./kernel/locking/mutex.c:281: WARNING: Duplicate C declaration, also defined in 'translations/it_IT/kernel-hacking/locking'.
      	Declaration is 'mutex_lock'.
      	...
      
      Add a namespace tag there, in order to prevent that.
      Acked-by: default avatarFederico Vaga <federico.vaga@vaga.pv.it>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      71a8156e
    • Mauro Carvalho Chehab's avatar
      docs: trace-uses.rst: remove bogus c-domain tags · d7faad15
      Mauro Carvalho Chehab authored
      There are some c-domain tags that are wrong. While this won't
      cause problems with Sphinx < 3.0, this cause troubles with
      newer versions, as the C parser won't recognize the contents
      of the tag, and will drop it from the output.
      
      Let's just place them at literal blocks.
      Reviewed-by: default avatarKamalesh Babulal <kamalesh@linux.vnet.ibm.com>
      Acked-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      d7faad15
    • Mauro Carvalho Chehab's avatar
      docs: get rid of :c:type explicit declarations for structs · 9303c9d5
      Mauro Carvalho Chehab authored
      The :c:type:`foo` only works properly with structs before
      Sphinx 3.x.
      
      On Sphinx 3.x, structs should now be declared using the
      .. c:struct, and referenced via :c:struct tag.
      
      As we now have the automarkup.py macro, that automatically
      convert:
      	struct foo
      
      into cross-references, let's get rid of that, solving
      several warnings when building docs with Sphinx 3.x.
      
      Reviewed-by: André Almeida <andrealmeid@collabora.com> # blk-mq.rst
      Reviewed-by: Takashi Iwai <tiwai@suse.de> # sound
      Reviewed-by: default avatarMike Rapoport <rppt@linux.ibm.com>
      Reviewed-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      9303c9d5
    • Mauro Carvalho Chehab's avatar
      docs: remove some replace macros like |struct foo| · abc59fd4
      Mauro Carvalho Chehab authored
      There are three files with replace macros for structs,
      mapping them into Sphinx 2.x C domain references.
      
      Well, this is broken on Sphinx 3.x. Also, for Sphinx 2.x,
      the automarkup macro should be able to take care of them.
      
      So, let's just drop those.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      abc59fd4
    • Mauro Carvalho Chehab's avatar
      media: cec-core.rst: don't use c:type for structs · 5b76632e
      Mauro Carvalho Chehab authored
      The new C domain code on Sphinx 3 doesn't allow anymore
      to use c:type:: for structs.
      
      Now that cdomain.py has backward support, let's use
      c:struct:: instead.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      5b76632e
    • Mauro Carvalho Chehab's avatar
      media: docs: make RC documents more compatible with Sphinx 3.1+ · 5f536f4a
      Mauro Carvalho Chehab authored
      Sphinx 3.x broke support for the cdomain.py extension, as the
      c domain code was rewritten. Due to that, the c tags need to
      be re-written, in order to use the new c domain notation.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      5f536f4a
    • Mauro Carvalho Chehab's avatar
      media: docs: make MC documents more compatible with Sphinx 3.1+ · 937e6805
      Mauro Carvalho Chehab authored
      Sphinx 3.x broke support for the cdomain.py extension, as the
      c domain code was rewritten. Due to that, the c tags need to
      be re-written, in order to use the new c domain notation.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      937e6805
    • Mauro Carvalho Chehab's avatar
      media: docs: make DVB documents more compatible with Sphinx 3.1+ · f9b2e8aa
      Mauro Carvalho Chehab authored
      Sphinx 3.x broke support for the cdomain.py extension, as the
      c domain code was rewritten. Due to that, the c tags need to
      be re-written, in order to use the new c domain notation.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      f9b2e8aa
    • Mauro Carvalho Chehab's avatar
      media: docs: make V4L documents more compatible with Sphinx 3.1+ · 407e84cd
      Mauro Carvalho Chehab authored
      Sphinx 3.x broke support for the cdomain.py extension, as the
      c domain code was rewritten. Due to that, the c tags need to
      be re-written, in order to use the new c domain notation.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      407e84cd
    • Mauro Carvalho Chehab's avatar
      media: docs: make CEC documents compatible with Sphinx 3.1+ · 01fae02d
      Mauro Carvalho Chehab authored
      Sphinx 3.x broke support for the cdomain.py extension, as the
      c domain code was rewritten. Due to that, the c tags need to
      be re-written, in order to use the new c domain notation.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      01fae02d
    • Nícolas F. R. A. Prado's avatar
      docs: automarkup.py: Add cross-reference for parametrized C macros · c51d9b04
      Nícolas F. R. A. Prado authored
      Sphinx 3 added support for declaring C macros with parameters using the
      :c:macro role.
      
      To support automarkup for both functions and parametrized macros using
      the same regex (words ending in ()), try to cross-reference to both, and
      only fall back to regular text if neither exist.
      Signed-off-by: default avatarNícolas F. R. A. Prado <nfraprado@protonmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      c51d9b04
    • Nícolas F. R. A. Prado's avatar
      docs: automarkup.py: Skip C reserved words when cross-referencing · 3050edfd
      Nícolas F. R. A. Prado authored
      With the transition to Sphinx 3, new warnings were caused by
      automarkup, exposing bugs in the name matching.
      
      When automarkup parsed a text like "struct struct" in the documentation,
      it tried to cross-reference to a "struct" symbol, which is recognized as
      a C reserved word by Sphinx 3, generating a warning.
      
      Add some C reserved words (only the ones that were causing warnings) to
      a list and skip them while trying to cross-reference.
      Signed-off-by: default avatarNícolas F. R. A. Prado <nfraprado@protonmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      3050edfd
    • Nícolas F. R. A. Prado's avatar
      docs: automarkup.py: Fix regexes to solve sphinx 3 warnings · f66e47f9
      Nícolas F. R. A. Prado authored
      With the transition to Sphinx 3, new warnings were generated by
      automarkup, exposing bugs in the regexes.
      
      The warnings were caused by the expressions matching words in the
      translated versions of the documentation, since any unicode character
      was matched.
      
      Fix the regular expression by making the C regexes use ASCII and
      ensuring the expressions only match the beginning of words,
      in order to avoid warnings like this:
      
      	WARNING: Unparseable C cross-reference: '调用debugfs_rename'
      
      That's probably due to the lack of using spaces between words
      on Chinese.
      Signed-off-by: default avatarNícolas F. R. A. Prado <nfraprado@protonmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      f66e47f9
    • Nícolas F. R. A. Prado's avatar
      docs: automarkup.py: Use new C roles in Sphinx 3 · 06dc65b0
      Nícolas F. R. A. Prado authored
      While Sphinx 2 used a single c:type role for struct, union, enum and
      typedef, Sphinx 3 uses a specific role for each one.
      To keep backward compatibility, detect the Sphinx version and use the
      correct roles for that version.
      Signed-off-by: default avatarNícolas F. R. A. Prado <nfraprado@protonmail.com>
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      06dc65b0
    • Mauro Carvalho Chehab's avatar
      docs: kerneldoc.py: add support for kerneldoc -nosymbol · 2791f47d
      Mauro Carvalho Chehab authored
      Currently, there's no way to exclude identifiers from
      a kernel-doc markup. Add support for it.
      Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
      2791f47d