1. 28 6月, 2012 1 次提交
    • Y
      scripts/config: add option to not upper-case symbols · 4edc7e32
      Yann E. MORIN 提交于
      Currently, scripts/config mangles the config option symbols to always
      be upper-case.
      
      While the Linux kernel almost exclusively uses upper-case symbols, there
      are still a few symbols with lower-case which this script can not handle:
      
        $ grep -r -E '^[[:space:]]*config[[:space:]]+[^[:space:]]*[[:lower:]][^[:space:]=.]*$' . |wc -l
        173
      (that's roughly 1.3% of the symbols in 3.5-rc1)
      
      Eg.:
        ./arch/arm/Kconfig:config VFPv3
        ./arch/powerpc/platforms/Kconfig.cputype:config 40x
        ./arch/x86/Kconfig:config SCx200HR_TIMER
        ./drivers/video/console/Kconfig:config FONT_8x8
        ./drivers/video/Kconfig:config NTSC_640x480
      
      Also, other projects that use kconfig may allow for lower- or mixed-case
      symbols, and may find easier to reuse this script than implement each
      their own (potentially flawed) logic. For such a use-case, see:
          http://marc.info/?l=linux-kbuild&m=133409932115848&w=2
      
      This patch adds a new option to keep the given case, and keep the current
      default to upper-case the symbols.
      Signed-off-by: N"Yann E. MORIN" <yann.morin.1998@free.fr>
      Signed-off-by: NMichal Marek <mmarek@suse.cz>
      4edc7e32
  2. 16 5月, 2012 1 次提交
    • Y
      scripts/config: properly report and set string options · d6686da8
      Yann E. MORIN 提交于
      Currently, scripts/config removes the leading double-quote from
      string options, but leaves the trailing double-quote.
      
      Also, double-quotes in a string are escaped, but scripts/config
      does not unescape those when printing
      
      Finally, scripts/config does not escape double-quotes when setting
      string options.
      
      Eg. the current behavior:
          $ grep -E '^CONFIG_FOO=' .config
          CONFIG_FOO="Bar \"Buz\" Meh"
          $ ./scripts/config -s FOO
          Bar \"Buz\" Meh"
          $ ./scripts/config --set-str FOO 'Alpha "Bravo" Charlie'
          $ grep -E '^CONFIG_FOO=' .config
          CONFIG_FOO="Alpha "Bravo" Charlie"
      
      Fix those three, giving this new behavior:
          $ grep -E '^CONFIG_FOO=' .config
          CONFIG_FOO="Bar \"Buz\" Meh"
          $ ./scripts/config -s FOO
          Bar "Buz" Meh
          $ ./scripts/config --set-str FOO 'Alpha "Bravo" Charlie'
          $ grep -E '^CONFIG_FOO=' .config
          CONFIG_FOO="Alpha \"Bravo\" Charlie"
      Signed-off-by: N"Yann E. MORIN" <yann.morin.1998@free.fr>
      Acked-by: NAndi Kleen <andi@firstfloor.org>
      Signed-off-by: NMichal Marek <mmarek@suse.cz>
      d6686da8
  3. 15 12月, 2010 1 次提交
  4. 25 11月, 2010 1 次提交
  5. 15 6月, 2009 3 次提交
  6. 15 1月, 2009 1 次提交
  7. 08 1月, 2009 1 次提交
    • A
      kconfig: add script to manipulate .config files on the command line · 8e54701e
      Andi Kleen 提交于
      I often change single options in .config files. Instead of using
      an editor or one of the frontends it's convenient to do this from
      the command line. It's also useful to do from automated build scripts
      when building different variants from a base config file.
      
      I extracted most of the CONFIG manipulation code from one of my
      build scripts into a new shell script scripts/config
      
      The script is not integrated with the normal Kconfig machinery
      and doesn't do any checking against Kconfig files, but just manipulates
      that text format. This is always done at make time anyways.
      
      I believe this script would be a useful standard addition for scripts/*
      
      Sample usage:
      
      ./scripts/config --disable smp
      Disable SMP in .config file
      
      ./scripts/config --file otherdir/.config --module e1000e
      Enable E1000E as module in otherdir/.config
      
      ./scripts/config --state smp
      y
      Check state of config option CONFIG_SMP
      
      After merging into git please make scripts/config executable
      Signed-off-by: NAndi Kleen <ak@linux.intel.com>
      Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
      8e54701e