Mercurial > mplayer.hg
view vidix/pci_db2c.awk @ 30920:570e001f2e53
Convert asm keyword to __asm__.
Neither the asm() nor the __asm__() keyword is part of the C99
standard, but while GCC accepts the former in C89 syntax, it is not
accepted in C99 unless GNU extensions are turned on (with -fasm).
The latter form is accepted in any syntax as an extension (without
requiring further command-line options).
Sun Studio C99 compiler also does not accept asm() while accepting
__asm__(), albeit reporting warnings that it's not valid C99 syntax.
author | diego |
---|---|
date | Fri, 26 Mar 2010 08:13:10 +0000 |
parents | e11d2e31353c |
children |
line wrap: on
line source
#!/usr/bin/awk -f # This file converts given pci.db to "C" source and header files # For latest version of pci ids see: http://pciids.sf.net # Copyright 2002 Nick Kurshev # # Tested with Gawk v 3.0.x and Mawk 1.3.3 # But it should work with standard Awk implementations (hopefully). # (Nobody tested it with Nawk, but it should work, too). # # This file is part of MPlayer. # # MPlayer is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # MPlayer is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License along # with MPlayer; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA BEGIN { if (ARGC != 3) { # check for arguments: print "Usage ./pci_db2c.awk pci.db (and make sure pci.db file exists first)"; exit(1); } in_file = ARGV[1]; with_pci_db = ARGV[2]; dev_ids_c_file = "vidix/pci_dev_ids.c" ids_h_file = "vidix/pci_ids.h" names_c_file = "vidix/pci_names.c" vendors_h_file = "vidix/pci_vendors.h"; # print out head lines print_head(vendors_h_file); print_head(ids_h_file); print_head(names_c_file); print_head(dev_ids_c_file); print "#include <stdlib.h>" > dev_ids_c_file; print "#include \"pci_names.h\"" > dev_ids_c_file; print_guards_start(vendors_h_file); print_guards_start(ids_h_file); print "#include \"pci_vendors.h\"" > ids_h_file print "" > ids_h_file print "#include <stddef.h>" > names_c_file print "#include \"pci_names.h\"" > names_c_file if (with_pci_db) { print "#include \"pci_dev_ids.c\"" > names_c_file print "" > names_c_file print "static struct vendor_id_s vendor_ids[] = {" > names_c_file } first_pass = 1; init_name_db(); while (getline < in_file) { n = split($0, field, "[\t]"); name_field = kill_double_quoting(field[3]) if (field[1] == "v" && length(field[3]) > 0 && field[4] == "0") { init_device_db() svend_name = get_short_vendor_name(field[3]) printf("#define VENDOR_%s\t", svend_name) > vendors_h_file; if (length(svend_name) < 9) printf("\t") > vendors_h_file; printf("0x%s /*%s*/\n", field[2], name_field) > vendors_h_file; if (with_pci_db) printf("{ 0x%s, \"%s\", dev_lst_%s },\n", field[2], name_field, field[2]) > names_c_file; printf("/* Vendor: %s: %s */\n", field[2], name_field) > ids_h_file if (first_pass == 1) first_pass = 0; else print "{ 0xFFFF, NULL }\n};" > dev_ids_c_file; printf("static const struct device_id_s dev_lst_%s[] = {\n", field[2]) > dev_ids_c_file } if (field[1] == "d" && length(field[3]) > 0 && field[4] == "0") { sdev_name = get_short_device_name(field[3]) full_name = sprintf("#define DEVICE_%s_%s", svend_name, sdev_name); printf("%s\t", full_name) > ids_h_file if (length(full_name) < 9) printf("\t") > ids_h_file; if (length(full_name) < 17) printf("\t") > ids_h_file; if (length(full_name) < 25) printf("\t") > ids_h_file; if (length(full_name) < 32) printf("\t") > ids_h_file; if (length(full_name) < 40) printf("\t") > ids_h_file; if (length(full_name) < 48) printf("\t") > ids_h_file; printf("0x%s /*%s*/\n", substr(field[2], 5), name_field) > ids_h_file printf("{ 0x%s, \"%s\" },\n", substr(field[2], 5), name_field) > dev_ids_c_file } if (field[1] == "s" && length(field[3]) > 0 && field[4] == "0") { subdev_name = get_short_subdevice_name(field[3]) full_name = sprintf("#define SUBDEVICE_%s_%s", svend_name, subdev_name) printf("\t%s\t", full_name) > ids_h_file if (length(full_name) < 9) printf("\t") > ids_h_file; if (length(full_name) < 17) printf("\t") > ids_h_file; if (length(full_name) < 25) printf("\t") > ids_h_file; if (length(full_name) < 32) printf("\t") > ids_h_file; if (length(full_name) < 40) printf("\t") > ids_h_file; printf("0x%s /*%s*/\n", substr(field[2], 9), name_field) > ids_h_file } } print_guards_end(vendors_h_file); print_guards_end(ids_h_file); if (with_pci_db) print "};" > names_c_file print "{ 0xFFFF, NULL }" > dev_ids_c_file; print "};" > dev_ids_c_file print_func_bodies(names_c_file); } function construct_guard_name(out_file) { split(out_file, path_components, "/"); sub(".h","_h", path_components[2]); return "MPLAYER_" toupper(path_components[2]); } function print_guards_start(out_file) { guard_name = construct_guard_name(out_file); printf("#ifndef %s\n", guard_name) > out_file printf("#define %s\n", guard_name) > out_file print "" > out_file } function print_guards_end(out_file) { guard_name = construct_guard_name(out_file); print "" > out_file printf("#endif /* %s */\n", guard_name) > out_file } function print_head(out_file) { printf("/* File: %s\n", out_file) > out_file; printf(" * This file was generated automatically. Don't modify it. */\n") > out_file; print "" > out_file } function print_func_bodies(out_file) { print "" > out_file print "const char *pci_vendor_name(unsigned short id)" > out_file print "{" > out_file if (with_pci_db) { print " unsigned i;" > out_file print " for (i = 0; i < sizeof(vendor_ids) / sizeof(struct vendor_id_s); i++) {" > out_file print " if (vendor_ids[i].id == id)" > out_file print " return vendor_ids[i].name;" > out_file print " }" > out_file } print " return NULL;" > out_file print "}" > out_file print "" > out_file print "const char *pci_device_name(unsigned short vendor_id, unsigned short device_id)" > out_file print "{" > out_file if (with_pci_db) { print " unsigned i, j;" > out_file print " for (i = 0; i < sizeof(vendor_ids) / sizeof(struct vendor_id_s); i++) {" > out_file print " if (vendor_ids[i].id == vendor_id) {" > out_file print " j = 0;" > out_file print " while (vendor_ids[i].dev_list[j].id != 0xFFFF) {" > out_file print " if (vendor_ids[i].dev_list[j].id == device_id)" > out_file print " return vendor_ids[i].dev_list[j].name;" > out_file print " j++;" > out_file print " };" > out_file print " break;" > out_file print " }" > out_file print " }" > out_file } print " return NULL;" > out_file print "}" > out_file } function kill_double_quoting(fld) { n = split(fld, phrases, "[\"]"); new_fld = phrases[1] for (i = 2; i <= n; i++) new_fld = sprintf("%s\\\"%s", new_fld, phrases[i]) return new_fld } function init_name_db() { vendor_names[1] = "" } function init_device_db() { # delete device_names for (i in device_names) delete device_names[i]; device_names[1] = "" # delete subdevice_names for (i in subdevice_names) delete subdevice_names[i]; subdevice_names[1] = "" } function get_short_vendor_name(from) { n = split(from, name, "[ ]"); new_name = toupper(name[1]); if (length(new_name) < 3) new_name = sprintf("%s_%s", new_name, toupper(name[2])); n = split(new_name, name, "[^0-9A-Za-z]"); svendor = name[1]; for (i = 2; i <= n; i++) svendor = sprintf("%s%s%s", svendor, length(name[i]) ? "_" : "", name[i]); new_name = svendor; vend_suffix = 2; # check for unique while (new_name in vendor_names) { new_name = sprintf("%s%u", svendor, vend_suffix) vend_suffix = vend_suffix + 1; } # Add new name in array of vendor's names vendor_names[new_name] = new_name return new_name; } function get_short_device_name(from_name) { n = split(from_name, name, "[ ]"); new_name = toupper(name[1]); if (length(name[2])) new_name = sprintf("%s_%s", new_name, toupper(name[2])); if (length(name[3])) new_name = sprintf("%s_%s", new_name, toupper(name[3])); n = split(new_name, name, "[^0-9A-Za-z]"); sdevice = name[1]; for (i = 2; i <= n; i++) sdevice = sprintf("%s%s%s", sdevice, length(name[i]) ? "_" : "", name[i]); new_name = sdevice; dev_suffix = 2; # check for unique while (new_name in device_names) { new_name = sprintf("%s%u", sdevice, dev_suffix) dev_suffix = dev_suffix + 1; } # Add new name in array of device names device_names[new_name] = new_name return new_name; } function get_short_subdevice_name(from_name) { n = split(from_name, name, "[ ]"); new_name = toupper(name[1]); if (length(name[2])) new_name = sprintf("%s_%s", new_name, toupper(name[2])); if (length(name[3])) new_name = sprintf("%s_%s", new_name, toupper(name[3])); n = split(new_name, name, "[^0-9A-Za-z]"); ssdevice = name[1]; for (i = 2; i <= n; i++) ssdevice = sprintf("%s%s%s", ssdevice, length(name[i]) ? "_" : "", name[i]); new_name = ssdevice; sdev_suffix = 2; # check for unique while (new_name in subdevice_names) { new_name = sprintf("%s%u", ssdevice, sdev_suffix) sdev_suffix = sdev_suffix + 1; } # Add new name in array of subdevice names subdevice_names[new_name] = new_name return new_name; }