idnits 2.17.00 (12 Aug 2021) /tmp/idnits49836/draft-birrane-dtn-adm-agent-05.txt: Checking boilerplate required by RFC 5378 and the IETF Trust (see https://trustee.ietf.org/license-info): ---------------------------------------------------------------------------- No issues found here. Checking nits according to https://www.ietf.org/id-info/1id-guidelines.txt: ---------------------------------------------------------------------------- No issues found here. Checking nits according to https://www.ietf.org/id-info/checklist : ---------------------------------------------------------------------------- ** The document seems to lack a Security Considerations section. ** The abstract seems to contain references ([I-D.birrane-dtn-adm]), which it shouldn't. Please replace those with straight textual mentions of the documents in question. Miscellaneous warnings: ---------------------------------------------------------------------------- == The copyright year in the IETF Trust and authors Copyright Line does not match the current year == Line 519 has weird spacing: '...emplate ident...' -- The document date (March 11, 2019) is 1160 days in the past. Is this intentional? Checking references for intended status: Experimental ---------------------------------------------------------------------------- == Outdated reference: A later version (-03) exists of draft-birrane-dtn-adm-02 == Outdated reference: A later version (-08) exists of draft-birrane-dtn-amp-04 Summary: 2 errors (**), 0 flaws (~~), 4 warnings (==), 1 comment (--). Run idnits with the --verbose option for more detailed information about the items above. -------------------------------------------------------------------------------- 2 Delay-Tolerant Networking E. Birrane 3 Internet-Draft E. DiPietro 4 Intended status: Experimental D. Linko 5 Expires: September 12, 2019 Johns Hopkins Applied Physics Laboratory 6 March 11, 2019 8 Asynchronous Management Protocol Agent Application Data Model 9 draft-birrane-dtn-adm-agent-05 11 Abstract 13 This document describes an Application Data Model (ADM) for an 14 Asynchronous Management Protocol (AMP) Agent. The AMP Agent 15 represents a managed device in the Asynchronous Management 16 Architecture. This document is in compliance with the template 17 provided by [I-D.birrane-dtn-adm]. 19 Status of This Memo 21 This Internet-Draft is submitted in full conformance with the 22 provisions of BCP 78 and BCP 79. 24 Internet-Drafts are working documents of the Internet Engineering 25 Task Force (IETF). Note that other groups may also distribute 26 working documents as Internet-Drafts. The list of current Internet- 27 Drafts is at https://datatracker.ietf.org/drafts/current/. 29 Internet-Drafts are draft documents valid for a maximum of six months 30 and may be updated, replaced, or obsoleted by other documents at any 31 time. It is inappropriate to use Internet-Drafts as reference 32 material or to cite them other than as "work in progress." 34 This Internet-Draft will expire on September 12, 2019. 36 Copyright Notice 38 Copyright (c) 2019 IETF Trust and the persons identified as the 39 document authors. All rights reserved. 41 This document is subject to BCP 78 and the IETF Trust's Legal 42 Provisions Relating to IETF Documents 43 (https://trustee.ietf.org/license-info) in effect on the date of 44 publication of this document. Please review these documents 45 carefully, as they describe your rights and restrictions with respect 46 to this document. Code Components extracted from this document must 47 include Simplified BSD License text as described in Section 4.e of 48 the Trust Legal Provisions and are provided without warranty as 49 described in the Simplified BSD License. 51 Table of Contents 53 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 2 54 1.1. Technical Notes . . . . . . . . . . . . . . . . . . . . . 2 55 1.2. Scope . . . . . . . . . . . . . . . . . . . . . . . . . . 3 56 1.3. Requirements Language . . . . . . . . . . . . . . . . . . 3 57 2. Structure and Design of this ADM . . . . . . . . . . . . . . 3 58 3. Naming and Identification . . . . . . . . . . . . . . . . . . 4 59 3.1. Namespace and Nicknames . . . . . . . . . . . . . . . . . 4 60 4. AMP Agent ADM JSON Encoding . . . . . . . . . . . . . . . . . 5 61 5. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 23 62 6. References . . . . . . . . . . . . . . . . . . . . . . . . . 23 63 6.1. Informative References . . . . . . . . . . . . . . . . . 23 64 6.2. Normative References . . . . . . . . . . . . . . . . . . 23 65 Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . 24 67 1. Introduction 69 An Application Data Model (ADM) provides a guaranteed interface for 70 the management of an application or protocol in accordance with the 71 Asynchronous Management Architecture (AMA) defined in 72 [I-D.birrane-dtn-ama]. The ADM described in this document complies 73 with the ADM Template provided in [I-D.birrane-dtn-adm] as encoded 74 using the JSON syntax. 76 The AMP Agent ADM provides the set of information necessary to 77 remotely manage agents in accordance with the Asynchronous Management 78 Protocol (AMP) defined in [I-D.birrane-dtn-amp]. AMP provides a 79 compact binary encoding of ADM objects and specifies a protocol for 80 the exchange of those objects. 82 1.1. Technical Notes 84 o This document describes Version 3.0 of the Agent ADM. 86 o The namespace associated with this ADM has not been finalized and, 87 therefore, any namespace references and associated encodings are 88 subject to change until the moderated namespace for this ADM has 89 been published. 91 o Agent applications MAY choose to ignore the name, description, or 92 other annotative information associated with the component 93 definitions within this ADM where such items are only used to 94 provide human-readable information or are otherwise not necessary 95 to manage a device. 97 1.2. Scope 99 This ADM specifies those components of the Asynchronous Management 100 Model (AMM) common to the management of any instance of any AMP 101 Agent. 103 Any Manager software implementing this ADM MUST perform the 104 responsibilities of an AMA Manager as outlined in 105 [I-D.birrane-dtn-adm] as they relate to the objects included in this 106 document. 108 Any Agent software implementing this ADM MUST perform the 109 responsibilities of an AMA Agent as outlined in [I-D.birrane-dtn-adm] 110 as they relate to the objects included in this document. 112 1.3. Requirements Language 114 The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", 115 "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this 116 document are to be interpreted as described in RFC 2119 [RFC2119]. 118 2. Structure and Design of this ADM 120 The AMP Agent ADM's structure is in accordance to 121 [I-D.birrane-dtn-adm]. This ADM contains metadata, table templates, 122 and controls, variables, report templates, macros, edd, and 123 operators. The contents of this ADM are derived from the main 124 functions and data that an agent needs to run AMP 125 [I-D.birrane-dtn-amp]. 127 The Metadata that is present in this document is common to all ADMs. 128 All ADMs have metadata that includes the name, namespace, and version 129 of the ADM as well as the name of the organization that is issuing 130 that particular ADM. This is important for identification purposes 131 of the ADMs and to ensure version control. 133 Because there are calculations done in various ADM objects that are 134 needed for AMP, the operators that were chosen were ones that were 135 the most common. For each of the most common operators, the only 136 ones that were expressed in the document were ones that had the same 137 input types and result types. This is to prevent a long list of 138 operators that may never be used. The additional information 139 provided in this ADM dealt with the number of known variables, 140 macros, rules, controls and constants as well as the number of those 141 instances that were running. 143 3. Naming and Identification 145 This section outlines the namespaces used to uniquely identify ADM 146 objects in this specification. 148 3.1. Namespace and Nicknames 150 In accordance with [I-D.birrane-dtn-adm], every ADM is assigned a 151 moderated Namespace. In accordance with [I-D.birrane-dtn-amp], these 152 namespaces may be enumerated for compactness. The namespace and ADM 153 identification for these objects is defined as follows. 155 +-----------------+-----------+ 156 | Identifier | Value | 157 +-----------------+-----------+ 158 | Namespace | Amp/Agent | 159 | | | 160 | ADM Enumeration | 1 | 161 +-----------------+-----------+ 163 Table 1: Namespace Information 165 Given the above ADM enumeration, in accordance with 166 [I-D.birrane-dtn-amp], the following AMP nicknames are defined. 168 +----------+------------------------------+ 169 | Nickname | Collection | 170 +----------+------------------------------+ 171 | 20 | Amp/Agent/Const | 172 | | | 173 | 21 | Amp/Agent/Ctrl | 174 | | | 175 | 22 | Amp/Agent/Edd | 176 | | | 177 | 23 | Amp/Agent/Mac | 178 | | | 179 | 24 | Amp/Agent/Oper | 180 | | | 181 | 25 | Amp/Agent/Rptt | 182 | | | 183 | 27 | Amp/Agent/Tblt | 184 | | | 185 | 29 | Amp/Agent/Var | 186 | | | 187 | 30 | Amp/Agent/Mdat | 188 | | | 189 | 31-49 | Amp/Agent/Reserved | 190 +----------+------------------------------+ 192 Table 2: Agent ADM Nicknames 194 4. AMP Agent ADM JSON Encoding 196 { 197 "Mdat": [{ 198 "name": "name", 199 "type": "STR", 200 "value": "amp_agent", 201 "description": "The human-readable name of the ADM." 202 }, 203 { 204 "name": "namespace", 205 "type": "STR", 206 "value": "Amp/Agent", 207 "description": "The namespace of the ADM." 208 }, 209 { 210 "name": "version", 211 "type": "STR", 212 "value": "v3.1", 213 "description": "The version of the ADM." 214 }, 215 { 216 "name": "organization", 217 "type": "STR", 218 "value": "JHUAPL", 219 "description": "The name of the issuing organization of the 220 ADM." 221 } 222 ], 224 "Edd": [{ 225 "name": "num_rpt_tpls", 226 "type": "UINT", 227 "description": "This is the number of report templates known to 228 the Agent." 229 }, 230 { 231 "name": "num_tbl_tpls", 232 "type": "UINT", 233 "description": "This is the number of table templates known to 234 the Agent." 235 }, 236 { 237 "name": "sent_reports", 238 "type": "UINT", 239 "description": "This is the number of reports sent by the 240 Agent." 241 }, 242 { 243 "name": "num_tbr", 244 "type": "UINT", 245 "description": "This is the number of time-based rules running 246 on the Agent." 247 }, 248 { 249 "name": "run_tbr", 250 "type": "UINT", 251 "description": "This is the number of time-based rules run by 252 the Agent since the last reset." 253 }, 254 { 255 "name": "num_sbr", 256 "type": "UINT", 257 "description": "This is the number of state-based rules running 258 on the Agent." 259 }, 260 { 261 "name": "run_sbr", 262 "type": "UINT", 263 "description": "This is the number of state-based rules run by 264 the agent since the last reset." 265 }, 266 { 267 "name": "num_const", 268 "type": "UINT", 269 "description": "This is the number of constants known by the 270 Agent." 271 }, 272 { 273 "name": "num_var", 274 "type": "UINT", 275 "description": "This is the number of variables known by the 276 Agent." 277 }, 278 { 279 "name": "num_macros", 280 "type": "UINT", 281 "description": "This is the number of macros known by the 282 Agent." 283 }, 284 { 285 "name": "run_macros", 286 "type": "UINT", 287 "description": "This is the number of macros run by the agent 288 since the last reset." 289 }, 290 { 291 "name": "num_controls", 292 "type": "UINT", 293 "description": "This is the number of controls known by the 294 Agent." 295 }, 296 { 297 "name": "run_controls", 298 "type": "UINT", 299 "description": "This is the number of controls run by the Agent 300 since the last reset." 301 }, 302 { 303 "name": "cur_time", 304 "type": "TV", 305 "description": "This is the current system time." 306 } 307 ], 309 "Var": [{ 310 "name": "num_rules", 311 "type": "UINT", 312 "initializer": { 313 "type": "UINT", 314 "postfix-expr": [{ 315 "ns": "Amp/Agent", 316 "nm": "edd.num_tbr" 317 }, { 318 "ns": "Amp/Agent", 319 "nm": "edd.num_sbr" 320 }, { 321 "ns": "Amp/Agent", 322 "nm": "oper.plusUINT" 323 }] 324 }, 325 "description": "This is the number of rules known to the Agent 326 (#TBR + #SBR)." 327 }], 329 "Tblt":[ 330 { 331 "name":"adms", 332 "columns":[{ 333 "type":"STR", 334 "name":"adm_name" 335 }], 336 "description":"This table lists all the ADMs that are supported 337 by the Agent." 338 }, 339 { 340 "name":"variables", 341 "columns":[{ 342 "type":"ARI", 343 "name":"ids" 344 }], 345 "description":"This table lists the ARI for every variable that 346 is known to the agent." 347 }, 348 { 349 "name":"rptts", 350 "columns":[{ 351 "type":"ARI", 352 "name":"ids" 353 }], 354 "description":"This table lists the ARI for every report 355 template that is known to the agent." 356 }, 357 { 358 "name":"macros", 359 "columns":[{ 360 "type":"ARI", 361 "name":"ids" 362 }], 363 "description":"This table lists the ARI for every macro that is 364 known to the agent." 365 }, 366 { 367 "name":"rules", 368 "columns":[{ 369 "type":"ARI", 370 "name":"ids" 371 }], 372 "description":"This table lists the ARI for every rule that is 373 known to the agent." 374 }, 375 { 376 "name":"tblts", 377 "columns":[{ 378 "type":"ARI", 379 "name":"ids" 380 }], 381 "description":"This table lists the ARI for every table template 382 that is known to the agent." 383 } 385 ], 387 "Rptt": [{ 388 "name": "full_report", 389 "definition": [{ 390 "ns": "Amp/Agent", 391 "nm": "mdat.name" 392 }, 393 { 394 "ns": "Amp/Agent", 395 "nm": "mdat.version" 396 }, 397 { 398 "ns": "Amp/Agent", 399 "nm": "edd.num_rpt_tpls" 400 }, 401 { 402 "ns": "Amp/Agent", 403 "nm": "edd.num_tbl_tpls" 404 }, 405 { 406 "ns": "Amp/Agent", 407 "nm": "edd.sent_reports" 409 }, 410 { 411 "ns": "Amp/Agent", 412 "nm": "edd.num_tbr" 413 }, 414 { 415 "ns": "Amp/Agent", 416 "nm": "edd.run_tbr" 417 }, 418 { 419 "ns": "Amp/Agent", 420 "nm": "edd.num_sbr" 421 }, 422 { 423 "ns": "Amp/Agent", 424 "nm": "edd.run_sbr" 425 }, 426 { 427 "ns": "Amp/Agent", 428 "nm": "edd.num_const" 429 }, 430 { 431 "ns": "Amp/Agent", 432 "nm": "edd.num_var" 433 }, 434 { 435 "ns": "Amp/Agent", 436 "nm": "edd.num_macros" 437 }, 438 { 439 "ns": "Amp/Agent", 440 "nm": "edd.run_macros" 441 }, 442 { 443 "ns": "Amp/Agent", 444 "nm": "edd.num_controls" 445 }, 446 { 447 "ns": "Amp/Agent", 448 "nm": "edd.run_controls" 449 }, 450 { 451 "ns": "Amp/Agent", 452 "nm": "var.num_rules" 453 } 454 ], 455 "description": "This is all known meta-data, EDD, and VAR values 456 known by the Agent." 458 }], 460 "Ctrl": [ 461 { 462 "name": "add_var", 463 "parmspec": [{ 464 "type": "ARI", 465 "name": "id" 466 }, 467 { 468 "type": "EXPR", 469 "name": "def" 470 }, 471 { 472 "type": "BYTE", 473 "name": "type" 474 } 475 ], 476 "description": "This control configures a new variable 477 definition on the Agent." 478 }, 479 { 480 "name": "del_var", 481 "parmspec": [{ 482 "type": "AC", 483 "name": "ids" 484 }], 485 "description": "This control removes one or more variable 486 definitions from the Agent." 487 }, 488 { 489 "name": "add_rptt", 490 "parmspec": [{ 491 "type": "ARI", 492 "name": "id" 493 }, 494 { 495 "type": "AC", 496 "name": "template" 497 } 498 ], 499 "description": "This control configures a new report template 500 definition on the Agent." 501 }, 502 { 503 "name": "del_rptt", 504 "parmspec": [{ 505 "type": "AC", 506 "name": "ids" 507 }], 508 "description": "This control removes one or more report template 509 definitions from the Agent." 510 }, 512 { 513 "name": "desc_rptt", 514 "parmspec": [{ 515 "type": "AC", 516 "name": "ids" 517 }], 518 "description": "This control produces a detailed description of 519 one or more report template identifier(ARI) 520 known to the Agent." 521 }, 522 { 523 "name": "gen_rpts", 524 "parmspec": [{ 525 "type": "AC", 526 "name": "ids" 527 }, 528 { 529 "type": "TNVC", 530 "name": "rxmgrs" 531 } 532 ], 533 "description": "This control causes the Agent to produce a 534 report entry for each identified report 535 templates and send them to one or more 536 identified managers(ARIs)." 537 }, 538 { 539 "name":"gen_tbls", 540 "parmspec":[{ 541 "type":"AC", 542 "name":"ids" 543 }, 544 { 545 "type": "TNVC", 546 "name": "rxmgrs" 547 } 548 ], 549 "description": "This control causes the Agent to produce a 550 table for each identified table templates and 551 send them to one or more identified managers." 552 }, 553 { 554 "name": "add_macro", 555 "parmspec": [{ 556 "type": "STR", 557 "name": "name" 558 }, 559 { 560 "type": "ARI", 561 "name": "id" 562 }, 563 { 564 "type": "AC", 565 "name": "def" 566 } 567 ], 568 "description": "This control configures a new macro definition 569 on the Agent." 570 }, 571 { 572 "name": "del_macro", 573 "parmspec": [{ 574 "type": "AC", 575 "name": "ids" 576 }], 577 "description": "This control removes one or more macro 578 definitions from the Agent." 579 }, 580 { 581 "name": "desc_macro", 582 "parmspec": [{ 583 "type": "AC", 584 "name": "ids" 585 }], 586 "description": "This control produces a detailed description of 587 one or more macro identifier(ARI) known to the 588 Agent." 589 }, 590 { 591 "name": "add_tbr", 592 "parmspec": [{ 593 "type": "ARI", 594 "name": "id" 595 }, 596 { 597 "type": "TV", 598 "name": "start" 599 }, 600 { 601 "type": "TV", 602 "name": "period" 603 }, 604 { 605 "type": "UVAST", 606 "name": "count" 607 }, 608 { 609 "type": "AC", 610 "name": "action" 611 }, 612 { 613 "type": "STR", 614 "name": "description" 615 } 617 ], 618 "description": "This control configures a new time-based 619 rule (TBR) definition on the Agent." 620 }, 621 { 622 "name": "add_sbr", 623 "parmspec": [{ 624 "type": "ARI", 625 "name": "id" 626 }, 627 { 628 "type": "TV", 629 "name": "start" 630 }, 631 { 632 "type": "EXPR", 633 "name": "state" 634 }, 635 { 636 "type": "UVAST", 637 "name": "max_eval" 638 }, 639 { 640 "type": "UVAST", 641 "name": "count" 642 }, 643 { 644 "type": "AC", 645 "name": "action" 646 }, 647 { 648 "type": "STR", 649 "name": "description" 651 } 653 ], 654 "description": "This control configures a new state-based 655 rule (SBR) definition on the Agent." 656 }, 657 { 658 "name": "del_rule", 659 "parmspec": [{ 660 "type": "AC", 661 "name": "ids" 662 }], 663 "description": "This control removes one or more rule 664 definitions from the Agent." 665 }, 666 { 667 "name": "desc_rule", 668 "parmspec": [{ 669 "type": "AC", 670 "name": "ids" 671 }], 672 "description": "This control produces a detailed description 673 of one or more rules known to the Agent." 674 }, 675 { 676 "name": "store_var", 677 "parmspec": [{ 678 "type": "ARI", 679 "name": "id" 680 }, 681 { 682 "type": "EXPR", 683 "name": "value" 684 }], 685 "description": "This control stores variables." 686 }, 687 { 688 "name": "reset_counts", 689 "description": "This control resets all Agent ADM statistics 690 reported in the Agent ADM report." 691 } 692 ], 694 "Const": [{ 695 "name": "amp_epoch", 696 "type": "TS", 697 "value": "1504915200", 698 "description": "This constant is the time epoch for the Agent." 700 }], 702 "Mac": [{ 703 "name": "user_desc", 704 "parmspec": [{ 705 "type": "AC", 706 "name": "RPTTs" 707 }, 708 { 709 "type": "AC", 710 "name": "Rules" 711 }], 713 "definition": [{ 714 "ns": "Amp/Agent", 715 "nm": "ctrl.desc_rptt", 716 "ap": [{ 717 "type": "ParmName", 718 "value": "RPTTs" 719 }] 720 }, 721 { 722 "ns": "Amp/Agent", 723 "nm": "ctrl.desc_rule", 724 "ap": [{ 725 "type": "ParmName", 726 "value": "Rules" 727 }] 728 } 729 ], 730 "description": "This macro lists all of the user defined data." 731 }], 733 "Oper": [{ 734 "name": "plusINT", 735 "result-type": "INT", 736 "in-type": ["INT", "INT"], 737 "description": "Int32 addition" 738 }, 739 { 740 "name": "plusUINT", 741 "result-type": "UINT", 742 "in-type": ["UINT", "UINT"], 743 "description": "Unsigned Int32 addition" 744 }, 745 { 746 "name": "plusVAST", 747 "result-type": "VAST", 748 "in-type": ["VAST", "VAST"], 749 "description": "Int64 addition" 750 }, 751 { 752 "name": "plusUVAST", 753 "result-type": "UVAST", 754 "in-type": ["UVAST", "UVAST"], 755 "description": "Unsigned Int64 addition" 756 }, 757 { 758 "name": "plusREAL32", 759 "result-type": "REAL32", 760 "in-type": ["REAL32", "REAL32"], 761 "description": "Real32 addition" 762 }, 763 { 764 "name": "plusREAL64", 765 "result-type": "REAL64", 766 "in-type": ["REAL64", "REAL64"], 767 "description": "Real64 addition" 768 }, 769 { 770 "name": "minusINT", 771 "result-type": "INT", 772 "in-type": ["INT", "INT"], 773 "description": "Int32 subtraction" 774 }, 775 { 776 "name": "minusUINT", 777 "result-type": "UINT", 778 "in-type": ["UINT", "UINT"], 779 "description": "Unsigned Int32 subtraction" 780 }, 781 { 782 "name": "minusVAST", 783 "result-type": "VAST", 784 "in-type": ["VAST", "VAST"], 785 "description": "Int64 subtraction" 786 }, 787 { 788 "name": "minusUVAST", 789 "result-type": "UVAST", 790 "in-type": ["UVAST", "UVAST"], 791 "description": "Unsigned Int64 subtraction" 792 }, 793 { 794 "name": "minusREAL32", 795 "result-type": "REAL32", 796 "in-type": ["REAL32", "REAL32"], 797 "description": "Real32 subtraction" 798 }, 799 { 800 "name": "minusREAL64", 801 "result-type": "REAL64", 802 "in-type": ["REAL64", "REAL64"], 803 "description": "Real64 subtraction" 804 }, 805 { 806 "name": "multINT", 807 "result-type": "INT", 808 "in-type": ["INT", "INT"], 809 "description": "Int32 multiplication" 810 }, 811 { 812 "name": "multUINT", 813 "result-type": "UINT", 814 "in-type": ["UINT", "UINT"], 815 "description": "Unsigned Int32 multiplication" 816 }, 817 { 818 "name": "multVAST", 819 "result-type": "VAST", 820 "in-type": ["VAST", "VAST"], 821 "description": "Int64 multiplication" 822 }, 823 { 824 "name": "multUVAST", 825 "result-type": "UVAST", 826 "in-type": ["UVAST", "UVAST"], 827 "description": "Unsigned Int64 multiplication" 828 }, 829 { 830 "name": "multREAL32", 831 "result-type": "REAL32", 832 "in-type": ["REAL32", "REAL32"], 833 "description": "Real32 multiplication" 834 }, 835 { 836 "name": "multREAL64", 837 "result-type": "REAL64", 838 "in-type": ["REAL64", "REAL64"], 839 "description": "Real64 multiplication" 840 }, 841 { 842 "name": "divINT", 843 "result-type": "INT", 844 "in-type": ["INT", "INT"], 845 "description": "Int32 division" 846 }, 847 { 848 "name": "divUINT", 849 "result-type": "UINT", 850 "in-type": ["UINT", "UINT"], 851 "description": "Unsigned Int32 division" 852 }, 853 { 854 "name": "divVAST", 855 "result-type": "VAST", 856 "in-type": ["VAST", "VAST"], 857 "description": "Int64 division" 858 }, 859 { 860 "name": "divUVAST", 861 "result-type": "UVAST", 862 "in-type": ["UVAST", "UVAST"], 863 "description": "Unsigned Int64 division" 864 }, 865 { 866 "name": "divREAL32", 867 "result-type": "REAL32", 868 "in-type": ["REAL32", "REAL32"], 869 "description": "Real32 division" 870 }, 871 { 872 "name": "divREAL64", 873 "result-type": "REAL64", 874 "in-type": ["REAL64", "REAL64"], 875 "description": "Real64 division" 876 }, 877 { 878 "name": "modINT", 879 "result-type": "INT", 880 "in-type": ["INT", "INT"], 881 "description": "Int32 modulus division" 882 }, 883 { 884 "name": "modUINT", 885 "result-type": "UINT", 886 "in-type": ["UINT", "UINT"], 887 "description": "Unsigned Int32 modulus division" 888 }, 889 { 890 "name": "modVAST", 891 "result-type": "VAST", 892 "in-type": ["VAST", "VAST"], 893 "description": "Int64 modulus division" 894 }, 895 { 896 "name": "modUVAST", 897 "result-type": "UVAST", 898 "in-type": ["UVAST", "UVAST"], 899 "description": "Unsigned Int64 modulus division" 900 }, 901 { 902 "name": "modREAL32", 903 "result-type": "REAL32", 904 "in-type": ["REAL32", "REAL32"], 905 "description": "Real32 modulus division" 906 }, 907 { 908 "name": "modREAL64", 909 "result-type": "REAL64", 910 "in-type": ["REAL64", "REAL64"], 911 "description": "Real64 modulus division" 912 }, 913 { 914 "name": "expINT", 915 "result-type": "INT", 916 "in-type": ["INT", "INT"], 917 "description": "Int32 exponentiation" 918 }, 919 { 920 "name": "expUINT", 921 "result-type": "UINT", 922 "in-type": ["UINT", "UINT"], 923 "description": "Unsigned int32 exponentiation" 924 }, 925 { 926 "name": "expVAST", 927 "result-type": "VAST", 928 "in-type": ["VAST", "VAST"], 929 "description": "Int64 exponentiation" 930 }, 931 { 932 "name": "expUVAST", 933 "result-type": "UVAST", 934 "in-type": ["UVAST", "UVAST"], 935 "description": "Unsigned Int64 exponentiation" 936 }, 937 { 938 "name": "expREAL32", 939 "result-type": "REAL32", 940 "in-type": ["REAL32", "REAL32"], 941 "description": "Real32 exponentiation" 942 }, 943 { 944 "name": "expREAL64", 945 "result-type": "REAL64", 946 "in-type": ["REAL64", "REAL64"], 947 "description": "Real64 exponentiation" 948 }, 949 { 950 "name": "bitAND", 951 "result-type": "UVAST", 952 "in-type": ["UVAST", "UVAST"], 953 "description": "Bitwise and" 954 }, 955 { 956 "name": "bitOR", 957 "result-type": "UVAST", 958 "in-type": ["UVAST", "UVAST"], 959 "description": "Bitwise or" 960 }, 961 { 962 "name": "bitXOR", 963 "result-type": "UVAST", 964 "in-type": ["UVAST", "UVAST"], 965 "description": "Bitwise xor" 966 }, 967 { 968 "name": "bitNOT", 969 "result-type": "UVAST", 970 "in-type": ["UVAST"], 971 "description": "Bitwise not" 972 }, 973 { 974 "name": "logAND", 975 "result-type": "BOOL", 976 "in-type": ["BOOL", "BOOL"], 977 "description": "Logical and" 978 }, 979 { 980 "name": "logOR", 981 "result-type": "BOOL", 982 "in-type": ["BOOL", "BOOL"], 983 "description": "Logical or" 984 }, 985 { 986 "name": "logNOT", 987 "result-type": "BOOL", 988 "in-type": ["BOOL"], 989 "description": "Logical not" 990 }, 991 { 992 "name": "abs", 993 "result-type": "UVAST", 994 "in-type": ["VAST"], 995 "description": "absolute value" 996 }, 997 { 998 "name": "lessThan", 999 "result-type": "BOOL", 1000 "in-type": ["UNK", "UNK"], 1001 "description": "<" 1002 }, 1003 { 1004 "name": "greaterThan", 1005 "result-type": "BOOL", 1006 "in-type": ["UNK", "UNK"], 1007 "description": ">" 1008 }, 1009 { 1010 "name": "lessEqual", 1011 "result-type": "BOOL", 1012 "in-type": ["UNK", "UNK"], 1013 "description": "<=" 1014 }, 1015 { 1016 "name": "greaterEqual", 1017 "result-type": "BOOL", 1018 "in-type": ["UNK", "UNK"], 1019 "description": ">=" 1020 }, 1021 { 1022 "name": "notEqual", 1023 "result-type": "BOOL", 1024 "in-type": ["UNK", "UNK"], 1025 "description": "!=" 1026 }, 1027 { 1028 "name": "Equal", 1029 "result-type": "BOOL", 1030 "in-type": ["UNK", "UNK"], 1031 "description": "==" 1032 }, 1033 { 1034 "name": "bitShiftLeft", 1035 "result-type": "UVAST", 1036 "in-type": ["UVAST", "UVAST"], 1037 "description": "<<" 1038 }, 1039 { 1040 "name": "bitShiftRight", 1041 "result-type": "UVAST", 1042 "in-type": ["UVAST", "UVAST"], 1043 "description": ">>" 1044 }, 1045 { 1046 "name": "STOR", 1047 "result-type": "UNK", 1048 "in-type": ["UNK", "UNK"], 1049 "description": "Store value of parm 2 in parm 1" 1050 } 1051 ] 1052 } 1054 5. IANA Considerations 1056 This document defines a moderated Namespace: "Amp/Agent" with the ADM 1057 enumeration of 0. 1059 6. References 1061 6.1. Informative References 1063 [I-D.birrane-dtn-ama] 1064 Birrane, E., "Asynchronous Management Architecture", 1065 draft-birrane-dtn-ama-07 (work in progress), June 2018. 1067 6.2. Normative References 1069 [I-D.birrane-dtn-adm] 1070 Birrane, E., DiPietro, E., and D. Linko, "AMA Application 1071 Data Model", draft-birrane-dtn-adm-02 (work in progress), 1072 June 2018. 1074 [I-D.birrane-dtn-amp] 1075 Birrane, E., "Asynchronous Management Protocol", draft- 1076 birrane-dtn-amp-04 (work in progress), June 2018. 1078 [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate 1079 Requirement Levels", BCP 14, RFC 2119, 1080 DOI 10.17487/RFC2119, March 1997, 1081 . 1083 Authors' Addresses 1085 Edward J. Birrane 1086 Johns Hopkins Applied Physics Laboratory 1088 Email: Edward.Birrane@jhuapl.edu 1090 Evana DiPietro 1091 Johns Hopkins Applied Physics Laboratory 1093 Email: Evana.DiPietro@jhuapl.edu 1095 David Linko 1096 Johns Hopkins Applied Physics Laboratory 1098 Email: David.Linko@jhuapl.edu