diff options
author | 2014-11-12 15:09:01 +0100 | |
---|---|---|
committer | 2014-11-12 15:09:01 +0100 | |
commit | 890ca861f868a10617029ffc87eae7d48ea6876c (patch) | |
tree | 713383f4e3bbd94ddb9816a25e6b3911511908f1 /scripts/basic/bin2c.c | |
parent | x86, msr: Use seek definitions instead of hard-coded values (diff) | |
parent | Linux 3.18-rc4 (diff) | |
download | linux-dev-890ca861f868a10617029ffc87eae7d48ea6876c.tar.xz linux-dev-890ca861f868a10617029ffc87eae7d48ea6876c.zip |
Merge tag 'v3.18-rc4' into x86/cleanups, to refresh the tree before pulling new changes.
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'scripts/basic/bin2c.c')
-rw-r--r-- | scripts/basic/bin2c.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/scripts/basic/bin2c.c b/scripts/basic/bin2c.c new file mode 100644 index 000000000000..af187e695345 --- /dev/null +++ b/scripts/basic/bin2c.c @@ -0,0 +1,35 @@ +/* + * Unloved program to convert a binary on stdin to a C include on stdout + * + * Jan 1999 Matt Mackall <mpm@selenic.com> + * + * This software may be used and distributed according to the terms + * of the GNU General Public License, incorporated herein by reference. + */ + +#include <stdio.h> + +int main(int argc, char *argv[]) +{ + int ch, total = 0; + + if (argc > 1) + printf("const char %s[] %s=\n", + argv[1], argc > 2 ? argv[2] : ""); + + do { + printf("\t\""); + while ((ch = getchar()) != EOF) { + total++; + printf("\\x%02x", ch); + if (total % 16 == 0) + break; + } + printf("\"\n"); + } while (ch != EOF); + + if (argc > 1) + printf("\t;\n\nconst int %s_size = %d;\n", argv[1], total); + + return 0; +} |