coqos_add.1 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. .TH coqos_add 1 "Mar 2014" "plc-utils-2.1.6" "Qualcomm Atheros Powerline Toolkit"
  2. .SH NAME
  3. coqos_add - Add a managed data stream
  4. .SH SYNOPSIS
  5. .BR coqos_add
  6. .IR action
  7. .IR priority
  8. .IR rate
  9. .IR ttl
  10. .IR operand
  11. .IR condition
  12. .RI [ condition ]
  13. [...]
  14. .RI [ device ]
  15. [...]
  16. .SH DESCRIPTION
  17. .B This page is under construction.
  18. .PP
  19. Add a managed stream to one or more powerline devices using the VS_CONN_ADD message.
  20. Consult the Qualcomm Atheros Firmware Technical Reference Manual for a description of this vendor specific message type.
  21. .PP
  22. This program is part of the Qualcomm Atheros Powerline Toolkit.
  23. See the \fBplc\fR man page for an overview and installation instructions.
  24. .SH BACKGROUND
  25. .PP
  26. Bandwidth management prioritizes streams so that data from lowest priority stream is dropped first whenever one of the following conditions is detected.
  27. This ensures that the remaining streams continue operate at their full pontential.
  28. .TP
  29. .B Degraded line condition
  30. The channel degrades to the point where the available PHY rate from the transmitter to the receiver is too low due to the variability of the power line.s characteristics.
  31. .TP
  32. .B Over subscription
  33. Too much data is being sent per second, resulting in packet loss due to excessive collisions due to excessive channel oversubscription.
  34. .TP
  35. .B Lack of channel Capacity
  36. On starting new source there is not enough channel capacity to support it.
  37. .SH OPTIONS
  38. .TP
  39. .RB - e
  40. Redirects stderr messages to stdout.
  41. By convention progress messages and error messages are printed on stderr while primary program output is printed on stdout.
  42. This option prints all output on stdout in cases where this is desired.
  43. .TP
  44. -\fBi \fIinterface\fR
  45. Select the host Ethernet interface.
  46. All requests are sent via this host interface and only reponses received via this host interface are recognized.
  47. The default interface is \fBeth1\fR because most people use \fBeth0\fR as their principle network connection; however, if environment string "PLC" is defined then it takes precedence over the default interface.
  48. This option then takes precedence over either default.
  49. .TP
  50. .RB - q
  51. Suppresses status messages on stderr.
  52. .TP
  53. .RB - r
  54. Display relative memory offsets on output.
  55. This option is the default.
  56. .TP
  57. .RB - v
  58. Prints additional information on stdout.
  59. In particular, this option dumps outgoing Ethernet packets on stdout.
  60. .TP
  61. .RB - ? ,-- help
  62. Displays program help information on stderr.
  63. This option takes precedence over all other options on the command line except version information.
  64. .TP
  65. .RB - ! ,-- version
  66. Displays program version information on stderr.
  67. This option takes precedence over all other options on the command line except help information.
  68. Use this option when sending screen dumps to Atheros technical staff.
  69. .SH ARGUMENTS
  70. .TP
  71. .IR action
  72. The action taken for frames that satisfy the selection criteria.
  73. Valid actions are "\fBCAP0\fR", "\fBCAP1\fR", "\fBCAP2\fR", "\fBCAP3\fR" to specify the channel access priority queue.
  74. CAP0 and CAP1 are for best effort data.
  75. CAP2 is for video and non urgent MMEs.
  76. CAP3 is for voice, urgent MMEs and control messages such as IGMP and MLD.
  77. .TP
  78. .IR priority
  79. The relative priority of this stream.
  80. Valid values are \fB0\fR through \fB15\fR where 0 is the lowest priority and 15 is the highest.
  81. .TP
  82. .IR destination
  83. The destination MAC address.
  84. .TP
  85. .IR rate
  86. The average expected data rate for this stream.
  87. Valid values are \fB1\fR to \fB9000\fR where units are in 10kbps so the minimum rate is 10kbps and the maximum rate is 90mbps.
  88. .TP
  89. .IR ttl
  90. The time to live for this stream.
  91. Valid values are 10000 to 2000000 where units are in microseconds so the minimum is time is 10 milliseconds and the maximum time is 2 seconds.
  92. .TP
  93. .IR operand
  94. The operand specifies the logical relationship between conditions before the \fIaction\fR to be taken.
  95. Valid operands are listed and described under \fBOPERANDS\fR.
  96. .TP
  97. .IR condition
  98. A conditional expression consisting of a \fIfield\fR, \fIoperator\fR and \fIvalue\fR.
  99. See \fBCONDITIONS\fR for more information.
  100. .TP
  101. .IR device
  102. The MAC address of some powerline device.
  103. More than one address may be specified on the command line.
  104. If more than one address is specified then operations are performed on each device in turn.
  105. The default address is "\fBlocal\fR".
  106. See \fBDEVICES\fR for more information.
  107. .SH CONDITIONS
  108. A condition consists of a \fIfield\fR, an \fIoperator\fR and a \fIvalue\fR.
  109. One condition is required but three are permitted.
  110. Condition order is not important but all conditions must appear after the \fIoperand\fR and before the \fIcontrol\fR.
  111. .TP
  112. .IR field
  113. The field is the part of the Ethernet frame to be examined.
  114. Some fields are not valid for some actions but this program does not enforce such rules since validation is performed by runtime firmware on each device.
  115. Recognized fields are listed and described under \fBFIELDS\fR.
  116. .TP
  117. .IR operator
  118. The operator specifies the relationsip that must exist between the \fIfield\fR and \fIvalue\fR in order for the \fIcondition\fR to evaluate \fBTrue\fR.
  119. Currently, only equality operators are supported.
  120. Valid operators are listed and described under \fBOPERATORS\fR.
  121. .TP
  122. .IR value
  123. The value must be appropriate to the field type.
  124. Some fields are MAC or IP addresses, some are integers, some are bitmaps and others are states.
  125. Integers and bitmaps may be expressed in binary, decimal or hexadecimal format.
  126. Binary values staRt with \fB0b\fR.
  127. Hexadecimal values start with \fB0x\fR.
  128. States are expressed using keywords.
  129. Users are responsible for knowing how many bits are significant for each type of value.
  130. Valid values are described along with fields under \fBFIELDS\fR.
  131. .SH OPERANDS
  132. The \fIoperand\fR indicates the logical relationship that must exist between conditions in the rule set before the action is applied to a frame.
  133. Operands are expressed as discrete alphanumeric strings entered in upper, lower or mixed character case.
  134. Failure to enter a known operand will result in an error message that lists all possible operands.
  135. They are positon sensitive.
  136. One operand is allowed and it must appear after the \fIaction\fR and before any \fIcondition\fR.
  137. .TP
  138. .BR Any
  139. Apply the action to frames that satisfy \fBany\fR of the conditions.
  140. This is equivalent to the logical \fBor\fR operation.
  141. .TP
  142. .BR All
  143. Apply the action to frames that satisfy \fBall\fR of the conditions.
  144. This is equivalent to the logical \fBand\fR operation.
  145. .TP
  146. .BR Always
  147. Apply the action to all frames, regardless of any and all conditions that may be specified.
  148. .SH FIELDS
  149. Fields indicate the portion of the frame that is inspected during selection and the size and format of the value permited in the condition statement.
  150. They are expressed as discrete alphanumeric strings entered in upper, lower or mixed character case.
  151. Failure to enter a known field will result in an error message that lists all possible fields.
  152. .TP
  153. .BR ET
  154. A 16-bit Ethertype expressed in decimal, hexadecimal or binary.
  155. The format is described in IEEE Standard 802-2001 [4].
  156. .TP
  157. .BR EthDA
  158. A 48-bit Ethernet destination address expressed in hexadecimal.
  159. The format is described in IEEE Standard 802-2001 [4].
  160. .TP
  161. .BR EthSA
  162. A 48-bit Ethernet source address expressed in hexadecimal.
  163. The format is described in IEEE Standard 802-2001 [4].
  164. .TP
  165. .BR VLANUP
  166. An 8-bit Ethernet VLAN tag where the lower 3 bits are the User Priority sub-field of a VLAN Tag defined in IEEE Std 802.1Q-1998 (Virtual Bridged Local Area Networks) [11].
  167. The upper 5 bits should be zero.
  168. .TP
  169. .BR VLANID
  170. A 16-bit VLAN identifier where the lower 12 bits are the VLAN Identifier (VID) defined in IEEE Std 802.1Q-1998 (Virtual Bridged Local Area Networks) [11].
  171. The upper 4 bits should be zero.
  172. .TP
  173. .BR IPV4TOS
  174. An 8-bit Type-of-Service code where the format is defined in the RFC 791 (Internet Protocol) [14].
  175. .TP
  176. .BR IPV4PROT
  177. An 8-bit Ethernet Protocol identifier.
  178. The format is defined in the RFC 791 (Internet Protocol) [14].
  179. .TP
  180. .BR IPV4SA
  181. A 32-bit Internet Protocol source address expressed in dotted-decimal notation.
  182. The official format is defined in RFC 791 (Internet Protocol) [14].
  183. Our implementation permits empty octets and leading zeros within fields.
  184. For example, "..." is equivalent to "0.0.0.0 and "127..000.001" is equivalent to "127.0.0.1".
  185. .TP
  186. .BR IPV4DA
  187. A 32-bit Internet Protocol destination address expressed in dotted-decimal notation. The official format is defined in RFC 791 (internet Protocol) [14]. Our implementation permits empty octets and leading zeros within fields. For example, "..." is equivalent to "0.0.0.0 and "127..000.001" is equivalent to "127.0.0.1".
  188. .TP
  189. .BR IPV6TC
  190. An 8-bit Internet Protocol V6 traffic class expressed as defined in RFC 2460 (Internet Protocol Version 6) [17].
  191. .TP
  192. .BR IPV6FL
  193. A 24-bit IPV6 flow label where the lower 20 bits are the IPv6 Flow Label defined in RFC 2460 (Internat Protocol Version 6) [17].
  194. The upper 4 bits should be zero.
  195. The value can be entered either as a decimal, binary or hex integer.
  196. .TP
  197. .BR IPV6SA
  198. A 128-bit IPV6 source address expressed as colon-separated hexadecmial quartets (octet pairs).
  199. The official format is defined in RFC 2460 (Internet Protocol Version 6) [17].
  200. Our implementation permits multiple empty fields, abreviated fields and leading zeros within fields.
  201. When multiple empty fields appear, only the right-most occurance expands to zeros.
  202. For example, "FFFF::DDDD::BBBB::AAAA" is equivalent to "FFFF:0000:DDDD:0000:BBBB:0000:0000:AAAA".
  203. .TP
  204. .BR IPV6DA
  205. A 128-bit IPV6 destination address expressed as colon-separated hexadecimal quartets (octet pairs).
  206. The official format is defined in RFC 2460 (Internet Protocol Version 6) [17].
  207. Our implementation permits multiple empty fields, abbreviated fields and leading zeros within fields.
  208. When multiple empty fields appear, only the right-most occurance expands to zeros.
  209. For example, "AAAA::BBBB::CCCC::DDDD" is equivalent to "AAAA:0000:BBBB:0000:CCCC:0000:0000:DDDD".
  210. .TP
  211. .BR TCPSP
  212. A 16-bit TCP source port as a decimal integer.
  213. The format is defined in RFC 793 (Transmission Control Protocol [15]).
  214. .TP
  215. .BR TCPDP
  216. A 16-bit TCP destination port expressed as a decimal integer.
  217. The format is defined in RFC 793 (Transmission Control Protocol [15]).
  218. .TP
  219. .BR UDPSP
  220. A 16-bit UDP source port expressed as a decimal integer.
  221. The format is defined in RFC 768 (User Datagram Protocol [13]).
  222. .TP
  223. .BR UDPDP
  224. A 16-bit UDP destination port expressed as a decimal integer.
  225. The format is defined in RFC 768 (User Datagram Protocol [13]).
  226. .TP
  227. .BR IPSP
  228. A 16-bit IP source port expressed as a decimal integer.
  229. This condition applies to either TCP or UDP packets, depending on the protocol used, and is valid only for actions "\fBCAP0\fR", "\fBCAP1\fR", "\fBCAP2\fR", "\fBCAP3\fR" and "\fBDrop\fR".
  230. .TP
  231. .BR IPDP
  232. A 16-bit IP destination port expressed as a decimal integer.
  233. This condition applies to either TCP or UDP packets, depending on the protocol used, and is valid only for actions "\fBCAP0\fR", "\fBCAP1\fR", "\fBCAP2\fR", "\fBCAP3\fR" and "\fBDrop\fR".
  234. .TP
  235. .BR MME
  236. A 24-bit Atheros HomePlugAV Management Message type expressed in hexadecimal.
  237. The first byte is the MMV and the next two bytes are the MMTYPE for a HomePlug AV frame as defined in the HomePlug AV Specification.
  238. The MMTYPE will match any MME sub-type (Request; Confirm; Indicate; Response).
  239. This field is only valid for action "\fBBoost\fR".
  240. .SH OPERATORS
  241. An operator indicates an equality between a \fIfield\fR and a \fIvalue\fR.
  242. An operator is an alphanumeric string entered in upper, lower or mixed character case.
  243. Failure to enter a known operator will result in an error message that lists all possible operators.
  244. Operators are position sensitive and must appear between each \fIfield\fR and \fIvalue\fR.
  245. .TP
  246. .BR Is
  247. Indicates that the frame field must equal the associated value for the condition to evaluate true.
  248. .TP
  249. .BR Not
  250. Indicates that the frame field must not equal the associated value for the condition to true true.
  251. .SH STATES
  252. A state is a special case of \fIvalue\fR.
  253. .TP
  254. .BR True , On , Yes , Present
  255. Indicates a positive state or presence of some entity.
  256. All are equivalent and can be used interchangeably.
  257. Double negatives are permitted so "Is True" is equvalent to "Not False".
  258. .TP
  259. .BR False , Off , No , Missing
  260. Indicates a negative state or absence of some entity.
  261. ALl are equivalent and can be used interchangeably.
  262. Double negatives are permitted so "Is False" is equvalent to "Not True".
  263. .SH DEVICES
  264. Powerline devices use Ethernet Media Access Control (MAC) addresses.
  265. A MAC address is a 48-bit value entered as 12 hexadecimal digits in upper, lower or mixed character case.
  266. Octets may be separated with colons for clarity.
  267. For example, "00b052000001", "00:b0:52:00:00:01" and "00b052:000001" are valid and equivalent.
  268. .PP
  269. The following MAC addresses are common or special and may be entered by name instead of number.
  270. .TP
  271. .BR all
  272. Same as "broadcast".
  273. .TP
  274. .BR broadcast
  275. A synonym for the Ethernet broadcast address, \fBFF:FF:FF:FF:FF:FF\fR.
  276. All devices, whether local, remote or foreign recognize messages sent to this address.
  277. A remote device is any device at the far end of a powerline connection.
  278. A foreign device is any device not manufactured by Atheros.
  279. .TP
  280. .BR local
  281. A synonym for the Qualcomm Atheros vendor specific Local Management Address (LMA), \fB00:B0:52:00:00:01\fR.
  282. All local Atheros devices recognize this address but remote and foreign devices do not.
  283. A remote device is any device at the far end of a powerline connection.
  284. A foreign device is any device not manufactured by Atheros.
  285. ..SH REFERENCES
  286. See the Qualcomm Atheros HomePlug AV Firmware Technical Reference Manual for more information.
  287. .SH DISCLAIMER
  288. Atheros HomePlug AV Vendor Specific Management Message structure and content is proprietary to Qualcomm Atheros, Ocala FL USA.
  289. Consequently, public information may not be available.
  290. Qualcomm Atheros reserves the right to modify message structure and content in future firmware releases without any obligation to notify or compensate users of this program.
  291. .SH EXAMPLES
  292. The following example adds a temporary stream to device \fB00:b0:52:BA:BE:01\fR which will then manage the bandwidth for that stream until removed with program \fBcoqos_rel\fR.
  293. .PP
  294. # coqos_add CAP2 15 5000 200000 any ethda is 192.168.105 00:B0:52:BA:BE:01
  295. .PP
  296. This adds a stream to the bandwidth manager that sets all traffic to destination address of 192.168.0.105 as priority 15 (the highest priority).
  297. This would then need to also be sent to each device on the network.
  298. Refer to int6krule for more details on how to specify conditions.
  299. .SH SEE ALSO
  300. .BR coqos_info ( 1 ),
  301. .BR coqos_man ( 1 ),
  302. .BR coqos_mod ( 1 ),
  303. .BR coqos_rel ( 1 )
  304. .SH CREDITS
  305. Bill Wike <bill.wike@qca.qualcomm.com>
  306. Nathaniel Houghton <nhoughto@qca.qualcomm.com>
  307. Charles Maier <cmaier@qca.qualcomm.com>