1. 03 2月, 2008 1 次提交
  2. 29 1月, 2008 16 次提交
    • S
      kbuild: warn about ld added unique sections · e241a630
      Sam Ravnborg 提交于
      If there is a mixture of specifying sections for code in gcc
      and assembler then if the assembler code do not add
      the "ax" flags the linker will see this as two different sections
      and generate unique sections for each. ld does so by adding a dot
      and a number.
      Teach modpost to warn if a section shows up that match this
      pattern - but do this only for non-debug sections.
      
      It will result in warnings like this:
      
      WARNING: vmlinux.o (.sched.text.1): unexpected section name.
      The (.[number]+) following section name are ld generated and not expected.
      Did you forget to use "ax"/"aw" in a .S file?
      Note that for example <linux/init.h> contains
      section definitions for use in .S files.
      
      All warnings seen with a defconfig build for:
      x86 (32+64bit) and sparc64 has been fixed (via respective maintainers).
      
      arm, powerpc (64 bit), s390 (32 bit), ia64, alpha, sh4 checked - no
      warnings seen with a defconfig build.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      e241a630
    • S
      kbuild: add verbose option to Section mismatch reporting in modpost · 588ccd73
      Sam Ravnborg 提交于
      If the config option CONFIG_SECTION_MISMATCH is not set and
      we see a Section mismatch present the following to the user:
      
      modpost: Found 1 section mismatch(es).
      To see additional details select "Enable full Section mismatch analysis"
      in the Kernel Hacking menu (CONFIG_SECTION_MISMATCH).
      
      If the option CONFIG_SECTION_MISMATCH is selected
      then be verbose in the Section mismatch reporting from mdopost.
      Sample outputs:
      
      WARNING: o-x86_64/vmlinux.o(.text+0x7396): Section mismatch in reference from the function discover_ebda() to the variable .init.data:ebda_addr
      The function  discover_ebda() references
      the variable __initdata ebda_addr.
      This is often because discover_ebda lacks a __initdata
      annotation or the annotation of ebda_addr is wrong.
      
      WARNING: o-x86_64/vmlinux.o(.data+0x74d58): Section mismatch in reference from the variable pci_serial_quirks to the function .devexit.text:pci_plx9050_exit()
      The variable pci_serial_quirks references
      the function __devexit pci_plx9050_exit()
      If the reference is valid then annotate the
      variable with __exit* (see linux/init.h) or name the variable:
      *driver, *_template, *_timer, *_sht, *_ops, *_probe, *_probe_one, *_console,
      
      WARNING: o-x86_64/vmlinux.o(__ksymtab+0x630): Section mismatch in reference from the variable __ksymtab_arch_register_cpu to the function .cpuinit.text:arch_register_cpu()
      The symbol arch_register_cpu is exported and annotated __cpuinit
      Fix this by removing the __cpuinit annotation of arch_register_cpu or drop the export.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      588ccd73
    • A
      remove __attribute_used__ · 3ff6eecc
      Adrian Bunk 提交于
      Remove the deprecated __attribute_used__.
      
      [Introduce __section in a few places to silence checkpatch /sam]
      Signed-off-by: NAdrian Bunk <bunk@kernel.org>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      3ff6eecc
    • S
      kbuild: simplified warning report in modpost · 58fb0d4f
      Sam Ravnborg 提交于
      Refactor code so the warning report function
      does nothing else than reporting warnings.
      As a side effect some other code paths were cleaned
      up by this.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      58fb0d4f
    • S
      kbuild: introduce a few helpers in modpost · ff13f926
      Sam Ravnborg 提交于
      Introducing helpers to retreive symbol and section
      names cleaned up the code a bit.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      ff13f926
    • S
      kbuild: use simpler section mismatch warnings in modpost · 157c23c8
      Sam Ravnborg 提交于
      The typical layout is now:
      WARNING: vmlinux.o(.text+0x372ec): Section mismatch: reference to .devinit.text:pci_scan_one_pbm in 'psycho_scan_bus'
      
      This is first step towards more readable warnings.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      157c23c8
    • S
      Use separate sections for __dev/__cpu/__mem code/data · eb8f6890
      Sam Ravnborg 提交于
      Introducing separate sections for __dev* (HOTPLUG),
      __cpu* (HOTPLUG_CPU) and __mem* (MEMORY_HOTPLUG)
      allows us to do a much more reliable Section mismatch
      check in modpost. We are no longer dependent on the actual
      configuration of for example HOTPLUG.
      
      This has the effect that all users see much more
      Section mismatch warnings than before because they
      were almost all hidden when HOTPLUG was enabled.
      The advantage of this is that when building a piece
      of code then it is much more likely that the Section
      mismatch errors are spotted and the warnings will be
      felt less random of nature.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      Cc: Greg KH <greg@kroah.com>
      Cc: Randy Dunlap <randy.dunlap@oracle.com>
      Cc: Adrian Bunk <bunk@kernel.org>
      eb8f6890
    • S
      kbuild: check section names consistently in modpost · 6c5bd235
      Sam Ravnborg 提交于
      Now that match() is introduced use it consistently so
      we can share the section name definitions.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      6c5bd235
    • S
      kbuild: introduce blacklisting in modpost · 10668220
      Sam Ravnborg 提交于
      Change the logic in modpost so we identify all the
      bad combinations of sections that refer to other
      sections.
      Compared to the previous approach we are much less
      dependent on knowledge of what additional sections
      the tool chain uses and thus we can keep the false
      positives low.
      
      The implmentation is changed to use a table based
      lookup and we now check all combinations in first
      pass so we no longer need separate passes for init
      and exit sections.
      
      Tested that the same warnings are generated for
      an allyesconfig build without CONFIG_HOTPLUG.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      Cc: Randy Dunlap <randy.dunlap@oracle.com>
      Cc: Adrian Bunk <bunk@kernel.org>
      10668220
    • S
      kbuild: code refactoring in modpost · 5b24c071
      Sam Ravnborg 提交于
      Split a too long function up in smaller bits to make
      prgram logic easier to follow.
      A few related changes done due to parameter
      changes.
      
      No functional changes.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      5b24c071
    • S
      kbuild: try harder to find symbol names in modpost · 9ad21c3f
      Sam Ravnborg 提交于
      The relocation record sometimes contained an address
      which was not an exactly match for a symbol.
      
      Implment some simple logic such that if there
      is a symbol within 20 bytes of the address contained
      in the relocation record then print the name of this
      symbol.
      
      With this change modpost could find symbol names
      for the remaining .init.text symbols in my
      allyesconfig build for x86_64.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      9ad21c3f
    • S
      kbuild: fix so modpost can now check any .o file · d1f25e66
      Sam Ravnborg 提交于
      It is very convinient to say:
      scripts/mod/modpost mm/built-in.o
      
      to check if any section mismatch errors occured
      in mm/ (as an example).
      Fix it so this is possible again.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      d1f25e66
    • S
      kbuild: clean up modpost.c · df578e7d
      Sam Ravnborg 提交于
      akpm complained about overly long lines in modpost.c and
      when started additional style issues were fixed:
      
      o Updated my copyright
      o Removed unneeded {}
      o Drop assignments in if ()
      o Spaces around operators
      o Break long lines
      o locate * near variable not type
      o Fix a format specifier for sizeof()
      o Corrected placement of '{' and '}'
      o spaces to tabs (but use tabs only for indention)
      
      modpost.c is not checkpatch clean. Readability were favoured
      on top of checkpatch compliance.
      But checkpatch were used to find additional stuff to clean up.
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      df578e7d
    • A
      kbuild: fix a buffer overflow in modpost · 666ab414
      Andi Kleen 提交于
      When passing an file name > 1k the stack could be overflowed.
      Not really a security issue, but still better plugged.
      Signed-off-by: NAndi Kleen <ak@suse.de>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      666ab414
    • A
      kbuild: fix format string warnings in modpost · 58b7a68d
      Andi Kleen 提交于
      Fix wrong format strings in modpost exposed by the previous patch.
      Including one missing argument -- some random data was printed instead.
      Signed-off-by: NAndi Kleen <ak@suse.de>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      58b7a68d
    • A
      kbuild: declare the modpost error functions as printf like · 6d9a89ea
      Andi Kleen 提交于
      This way gcc can warn for wrong format strings
      Signed-off-by: NAndi Kleen <ak@suse.de>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      6d9a89ea
  3. 18 10月, 2007 1 次提交
    • T
      kbuild: modpost problem when symbols move from one module to another · 4b21960f
      Trent Piepho 提交于
      When part of build an external module tree, modpost first reads in the
      kernel's and then the external tree's Module.symvers files.  From these files
      it establishes a symbol => module mapping.  When it later reads in each module
      built and processes the symbols it finds, it discovers the symbol=>module
      mapping from Module.symvers and leaves it as it is.
      
      The problem comes with a module has been re-named or a symbol has moved from
      one module to another, since the Module.symvers file was generated.  modpost
      does not update the symbol=>module mapping when it finds the new location of
      the symbol when scanning the newly built modules.  This results in the module
      containing incorrect dependency information and the new Module.symvers file
      written by modpost will also contain the incorrect mappings, perpetuating the
      problem to the next build, and so on.
      
      When building the out of kernel development tree for kernel subsystem, like
      v4l-dvb or ALSA, deleting the external Module.symvers file before building
      (which the kernel build system doesn't do and shouldn't be necessary anyway),
      won't fix the problem.  modpost still reads the kernel's Module.symvers, and
      since we a building a kernel subsystem, it will define the same symbols as the
      external modules.
      Signed-off-by: NTrent Piepho <xyzzy@speakeasy.org>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      4b21960f
  4. 13 10月, 2007 1 次提交
    • P
      kbuild: fix segfault in modpost · a83710e5
      Petr Stetiar 提交于
      Fix modpost segfault.
      
      Before:
      -------
      ynezz@ntbk:~/linux-2.6.git$ scripts/mod/modpost vmlinux ath_pci.o
      Segmentation fault
      
      After:
      ------
      ynezz@ntbk:~/linux-2.6.git$ scripts/mod/modpost vmlinux ath_pci.o
      FATAL: section header offset=815726848 in file 'ath_pci.o' is bigger then filesize=153968
      
      Sam: This seems to warn for a binutils issue. Anyway modpost should not
      segfault.
      Signed-off-by: NPetr Stetiar <ynezz@true.cz>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      a83710e5
  5. 11 10月, 2007 1 次提交
    • P
      [NETNS]: Move some code into __init section when CONFIG_NET_NS=n · 4665079c
      Pavel Emelyanov 提交于
      With the net namespaces many code leaved the __init section,
      thus making the kernel occupy more memory than it did before.
      Since we have a config option that prohibits the namespace
      creation, the functions that initialize/finalize some netns
      stuff are simply not needed and can be freed after the boot.
      
      Currently, this is almost not noticeable, since few calls
      are no longer in __init, but when the namespaces will be
      merged it will be possible to free more code. I propose to
      use the __net_init, __net_exit and __net_initdata "attributes"
      for functions/variables that are not used if the CONFIG_NET_NS
      is not set to save more space in memory.
      
      The exiting functions cannot just reside in the __exit section,
      as noticed by David, since the init section will have
      references on it and the compilation will fail due to modpost
      checks. These references can exist, since the init namespace
      never dies and the exit callbacks are never called. So I
      introduce the __exit_refok attribute just like it is already
      done with the __init_refok.
      Signed-off-by: NPavel Emelyanov <xemul@openvz.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      4665079c
  6. 01 8月, 2007 1 次提交
  7. 26 7月, 2007 4 次提交
  8. 20 7月, 2007 1 次提交
  9. 17 7月, 2007 14 次提交