genregdb.awk 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #!/usr/bin/awk -f
  2. #
  3. # genregdb.awk -- generate regdb.c from db.txt
  4. #
  5. # Actually, it reads from stdin (presumed to be db.txt) and writes
  6. # to stdout (presumed to be regdb.c), but close enough...
  7. #
  8. # Copyright 2009 John W. Linville <linville@tuxdriver.com>
  9. #
  10. # This program is free software; you can redistribute it and/or modify
  11. # it under the terms of the GNU General Public License version 2 as
  12. # published by the Free Software Foundation.
  13. #
  14. BEGIN {
  15. active = 0
  16. rules = 0;
  17. print "/*"
  18. print " * DO NOT EDIT -- file generated from data in db.txt"
  19. print " */"
  20. print ""
  21. print "#include <linux/nl80211.h>"
  22. print "#include <net/cfg80211.h>"
  23. print ""
  24. regdb = "const struct ieee80211_regdomain *reg_regdb[] = {\n"
  25. }
  26. /^[ \t]*#/ {
  27. # Ignore
  28. }
  29. !active && /^[ \t]*$/ {
  30. # Ignore
  31. }
  32. !active && /country/ {
  33. country=$2
  34. sub(/:/, "", country)
  35. printf "static const struct ieee80211_regdomain regdom_%s = {\n", country
  36. printf "\t.alpha2 = \"%s\",\n", country
  37. printf "\t.reg_rules = {\n"
  38. active = 1
  39. regdb = regdb "\t&regdom_" country ",\n"
  40. }
  41. active && /^[ \t]*\(/ {
  42. start = $1
  43. sub(/\(/, "", start)
  44. end = $3
  45. bw = $5
  46. sub(/\),/, "", bw)
  47. gain = $6
  48. sub(/\(/, "", gain)
  49. sub(/,/, "", gain)
  50. power = $7
  51. sub(/\)/, "", power)
  52. sub(/,/, "", power)
  53. # power might be in mW...
  54. units = $8
  55. sub(/\)/, "", units)
  56. sub(/,/, "", units)
  57. if (units == "mW") {
  58. if (power == 100) {
  59. power = 20
  60. } else if (power == 200) {
  61. power = 23
  62. } else if (power == 500) {
  63. power = 27
  64. } else if (power == 1000) {
  65. power = 30
  66. } else {
  67. print "Unknown power value in database!"
  68. }
  69. }
  70. flagstr = ""
  71. for (i=8; i<=NF; i++)
  72. flagstr = flagstr $i
  73. split(flagstr, flagarray, ",")
  74. flags = ""
  75. for (arg in flagarray) {
  76. if (flagarray[arg] == "NO-OFDM") {
  77. flags = flags "\n\t\t\tNL80211_RRF_NO_OFDM | "
  78. } else if (flagarray[arg] == "NO-CCK") {
  79. flags = flags "\n\t\t\tNL80211_RRF_NO_CCK | "
  80. } else if (flagarray[arg] == "NO-INDOOR") {
  81. flags = flags "\n\t\t\tNL80211_RRF_NO_INDOOR | "
  82. } else if (flagarray[arg] == "NO-OUTDOOR") {
  83. flags = flags "\n\t\t\tNL80211_RRF_NO_OUTDOOR | "
  84. } else if (flagarray[arg] == "DFS") {
  85. flags = flags "\n\t\t\tNL80211_RRF_DFS | "
  86. } else if (flagarray[arg] == "PTP-ONLY") {
  87. flags = flags "\n\t\t\tNL80211_RRF_PTP_ONLY | "
  88. } else if (flagarray[arg] == "PTMP-ONLY") {
  89. flags = flags "\n\t\t\tNL80211_RRF_PTMP_ONLY | "
  90. } else if (flagarray[arg] == "PASSIVE-SCAN") {
  91. flags = flags "\n\t\t\tNL80211_RRF_PASSIVE_SCAN | "
  92. } else if (flagarray[arg] == "NO-IBSS") {
  93. flags = flags "\n\t\t\tNL80211_RRF_NO_IBSS | "
  94. }
  95. }
  96. flags = flags "0"
  97. printf "\t\tREG_RULE(%d, %d, %d, %d, %d, %s),\n", start, end, bw, gain, power, flags
  98. rules++
  99. }
  100. active && /^[ \t]*$/ {
  101. active = 0
  102. printf "\t},\n"
  103. printf "\t.n_reg_rules = %d\n", rules
  104. printf "};\n\n"
  105. rules = 0;
  106. }
  107. END {
  108. print regdb "};"
  109. print ""
  110. print "int reg_regdb_size = ARRAY_SIZE(reg_regdb);"
  111. }